diff options
author | Michael Chan <mchan@broadcom.com> | 2012-07-29 15:15:43 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-07-30 02:18:31 -0400 |
commit | 091f0ea30074bc43f9250961b3247af713024bc6 (patch) | |
tree | 6811dce54854469457b3c5e20d150f160de0c4ba /drivers/net/ethernet/broadcom/tg3.h | |
parent | 10ce95d6ef36c65df7dcd3b8fcf86913f8b298bd (diff) |
tg3: Add New 5719 Read DMA workaround
After Power-on-reset, the 5719's TX DMA length registers may contain
uninitialized values and cause TX DMA to stall. Check for invalid
values and set a register bit to flush the TX channels. The bit
needs to be turned off after the DMA channels have been flushed.
Signed-off-by: Michael Chan <mchan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/broadcom/tg3.h')
-rw-r--r-- | drivers/net/ethernet/broadcom/tg3.h | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/net/ethernet/broadcom/tg3.h b/drivers/net/ethernet/broadcom/tg3.h index 6fb45a500032..6d52cb286826 100644 --- a/drivers/net/ethernet/broadcom/tg3.h +++ b/drivers/net/ethernet/broadcom/tg3.h | |||
@@ -1376,7 +1376,11 @@ | |||
1376 | #define TG3_LSO_RD_DMA_CRPTEN_CTRL 0x00004910 | 1376 | #define TG3_LSO_RD_DMA_CRPTEN_CTRL 0x00004910 |
1377 | #define TG3_LSO_RD_DMA_CRPTEN_CTRL_BLEN_BD_4K 0x00030000 | 1377 | #define TG3_LSO_RD_DMA_CRPTEN_CTRL_BLEN_BD_4K 0x00030000 |
1378 | #define TG3_LSO_RD_DMA_CRPTEN_CTRL_BLEN_LSO_4K 0x000c0000 | 1378 | #define TG3_LSO_RD_DMA_CRPTEN_CTRL_BLEN_LSO_4K 0x000c0000 |
1379 | /* 0x4914 --> 0x4c00 unused */ | 1379 | #define TG3_LSO_RD_DMA_TX_LENGTH_WA 0x02000000 |
1380 | /* 0x4914 --> 0x4be0 unused */ | ||
1381 | |||
1382 | #define TG3_NUM_RDMA_CHANNELS 4 | ||
1383 | #define TG3_RDMA_LENGTH 0x00004be0 | ||
1380 | 1384 | ||
1381 | /* Write DMA control registers */ | 1385 | /* Write DMA control registers */ |
1382 | #define WDMAC_MODE 0x00004c00 | 1386 | #define WDMAC_MODE 0x00004c00 |
@@ -2959,6 +2963,7 @@ enum TG3_FLAGS { | |||
2959 | TG3_FLAG_L1PLLPD_EN, | 2963 | TG3_FLAG_L1PLLPD_EN, |
2960 | TG3_FLAG_APE_HAS_NCSI, | 2964 | TG3_FLAG_APE_HAS_NCSI, |
2961 | TG3_FLAG_4K_FIFO_LIMIT, | 2965 | TG3_FLAG_4K_FIFO_LIMIT, |
2966 | TG3_FLAG_5719_RDMA_BUG, | ||
2962 | TG3_FLAG_RESET_TASK_PENDING, | 2967 | TG3_FLAG_RESET_TASK_PENDING, |
2963 | TG3_FLAG_5705_PLUS, | 2968 | TG3_FLAG_5705_PLUS, |
2964 | TG3_FLAG_IS_5788, | 2969 | TG3_FLAG_IS_5788, |