On Tue, Sep 21, 2021 at 10:34:33AM -0700, Bart Van Assche wrote: > Conditional statements are faster than indirect calls. Hence call > scsi_done() directly. > > Signed-off-by: Bart Van Assche <bvanassche@xxxxxxx> > --- > drivers/staging/unisys/visorhba/visorhba_main.c | 14 ++++++-------- > 1 file changed, 6 insertions(+), 8 deletions(-) > > diff --git a/drivers/staging/unisys/visorhba/visorhba_main.c b/drivers/staging/unisys/visorhba/visorhba_main.c > index 41f8a72a2a95..6a8fa0587280 100644 > --- a/drivers/staging/unisys/visorhba/visorhba_main.c > +++ b/drivers/staging/unisys/visorhba/visorhba_main.c > @@ -327,7 +327,7 @@ static int visorhba_abort_handler(struct scsi_cmnd *scsicmd) > rtn = forward_taskmgmt_command(TASK_MGMT_ABORT_TASK, scsidev); > if (rtn == SUCCESS) { > scsicmd->result = DID_ABORT << 16; > - scsicmd->scsi_done(scsicmd); > + scsi_done(scsicmd); > } > return rtn; > } > @@ -354,7 +354,7 @@ static int visorhba_device_reset_handler(struct scsi_cmnd *scsicmd) > rtn = forward_taskmgmt_command(TASK_MGMT_LUN_RESET, scsidev); > if (rtn == SUCCESS) { > scsicmd->result = DID_RESET << 16; > - scsicmd->scsi_done(scsicmd); > + scsi_done(scsicmd); > } > return rtn; > } > @@ -383,7 +383,7 @@ static int visorhba_bus_reset_handler(struct scsi_cmnd *scsicmd) > rtn = forward_taskmgmt_command(TASK_MGMT_BUS_RESET, scsidev); > if (rtn == SUCCESS) { > scsicmd->result = DID_RESET << 16; > - scsicmd->scsi_done(scsicmd); > + scsi_done(scsicmd); > } > return rtn; > } > @@ -476,8 +476,7 @@ static int visorhba_queue_command_lck(struct scsi_cmnd *scsicmd, > */ > cmdrsp->scsi.handle = insert_location; > > - /* save done function that we have call when cmd is complete */ > - scsicmd->scsi_done = visorhba_cmnd_done; > + WARN_ON_ONCE(visorhba_cmnd_done != scsi_done); > /* save destination */ > cmdrsp->scsi.vdest.channel = scsidev->channel; > cmdrsp->scsi.vdest.id = scsidev->id; > @@ -686,8 +685,7 @@ static void visorhba_serverdown_complete(struct visorhba_devdata *devdata) > case CMD_SCSI_TYPE: > scsicmd = pendingdel->sent; > scsicmd->result = DID_RESET << 16; > - if (scsicmd->scsi_done) > - scsicmd->scsi_done(scsicmd); > + scsi_done(scsicmd); > break; > case CMD_SCSITASKMGMT_TYPE: > cmdrsp = pendingdel->sent; > @@ -853,7 +851,7 @@ static void complete_scsi_command(struct uiscmdrsp *cmdrsp, > else > do_scsi_nolinuxstat(cmdrsp, scsicmd); > > - scsicmd->scsi_done(scsicmd); > + scsi_done(scsicmd); > } > > /* Acked-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>