Commit a4cb428d authored by Matt Carlson's avatar Matt Carlson Committed by David S. Miller

tg3: Make the TX BD DMA limit configurable

The 57766 ASIC rev will impose a new TX BD DMA limit on the driver.
This patch prepares for 57766 support by making the tx BD DMA limit
tunable.
Signed-off-by: default avatarMatt Carlson <mcarlson@broadcom.com>
Reviewed-by: default avatarMichael Chan <mchan@broadcom.com>
Reviewed-by: default avatarBenjamin Li <benli@broadcom.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 4f272096
...@@ -199,7 +199,7 @@ static inline void _tg3_flag_clear(enum TG3_FLAGS flag, unsigned long *bits) ...@@ -199,7 +199,7 @@ static inline void _tg3_flag_clear(enum TG3_FLAGS flag, unsigned long *bits)
/* minimum number of free TX descriptors required to wake up TX process */ /* minimum number of free TX descriptors required to wake up TX process */
#define TG3_TX_WAKEUP_THRESH(tnapi) ((tnapi)->tx_pending / 4) #define TG3_TX_WAKEUP_THRESH(tnapi) ((tnapi)->tx_pending / 4)
#define TG3_TX_BD_DMA_MAX 4096 #define TG3_TX_BD_DMA_MAX_4K 4096
#define TG3_RAW_IP_ALIGN 2 #define TG3_RAW_IP_ALIGN 2
...@@ -6449,17 +6449,17 @@ static bool tg3_tx_frag_set(struct tg3_napi *tnapi, u32 *entry, u32 *budget, ...@@ -6449,17 +6449,17 @@ static bool tg3_tx_frag_set(struct tg3_napi *tnapi, u32 *entry, u32 *budget,
if (tg3_40bit_overflow_test(tp, map, len)) if (tg3_40bit_overflow_test(tp, map, len))
hwbug = 1; hwbug = 1;
if (tg3_flag(tp, 4K_FIFO_LIMIT)) { if (tp->dma_limit) {
u32 prvidx = *entry; u32 prvidx = *entry;
u32 tmp_flag = flags & ~TXD_FLAG_END; u32 tmp_flag = flags & ~TXD_FLAG_END;
while (len > TG3_TX_BD_DMA_MAX && *budget) { while (len > tp->dma_limit && *budget) {
u32 frag_len = TG3_TX_BD_DMA_MAX; u32 frag_len = tp->dma_limit;
len -= TG3_TX_BD_DMA_MAX; len -= tp->dma_limit;
/* Avoid the 8byte DMA problem */ /* Avoid the 8byte DMA problem */
if (len <= 8) { if (len <= 8) {
len += TG3_TX_BD_DMA_MAX / 2; len += tp->dma_limit / 2;
frag_len = TG3_TX_BD_DMA_MAX / 2; frag_len = tp->dma_limit / 2;
} }
tnapi->tx_buffers[*entry].fragmented = true; tnapi->tx_buffers[*entry].fragmented = true;
...@@ -14041,7 +14041,7 @@ static int __devinit tg3_get_invariants(struct tg3 *tp) ...@@ -14041,7 +14041,7 @@ static int __devinit tg3_get_invariants(struct tg3 *tp)
tg3_flag_set(tp, SHORT_DMA_BUG); tg3_flag_set(tp, SHORT_DMA_BUG);
if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5719) if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5719)
tg3_flag_set(tp, 4K_FIFO_LIMIT); tp->dma_limit = TG3_TX_BD_DMA_MAX_4K;
if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5717 || if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5717 ||
GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5719 || GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5719 ||
......
...@@ -2994,6 +2994,7 @@ struct tg3 { ...@@ -2994,6 +2994,7 @@ struct tg3 {
/* begin "tx thread" cacheline section */ /* begin "tx thread" cacheline section */
void (*write32_tx_mbox) (struct tg3 *, u32, void (*write32_tx_mbox) (struct tg3 *, u32,
u32); u32);
u32 dma_limit;
/* begin "rx thread" cacheline section */ /* begin "rx thread" cacheline section */
struct tg3_napi napi[TG3_IRQ_MAX_VECS]; struct tg3_napi napi[TG3_IRQ_MAX_VECS];
......
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