Since commit d7d40280f868 breaks sbc_parse_verify(), revert it. Signed-off-by: Bart Van Assche <bart.vanassche@xxxxxxxxxxx> Cc: Christoph Hellwig <hch@xxxxxx> Cc: Hannes Reinecke <hare@xxxxxxxx> Cc: David Disseldorp <ddiss@xxxxxxx> --- drivers/target/target_core_sbc.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/drivers/target/target_core_sbc.c b/drivers/target/target_core_sbc.c index 2cc8753eacad..a0ad618f1b1a 100644 --- a/drivers/target/target_core_sbc.c +++ b/drivers/target/target_core_sbc.c @@ -836,8 +836,10 @@ sbc_check_dpofua(struct se_device *dev, struct se_cmd *cmd, unsigned char *cdb) * @cmd: (in) structure that describes the SCSI command to be parsed. * @sectors: (out) Number of logical blocks on the storage medium that will be * affected by the SCSI command. + * @bufflen: (out) Expected length of the SCSI Data-Out buffer. */ -static sense_reason_t sbc_parse_verify(struct se_cmd *cmd, unsigned int *sectors) +static sense_reason_t sbc_parse_verify(struct se_cmd *cmd, int *sectors, + u32 *bufflen) { struct se_device *dev = cmd->se_dev; u8 *cdb = cmd->t_task_cdb; @@ -869,7 +871,10 @@ static sense_reason_t sbc_parse_verify(struct se_cmd *cmd, unsigned int *sectors switch (bytchk) { case 0: + *bufflen = 0; + break; case 1: + *bufflen = sbc_get_size(cmd, *sectors); cmd->se_cmd_flags |= SCF_SCSI_DATA_CDB; break; default: @@ -962,7 +967,7 @@ sbc_parse_cdb(struct se_cmd *cmd, struct sbc_ops *ops) break; case WRITE_VERIFY: case WRITE_VERIFY_16: - ret = sbc_parse_verify(cmd, §ors); + ret = sbc_parse_verify(cmd, §ors, &size); if (ret) return ret; cmd->execute_cmd = sbc_execute_rw; @@ -1164,7 +1169,7 @@ sbc_parse_cdb(struct se_cmd *cmd, struct sbc_ops *ops) break; case VERIFY: case VERIFY_16: - ret = sbc_parse_verify(cmd, §ors); + ret = sbc_parse_verify(cmd, §ors, &size); if (ret) return ret; cmd->execute_cmd = sbc_emulate_noop; -- 2.12.2 -- To unsubscribe from this list: send the line "unsubscribe target-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html