Merge branch 'for-davem' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
[cascardo/linux.git] / drivers / net / ethernet / freescale / fec.h
index 9af296a..469691a 100644 (file)
@@ -38,9 +38,9 @@
 #define FEC_ADDR_LOW           0x0e4 /* Low 32bits MAC address */
 #define FEC_ADDR_HIGH          0x0e8 /* High 16bits MAC address */
 #define FEC_OPD                        0x0ec /* Opcode + Pause duration */
-#define FEC_TXIC0              0xF0  /* Tx Interrupt Coalescing for ring 0 */
-#define FEC_TXIC1              0xF4  /* Tx Interrupt Coalescing for ring 1 */
-#define FEC_TXIC2              0xF8  /* Tx Interrupt Coalescing for ring 2 */
+#define FEC_TXIC0              0x0f0 /* Tx Interrupt Coalescing for ring 0 */
+#define FEC_TXIC1              0x0f4 /* Tx Interrupt Coalescing for ring 1 */
+#define FEC_TXIC2              0x0f8 /* Tx Interrupt Coalescing for ring 2 */
 #define FEC_RXIC0              0x100 /* Rx Interrupt Coalescing for ring 0 */
 #define FEC_RXIC1              0x104 /* Rx Interrupt Coalescing for ring 1 */
 #define FEC_RXIC2              0x108 /* Rx Interrupt Coalescing for ring 2 */
 #define FEC_R_FSTART           0x150 /* FIFO receive start reg */
 #define FEC_R_DES_START_1      0x160 /* Receive descriptor ring 1 */
 #define FEC_X_DES_START_1      0x164 /* Transmit descriptor ring 1 */
+#define FEC_R_BUFF_SIZE_1      0x168 /* Maximum receive buff ring1 size */
 #define FEC_R_DES_START_2      0x16c /* Receive descriptor ring 2 */
 #define FEC_X_DES_START_2      0x170 /* Transmit descriptor ring 2 */
+#define FEC_R_BUFF_SIZE_2      0x174 /* Maximum receive buff ring2 size */
 #define FEC_R_DES_START_0      0x180 /* Receive descriptor ring */
 #define FEC_X_DES_START_0      0x184 /* Transmit descriptor ring */
-#define FEC_R_BUFF_SIZE                0x188 /* Maximum receive buff size */
+#define FEC_R_BUFF_SIZE_0      0x188 /* Maximum receive buff size */
 #define FEC_R_FIFO_RSFL                0x190 /* Receive FIFO section full threshold */
 #define FEC_R_FIFO_RSEM                0x194 /* Receive FIFO section empty threshold */
 #define FEC_R_FIFO_RAEM                0x198 /* Receive FIFO almost empty threshold */
 #define FEC_R_FIFO_RAFL                0x19c /* Receive FIFO almost full threshold */
-#define FEC_RACC               0x1C4 /* Receive Accelerator function */
+#define FEC_RACC               0x1c4 /* Receive Accelerator function */
 #define FEC_RCMR_1             0x1c8 /* Receive classification match ring 1 */
 #define FEC_RCMR_2             0x1cc /* Receive classification match ring 2 */
 #define FEC_DMA_CFG_1          0x1d8 /* DMA class configuration for ring 1 */
 #define RMON_T_DROP            0x200 /* Count of frames not cntd correctly */
 #define RMON_T_PACKETS         0x204 /* RMON TX packet count */
 #define RMON_T_BC_PKT          0x208 /* RMON TX broadcast pkts */
-#define RMON_T_MC_PKT          0x20C /* RMON TX multicast pkts */
+#define RMON_T_MC_PKT          0x20c /* RMON TX multicast pkts */
 #define RMON_T_CRC_ALIGN       0x210 /* RMON TX pkts with CRC align err */
 #define RMON_T_UNDERSIZE       0x214 /* RMON TX pkts < 64 bytes, good CRC */
 #define RMON_T_OVERSIZE                0x218 /* RMON TX pkts > MAX_FL bytes good CRC */
