mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-11-10 16:36:16 +02:00
01415999cf
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31553 3c298f89-4303-0410-b956-a3cf2f4a3e73
21 lines
580 B
Diff
21 lines
580 B
Diff
--- a/drivers/net/ethernet/freescale/gianfar.c
|
|
+++ b/drivers/net/ethernet/freescale/gianfar.c
|
|
@@ -1005,7 +1005,16 @@ static int gfar_probe(struct platform_de
|
|
/* We need to delay at least 3 TX clocks */
|
|
udelay(2);
|
|
|
|
- tempval = (MACCFG1_TX_FLOW | MACCFG1_RX_FLOW);
|
|
+ if ((mfspr(SPRN_SVR) & 0xffff) >= 0x0011) {
|
|
+ tempval = (MACCFG1_TX_FLOW | MACCFG1_RX_FLOW);
|
|
+ } else {
|
|
+ /*
|
|
+ * Do not enable flow control on chips earlier than rev 1.1,
|
|
+ * because of the eTSEC27 erratum
|
|
+ */
|
|
+ tempval = 0;
|
|
+ }
|
|
+
|
|
gfar_write(®s->maccfg1, tempval);
|
|
|
|
/* Initialize MACCFG2. */
|