aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/tg3.c16
-rw-r--r--drivers/net/tg3.h2
2 files changed, 11 insertions, 7 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c
index 65ff286b508a..ff65ae8b592e 100644
--- a/drivers/net/tg3.c
+++ b/drivers/net/tg3.c
@@ -631,7 +631,7 @@ static void tg3_enable_ints(struct tg3 *tp)
631 if (tp->tg3_flags2 & TG3_FLG2_1SHOT_MSI) 631 if (tp->tg3_flags2 & TG3_FLG2_1SHOT_MSI)
632 tw32_mailbox_f(tnapi->int_mbox, tnapi->last_tag << 24); 632 tw32_mailbox_f(tnapi->int_mbox, tnapi->last_tag << 24);
633 633
634 coal_now = HOSTCC_MODE_NOW; 634 coal_now = tnapi->coal_now;
635 635
636 /* Force an initial interrupt */ 636 /* Force an initial interrupt */
637 if (!(tp->tg3_flags & TG3_FLAG_TAGGED_STATUS) && 637 if (!(tp->tg3_flags & TG3_FLAG_TAGGED_STATUS) &&
@@ -682,7 +682,7 @@ static void tg3_int_reenable(struct tg3_napi *tnapi)
682 if (!(tp->tg3_flags & TG3_FLAG_TAGGED_STATUS) && 682 if (!(tp->tg3_flags & TG3_FLAG_TAGGED_STATUS) &&
683 tg3_has_work(tnapi)) 683 tg3_has_work(tnapi))
684 tw32(HOSTCC_MODE, tp->coalesce_mode | 684 tw32(HOSTCC_MODE, tp->coalesce_mode |
685 (HOSTCC_MODE_ENABLE | HOSTCC_MODE_NOW)); 685 HOSTCC_MODE_ENABLE | tnapi->coal_now);
686} 686}
687 687
688static inline void tg3_netif_stop(struct tg3 *tp) 688static inline void tg3_netif_stop(struct tg3 *tp)
@@ -7622,7 +7622,7 @@ static void tg3_timer(unsigned long __opaque)
7622 tp->grc_local_ctrl | GRC_LCLCTRL_SETINT); 7622 tp->grc_local_ctrl | GRC_LCLCTRL_SETINT);
7623 } else { 7623 } else {
7624 tw32(HOSTCC_MODE, tp->coalesce_mode | 7624 tw32(HOSTCC_MODE, tp->coalesce_mode |
7625 (HOSTCC_MODE_ENABLE | HOSTCC_MODE_NOW)); 7625 HOSTCC_MODE_ENABLE | HOSTCC_MODE_NOW);
7626 } 7626 }
7627 7627
7628 if (!(tr32(WDMAC_MODE) & WDMAC_MODE_ENABLE)) { 7628 if (!(tr32(WDMAC_MODE) & WDMAC_MODE_ENABLE)) {
@@ -7765,7 +7765,7 @@ static int tg3_test_interrupt(struct tg3 *tp)
7765 tg3_enable_ints(tp); 7765 tg3_enable_ints(tp);
7766 7766
7767 tw32_f(HOSTCC_MODE, tp->coalesce_mode | HOSTCC_MODE_ENABLE | 7767 tw32_f(HOSTCC_MODE, tp->coalesce_mode | HOSTCC_MODE_ENABLE |
7768 HOSTCC_MODE_NOW); 7768 tnapi->coal_now);
7769 7769
7770 for (i = 0; i < 5; i++) { 7770 for (i = 0; i < 5; i++) {
7771 u32 int_mbox, misc_host_ctrl; 7771 u32 int_mbox, misc_host_ctrl;
@@ -9840,7 +9840,7 @@ static int tg3_test_memory(struct tg3 *tp)
9840static int tg3_run_loopback(struct tg3 *tp, int loopback_mode) 9840static int tg3_run_loopback(struct tg3 *tp, int loopback_mode)
9841{ 9841{
9842 u32 mac_mode, rx_start_idx, rx_idx, tx_idx, opaque_key; 9842 u32 mac_mode, rx_start_idx, rx_idx, tx_idx, opaque_key;
9843 u32 desc_idx; 9843 u32 desc_idx, coal_now;
9844 struct sk_buff *skb, *rx_skb; 9844 struct sk_buff *skb, *rx_skb;
9845 u8 *tx_data; 9845 u8 *tx_data;
9846 dma_addr_t map; 9846 dma_addr_t map;
@@ -9851,6 +9851,7 @@ static int tg3_run_loopback(struct tg3 *tp, int loopback_mode)
9851 9851
9852 tnapi = &tp->napi[0]; 9852 tnapi = &tp->napi[0];
9853 rnapi = &tp->napi[0]; 9853 rnapi = &tp->napi[0];
9854 coal_now = tnapi->coal_now | rnapi->coal_now;
9854 9855
9855 if (loopback_mode == TG3_MAC_LOOPBACK) { 9856 if (loopback_mode == TG3_MAC_LOOPBACK) {
9856 /* HW errata - mac loopback fails in some cases on 5780. 9857 /* HW errata - mac loopback fails in some cases on 5780.
@@ -9929,7 +9930,7 @@ static int tg3_run_loopback(struct tg3 *tp, int loopback_mode)
9929 map = pci_map_single(tp->pdev, skb->data, tx_len, PCI_DMA_TODEVICE); 9930 map = pci_map_single(tp->pdev, skb->data, tx_len, PCI_DMA_TODEVICE);
9930 9931
9931 tw32_f(HOSTCC_MODE, tp->coalesce_mode | HOSTCC_MODE_ENABLE | 9932 tw32_f(HOSTCC_MODE, tp->coalesce_mode | HOSTCC_MODE_ENABLE |
9932 HOSTCC_MODE_NOW); 9933 rnapi->coal_now);
9933 9934
9934 udelay(10); 9935 udelay(10);
9935 9936
@@ -9950,7 +9951,7 @@ static int tg3_run_loopback(struct tg3 *tp, int loopback_mode)
9950 /* 250 usec to allow enough time on some 10/100 Mbps devices. */ 9951 /* 250 usec to allow enough time on some 10/100 Mbps devices. */
9951 for (i = 0; i < 25; i++) { 9952 for (i = 0; i < 25; i++) {
9952 tw32_f(HOSTCC_MODE, tp->coalesce_mode | HOSTCC_MODE_ENABLE | 9953 tw32_f(HOSTCC_MODE, tp->coalesce_mode | HOSTCC_MODE_ENABLE |
9953 HOSTCC_MODE_NOW); 9954 coal_now);
9954 9955
9955 udelay(10); 9956 udelay(10);
9956 9957
@@ -13428,6 +13429,7 @@ static int __devinit tg3_init_one(struct pci_dev *pdev,
13428 tp->napi[0].int_mbox = MAILBOX_INTERRUPT_0 + TG3_64BIT_REG_LOW; 13429 tp->napi[0].int_mbox = MAILBOX_INTERRUPT_0 + TG3_64BIT_REG_LOW;
13429 tp->napi[0].consmbox = MAILBOX_RCVRET_CON_IDX_0 + TG3_64BIT_REG_LOW; 13430 tp->napi[0].consmbox = MAILBOX_RCVRET_CON_IDX_0 + TG3_64BIT_REG_LOW;
13430 tp->napi[0].prodmbox = MAILBOX_SNDHOST_PROD_IDX_0 + TG3_64BIT_REG_LOW; 13431 tp->napi[0].prodmbox = MAILBOX_SNDHOST_PROD_IDX_0 + TG3_64BIT_REG_LOW;
13432 tp->napi[0].coal_now = HOSTCC_MODE_NOW;
13431 tp->napi[0].tx_pending = TG3_DEF_TX_RING_PENDING; 13433 tp->napi[0].tx_pending = TG3_DEF_TX_RING_PENDING;
13432 netif_napi_add(dev, &tp->napi[0].napi, tg3_poll, 64); 13434 netif_napi_add(dev, &tp->napi[0].napi, tg3_poll, 64);
13433 dev->ethtool_ops = &tg3_ethtool_ops; 13435 dev->ethtool_ops = &tg3_ethtool_ops;
diff --git a/drivers/net/tg3.h b/drivers/net/tg3.h
index a816b2c0f167..626b96805c3e 100644
--- a/drivers/net/tg3.h
+++ b/drivers/net/tg3.h
@@ -1031,6 +1031,7 @@
1031#define HOSTCC_MODE_CLRTICK_TXBD 0x00000400 1031#define HOSTCC_MODE_CLRTICK_TXBD 0x00000400
1032#define HOSTCC_MODE_NOINT_ON_NOW 0x00000800 1032#define HOSTCC_MODE_NOINT_ON_NOW 0x00000800
1033#define HOSTCC_MODE_NOINT_ON_FORCE 0x00001000 1033#define HOSTCC_MODE_NOINT_ON_FORCE 0x00001000
1034#define HOSTCC_MODE_COAL_VEC1_NOW 0x00002000
1034#define HOSTCC_STATUS 0x00003c04 1035#define HOSTCC_STATUS 0x00003c04
1035#define HOSTCC_STATUS_ERROR_ATTN 0x00000004 1036#define HOSTCC_STATUS_ERROR_ATTN 0x00000004
1036#define HOSTCC_RXCOL_TICKS 0x00003c08 1037#define HOSTCC_RXCOL_TICKS 0x00003c08
@@ -2497,6 +2498,7 @@ struct tg3_napi {
2497 u32 last_tag; 2498 u32 last_tag;
2498 u32 last_irq_tag; 2499 u32 last_irq_tag;
2499 u32 int_mbox; 2500 u32 int_mbox;
2501 u32 coal_now;
2500 u32 tx_prod; 2502 u32 tx_prod;
2501 u32 tx_cons; 2503 u32 tx_cons;
2502 u32 tx_pending; 2504 u32 tx_pending;