aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/tg3.c
diff options
context:
space:
mode:
authorMatt Carlson <mcarlson@broadcom.com>2011-04-20 03:57:36 -0400
committerDavid S. Miller <davem@davemloft.net>2011-04-21 20:05:55 -0400
commiteb07a9408e05f67caa671bdf2a509a4d2bd05abf (patch)
treee17b801356317ffa1225c2cb19e9580649d528fb /drivers/net/tg3.c
parent4d95847381228639844c7197deb8b2211274ef22 (diff)
tg3: Adjust rx prod ring bd replenish thresholds
The oldest tg3 devices had large rx producer ring BD caches. Back then, it made sense to make the BD cache replenish threshold only a function of the number of rx buffers posted by the driver. Since then, the BD cache sizes have shrunk to 25% of their original size and, in some cases, the ring sizes have quadrupled in size. Under such conditions, static BD cache replenish thresholds no longer match the hardware constraints. This patch attempts to factor in the BD cache size into the bd cache replenish strategy, taking the existing hardware bugs into account. Signed-off-by: Matt Carlson <mcarlson@broadcom.com> Reviewed-by: Michael Chan <mchan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
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;