tg3: Fix 57765 A0 bootcode race condition
On A0 revision of 57765 asic rev devices, the bootcode will perform some hardware operations, after the magic signature is presented, that will collide with setup operations performed by the driver. The best way to avoid the contention is to have the driver delay an additional 10 milliseconds. B0 revisions of the chip will make this workaround unnecessary. Signed-off-by: Matt Carlson <mcarlson@broadcom.com> Signed-off-by: Benjamin Li <benli@broadcom.com> Reviewed-by: Michael Chan <mchan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f89f38b8ec
commit
6b10c1653e
|
@ -6721,6 +6721,13 @@ static int tg3_poll_fw(struct tg3 *tp)
|
||||||
tp->dev->name);
|
tp->dev->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (tp->pci_chip_rev_id == CHIPREV_ID_57765_A0) {
|
||||||
|
/* The 57765 A0 needs a little more
|
||||||
|
* time to do some important work.
|
||||||
|
*/
|
||||||
|
mdelay(10);
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -110,6 +110,7 @@
|
||||||
#define CHIPREV_ID_57780_A0 0x57780000
|
#define CHIPREV_ID_57780_A0 0x57780000
|
||||||
#define CHIPREV_ID_57780_A1 0x57780001
|
#define CHIPREV_ID_57780_A1 0x57780001
|
||||||
#define CHIPREV_ID_5717_A0 0x05717000
|
#define CHIPREV_ID_5717_A0 0x05717000
|
||||||
|
#define CHIPREV_ID_57765_A0 0x57785000
|
||||||
#define GET_ASIC_REV(CHIP_REV_ID) ((CHIP_REV_ID) >> 12)
|
#define GET_ASIC_REV(CHIP_REV_ID) ((CHIP_REV_ID) >> 12)
|
||||||
#define ASIC_REV_5700 0x07
|
#define ASIC_REV_5700 0x07
|
||||||
#define ASIC_REV_5701 0x00
|
#define ASIC_REV_5701 0x00
|
||||||
|
|
Loading…
Reference in New Issue