-#define RMON_T_FRAG            0x21C /* RMON TX pkts < 64 bytes, bad CRC */
+#define RMON_T_FRAG            0x21c /* RMON TX pkts < 64 bytes, bad CRC */
 #define RMON_T_JAB             0x220 /* RMON TX pkts > MAX_FL bytes, bad CRC */
 #define RMON_T_COL             0x224 /* RMON TX collision count */
 #define RMON_T_P64             0x228 /* RMON TX 64 byte pkts */
-#define RMON_T_P65TO127                0x22C /* RMON TX 65 to 127 byte pkts */
+#define RMON_T_P65TO127                0x22c /* RMON TX 65 to 127 byte pkts */
 #define RMON_T_P128TO255       0x230 /* RMON TX 128 to 255 byte pkts */
 #define RMON_T_P256TO511       0x234 /* RMON TX 256 to 511 byte pkts */
 #define RMON_T_P512TO1023      0x238 /* RMON TX 512 to 1023 byte pkts */
-#define RMON_T_P1024TO2047     0x23C /* RMON TX 1024 to 2047 byte pkts */
+#define RMON_T_P1024TO2047     0x23c /* RMON TX 1024 to 2047 byte pkts */
 #define RMON_T_P_GTE2048       0x240 /* RMON TX pkts > 2048 bytes */
 #define RMON_T_OCTETS          0x244 /* RMON TX octets */
 #define IEEE_T_DROP            0x248 /* Count of frames not counted crtly */
-#define IEEE_T_FRAME_OK                0x24C /* Frames tx'd OK */
+#define IEEE_T_FRAME_OK                0x24c /* Frames tx'd OK */
 #define IEEE_T_1COL            0x250 /* Frames tx'd with single collision */
 #define IEEE_T_MCOL            0x254 /* Frames tx'd with multiple collision */
 #define IEEE_T_DEF             0x258 /* Frames tx'd after deferral delay */
-#define IEEE_T_LCOL            0x25C /* Frames tx'd with late collision */
+#define IEEE_T_LCOL            0x25c /* Frames tx'd with late collision */
 #define IEEE_T_EXCOL           0x260 /* Frames tx'd with excesv collisions */
 #define IEEE_T_MACERR          0x264 /* Frames tx'd with TX FIFO underrun */
 #define IEEE_T_CSERR           0x268 /* Frames tx'd with carrier sense err */
-#define IEEE_T_SQE             0x26C /* Frames tx'd with SQE err */
+#define IEEE_T_SQE             0x26c /* Frames tx'd with SQE err */
 #define IEEE_T_FDXFC           0x270 /* Flow control pause frames tx'd */
 #define IEEE_T_OCTETS_OK       0x274 /* Octet count for frames tx'd w/o err */
 #define RMON_R_PACKETS         0x284 /* RMON RX packet count */
 #define RMON_R_BC_PKT          0x288 /* RMON RX broadcast pkts */
-#define RMON_R_MC_PKT          0x28C /* RMON RX multicast pkts */
+#define RMON_R_MC_PKT          0x28c /* RMON RX multicast pkts */
 #define RMON_R_CRC_ALIGN       0x290 /* RMON RX pkts with CRC alignment err */
 #define RMON_R_UNDERSIZE       0x294 /* RMON RX pkts < 64 bytes, good CRC */
 #define RMON_R_OVERSIZE                0x298 /* RMON RX pkts > MAX_FL bytes good CRC */
