Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 2cd614c8 authored by Darrick J. Wong's avatar Darrick J. Wong Committed by James Bottomley
Browse files

[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: default avatarDarrick J. Wong <djwong@us.ibm.com>
Signed-off-by: default avatarJames Bottomley <James.Bottomley@SteelEye.com>
parent bbf17d64
Loading
Loading
Loading
Loading
+3 −2
Original line number Diff line number Diff line
@@ -1879,7 +1879,7 @@ int sas_smp_handler(struct Scsi_Host *shost, struct sas_rphy *rphy,
		    struct request *req)
{
	struct domain_device *dev;
	int ret, type = rphy->identify.device_type;
	int ret, type;
	struct request *rsp = req->next_rq;

	if (!rsp) {
@@ -1888,12 +1888,13 @@ int sas_smp_handler(struct Scsi_Host *shost, struct sas_rphy *rphy,
		return -EINVAL;
	}

	/* seems aic94xx doesn't support */
	/* no rphy means no smp target support (ie aic94xx host) */
	if (!rphy) {
		printk("%s: can we send a smp request to a host?\n",
		       __FUNCTION__);
		return -EINVAL;
	}
	type = rphy->identify.device_type;

	if (type != SAS_EDGE_EXPANDER_DEVICE &&
	    type != SAS_FANOUT_EXPANDER_DEVICE) {