diff options
-rw-r--r-- | drivers/net/tg3.c | 111 |
1 files changed, 65 insertions, 46 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c index 54fff5bb6f98..982ed44f0752 100644 --- a/drivers/net/tg3.c +++ b/drivers/net/tg3.c | |||
@@ -752,42 +752,6 @@ static void tg3_int_reenable(struct tg3_napi *tnapi) | |||
752 | HOSTCC_MODE_ENABLE | tnapi->coal_now); | 752 | HOSTCC_MODE_ENABLE | tnapi->coal_now); |
753 | } | 753 | } |
754 | 754 | ||
755 | static void tg3_napi_disable(struct tg3 *tp) | ||
756 | { | ||
757 | int i; | ||
758 | |||
759 | for (i = tp->irq_cnt - 1; i >= 0; i--) | ||
760 | napi_disable(&tp->napi[i].napi); | ||
761 | } | ||
762 | |||
763 | static void tg3_napi_enable(struct tg3 *tp) | ||
764 | { | ||
765 | int i; | ||
766 | |||
767 | for (i = 0; i < tp->irq_cnt; i++) | ||
768 | napi_enable(&tp->napi[i].napi); | ||
769 | } | ||
770 | |||
771 | static inline void tg3_netif_stop(struct tg3 *tp) | ||
772 | { | ||
773 | tp->dev->trans_start = jiffies; /* prevent tx timeout */ | ||
774 | tg3_napi_disable(tp); | ||
775 | netif_tx_disable(tp->dev); | ||
776 | } | ||
777 | |||
778 | static inline void tg3_netif_start(struct tg3 *tp) | ||
779 | { | ||
780 | /* NOTE: unconditional netif_tx_wake_all_queues is only | ||
781 | * appropriate so long as all callers are assured to | ||
782 | * have free tx slots (such as after tg3_init_hw) | ||
783 | */ | ||
784 | netif_tx_wake_all_queues(tp->dev); | ||
785 | |||
786 | tg3_napi_enable(tp); | ||
787 | tp->napi[0].hw_status->status |= SD_STATUS_UPDATED; | ||
788 | tg3_enable_ints(tp); | ||
789 | } | ||
790 | |||
791 | static void tg3_switch_clocks(struct tg3 *tp) | 755 | static void tg3_switch_clocks(struct tg3 *tp) |
792 | { | 756 | { |
793 | u32 clock_ctrl; | 757 | u32 clock_ctrl; |
@@ -4338,6 +4302,11 @@ static int tg3_setup_phy(struct tg3 *tp, int force_reset) | |||
4338 | return err; | 4302 | return err; |
4339 | } | 4303 | } |
4340 | 4304 | ||
4305 | static inline int tg3_irq_sync(struct tg3 *tp) | ||
4306 | { | ||
4307 | return tp->irq_sync; | ||
4308 | } | ||
4309 | |||
4341 | /* This is called whenever we suspect that the system chipset is re- | 4310 | /* This is called whenever we suspect that the system chipset is re- |
4342 | * ordering the sequence of MMIO to the tx send mailbox. The symptom | 4311 | * ordering the sequence of MMIO to the tx send mailbox. The symptom |
4343 | * is bogus tx completions. We try to recover by setting the | 4312 | * is bogus tx completions. We try to recover by setting the |
@@ -5083,6 +5052,59 @@ tx_recovery: | |||
5083 | return work_done; | 5052 | return work_done; |
5084 | } | 5053 | } |
5085 | 5054 | ||
5055 | static void tg3_napi_disable(struct tg3 *tp) | ||
5056 | { | ||
5057 | int i; | ||
5058 | |||
5059 | for (i = tp->irq_cnt - 1; i >= 0; i--) | ||
5060 | napi_disable(&tp->napi[i].napi); | ||
5061 | } | ||
5062 | |||
5063 | static void tg3_napi_enable(struct tg3 *tp) | ||
5064 | { | ||
5065 | int i; | ||
5066 | |||
5067 | for (i = 0; i < tp->irq_cnt; i++) | ||
5068 | napi_enable(&tp->napi[i].napi); | ||
5069 | } | ||
5070 | |||
5071 | static void tg3_napi_init(struct tg3 *tp) | ||
5072 | { | ||
5073 | int i; | ||
5074 | |||
5075 | netif_napi_add(tp->dev, &tp->napi[0].napi, tg3_poll, 64); | ||
5076 | for (i = 1; i < tp->irq_cnt; i++) | ||
5077 | netif_napi_add(tp->dev, &tp->napi[i].napi, tg3_poll_msix, 64); | ||
5078 | } | ||
5079 | |||
5080 | static void tg3_napi_fini(struct tg3 *tp) | ||
5081 | { | ||
5082 | int i; | ||
5083 | |||
5084 | for (i = 0; i < tp->irq_cnt; i++) | ||
5085 | netif_napi_del(&tp->napi[i].napi); | ||
5086 | } | ||
5087 | |||
5088 | static inline void tg3_netif_stop(struct tg3 *tp) | ||
5089 | { | ||
5090 | tp->dev->trans_start = jiffies; /* prevent tx timeout */ | ||
5091 | tg3_napi_disable(tp); | ||
5092 | netif_tx_disable(tp->dev); | ||
5093 | } | ||
5094 | |||
5095 | static inline void tg3_netif_start(struct tg3 *tp) | ||
5096 | { | ||
5097 | /* NOTE: unconditional netif_tx_wake_all_queues is only | ||
5098 | * appropriate so long as all callers are assured to | ||
5099 | * have free tx slots (such as after tg3_init_hw) | ||
5100 | */ | ||
5101 | netif_tx_wake_all_queues(tp->dev); | ||
5102 | |||
5103 | tg3_napi_enable(tp); | ||
5104 | tp->napi[0].hw_status->status |= SD_STATUS_UPDATED; | ||
5105 | tg3_enable_ints(tp); | ||
5106 | } | ||
5107 | |||
5086 | static void tg3_irq_quiesce(struct tg3 *tp) | 5108 | static void tg3_irq_quiesce(struct tg3 *tp) |
5087 | { | 5109 | { |
5088 | int i; | 5110 | int i; |
@@ -5096,11 +5118,6 @@ static void tg3_irq_quiesce(struct tg3 *tp) | |||
5096 | synchronize_irq(tp->napi[i].irq_vec); | 5118 | synchronize_irq(tp->napi[i].irq_vec); |
5097 | } | 5119 | } |
5098 | 5120 | ||
5099 | static inline int tg3_irq_sync(struct tg3 *tp) | ||
5100 | { | ||
5101 | return tp->irq_sync; | ||
5102 | } | ||
5103 | |||
5104 | /* Fully shutdown all tg3 driver activity elsewhere in the system. | 5121 | /* Fully shutdown all tg3 driver activity elsewhere in the system. |
5105 | * If irq_sync is non-zero, then the IRQ handler must be synchronized | 5122 | * If irq_sync is non-zero, then the IRQ handler must be synchronized |
5106 | * with as well. Most of the time, this is not necessary except when | 5123 | * with as well. Most of the time, this is not necessary except when |
@@ -8920,6 +8937,8 @@ static int tg3_open(struct net_device *dev) | |||
8920 | if (err) | 8937 | if (err) |
8921 | goto err_out1; | 8938 | goto err_out1; |
8922 | 8939 | ||
8940 | tg3_napi_init(tp); | ||
8941 | |||
8923 | tg3_napi_enable(tp); | 8942 | tg3_napi_enable(tp); |
8924 | 8943 | ||
8925 | for (i = 0; i < tp->irq_cnt; i++) { | 8944 | for (i = 0; i < tp->irq_cnt; i++) { |
@@ -9007,6 +9026,7 @@ err_out3: | |||
9007 | 9026 | ||
9008 | err_out2: | 9027 | err_out2: |
9009 | tg3_napi_disable(tp); | 9028 | tg3_napi_disable(tp); |
9029 | tg3_napi_fini(tp); | ||
9010 | tg3_free_consistent(tp); | 9030 | tg3_free_consistent(tp); |
9011 | 9031 | ||
9012 | err_out1: | 9032 | err_out1: |
@@ -9054,6 +9074,8 @@ static int tg3_close(struct net_device *dev) | |||
9054 | memcpy(&tp->estats_prev, tg3_get_estats(tp), | 9074 | memcpy(&tp->estats_prev, tg3_get_estats(tp), |
9055 | sizeof(tp->estats_prev)); | 9075 | sizeof(tp->estats_prev)); |
9056 | 9076 | ||
9077 | tg3_napi_fini(tp); | ||
9078 | |||
9057 | tg3_free_consistent(tp); | 9079 | tg3_free_consistent(tp); |
9058 | 9080 | ||
9059 | tg3_set_power_state(tp, PCI_D3hot); | 9081 | tg3_set_power_state(tp, PCI_D3hot); |
@@ -14604,13 +14626,10 @@ static int __devinit tg3_init_one(struct pci_dev *pdev, | |||
14604 | tnapi->consmbox = rcvmbx; | 14626 | tnapi->consmbox = rcvmbx; |
14605 | tnapi->prodmbox = sndmbx; | 14627 | tnapi->prodmbox = sndmbx; |
14606 | 14628 | ||
14607 | if (i) { | 14629 | if (i) |
14608 | tnapi->coal_now = HOSTCC_MODE_COAL_VEC1_NOW << (i - 1); | 14630 | tnapi->coal_now = HOSTCC_MODE_COAL_VEC1_NOW << (i - 1); |
14609 | netif_napi_add(dev, &tnapi->napi, tg3_poll_msix, 64); | 14631 | else |
14610 | } else { | ||
14611 | tnapi->coal_now = HOSTCC_MODE_NOW; | 14632 | tnapi->coal_now = HOSTCC_MODE_NOW; |
14612 | netif_napi_add(dev, &tnapi->napi, tg3_poll, 64); | ||
14613 | } | ||
14614 | 14633 | ||
14615 | if (!(tp->tg3_flags & TG3_FLAG_SUPPORT_MSIX)) | 14634 | if (!(tp->tg3_flags & TG3_FLAG_SUPPORT_MSIX)) |
14616 | break; | 14635 | break; |