]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
libsas: sas_rediscover_dev did not look at the SMP exec status.
authorJeff Skirvin <jeffrey.d.skirvin@intel.com>
Sat, 10 Mar 2012 05:55:50 +0000 (05:55 +0000)
committerDan Williams <dan.j.williams@intel.com>
Fri, 13 Apr 2012 06:20:50 +0000 (23:20 -0700)
The discovery function "sas_rediscover_dev" had two bugs: 1) it did
not pay attention to the return status from the SMP task execution;
2) the stack variable used for the returned SAS address was compared
against 0 without being initialized.

Signed-off-by: Jeff Skirvin <jeffrey.d.skirvin@intel.com>
[djbw: todo sanitize smp_execute_task return values (see: residue)]
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
drivers/scsi/libsas/sas_expander.c

index f1e8e0a27ecda13bb57fee2e819cfcd7b04182c6..63d3e5965757afc66422c6c65c2858854dc89cc7 100644 (file)
@@ -2005,6 +2005,7 @@ static int sas_rediscover_dev(struct domain_device *dev, int phy_id, bool last)
        u8 sas_addr[8];
        int res;
 
+       memset(sas_addr, 0, 8);
        res = sas_get_phy_attached_dev(dev, phy_id, sas_addr, &type);
        switch (res) {
        case SMP_RESP_NO_PHY:
@@ -2017,9 +2018,13 @@ static int sas_rediscover_dev(struct domain_device *dev, int phy_id, bool last)
                return res;
        case SMP_RESP_FUNC_ACC:
                break;
+       case -ECOMM:
+               break;
+       default:
+               return res;
        }
 
-       if (SAS_ADDR(sas_addr) == 0) {
+       if ((SAS_ADDR(sas_addr) == 0) || (res == -ECOMM)) {
                phy->phy_state = PHY_EMPTY;
                sas_unregister_devs_sas_addr(dev, phy_id, last);
                return res;