Commit ad3660c2 authored by Claudiu Manoil's avatar Claudiu Manoil Committed by David S. Miller

gianfar: Enable eTSEC-A002 erratum w/a for all parts

A002 is still in "no plans to fix" state, and applies to all
the current P1/P2 parts as well, so it's resonable to enable
its workaround by default, for all the soc's with etsec.
The impact of not enabling this workaround for affected parts
is that under certain conditons (runt frames or even frames
with RX error detected at PHY level) during controller reset,
the controller might fail to indicate Rx reset (GRS) completion.
Signed-off-by: default avatarClaudiu Manoil <claudiu.manoil@freescale.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent f6063850
...@@ -947,6 +947,9 @@ static void gfar_detect_errata(struct gfar_private *priv) ...@@ -947,6 +947,9 @@ static void gfar_detect_errata(struct gfar_private *priv)
unsigned int mod = (svr >> 16) & 0xfff6; /* w/o E suffix */ unsigned int mod = (svr >> 16) & 0xfff6; /* w/o E suffix */
unsigned int rev = svr & 0xffff; unsigned int rev = svr & 0xffff;
/* no plans to fix */
priv->errata |= GFAR_ERRATA_A002;
/* MPC8313 Rev 2.0 and higher; All MPC837x */ /* MPC8313 Rev 2.0 and higher; All MPC837x */
if ((pvr == 0x80850010 && mod == 0x80b0 && rev >= 0x0020) || if ((pvr == 0x80850010 && mod == 0x80b0 && rev >= 0x0020) ||
(pvr == 0x80861010 && (mod & 0xfff9) == 0x80c0)) (pvr == 0x80861010 && (mod & 0xfff9) == 0x80c0))
...@@ -957,11 +960,6 @@ static void gfar_detect_errata(struct gfar_private *priv) ...@@ -957,11 +960,6 @@ static void gfar_detect_errata(struct gfar_private *priv)
(pvr == 0x80861010 && (mod & 0xfff9) == 0x80c0)) (pvr == 0x80861010 && (mod & 0xfff9) == 0x80c0))
priv->errata |= GFAR_ERRATA_76; priv->errata |= GFAR_ERRATA_76;
/* MPC8313 and MPC837x all rev */
if ((pvr == 0x80850010 && mod == 0x80b0) ||
(pvr == 0x80861010 && (mod & 0xfff9) == 0x80c0))
priv->errata |= GFAR_ERRATA_A002;
/* MPC8313 Rev < 2.0, MPC8548 rev 2.0 */ /* MPC8313 Rev < 2.0, MPC8548 rev 2.0 */
if ((pvr == 0x80850010 && mod == 0x80b0 && rev < 0x0020) || if ((pvr == 0x80850010 && mod == 0x80b0 && rev < 0x0020) ||
(pvr == 0x80210020 && mod == 0x8030 && rev == 0x0020)) (pvr == 0x80210020 && mod == 0x8030 && rev == 0x0020))
...@@ -1599,7 +1597,7 @@ static int __gfar_is_rx_idle(struct gfar_private *priv) ...@@ -1599,7 +1597,7 @@ static int __gfar_is_rx_idle(struct gfar_private *priv)
/* Normaly TSEC should not hang on GRS commands, so we should /* Normaly TSEC should not hang on GRS commands, so we should
* actually wait for IEVENT_GRSC flag. * actually wait for IEVENT_GRSC flag.
*/ */
if (likely(!gfar_has_errata(priv, GFAR_ERRATA_A002))) if (!gfar_has_errata(priv, GFAR_ERRATA_A002))
return 0; return 0;
/* Read the eTSEC register at offset 0xD1C. If bits 7-14 are /* Read the eTSEC register at offset 0xD1C. If bits 7-14 are
......
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