diff options
| author | Dan Williams <dan.j.williams@intel.com> | 2012-01-28 17:24:40 -0800 | 
|---|---|---|
| committer | James Bottomley <JBottomley@Parallels.com> | 2012-02-29 15:40:33 -0600 | 
| commit | 899fcf40f3177697ccfb029d0484cb8ec09a51ca (patch) | |
| tree | 2983a14444ca62958e50e2fdbd4dc945d7a38849 /drivers/scsi/libsas/sas_discover.c | |
| parent | 9a10b33caf78f897356ac006c455e6060a40af15 (diff) | |
[SCSI] libsas: set attached device type and target protocols for local phys
Before:
$ cat /sys/class/sas_phy/phy-6\:3/device_type
none
$ cat /sys/class/sas_phy/phy-6\:3/target_port_protocols
none
After:
$ cat /sys/class/sas_phy/phy-6\:3/device_type
end device
$ cat /sys/class/sas_phy/phy-6\:3/target_port_protocols
sata
Also downgrade the phy_list_lock to _irq instead of _irqsave since
libsas will never call sas_get_port_device with interrupts disbled.
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi/libsas/sas_discover.c')
| -rw-r--r-- | drivers/scsi/libsas/sas_discover.c | 12 | 
1 files changed, 8 insertions, 4 deletions
| diff --git a/drivers/scsi/libsas/sas_discover.c b/drivers/scsi/libsas/sas_discover.c index 0d58a8beaa3d..364679675602 100644 --- a/drivers/scsi/libsas/sas_discover.c +++ b/drivers/scsi/libsas/sas_discover.c @@ -69,7 +69,6 @@ void sas_init_dev(struct domain_device *dev)   */  static int sas_get_port_device(struct asd_sas_port *port)  { -	unsigned long flags;  	struct asd_sas_phy *phy;  	struct sas_rphy *rphy;  	struct domain_device *dev; @@ -78,9 +77,9 @@ static int sas_get_port_device(struct asd_sas_port *port)  	if (!dev)  		return -ENOMEM; -	spin_lock_irqsave(&port->phy_list_lock, flags); +	spin_lock_irq(&port->phy_list_lock);  	if (list_empty(&port->phy_list)) { -		spin_unlock_irqrestore(&port->phy_list_lock, flags); +		spin_unlock_irq(&port->phy_list_lock);  		sas_put_device(dev);  		return -ENODEV;  	} @@ -89,7 +88,7 @@ static int sas_get_port_device(struct asd_sas_port *port)  	memcpy(dev->frame_rcvd, phy->frame_rcvd, min(sizeof(dev->frame_rcvd),  					     (size_t)phy->frame_rcvd_size));  	spin_unlock(&phy->frame_rcvd_lock); -	spin_unlock_irqrestore(&port->phy_list_lock, flags); +	spin_unlock_irq(&port->phy_list_lock);  	if (dev->frame_rcvd[0] == 0x34 && port->oob_mode == SATA_OOB_MODE) {  		struct dev_to_host_fis *fis = @@ -134,6 +133,11 @@ static int sas_get_port_device(struct asd_sas_port *port)  		sas_put_device(dev);  		return -ENODEV;  	} + +	spin_lock_irq(&port->phy_list_lock); +	list_for_each_entry(phy, &port->phy_list, port_phy_el) +		sas_phy_set_target(phy, dev); +	spin_unlock_irq(&port->phy_list_lock);  	rphy->identify.phy_identifier = phy->phy->identify.phy_identifier;  	memcpy(dev->sas_addr, port->attached_sas_addr, SAS_ADDR_SIZE);  	sas_fill_in_rphy(dev, rphy); | 
