aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/tg3.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/tg3.c')
-rw-r--r--drivers/net/tg3.c67
1 files changed, 46 insertions, 21 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c
index 58787ea8b7a4..4aecb0a82e56 100644
--- a/drivers/net/tg3.c
+++ b/drivers/net/tg3.c
@@ -7952,6 +7952,48 @@ static void tg3_rings_reset(struct tg3 *tp)
7952 } 7952 }
7953} 7953}
7954 7954
7955static void tg3_setup_rxbd_thresholds(struct tg3 *tp)
7956{
7957 u32 val, bdcache_maxcnt, host_rep_thresh, nic_rep_thresh;
7958
7959 if (!(tp->tg3_flags2 & TG3_FLG2_5750_PLUS) ||
7960 (tp->tg3_flags2 & TG3_FLG2_5780_CLASS) ||
7961 GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5750 ||
7962 GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5752)
7963 bdcache_maxcnt = TG3_SRAM_RX_STD_BDCACHE_SIZE_5700;
7964 else if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5755 ||
7965 GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5787)
7966 bdcache_maxcnt = TG3_SRAM_RX_STD_BDCACHE_SIZE_5755;
7967 else
7968 bdcache_maxcnt = TG3_SRAM_RX_STD_BDCACHE_SIZE_5906;
7969
7970 nic_rep_thresh = min(bdcache_maxcnt / 2, tp->rx_std_max_post);
7971 host_rep_thresh = max_t(u32, tp->rx_pending / 8, 1);
7972
7973 val = min(nic_rep_thresh, host_rep_thresh);
7974 tw32(RCVBDI_STD_THRESH, val);
7975
7976 if (tp->tg3_flags3 & TG3_FLG3_57765_PLUS)
7977 tw32(STD_REPLENISH_LWM, bdcache_maxcnt);
7978
7979 if (!(tp->tg3_flags & TG3_FLAG_JUMBO_CAPABLE) ||
7980 (tp->tg3_flags2 & TG3_FLG2_5780_CLASS))
7981 return;
7982
7983 if (!(tp->tg3_flags2 & TG3_FLG2_5705_PLUS))
7984 bdcache_maxcnt = TG3_SRAM_RX_JMB_BDCACHE_SIZE_5700;
7985 else
7986 bdcache_maxcnt = TG3_SRAM_RX_JMB_BDCACHE_SIZE_5717;
7987
7988 host_rep_thresh = max_t(u32, tp->rx_jumbo_pending / 8, 1);
7989
7990 val = min(bdcache_maxcnt / 2, host_rep_thresh);
7991 tw32(RCVBDI_JUMBO_THRESH, val);
7992
7993 if (tp->tg3_flags3 & TG3_FLG3_57765_PLUS)
7994 tw32(JMB_REPLENISH_LWM, bdcache_maxcnt);
7995}
7996
7955/* tp->lock is held. */ 7997/* tp->lock is held. */
7956static int tg3_reset_hw(struct tg3 *tp, int reset_phy) 7998static int tg3_reset_hw(struct tg3 *tp, int reset_phy)
7957{ 7999{
@@ -8223,21 +8265,10 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy)
8223 return -ENODEV; 8265 return -ENODEV;
8224 } 8266 }
8225 8267
8226 /* Setup replenish threshold. */ 8268 if (tp->pci_chip_rev_id == CHIPREV_ID_5906_A1)
8227 val = tp->rx_pending / 8; 8269 tw32(ISO_PKT_TX, (tr32(ISO_PKT_TX) & ~0x3) | 0x2);
8228 if (val == 0)
8229 val = 1;
8230 else if (val > tp->rx_std_max_post)
8231 val = tp->rx_std_max_post;
8232 else if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5906) {
8233 if (tp->pci_chip_rev_id == CHIPREV_ID_5906_A1)
8234 tw32(ISO_PKT_TX, (tr32(ISO_PKT_TX) & ~0x3) | 0x2);
8235 8270
8236 if (val > (TG3_RX_INTERNAL_RING_SZ_5906 / 2)) 8271 tg3_setup_rxbd_thresholds(tp);
8237 val = TG3_RX_INTERNAL_RING_SZ_5906 / 2;
8238 }
8239
8240 tw32(RCVBDI_STD_THRESH, val);
8241 8272
8242 /* Initialize TG3_BDINFO's at: 8273 /* Initialize TG3_BDINFO's at:
8243 * RCVDBDI_STD_BD: standard eth size rx ring 8274 * RCVDBDI_STD_BD: standard eth size rx ring
@@ -8275,8 +8306,6 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy)
8275 if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5719 || 8306 if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5719 ||
8276 ((tp->tg3_flags & TG3_FLAG_JUMBO_CAPABLE) && 8307 ((tp->tg3_flags & TG3_FLAG_JUMBO_CAPABLE) &&
8277 !(tp->tg3_flags2 & TG3_FLG2_5780_CLASS))) { 8308 !(tp->tg3_flags2 & TG3_FLG2_5780_CLASS))) {
8278 /* Setup replenish threshold. */
8279 tw32(RCVBDI_JUMBO_THRESH, tp->rx_jumbo_pending / 8);
8280 8309
8281 if (tp->tg3_flags & TG3_FLAG_JUMBO_RING_ENABLE) { 8310 if (tp->tg3_flags & TG3_FLAG_JUMBO_RING_ENABLE) {
8282 tw32(RCVDBDI_JUMBO_BD + TG3_BDINFO_HOST_ADDR + TG3_64BIT_REG_HIGH, 8311 tw32(RCVDBDI_JUMBO_BD + TG3_BDINFO_HOST_ADDR + TG3_64BIT_REG_HIGH,
@@ -8317,11 +8346,6 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy)
8317 tp->rx_jumbo_pending : 0; 8346 tp->rx_jumbo_pending : 0;
8318 tw32_rx_mbox(TG3_RX_JMB_PROD_IDX_REG, tpr->rx_jmb_prod_idx); 8347 tw32_rx_mbox(TG3_RX_JMB_PROD_IDX_REG, tpr->rx_jmb_prod_idx);
8319 8348
8320 if (tp->tg3_flags3 & TG3_FLG3_57765_PLUS) {
8321 tw32(STD_REPLENISH_LWM, 32);
8322 tw32(JMB_REPLENISH_LWM, 16);
8323 }
8324
8325 tg3_rings_reset(tp); 8349 tg3_rings_reset(tp);
8326 8350
8327 /* Initialize MAC address and backoff seed. */ 8351 /* Initialize MAC address and backoff seed. */
@@ -13599,6 +13623,7 @@ static int __devinit tg3_get_invariants(struct tg3 *tp)
13599 (tp->tg3_flags2 & TG3_FLG2_5780_CLASS)) 13623 (tp->tg3_flags2 & TG3_FLG2_5780_CLASS))
13600 tp->tg3_flags2 |= TG3_FLG2_5750_PLUS; 13624 tp->tg3_flags2 |= TG3_FLG2_5750_PLUS;
13601 13625
13626
13602 if ((GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5705) || 13627 if ((GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5705) ||
13603 (tp->tg3_flags2 & TG3_FLG2_5750_PLUS)) 13628 (tp->tg3_flags2 & TG3_FLG2_5750_PLUS))
13604 tp->tg3_flags2 |= TG3_FLG2_5705_PLUS; 13629 tp->tg3_flags2 |= TG3_FLG2_5705_PLUS;