-#define RMON_R_FRAG            0x29C /* RMON RX pkts < 64 bytes, bad CRC */
-#define RMON_R_JAB             0x2A0 /* RMON RX pkts > MAX_FL bytes, bad CRC */
-#define RMON_R_RESVD_O         0x2A4 /* Reserved */
-#define RMON_R_P64             0x2A8 /* RMON RX 64 byte pkts */
-#define RMON_R_P65TO127                0x2AC /* RMON RX 65 to 127 byte pkts */
-#define RMON_R_P128TO255       0x2B0 /* RMON RX 128 to 255 byte pkts */
-#define RMON_R_P256TO511       0x2B4 /* RMON RX 256 to 511 byte pkts */
-#define RMON_R_P512TO1023      0x2B8 /* RMON RX 512 to 1023 byte pkts */
-#define RMON_R_P1024TO2047     0x2BC /* RMON RX 1024 to 2047 byte pkts */
-#define RMON_R_P_GTE2048       0x2C0 /* RMON RX pkts > 2048 bytes */
-#define RMON_R_OCTETS          0x2C4 /* RMON RX octets */
-#define IEEE_R_DROP            0x2C8 /* Count frames not counted correctly */
-#define IEEE_R_FRAME_OK                0x2CC /* Frames rx'd OK */
-#define IEEE_R_CRC             0x2D0 /* Frames rx'd with CRC err */
-#define IEEE_R_ALIGN           0x2D4 /* Frames rx'd with alignment err */
-#define IEEE_R_MACERR          0x2D8 /* Receive FIFO overflow count */
-#define IEEE_R_FDXFC           0x2DC /* Flow control pause frames rx'd */
-#define IEEE_R_OCTETS_OK       0x2E0 /* Octet cnt for frames rx'd w/o err */
+#define RMON_R_FRAG            0x29c /* RMON RX pkts < 64 bytes, bad CRC */
+#define RMON_R_JAB             0x2a0 /* RMON RX pkts > MAX_FL bytes, bad CRC */
+#define RMON_R_RESVD_O         0x2a4 /* Reserved */
+#define RMON_R_P64             0x2a8 /* RMON RX 64 byte pkts */
+#define RMON_R_P65TO127                0x2ac /* RMON RX 65 to 127 byte pkts */
+#define RMON_R_P128TO255       0x2b0 /* RMON RX 128 to 255 byte pkts */
+#define RMON_R_P256TO511       0x2b4 /* RMON RX 256 to 511 byte pkts */
+#define RMON_R_P512TO1023      0x2b8 /* RMON RX 512 to 1023 byte pkts */
+#define RMON_R_P1024TO2047     0x2bc /* RMON RX 1024 to 2047 byte pkts */
+#define RMON_R_P_GTE2048       0x2c0 /* RMON RX pkts > 2048 bytes */
+#define RMON_R_OCTETS          0x2c4 /* RMON RX octets */
+#define IEEE_R_DROP            0x2c8 /* Count frames not counted correctly */
+#define IEEE_R_FRAME_OK                0x2cc /* Frames rx'd OK */
+#define IEEE_R_CRC             0x2d0 /* Frames rx'd with CRC err */
+#define IEEE_R_ALIGN           0x2d4 /* Frames rx'd with alignment err */
+#define IEEE_R_MACERR          0x2d8 /* Receive FIFO overflow count */
+#define IEEE_R_FDXFC           0x2dc /* Flow control pause frames rx'd */
+#define IEEE_R_OCTETS_OK       0x2e0 /* Octet cnt for frames rx'd w/o err */
 
 #else
 
 #define FEC_X_DES_START_0      0x3d4 /* Transmit descriptor ring */
 #define FEC_X_DES_START_1      FEC_X_DES_START_0
 #define FEC_X_DES_START_2      FEC_X_DES_START_0
-#define FEC_R_BUFF_SIZE                0x3d8 /* Maximum receive buff size */
+#define FEC_R_BUFF_SIZE_0      0x3d8 /* Maximum receive buff size */
+#define FEC_R_BUFF_SIZE_1      FEC_R_BUFF_SIZE_0
+#define FEC_R_BUFF_SIZE_2      FEC_R_BUFF_SIZE_0
 #define FEC_FIFO_RAM           0x400 /* FIFO RAM buffer */
 /* Not existed in real chip
  * Just for pass build.
  */
-#define FEC_RCMR_1             0xFFF
-#define FEC_RCMR_2             0xFFF
-#define FEC_DMA_CFG_1          0xFFF
-#define FEC_DMA_CFG_2          0xFFF
-#define FEC_TXIC0              0xFFF
-#define FEC_TXIC1              0xFFF
-#define FEC_TXIC2              0xFFF
-#define FEC_RXIC0              0xFFF
-#define FEC_RXIC1              0xFFF
-#define FEC_RXIC2              0xFFF
+#define FEC_RCMR_1             0xfff
+#define FEC_RCMR_2             0xfff
+#define FEC_DMA_CFG_1          0xfff
+#define FEC_DMA_CFG_2          0xfff
+#define FEC_TXIC0              0xfff
+#define FEC_TXIC1              0xfff
+#define FEC_TXIC2              0xfff
+#define FEC_RXIC0              0xfff
+#define FEC_RXIC1              0xfff
+#define FEC_RXIC2              0xfff
 #endif /* CONFIG_M5272 */
 
 
@@ -213,60 +217,60 @@ struct bufdesc_ex {
  *     The following definitions courtesy of commproc.h, which where
  *     Copyright (c) 1997 Dan Malek (dmalek@jlc.net).
  */
-#define BD_SC_EMPTY     ((ushort)0x8000)        /* Receive is empty */
-#define BD_SC_READY     ((ushort)0x8000)        /* Transmit is ready */
-#define BD_SC_WRAP      ((ushort)0x2000)        /* Last buffer descriptor */
-#define BD_SC_INTRPT    ((ushort)0x1000)        /* Interrupt on change */
-#define BD_SC_CM        ((ushort)0x0200)        /* Continuous mode */
-#define BD_SC_ID        ((ushort)0x0100)        /* Rec'd too many idles */
-#define BD_SC_P         ((ushort)0x0100)        /* xmt preamble */
-#define BD_SC_BR        ((ushort)0x0020)        /* Break received */
-#define BD_SC_FR        ((ushort)0x0010)        /* Framing error */
-#define BD_SC_PR        ((ushort)0x0008)        /* Parity error */
-#define BD_SC_OV        ((ushort)0x0002)        /* Overrun */
-#define BD_SC_CD        ((ushort)0x0001)        /* ?? */
+#define BD_SC_EMPTY    ((ushort)0x8000)        /* Receive is empty */
+#define BD_SC_READY    ((ushort)0x8000)        /* Transmit is ready */
+#define BD_SC_WRAP     ((ushort)0x2000)        /* Last buffer descriptor */
+#define BD_SC_INTRPT   ((ushort)0x1000)        /* Interrupt on change */
+#define BD_SC_CM       ((ushort)0x0200)        /* Continuous mode */
+#define BD_SC_ID       ((ushort)0x0100)        /* Rec'd too many idles */
+#define BD_SC_P                ((ushort)0x0100)        /* xmt preamble */
+#define BD_SC_BR       ((ushort)0x0020)        /* Break received */
+#define BD_SC_FR       ((ushort)0x0010)        /* Framing error */
+#define BD_SC_PR       ((ushort)0x0008)        /* Parity error */
+#define BD_SC_OV       ((ushort)0x0002)        /* Overrun */
+#define BD_SC_CD       ((ushort)0x0001)        /* ?? */
 
 /* Buffer descriptor control/status used by Ethernet receive.
-*/
-#define BD_ENET_RX_EMPTY        ((ushort)0x8000)
-#define BD_ENET_RX_WRAP         ((ushort)0x2000)
-#define BD_ENET_RX_INTR         ((ushort)0x1000)
-#define BD_ENET_RX_LAST         ((ushort)0x0800)
-#define BD_ENET_RX_FIRST        ((ushort)0x0400)
-#define BD_ENET_RX_MISS         ((ushort)0x0100)
-#define BD_ENET_RX_LG           ((ushort)0x0020)
-#define BD_ENET_RX_NO           ((ushort)0x0010)
-#define BD_ENET_RX_SH           ((ushort)0x0008)
-#define BD_ENET_RX_CR           ((ushort)0x0004)
-#define BD_ENET_RX_OV           ((ushort)0x0002)
-#define BD_ENET_RX_CL           ((ushort)0x0001)
-#define BD_ENET_RX_STATS        ((ushort)0x013f)        /* All status bits */
+ */
+#define BD_ENET_RX_EMPTY       ((ushort)0x8000)
+#define BD_ENET_RX_WRAP                ((ushort)0x2000)
+#define BD_ENET_RX_INTR                ((ushort)0x1000)
+#define BD_ENET_RX_LAST                ((ushort)0x0800)
+#define BD_ENET_RX_FIRST       ((ushort)0x0400)
+#define BD_ENET_RX_MISS                ((ushort)0x0100)
+#define BD_ENET_RX_LG          ((ushort)0x0020)
+#define BD_ENET_RX_NO          ((ushort)0x0010)
+#define BD_ENET_RX_SH          ((ushort)0x0008)
+#define BD_ENET_RX_CR          ((ushort)0x0004)
+#define BD_ENET_RX_OV          ((ushort)0x0002)
+#define BD_ENET_RX_CL          ((ushort)0x0001)
+#define BD_ENET_RX_STATS       ((ushort)0x013f)        /* All status bits */
 
 /* Enhanced buffer descriptor control/status used by Ethernet receive */
-#define BD_ENET_RX_VLAN         0x00000004
+#define BD_ENET_RX_VLAN                0x00000004
 
 /* Buffer descriptor control/status used by Ethernet transmit.
-*/
-#define BD_ENET_TX_READY        ((ushort)0x8000)
-#define BD_ENET_TX_PAD          ((ushort)0x4000)
-#define BD_ENET_TX_WRAP         ((ushort)0x2000)
-#define BD_ENET_TX_INTR         ((ushort)0x1000)
-#define BD_ENET_TX_LAST         ((ushort)0x0800)
-#define BD_ENET_TX_TC           ((ushort)0x0400)
-#define BD_ENET_TX_DEF          ((ushort)0x0200)
-#define BD_ENET_TX_HB           ((ushort)0x0100)
-#define BD_ENET_TX_LC           ((ushort)0x0080)
-#define BD_ENET_TX_RL           ((ushort)0x0040)
-#define BD_ENET_TX_RCMASK       ((ushort)0x003c)
-#define BD_ENET_TX_UN           ((ushort)0x0002)
-#define BD_ENET_TX_CSL          ((ushort)0x0001)
-#define BD_ENET_TX_STATS        ((ushort)0x0fff)        /* All status bits */
-
-/*enhanced buffer descriptor control/status used by Ethernet transmit*/
-#define BD_ENET_TX_INT          0x40000000
-#define BD_ENET_TX_TS           0x20000000
-#define BD_ENET_TX_PINS         0x10000000
-#define BD_ENET_TX_IINS         0x08000000
+ */
+#define BD_ENET_TX_READY       ((ushort)0x8000)
+#define BD_ENET_TX_PAD         ((ushort)0x4000)
+#define BD_ENET_TX_WRAP                ((ushort)0x2000)
+#define BD_ENET_TX_INTR                ((ushort)0x1000)
+#define BD_ENET_TX_LAST                ((ushort)0x0800)
+#define BD_ENET_TX_TC          ((ushort)0x0400)
+#define BD_ENET_TX_DEF         ((ushort)0x0200)
+#define BD_ENET_TX_HB          ((ushort)0x0100)
+#define BD_ENET_TX_LC          ((ushort)0x0080)
+#define BD_ENET_TX_RL          ((ushort)0x0040)
+#define BD_ENET_TX_RCMASK      ((ushort)0x003c)
+#define BD_ENET_TX_UN          ((ushort)0x0002)
+#define BD_ENET_TX_CSL         ((ushort)0x0001)
+#define BD_ENET_TX_STATS       ((ushort)0x0fff)        /* All status bits */
+
+/* enhanced buffer descriptor control/status used by Ethernet transmit */
+#define BD_ENET_TX_INT         0x40000000
+#define BD_ENET_TX_TS          0x20000000
+#define BD_ENET_TX_PINS                0x10000000
+#define BD_ENET_TX_IINS                0x08000000
 
 
 /* This device has up to three irqs on some platforms */
@@ -279,36 +283,40 @@ struct bufdesc_ex {
 #define FEC_ENET_MAX_TX_QS     3
 #define FEC_ENET_MAX_RX_QS     3
 
-#define FEC_R_DES_START(X)     ((X == 1) ? FEC_R_DES_START_1 : \
-                               ((X == 2) ? \
+#define FEC_R_DES_START(X)     (((X) == 1) ? FEC_R_DES_START_1 : \
+                               (((X) == 2) ? \
                                        FEC_R_DES_START_2 : FEC_R_DES_START_0))
-#define FEC_X_DES_START(X)     ((X == 1) ? FEC_X_DES_START_1 : \
-                               ((X == 2) ? \
+#define FEC_X_DES_START(X)     (((X) == 1) ? FEC_X_DES_START_1 : \
+                               (((X) == 2) ? \
                                        FEC_X_DES_START_2 : FEC_X_DES_START_0))
-#define FEC_R_DES_ACTIVE(X)    ((X == 1) ? FEC_R_DES_ACTIVE_1 : \
-                               ((X == 2) ? \
+#define FEC_R_BUFF_SIZE(X)     (((X) == 1) ? FEC_R_BUFF_SIZE_1 : \
+                               (((X) == 2) ? \
+                                       FEC_R_BUFF_SIZE_2 : FEC_R_BUFF_SIZE_0))
+#define FEC_R_DES_ACTIVE(X)    (((X) == 1) ? FEC_R_DES_ACTIVE_1 : \
+                               (((X) == 2) ? \
                                   FEC_R_DES_ACTIVE_2 : FEC_R_DES_ACTIVE_0))
-#define FEC_X_DES_ACTIVE(X)    ((X == 1) ? FEC_X_DES_ACTIVE_1 : \
-                               ((X == 2) ? \
+#define FEC_X_DES_ACTIVE(X)    (((X) == 1) ? FEC_X_DES_ACTIVE_1 : \
+                               (((X) == 2) ? \
                                   FEC_X_DES_ACTIVE_2 : FEC_X_DES_ACTIVE_0))
 
-#define FEC_DMA_CFG(X)         ((X == 2) ? FEC_DMA_CFG_2 : FEC_DMA_CFG_1)
+#define FEC_DMA_CFG(X)         (((X) == 2) ? FEC_DMA_CFG_2 : FEC_DMA_CFG_1)
 
 #define DMA_CLASS_EN           (1 << 16)
-#define FEC_RCMR(X)            ((X == 2) ? FEC_RCMR_2 : FEC_RCMR_1)
-#define IDLE_SLOPE_MASK                0xFFFF
+#define FEC_RCMR(X)            (((X) == 2) ? FEC_RCMR_2 : FEC_RCMR_1)
+#define IDLE_SLOPE_MASK                0xffff
 #define IDLE_SLOPE_1           0x200 /* BW fraction: 0.5 */
 #define IDLE_SLOPE_2           0x200 /* BW fraction: 0.5 */
-#define IDLE_SLOPE(X)          ((X == 1) ? (IDLE_SLOPE_1 & IDLE_SLOPE_MASK) : \
+#define IDLE_SLOPE(X)          (((X) == 1) ?                           \
+                               (IDLE_SLOPE_1 & IDLE_SLOPE_MASK) :      \
                                (IDLE_SLOPE_2 & IDLE_SLOPE_MASK))
