Commit cde3f74b authored by Darrick J. Wong's avatar Darrick J. Wong Committed by James Bottomley

[SCSI] libsas: Destroy the task collector thread after releasing ports

If we use task collector mode, we can end up destroying the task collector
thread before we release the ports, which is bad if a port release causes
a disk I/O (such as cache flushing).
Signed-off-by: default avatarDarrick J. Wong <djwong@us.ibm.com>
Signed-off-by: default avatarJames Bottomley <James.Bottomley@SteelEye.com>
parent 6d4dcd4d
...@@ -127,12 +127,13 @@ int sas_register_ha(struct sas_ha_struct *sas_ha) ...@@ -127,12 +127,13 @@ int sas_register_ha(struct sas_ha_struct *sas_ha)
int sas_unregister_ha(struct sas_ha_struct *sas_ha) int sas_unregister_ha(struct sas_ha_struct *sas_ha)
{ {
sas_unregister_ports(sas_ha);
if (sas_ha->lldd_max_execute_num > 1) { if (sas_ha->lldd_max_execute_num > 1) {
sas_shutdown_queue(sas_ha); sas_shutdown_queue(sas_ha);
sas_ha->lldd_max_execute_num = 1;
} }
sas_unregister_ports(sas_ha);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment