|
@@ -367,6 +367,56 @@ struct bufdesc_ex {
|
|
|
#define FEC_VLAN_TAG_LEN 0x04
|
|
|
#define FEC_ETHTYPE_LEN 0x02
|
|
|
|
|
|
+/* Controller is ENET-MAC */
|
|
|
+#define FEC_QUIRK_ENET_MAC (1 << 0)
|
|
|
+/* Controller needs driver to swap frame */
|
|
|
+#define FEC_QUIRK_SWAP_FRAME (1 << 1)
|
|
|
+/* Controller uses gasket */
|
|
|
+#define FEC_QUIRK_USE_GASKET (1 << 2)
|
|
|
+/* Controller has GBIT support */
|
|
|
+#define FEC_QUIRK_HAS_GBIT (1 << 3)
|
|
|
+/* Controller has extend desc buffer */
|
|
|
+#define FEC_QUIRK_HAS_BUFDESC_EX (1 << 4)
|
|
|
+/* Controller has hardware checksum support */
|
|
|
+#define FEC_QUIRK_HAS_CSUM (1 << 5)
|
|
|
+/* Controller has hardware vlan support */
|
|
|
+#define FEC_QUIRK_HAS_VLAN (1 << 6)
|
|
|
+/* ENET IP errata ERR006358
|
|
|
+ *
|
|
|
+ * If the ready bit in the transmit buffer descriptor (TxBD[R]) is previously
|
|
|
+ * detected as not set during a prior frame transmission, then the
|
|
|
+ * ENET_TDAR[TDAR] bit is cleared at a later time, even if additional TxBDs
|
|
|
+ * were added to the ring and the ENET_TDAR[TDAR] bit is set. This results in
|
|
|
+ * frames not being transmitted until there is a 0-to-1 transition on
|
|
|
+ * ENET_TDAR[TDAR].
|
|
|
+ */
|
|
|
+#define FEC_QUIRK_ERR006358 (1 << 7)
|
|
|
+/* ENET IP hw AVB
|
|
|
+ *
|
|
|
+ * i.MX6SX ENET IP add Audio Video Bridging (AVB) feature support.
|
|
|
+ * - Two class indicators on receive with configurable priority
|
|
|
+ * - Two class indicators and line speed timer on transmit allowing
|
|
|
+ * implementation class credit based shapers externally
|
|
|
+ * - Additional DMA registers provisioned to allow managing up to 3
|
|
|
+ * independent rings
|
|
|
+ */
|
|
|
+#define FEC_QUIRK_HAS_AVB (1 << 8)
|
|
|
+/* There is a TDAR race condition for mutliQ when the software sets TDAR
|
|
|
+ * and the UDMA clears TDAR simultaneously or in a small window (2-4 cycles).
|
|
|
+ * This will cause the udma_tx and udma_tx_arbiter state machines to hang.
|
|
|
+ * The issue exist at i.MX6SX enet IP.
|
|
|
+ */
|
|
|
+#define FEC_QUIRK_ERR007885 (1 << 9)
|
|
|
+/* ENET Block Guide/ Chapter for the iMX6SX (PELE) address one issue:
|
|
|
+ * After set ENET_ATCR[Capture], there need some time cycles before the counter
|
|
|
+ * value is capture in the register clock domain.
|
|
|
+ * The wait-time-cycles is at least 6 clock cycles of the slower clock between
|
|
|
+ * the register clock and the 1588 clock. The 1588 ts_clk is fixed to 25Mhz,
|
|
|
+ * register clock is 66Mhz, so the wait-time-cycles must be greater than 240ns
|
|
|
+ * (40ns * 6).
|
|
|
+ */
|
|
|
+#define FEC_QUIRK_BUG_CAPTURE (1 << 10)
|
|
|
+
|
|
|
struct fec_enet_priv_tx_q {
|
|
|
int index;
|
|
|
unsigned char *tx_bounce[TX_RING_SIZE];
|