-#define RCMR_MATCHEN            (0x1 << 16)
-#define RCMR_CMP_CFG(v, n)     ((v & 0x7) <<  (n << 2))
+#define RCMR_MATCHEN           (0x1 << 16)
+#define RCMR_CMP_CFG(v, n)     (((v) & 0x7) <<  (n << 2))
 #define RCMR_CMP_1             (RCMR_CMP_CFG(0, 0) | RCMR_CMP_CFG(1, 1) | \
                                RCMR_CMP_CFG(2, 2) | RCMR_CMP_CFG(3, 3))
 #define RCMR_CMP_2             (RCMR_CMP_CFG(4, 0) | RCMR_CMP_CFG(5, 1) | \
                                RCMR_CMP_CFG(6, 2) | RCMR_CMP_CFG(7, 3))
-#define RCMR_CMP(X)            ((X == 1) ? RCMR_CMP_1 : RCMR_CMP_2)
-#define FEC_TX_BD_FTYPE(X)     ((X & 0xF) << 20)
+#define RCMR_CMP(X)            (((X) == 1) ? RCMR_CMP_1 : RCMR_CMP_2)
+#define FEC_TX_BD_FTYPE(X)     (((X) & 0xf) << 20)
 
 /* The number of Tx and Rx buffers.  These are allocated from the page
  * pool.  The code may assume these are power of two, so it it best
@@ -326,8 +334,8 @@ struct bufdesc_ex {
 #define TX_RING_SIZE           512     /* Must be power of two */
 #define TX_RING_MOD_MASK       511     /*   for this to work */
 
