scsi: smartpqi: correct controller offline issue
authorKevin Barnett <kevin.barnett@microsemi.com>
Wed, 31 Aug 2016 19:54:47 +0000 (14:54 -0500)
committerMartin K. Petersen <martin.petersen@oracle.com>
Fri, 2 Sep 2016 10:21:38 +0000 (06:21 -0400)
Fixes: 6c223761e 'smartpqi: initial commit of Microsemi smartpqi driver'

Fixed a bug where the driver would not free all of the
controller resources if the controller ever went offline.

Reviewed-by: Scott Teel <scott.teel@microsemi.com>
Reviewed-by: Scott Benesh <scott.benesh@microsemi.com>
Reviewed-by: Johannes Thumshirn <jthumshirn@suse.de>
Reviewed-by: Tomas Henzl <thenzl@redhat.com>
Signed-off-by: Kevin Barnett <kevin.barnett@microsemi.com>
Signed-off-by: Don Brace <don.brace@microsemi.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/smartpqi/smartpqi_init.c

index 43bfeaca65db0b603ceef2ed920b824290fc1449..d759703da287587d7153dd5cfc2ee82a57d39a7b 100644 (file)
@@ -5609,19 +5609,14 @@ static void pqi_free_ctrl_resources(struct pqi_ctrl_info *ctrl_info)
 
 static void pqi_remove_ctrl(struct pqi_ctrl_info *ctrl_info)
 {
-       int rc;
+       cancel_delayed_work_sync(&ctrl_info->rescan_work);
+       cancel_delayed_work_sync(&ctrl_info->update_time_work);
+       pqi_remove_all_scsi_devices(ctrl_info);
+       pqi_unregister_scsi(ctrl_info);
 
-       if (ctrl_info->controller_online) {
-               cancel_delayed_work_sync(&ctrl_info->rescan_work);
-               cancel_delayed_work_sync(&ctrl_info->update_time_work);
-               pqi_remove_all_scsi_devices(ctrl_info);
-               pqi_unregister_scsi(ctrl_info);
-               ctrl_info->controller_online = false;
-       }
        if (ctrl_info->pqi_mode_enabled) {
                sis_disable_msix(ctrl_info);
-               rc = pqi_reset(ctrl_info);
-               if (rc == 0)
+               if (pqi_reset(ctrl_info) == 0)
                        sis_reenable_sis_mode(ctrl_info);
        }
        pqi_free_ctrl_resources(ctrl_info);