|
@@ -9276,6 +9276,19 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy)
|
|
|
tw32_f(RDMAC_MODE, rdmac_mode);
|
|
|
udelay(40);
|
|
|
|
|
|
+ if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5719) {
|
|
|
+ for (i = 0; i < TG3_NUM_RDMA_CHANNELS; i++) {
|
|
|
+ if (tr32(TG3_RDMA_LENGTH + (i << 2)) > TG3_MAX_MTU(tp))
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ if (i < TG3_NUM_RDMA_CHANNELS) {
|
|
|
+ val = tr32(TG3_LSO_RD_DMA_CRPTEN_CTRL);
|
|
|
+ val |= TG3_LSO_RD_DMA_TX_LENGTH_WA;
|
|
|
+ tw32(TG3_LSO_RD_DMA_CRPTEN_CTRL, val);
|
|
|
+ tg3_flag_set(tp, 5719_RDMA_BUG);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
tw32(RCVDCC_MODE, RCVDCC_MODE_ENABLE | RCVDCC_MODE_ATTN_ENABLE);
|
|
|
if (!tg3_flag(tp, 5705_PLUS))
|
|
|
tw32(MBFREE_MODE, MBFREE_MODE_ENABLE);
|
|
@@ -9635,6 +9648,16 @@ static void tg3_periodic_fetch_stats(struct tg3 *tp)
|
|
|
TG3_STAT_ADD32(&sp->tx_ucast_packets, MAC_TX_STATS_UCAST);
|
|
|
TG3_STAT_ADD32(&sp->tx_mcast_packets, MAC_TX_STATS_MCAST);
|
|
|
TG3_STAT_ADD32(&sp->tx_bcast_packets, MAC_TX_STATS_BCAST);
|
|
|
+ if (unlikely(tg3_flag(tp, 5719_RDMA_BUG) &&
|
|
|
+ (sp->tx_ucast_packets.low + sp->tx_mcast_packets.low +
|
|
|
+ sp->tx_bcast_packets.low) > TG3_NUM_RDMA_CHANNELS)) {
|
|
|
+ u32 val;
|
|
|
+
|
|
|
+ val = tr32(TG3_LSO_RD_DMA_CRPTEN_CTRL);
|
|
|
+ val &= ~TG3_LSO_RD_DMA_TX_LENGTH_WA;
|
|
|
+ tw32(TG3_LSO_RD_DMA_CRPTEN_CTRL, val);
|
|
|
+ tg3_flag_clear(tp, 5719_RDMA_BUG);
|
|
|
+ }
|
|
|
|
|
|
TG3_STAT_ADD32(&sp->rx_octets, MAC_RX_STATS_OCTETS);
|
|
|
TG3_STAT_ADD32(&sp->rx_fragments, MAC_RX_STATS_FRAGMENTS);
|