-#define BD_ENET_RX_INT          0x00800000
-#define BD_ENET_RX_PTP          ((ushort)0x0400)
+#define BD_ENET_RX_INT         0x00800000
+#define BD_ENET_RX_PTP         ((ushort)0x0400)
 #define BD_ENET_RX_ICE         0x00000020
 #define BD_ENET_RX_PCR         0x00000010
 #define FLAG_RX_CSUM_ENABLED   (BD_ENET_RX_ICE | BD_ENET_RX_PCR)
@@ -359,13 +367,13 @@ struct bufdesc_ex {
 /* ENET interrupt coalescing macro define */
 #define FEC_ITR_CLK_SEL                (0x1 << 30)
 #define FEC_ITR_EN             (0x1 << 31)
-#define FEC_ITR_ICFT(X)                ((X & 0xFF) << 20)
-#define FEC_ITR_ICTT(X)                ((X) & 0xFFFF)
+#define FEC_ITR_ICFT(X)                (((X) & 0xff) << 20)
+#define FEC_ITR_ICTT(X)                ((X) & 0xffff)
 #define FEC_ITR_ICFT_DEFAULT   200  /* Set 200 frame count threshold */
 #define FEC_ITR_ICTT_DEFAULT   1000 /* Set 1000us timer threshold */
 
-#define FEC_VLAN_TAG_LEN       0x04
-#define FEC_ETHTYPE_LEN                0x02
+#define FEC_VLAN_TAG_LEN       0x04
+#define FEC_ETHTYPE_LEN                0x02
 
 /* Controller is ENET-MAC */
 #define FEC_QUIRK_ENET_MAC             (1 << 0)
@@ -390,7 +398,7 @@ struct bufdesc_ex {
  * frames not being transmitted until there is a 0-to-1 transition on
  * ENET_TDAR[TDAR].
  */
-#define FEC_QUIRK_ERR006358            (1 << 7)
+#define FEC_QUIRK_ERR006358            (1 << 7)
 /* ENET IP hw AVB
  *
  * i.MX6SX ENET IP add Audio Video Bridging (AVB) feature support.
@@ -501,8 +509,9 @@ struct fec_enet_private {
        int     speed;
        struct  completion mdio_done;
        int     irq[FEC_IRQ_NUM];
-       int     bufdesc_ex;
+       bool    bufdesc_ex;
        int     pause_flag;
+       u32     quirks;
 
        struct  napi_struct napi;
        int     csum_flags;