aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDarrick J. Wong <djwong@us.ibm.com>2007-07-24 12:33:49 -0400
committerJames Bottomley <jejb@mulgrave.localdomain>2007-07-24 13:02:26 -0400
commit2cd614c8732172524c36cd5245620338928062b6 (patch)
tree82cf3eae2515f6ebe7a2fae8b51d06d034d990ed
parentbbf17d6483a7feb4c1eeef9fd553976d4f394e4c (diff)
[SCSI] libsas: SMP request handler shouldn't crash when rphy is NULL
sas_smp_handler crashes when smp utils are used with an aic94xx host because certain devices (the sas_host itself, specifically) lack rphy structures. No rphy means no SMP target support, but we shouldn't crash here. Signed-off-by: Darrick J. Wong <djwong@us.ibm.com> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
-rw-r--r--drivers/scsi/libsas/sas_expander.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/scsi/libsas/sas_expander.c b/drivers/scsi/libsas/sas_expander.c
index b500f0c1449c..8603ae65213d 100644
--- a/drivers/scsi/libsas/sas_expander.c
+++ b/drivers/scsi/libsas/sas_expander.c
@@ -1879,7 +1879,7 @@ int sas_smp_handler(struct Scsi_Host *shost, struct sas_rphy *rphy,
1879 struct request *req) 1879 struct request *req)
1880{ 1880{
1881 struct domain_device *dev; 1881 struct domain_device *dev;
1882 int ret, type = rphy->identify.device_type; 1882 int ret, type;
1883 struct request *rsp = req->next_rq; 1883 struct request *rsp = req->next_rq;
1884 1884
1885 if (!rsp) { 1885 if (!rsp) {
@@ -1888,12 +1888,13 @@ int sas_smp_handler(struct Scsi_Host *shost, struct sas_rphy *rphy,
1888 return -EINVAL; 1888 return -EINVAL;
1889 } 1889 }
1890 1890
1891 /* seems aic94xx doesn't support */ 1891 /* no rphy means no smp target support (ie aic94xx host) */
1892 if (!rphy) { 1892 if (!rphy) {
1893 printk("%s: can we send a smp request to a host?\n", 1893 printk("%s: can we send a smp request to a host?\n",
1894 __FUNCTION__); 1894 __FUNCTION__);
1895 return -EINVAL; 1895 return -EINVAL;
1896 } 1896 }
1897 type = rphy->identify.device_type;
1897 1898
1898 if (type != SAS_EDGE_EXPANDER_DEVICE && 1899 if (type != SAS_EDGE_EXPANDER_DEVICE &&
1899 type != SAS_FANOUT_EXPANDER_DEVICE) { 1900 type != SAS_FANOUT_EXPANDER_DEVICE) {