forked from Minki/linux
scsi: hisi_sas: check PHY state in get_wideport_bitmap_v3_hw()
We should check register PHY_STATE when getting the bitmap of a wideport, as, if the PHY is not ready, the value of register PHY_PORT_NUM_MA is not valid. V2 hw has done this check, and v3 hw should do this check too. Signed-off-by: Xiaofei Tan <tanxiaofei@huawei.com> Signed-off-by: John Garry <john.garry@huawei.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
729428ca90
commit
0e3231fc93
@ -755,10 +755,12 @@ static int get_wideport_bitmap_v3_hw(struct hisi_hba *hisi_hba, int port_id)
|
||||
{
|
||||
int i, bitmap = 0;
|
||||
u32 phy_port_num_ma = hisi_sas_read32(hisi_hba, PHY_PORT_NUM_MA);
|
||||
u32 phy_state = hisi_sas_read32(hisi_hba, PHY_STATE);
|
||||
|
||||
for (i = 0; i < hisi_hba->n_phy; i++)
|
||||
if (((phy_port_num_ma >> (i * 4)) & 0xf) == port_id)
|
||||
bitmap |= 1 << i;
|
||||
if (phy_state & BIT(i))
|
||||
if (((phy_port_num_ma >> (i * 4)) & 0xf) == port_id)
|
||||
bitmap |= BIT(i);
|
||||
|
||||
return bitmap;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user