mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00
scsi: message: fusion: Correct definitions for mptscsih_dev_reset()
mptscsih_dev_reset() is _not_ a device reset, but rather a target reset. Nevertheless it's being used for either purpose. This patch adds a correct implementation for mptscsih_dev_reset(), and renames the original function to mptscsih_target_reset(). Signed-off-by: Hannes Reinecke <hare@suse.de> Link: https://lore.kernel.org/r/20231002154328.43718-3-hare@suse.de Reviewed-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
d9987d4b96
commit
e6629081fb
2 changed files with 55 additions and 1 deletions
|
@ -1793,7 +1793,7 @@ mptscsih_abort(struct scsi_cmnd * SCpnt)
|
||||||
|
|
||||||
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
|
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
|
||||||
/**
|
/**
|
||||||
* mptscsih_dev_reset - Perform a SCSI TARGET_RESET! new_eh variant
|
* mptscsih_dev_reset - Perform a SCSI LOGICAL_UNIT_RESET!
|
||||||
* @SCpnt: Pointer to scsi_cmnd structure, IO which reset is due to
|
* @SCpnt: Pointer to scsi_cmnd structure, IO which reset is due to
|
||||||
*
|
*
|
||||||
* (linux scsi_host_template.eh_dev_reset_handler routine)
|
* (linux scsi_host_template.eh_dev_reset_handler routine)
|
||||||
|
@ -1808,6 +1808,58 @@ mptscsih_dev_reset(struct scsi_cmnd * SCpnt)
|
||||||
VirtDevice *vdevice;
|
VirtDevice *vdevice;
|
||||||
MPT_ADAPTER *ioc;
|
MPT_ADAPTER *ioc;
|
||||||
|
|
||||||
|
/* If we can't locate our host adapter structure, return FAILED status.
|
||||||
|
*/
|
||||||
|
if ((hd = shost_priv(SCpnt->device->host)) == NULL){
|
||||||
|
printk(KERN_ERR MYNAM ": lun reset: "
|
||||||
|
"Can't locate host! (sc=%p)\n", SCpnt);
|
||||||
|
return FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
|
ioc = hd->ioc;
|
||||||
|
printk(MYIOC_s_INFO_FMT "attempting lun reset! (sc=%p)\n",
|
||||||
|
ioc->name, SCpnt);
|
||||||
|
scsi_print_command(SCpnt);
|
||||||
|
|
||||||
|
vdevice = SCpnt->device->hostdata;
|
||||||
|
if (!vdevice || !vdevice->vtarget) {
|
||||||
|
retval = 0;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
|
retval = mptscsih_IssueTaskMgmt(hd,
|
||||||
|
MPI_SCSITASKMGMT_TASKTYPE_LOGICAL_UNIT_RESET,
|
||||||
|
vdevice->vtarget->channel,
|
||||||
|
vdevice->vtarget->id, vdevice->lun, 0,
|
||||||
|
mptscsih_get_tm_timeout(ioc));
|
||||||
|
|
||||||
|
out:
|
||||||
|
printk (MYIOC_s_INFO_FMT "lun reset: %s (sc=%p)\n",
|
||||||
|
ioc->name, ((retval == 0) ? "SUCCESS" : "FAILED" ), SCpnt);
|
||||||
|
|
||||||
|
if (retval == 0)
|
||||||
|
return SUCCESS;
|
||||||
|
else
|
||||||
|
return FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
|
||||||
|
/**
|
||||||
|
* mptscsih_target_reset - Perform a SCSI TARGET_RESET!
|
||||||
|
* @SCpnt: Pointer to scsi_cmnd structure, IO which reset is due to
|
||||||
|
*
|
||||||
|
* (linux scsi_host_template.eh_target_reset_handler routine)
|
||||||
|
*
|
||||||
|
* Returns SUCCESS or FAILED.
|
||||||
|
**/
|
||||||
|
int
|
||||||
|
mptscsih_target_reset(struct scsi_cmnd * SCpnt)
|
||||||
|
{
|
||||||
|
MPT_SCSI_HOST *hd;
|
||||||
|
int retval;
|
||||||
|
VirtDevice *vdevice;
|
||||||
|
MPT_ADAPTER *ioc;
|
||||||
|
|
||||||
/* If we can't locate our host adapter structure, return FAILED status.
|
/* If we can't locate our host adapter structure, return FAILED status.
|
||||||
*/
|
*/
|
||||||
if ((hd = shost_priv(SCpnt->device->host)) == NULL){
|
if ((hd = shost_priv(SCpnt->device->host)) == NULL){
|
||||||
|
@ -3256,6 +3308,7 @@ EXPORT_SYMBOL(mptscsih_slave_destroy);
|
||||||
EXPORT_SYMBOL(mptscsih_slave_configure);
|
EXPORT_SYMBOL(mptscsih_slave_configure);
|
||||||
EXPORT_SYMBOL(mptscsih_abort);
|
EXPORT_SYMBOL(mptscsih_abort);
|
||||||
EXPORT_SYMBOL(mptscsih_dev_reset);
|
EXPORT_SYMBOL(mptscsih_dev_reset);
|
||||||
|
EXPORT_SYMBOL(mptscsih_target_reset);
|
||||||
EXPORT_SYMBOL(mptscsih_bus_reset);
|
EXPORT_SYMBOL(mptscsih_bus_reset);
|
||||||
EXPORT_SYMBOL(mptscsih_host_reset);
|
EXPORT_SYMBOL(mptscsih_host_reset);
|
||||||
EXPORT_SYMBOL(mptscsih_bios_param);
|
EXPORT_SYMBOL(mptscsih_bios_param);
|
||||||
|
|
|
@ -120,6 +120,7 @@ extern void mptscsih_slave_destroy(struct scsi_device *device);
|
||||||
extern int mptscsih_slave_configure(struct scsi_device *device);
|
extern int mptscsih_slave_configure(struct scsi_device *device);
|
||||||
extern int mptscsih_abort(struct scsi_cmnd * SCpnt);
|
extern int mptscsih_abort(struct scsi_cmnd * SCpnt);
|
||||||
extern int mptscsih_dev_reset(struct scsi_cmnd * SCpnt);
|
extern int mptscsih_dev_reset(struct scsi_cmnd * SCpnt);
|
||||||
|
extern int mptscsih_target_reset(struct scsi_cmnd * SCpnt);
|
||||||
extern int mptscsih_bus_reset(struct scsi_cmnd * SCpnt);
|
extern int mptscsih_bus_reset(struct scsi_cmnd * SCpnt);
|
||||||
extern int mptscsih_host_reset(struct scsi_cmnd *SCpnt);
|
extern int mptscsih_host_reset(struct scsi_cmnd *SCpnt);
|
||||||
extern int mptscsih_bios_param(struct scsi_device * sdev, struct block_device *bdev, sector_t capacity, int geom[]);
|
extern int mptscsih_bios_param(struct scsi_device * sdev, struct block_device *bdev, sector_t capacity, int geom[]);
|
||||||
|
|
Loading…
Add table
Reference in a new issue