aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/mpt3sas
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/scsi/mpt3sas')
-rw-r--r--drivers/scsi/mpt3sas/mpt3sas_scsih.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/drivers/scsi/mpt3sas/mpt3sas_scsih.c b/drivers/scsi/mpt3sas/mpt3sas_scsih.c
index 73d3b81a0d06..9ebc9dce3046 100644
--- a/drivers/scsi/mpt3sas/mpt3sas_scsih.c
+++ b/drivers/scsi/mpt3sas/mpt3sas_scsih.c
@@ -1273,6 +1273,7 @@ _scsih_slave_alloc(struct scsi_device *sdev)
1273 struct MPT3SAS_DEVICE *sas_device_priv_data; 1273 struct MPT3SAS_DEVICE *sas_device_priv_data;
1274 struct scsi_target *starget; 1274 struct scsi_target *starget;
1275 struct _raid_device *raid_device; 1275 struct _raid_device *raid_device;
1276 struct _sas_device *sas_device;
1276 unsigned long flags; 1277 unsigned long flags;
1277 1278
1278 sas_device_priv_data = kzalloc(sizeof(struct scsi_device), GFP_KERNEL); 1279 sas_device_priv_data = kzalloc(sizeof(struct scsi_device), GFP_KERNEL);
@@ -1301,6 +1302,19 @@ _scsih_slave_alloc(struct scsi_device *sdev)
1301 spin_unlock_irqrestore(&ioc->raid_device_lock, flags); 1302 spin_unlock_irqrestore(&ioc->raid_device_lock, flags);
1302 } 1303 }
1303 1304
1305 if (!(sas_target_priv_data->flags & MPT_TARGET_FLAGS_VOLUME)) {
1306 spin_lock_irqsave(&ioc->sas_device_lock, flags);
1307 sas_device = mpt3sas_scsih_sas_device_find_by_sas_address(ioc,
1308 sas_target_priv_data->sas_address);
1309 if (sas_device && (sas_device->starget == NULL)) {
1310 sdev_printk(KERN_INFO, sdev,
1311 "%s : sas_device->starget set to starget @ %d\n",
1312 __func__, __LINE__);
1313 sas_device->starget = starget;
1314 }
1315 spin_unlock_irqrestore(&ioc->sas_device_lock, flags);
1316 }
1317
1304 return 0; 1318 return 0;
1305} 1319}
1306 1320