diff options
author | Mark Salyzyn <mark_salyzyn@xyratex.com> | 2012-01-17 12:56:45 -0500 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2012-02-19 09:08:51 -0500 |
commit | 5c4fb76af31e9dabcd132a0e69ed3799df1304c3 (patch) | |
tree | f73ee0d8f92cfc9c9c298c770ba21962b708c883 /drivers/scsi | |
parent | 46a243f72de931aad2632a0f3de3612534212ae9 (diff) |
[SCSI] pm8001: fix lockup on phy_control hard reset.
pm8001_phy_control PHY_FUNC_HARD_RESET locks up on second try via
smp_phy_control because response HW_EVENT_PHY_START_STATUS fails to complete
previous command. The PM8001F_RUN_TIME flag is not treated as a bit, but a
state in all readers, yet once we are operational or in the run time state,
the flags use a bit-set operation.
Signed-off-by: Mark Salyzyn <mark_salyzyn@xyratex.com>
Acked-by: Jack Wang <jack_wang@usish.com>
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi')
-rw-r--r-- | drivers/scsi/pm8001/pm8001_sas.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/scsi/pm8001/pm8001_sas.c b/drivers/scsi/pm8001/pm8001_sas.c index fb3dc9978861..7ae22a67bd31 100644 --- a/drivers/scsi/pm8001/pm8001_sas.c +++ b/drivers/scsi/pm8001/pm8001_sas.c | |||
@@ -615,7 +615,7 @@ static int pm8001_dev_found_notify(struct domain_device *dev) | |||
615 | wait_for_completion(&completion); | 615 | wait_for_completion(&completion); |
616 | if (dev->dev_type == SAS_END_DEV) | 616 | if (dev->dev_type == SAS_END_DEV) |
617 | msleep(50); | 617 | msleep(50); |
618 | pm8001_ha->flags |= PM8001F_RUN_TIME ; | 618 | pm8001_ha->flags = PM8001F_RUN_TIME; |
619 | return 0; | 619 | return 0; |
620 | found_out: | 620 | found_out: |
621 | spin_unlock_irqrestore(&pm8001_ha->lock, flags); | 621 | spin_unlock_irqrestore(&pm8001_ha->lock, flags); |