aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/broadcom
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/ethernet/broadcom')
-rw-r--r--drivers/net/ethernet/broadcom/tg3.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/drivers/net/ethernet/broadcom/tg3.c b/drivers/net/ethernet/broadcom/tg3.c
index 5af560966c70..1485013b4b8c 100644
--- a/drivers/net/ethernet/broadcom/tg3.c
+++ b/drivers/net/ethernet/broadcom/tg3.c
@@ -3819,6 +3819,7 @@ static int tg3_copper_is_advertising_all(struct tg3 *tp, u32 mask)
3819 if (tg3_ctrl != all_mask) 3819 if (tg3_ctrl != all_mask)
3820 return 0; 3820 return 0;
3821 } 3821 }
3822
3822 return 1; 3823 return 1;
3823} 3824}
3824 3825
@@ -4119,8 +4120,8 @@ relink:
4119 newlnkctl = oldlnkctl | PCI_EXP_LNKCTL_CLKREQ_EN; 4120 newlnkctl = oldlnkctl | PCI_EXP_LNKCTL_CLKREQ_EN;
4120 if (newlnkctl != oldlnkctl) 4121 if (newlnkctl != oldlnkctl)
4121 pci_write_config_word(tp->pdev, 4122 pci_write_config_word(tp->pdev,
4122 pci_pcie_cap(tp->pdev) + PCI_EXP_LNKCTL, 4123 pci_pcie_cap(tp->pdev) +
4123 newlnkctl); 4124 PCI_EXP_LNKCTL, newlnkctl);
4124 } 4125 }
4125 4126
4126 if (current_link_up != netif_carrier_ok(tp->dev)) { 4127 if (current_link_up != netif_carrier_ok(tp->dev)) {
@@ -6733,6 +6734,10 @@ static netdev_tx_t tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
6733 } 6734 }
6734 } 6735 }
6735 6736
6737 if (tg3_flag(tp, USE_JUMBO_BDFLAG) &&
6738 !mss && skb->len > VLAN_ETH_FRAME_LEN)
6739 base_flags |= TXD_FLAG_JMB_PKT;
6740
6736#ifdef BCM_KERNEL_SUPPORTS_8021Q 6741#ifdef BCM_KERNEL_SUPPORTS_8021Q
6737 if (vlan_tx_tag_present(skb)) { 6742 if (vlan_tx_tag_present(skb)) {
6738 base_flags |= TXD_FLAG_VLAN; 6743 base_flags |= TXD_FLAG_VLAN;
@@ -6740,10 +6745,6 @@ static netdev_tx_t tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
6740 } 6745 }
6741#endif 6746#endif
6742 6747
6743 if (tg3_flag(tp, USE_JUMBO_BDFLAG) &&
6744 !mss && skb->len > VLAN_ETH_FRAME_LEN)
6745 base_flags |= TXD_FLAG_JMB_PKT;
6746
6747 len = skb_headlen(skb); 6748 len = skb_headlen(skb);
6748 6749
6749 mapping = pci_map_single(tp->pdev, skb->data, len, PCI_DMA_TODEVICE); 6750 mapping = pci_map_single(tp->pdev, skb->data, len, PCI_DMA_TODEVICE);
@@ -14079,7 +14080,7 @@ static int __devinit tg3_get_invariants(struct tg3 *tp)
14079 /* BCM5785 devices are effectively PCIe devices, and should 14080 /* BCM5785 devices are effectively PCIe devices, and should
14080 * follow PCIe codepaths, but do not have a PCIe capabilities 14081 * follow PCIe codepaths, but do not have a PCIe capabilities
14081 * section. 14082 * section.
14082 */ 14083 */
14083 tg3_flag_set(tp, PCI_EXPRESS); 14084 tg3_flag_set(tp, PCI_EXPRESS);
14084 } else if (!tg3_flag(tp, 5705_PLUS) || 14085 } else if (!tg3_flag(tp, 5705_PLUS) ||
14085 tg3_flag(tp, 5780_CLASS)) { 14086 tg3_flag(tp, 5780_CLASS)) {
@@ -15539,7 +15540,7 @@ static int __devinit tg3_init_one(struct pci_dev *pdev,
15539 tnapi->tx_pending = TG3_DEF_TX_RING_PENDING; 15540 tnapi->tx_pending = TG3_DEF_TX_RING_PENDING;
15540 15541
15541 tnapi->int_mbox = intmbx; 15542 tnapi->int_mbox = intmbx;
15542 if (i < 4) 15543 if (i <= 4)
15543 intmbx += 0x8; 15544 intmbx += 0x8;
15544 else 15545 else
15545 intmbx += 0x4; 15546 intmbx += 0x4;