James Bottomley wrote:
In this case, as you can see all of the SETUP_X are using count to step
through an array and when we're finished we add a NULL to the end. For
the case of SETUP_PORT_ATTR, the array is i->port_attrs, so the bug here
is apparently that the NULL is going in the wrong array. Trying to put
a NULL at the zero element is manifestly wrong because sas_internal is
zero allocated.
Actually, as a final weirdness, we have a duplicate initialisation of
this anyway, so the correct patch is below.
James
---
diff --git a/drivers/scsi/scsi_transport_sas.c b/drivers/scsi/scsi_transport_sas.c
index 0895d3c..fd47cb1 100644
--- a/drivers/scsi/scsi_transport_sas.c
+++ b/drivers/scsi/scsi_transport_sas.c
@@ -1692,10 +1692,6 @@ sas_attach_transport(struct sas_function_template *ft)
i->f = ft;
count = 0;
- SETUP_PORT_ATTRIBUTE(num_phys);
- i->host_attrs[count] = NULL;
-
- count = 0;
SETUP_PHY_ATTRIBUTE(initiator_port_protocols);
SETUP_PHY_ATTRIBUTE(target_port_protocols);
SETUP_PHY_ATTRIBUTE(device_type);
er, eh?
It's not a duplicate initialization, as port attributes != phy
attributes. Different macro, same counter variable.
Your fix seems quite strange - num_phy attribute goes away?
Jeff
--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html