diff options
Diffstat (limited to 'drivers/net/skge.c')
-rw-r--r-- | drivers/net/skge.c | 81 |
1 files changed, 42 insertions, 39 deletions
diff --git a/drivers/net/skge.c b/drivers/net/skge.c index 8aa24c52f319..720af1c7854b 100644 --- a/drivers/net/skge.c +++ b/drivers/net/skge.c | |||
@@ -71,9 +71,9 @@ MODULE_AUTHOR("Stephen Hemminger <shemminger@linux-foundation.org>"); | |||
71 | MODULE_LICENSE("GPL"); | 71 | MODULE_LICENSE("GPL"); |
72 | MODULE_VERSION(DRV_VERSION); | 72 | MODULE_VERSION(DRV_VERSION); |
73 | 73 | ||
74 | static const u32 default_msg | 74 | static const u32 default_msg = (NETIF_MSG_DRV | NETIF_MSG_PROBE | |
75 | = NETIF_MSG_DRV| NETIF_MSG_PROBE| NETIF_MSG_LINK | 75 | NETIF_MSG_LINK | NETIF_MSG_IFUP | |
76 | | NETIF_MSG_IFUP| NETIF_MSG_IFDOWN; | 76 | NETIF_MSG_IFDOWN); |
77 | 77 | ||
78 | static int debug = -1; /* defaults above */ | 78 | static int debug = -1; /* defaults above */ |
79 | module_param(debug, int, 0); | 79 | module_param(debug, int, 0); |
@@ -188,8 +188,8 @@ static void skge_wol_init(struct skge_port *skge) | |||
188 | 188 | ||
189 | /* Force to 10/100 skge_reset will re-enable on resume */ | 189 | /* Force to 10/100 skge_reset will re-enable on resume */ |
190 | gm_phy_write(hw, port, PHY_MARV_AUNE_ADV, | 190 | gm_phy_write(hw, port, PHY_MARV_AUNE_ADV, |
191 | PHY_AN_100FULL | PHY_AN_100HALF | | 191 | (PHY_AN_100FULL | PHY_AN_100HALF | |
192 | PHY_AN_10FULL | PHY_AN_10HALF| PHY_AN_CSMA); | 192 | PHY_AN_10FULL | PHY_AN_10HALF | PHY_AN_CSMA)); |
193 | /* no 1000 HD/FD */ | 193 | /* no 1000 HD/FD */ |
194 | gm_phy_write(hw, port, PHY_MARV_1000T_CTRL, 0); | 194 | gm_phy_write(hw, port, PHY_MARV_1000T_CTRL, 0); |
195 | gm_phy_write(hw, port, PHY_MARV_CTRL, | 195 | gm_phy_write(hw, port, PHY_MARV_CTRL, |
@@ -258,25 +258,28 @@ static u32 skge_supported_modes(const struct skge_hw *hw) | |||
258 | u32 supported; | 258 | u32 supported; |
259 | 259 | ||
260 | if (hw->copper) { | 260 | if (hw->copper) { |
261 | supported = SUPPORTED_10baseT_Half | 261 | supported = (SUPPORTED_10baseT_Half | |
262 | | SUPPORTED_10baseT_Full | 262 | SUPPORTED_10baseT_Full | |
263 | | SUPPORTED_100baseT_Half | 263 | SUPPORTED_100baseT_Half | |
264 | | SUPPORTED_100baseT_Full | 264 | SUPPORTED_100baseT_Full | |
265 | | SUPPORTED_1000baseT_Half | 265 | SUPPORTED_1000baseT_Half | |
266 | | SUPPORTED_1000baseT_Full | 266 | SUPPORTED_1000baseT_Full | |
267 | | SUPPORTED_Autoneg| SUPPORTED_TP; | 267 | SUPPORTED_Autoneg | |
268 | SUPPORTED_TP); | ||
268 | 269 | ||
269 | if (hw->chip_id == CHIP_ID_GENESIS) | 270 | if (hw->chip_id == CHIP_ID_GENESIS) |
270 | supported &= ~(SUPPORTED_10baseT_Half | 271 | supported &= ~(SUPPORTED_10baseT_Half | |
271 | | SUPPORTED_10baseT_Full | 272 | SUPPORTED_10baseT_Full | |
272 | | SUPPORTED_100baseT_Half | 273 | SUPPORTED_100baseT_Half | |
273 | | SUPPORTED_100baseT_Full); | 274 | SUPPORTED_100baseT_Full); |
274 | 275 | ||
275 | else if (hw->chip_id == CHIP_ID_YUKON) | 276 | else if (hw->chip_id == CHIP_ID_YUKON) |
276 | supported &= ~SUPPORTED_1000baseT_Half; | 277 | supported &= ~SUPPORTED_1000baseT_Half; |
277 | } else | 278 | } else |
278 | supported = SUPPORTED_1000baseT_Full | SUPPORTED_1000baseT_Half | 279 | supported = (SUPPORTED_1000baseT_Full | |
279 | | SUPPORTED_FIBRE | SUPPORTED_Autoneg; | 280 | SUPPORTED_1000baseT_Half | |
281 | SUPPORTED_FIBRE | | ||
282 | SUPPORTED_Autoneg); | ||
280 | 283 | ||
281 | return supported; | 284 | return supported; |
282 | } | 285 | } |
@@ -366,7 +369,7 @@ static int skge_set_settings(struct net_device *dev, struct ethtool_cmd *ecmd) | |||
366 | } | 369 | } |
367 | } | 370 | } |
368 | 371 | ||
369 | return (0); | 372 | return 0; |
370 | } | 373 | } |
371 | 374 | ||
372 | static void skge_get_drvinfo(struct net_device *dev, | 375 | static void skge_get_drvinfo(struct net_device *dev, |
@@ -813,7 +816,7 @@ static int skge_get_eeprom_len(struct net_device *dev) | |||
813 | u32 reg2; | 816 | u32 reg2; |
814 | 817 | ||
815 | pci_read_config_dword(skge->hw->pdev, PCI_DEV_REG2, ®2); | 818 | pci_read_config_dword(skge->hw->pdev, PCI_DEV_REG2, ®2); |
816 | return 1 << ( ((reg2 & PCI_VPD_ROM_SZ) >> 14) + 8); | 819 | return 1 << (((reg2 & PCI_VPD_ROM_SZ) >> 14) + 8); |
817 | } | 820 | } |
818 | 821 | ||
819 | static u32 skge_vpd_read(struct pci_dev *pdev, int cap, u16 offset) | 822 | static u32 skge_vpd_read(struct pci_dev *pdev, int cap, u16 offset) |
@@ -1044,7 +1047,7 @@ static int skge_rx_fill(struct net_device *dev) | |||
1044 | 1047 | ||
1045 | skb_reserve(skb, NET_IP_ALIGN); | 1048 | skb_reserve(skb, NET_IP_ALIGN); |
1046 | skge_rx_setup(skge, e, skb, skge->rx_buf_size); | 1049 | skge_rx_setup(skge, e, skb, skge->rx_buf_size); |
1047 | } while ( (e = e->next) != ring->start); | 1050 | } while ((e = e->next) != ring->start); |
1048 | 1051 | ||
1049 | ring->to_clean = ring->start; | 1052 | ring->to_clean = ring->start; |
1050 | return 0; | 1053 | return 0; |
@@ -1052,7 +1055,7 @@ static int skge_rx_fill(struct net_device *dev) | |||
1052 | 1055 | ||
1053 | static const char *skge_pause(enum pause_status status) | 1056 | static const char *skge_pause(enum pause_status status) |
1054 | { | 1057 | { |
1055 | switch(status) { | 1058 | switch (status) { |
1056 | case FLOW_STAT_NONE: | 1059 | case FLOW_STAT_NONE: |
1057 | return "none"; | 1060 | return "none"; |
1058 | case FLOW_STAT_REM_SEND: | 1061 | case FLOW_STAT_REM_SEND: |
@@ -1322,7 +1325,7 @@ static void bcom_phy_init(struct skge_port *skge) | |||
1322 | /* Optimize MDIO transfer by suppressing preamble. */ | 1325 | /* Optimize MDIO transfer by suppressing preamble. */ |
1323 | r = xm_read16(hw, port, XM_MMU_CMD); | 1326 | r = xm_read16(hw, port, XM_MMU_CMD); |
1324 | r |= XM_MMU_NO_PRE; | 1327 | r |= XM_MMU_NO_PRE; |
1325 | xm_write16(hw, port, XM_MMU_CMD,r); | 1328 | xm_write16(hw, port, XM_MMU_CMD, r); |
1326 | 1329 | ||
1327 | switch (id1) { | 1330 | switch (id1) { |
1328 | case PHY_BCOM_ID1_C0: | 1331 | case PHY_BCOM_ID1_C0: |
@@ -1512,7 +1515,7 @@ static void xm_link_timer(unsigned long arg) | |||
1512 | { | 1515 | { |
1513 | struct skge_port *skge = (struct skge_port *) arg; | 1516 | struct skge_port *skge = (struct skge_port *) arg; |
1514 | struct net_device *dev = skge->netdev; | 1517 | struct net_device *dev = skge->netdev; |
1515 | struct skge_hw *hw = skge->hw; | 1518 | struct skge_hw *hw = skge->hw; |
1516 | int port = skge->port; | 1519 | int port = skge->port; |
1517 | int i; | 1520 | int i; |
1518 | unsigned long flags; | 1521 | unsigned long flags; |
@@ -1531,7 +1534,7 @@ static void xm_link_timer(unsigned long arg) | |||
1531 | goto link_down; | 1534 | goto link_down; |
1532 | } | 1535 | } |
1533 | 1536 | ||
1534 | /* Re-enable interrupt to detect link down */ | 1537 | /* Re-enable interrupt to detect link down */ |
1535 | if (xm_check_link(dev)) { | 1538 | if (xm_check_link(dev)) { |
1536 | u16 msk = xm_read16(hw, port, XM_IMSK); | 1539 | u16 msk = xm_read16(hw, port, XM_IMSK); |
1537 | msk &= ~XM_IS_INP_ASS; | 1540 | msk &= ~XM_IS_INP_ASS; |
@@ -1588,7 +1591,7 @@ static void genesis_mac_init(struct skge_hw *hw, int port) | |||
1588 | } | 1591 | } |
1589 | 1592 | ||
1590 | 1593 | ||
1591 | switch(hw->phy_type) { | 1594 | switch (hw->phy_type) { |
1592 | case SK_PHY_XMAC: | 1595 | case SK_PHY_XMAC: |
1593 | xm_phy_init(skge); | 1596 | xm_phy_init(skge); |
1594 | break; | 1597 | break; |
@@ -1695,7 +1698,7 @@ static void genesis_mac_init(struct skge_hw *hw, int port) | |||
1695 | 1698 | ||
1696 | if (jumbo) { | 1699 | if (jumbo) { |
1697 | /* Enable frame flushing if jumbo frames used */ | 1700 | /* Enable frame flushing if jumbo frames used */ |
1698 | skge_write16(hw, SK_REG(port,RX_MFF_CTRL1), MFF_ENA_FLUSH); | 1701 | skge_write16(hw, SK_REG(port, RX_MFF_CTRL1), MFF_ENA_FLUSH); |
1699 | } else { | 1702 | } else { |
1700 | /* enable timeout timers if normal frames */ | 1703 | /* enable timeout timers if normal frames */ |
1701 | skge_write16(hw, B3_PA_CTRL, | 1704 | skge_write16(hw, B3_PA_CTRL, |
@@ -1710,7 +1713,7 @@ static void genesis_stop(struct skge_port *skge) | |||
1710 | unsigned retries = 1000; | 1713 | unsigned retries = 1000; |
1711 | u16 cmd; | 1714 | u16 cmd; |
1712 | 1715 | ||
1713 | /* Disable Tx and Rx */ | 1716 | /* Disable Tx and Rx */ |
1714 | cmd = xm_read16(hw, port, XM_MMU_CMD); | 1717 | cmd = xm_read16(hw, port, XM_MMU_CMD); |
1715 | cmd &= ~(XM_MMU_ENA_RX | XM_MMU_ENA_TX); | 1718 | cmd &= ~(XM_MMU_ENA_RX | XM_MMU_ENA_TX); |
1716 | xm_write16(hw, port, XM_MMU_CMD, cmd); | 1719 | xm_write16(hw, port, XM_MMU_CMD, cmd); |
@@ -1789,7 +1792,7 @@ static void genesis_mac_intr(struct skge_hw *hw, int port) | |||
1789 | "mac interrupt status 0x%x\n", status); | 1792 | "mac interrupt status 0x%x\n", status); |
1790 | 1793 | ||
1791 | if (hw->phy_type == SK_PHY_XMAC && (status & XM_IS_INP_ASS)) { | 1794 | if (hw->phy_type == SK_PHY_XMAC && (status & XM_IS_INP_ASS)) { |
1792 | xm_link_down(hw, port); | 1795 | xm_link_down(hw, port); |
1793 | mod_timer(&skge->link_timer, jiffies + 1); | 1796 | mod_timer(&skge->link_timer, jiffies + 1); |
1794 | } | 1797 | } |
1795 | 1798 | ||
@@ -1823,7 +1826,7 @@ static void genesis_link_up(struct skge_port *skge) | |||
1823 | xm_write16(hw, port, XM_MMU_CMD, cmd); | 1826 | xm_write16(hw, port, XM_MMU_CMD, cmd); |
1824 | 1827 | ||
1825 | mode = xm_read32(hw, port, XM_MODE); | 1828 | mode = xm_read32(hw, port, XM_MODE); |
1826 | if (skge->flow_status== FLOW_STAT_SYMMETRIC || | 1829 | if (skge->flow_status == FLOW_STAT_SYMMETRIC || |
1827 | skge->flow_status == FLOW_STAT_LOC_SEND) { | 1830 | skge->flow_status == FLOW_STAT_LOC_SEND) { |
1828 | /* | 1831 | /* |
1829 | * Configure Pause Frame Generation | 1832 | * Configure Pause Frame Generation |
@@ -2466,7 +2469,7 @@ static int skge_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) | |||
2466 | if (!netif_running(dev)) | 2469 | if (!netif_running(dev)) |
2467 | return -ENODEV; /* Phy still in reset */ | 2470 | return -ENODEV; /* Phy still in reset */ |
2468 | 2471 | ||
2469 | switch(cmd) { | 2472 | switch (cmd) { |
2470 | case SIOCGMIIPHY: | 2473 | case SIOCGMIIPHY: |
2471 | data->phy_id = hw->phy_addr; | 2474 | data->phy_id = hw->phy_addr; |
2472 | 2475 | ||
@@ -2765,7 +2768,7 @@ static netdev_tx_t skge_xmit_frame(struct sk_buff *skb, | |||
2765 | * does. Looks like hardware is wrong? | 2768 | * does. Looks like hardware is wrong? |
2766 | */ | 2769 | */ |
2767 | if (ipip_hdr(skb)->protocol == IPPROTO_UDP && | 2770 | if (ipip_hdr(skb)->protocol == IPPROTO_UDP && |
2768 | hw->chip_rev == 0 && hw->chip_id == CHIP_ID_YUKON) | 2771 | hw->chip_rev == 0 && hw->chip_id == CHIP_ID_YUKON) |
2769 | control = BMU_TCP_CHECK; | 2772 | control = BMU_TCP_CHECK; |
2770 | else | 2773 | else |
2771 | control = BMU_UDP_CHECK; | 2774 | control = BMU_UDP_CHECK; |
@@ -2777,7 +2780,7 @@ static netdev_tx_t skge_xmit_frame(struct sk_buff *skb, | |||
2777 | control = BMU_CHECK; | 2780 | control = BMU_CHECK; |
2778 | 2781 | ||
2779 | if (!skb_shinfo(skb)->nr_frags) /* single buffer i.e. no fragments */ | 2782 | if (!skb_shinfo(skb)->nr_frags) /* single buffer i.e. no fragments */ |
2780 | control |= BMU_EOF| BMU_IRQ_EOF; | 2783 | control |= BMU_EOF | BMU_IRQ_EOF; |
2781 | else { | 2784 | else { |
2782 | struct skge_tx_desc *tf = td; | 2785 | struct skge_tx_desc *tf = td; |
2783 | 2786 | ||
@@ -3077,7 +3080,7 @@ static struct sk_buff *skge_rx_get(struct net_device *dev, | |||
3077 | pci_unmap_len(e, maplen), | 3080 | pci_unmap_len(e, maplen), |
3078 | PCI_DMA_FROMDEVICE); | 3081 | PCI_DMA_FROMDEVICE); |
3079 | skb = e->skb; | 3082 | skb = e->skb; |
3080 | prefetch(skb->data); | 3083 | prefetch(skb->data); |
3081 | skge_rx_setup(skge, e, nskb, skge->rx_buf_size); | 3084 | skge_rx_setup(skge, e, nskb, skge->rx_buf_size); |
3082 | } | 3085 | } |
3083 | 3086 | ||
@@ -3554,8 +3557,7 @@ static int skge_reset(struct skge_hw *hw) | |||
3554 | hw->ram_offset = 0x80000; | 3557 | hw->ram_offset = 0x80000; |
3555 | } else | 3558 | } else |
3556 | hw->ram_size = t8 * 512; | 3559 | hw->ram_size = t8 * 512; |
3557 | } | 3560 | } else if (t8 == 0) |
3558 | else if (t8 == 0) | ||
3559 | hw->ram_size = 0x20000; | 3561 | hw->ram_size = 0x20000; |
3560 | else | 3562 | else |
3561 | hw->ram_size = t8 * 4096; | 3563 | hw->ram_size = t8 * 4096; |
@@ -3709,7 +3711,7 @@ static int skge_device_event(struct notifier_block *unused, | |||
3709 | goto done; | 3711 | goto done; |
3710 | 3712 | ||
3711 | skge = netdev_priv(dev); | 3713 | skge = netdev_priv(dev); |
3712 | switch(event) { | 3714 | switch (event) { |
3713 | case NETDEV_CHANGENAME: | 3715 | case NETDEV_CHANGENAME: |
3714 | if (skge->debugfs) { | 3716 | if (skge->debugfs) { |
3715 | d = debugfs_rename(skge_debug, skge->debugfs, | 3717 | d = debugfs_rename(skge_debug, skge->debugfs, |
@@ -3914,7 +3916,7 @@ static int __devinit skge_probe(struct pci_dev *pdev, | |||
3914 | 3916 | ||
3915 | err = -ENOMEM; | 3917 | err = -ENOMEM; |
3916 | /* space for skge@pci:0000:04:00.0 */ | 3918 | /* space for skge@pci:0000:04:00.0 */ |
3917 | hw = kzalloc(sizeof(*hw) + strlen(DRV_NAME "@pci:" ) | 3919 | hw = kzalloc(sizeof(*hw) + strlen(DRV_NAME "@pci:") |
3918 | + strlen(pci_name(pdev)) + 1, GFP_KERNEL); | 3920 | + strlen(pci_name(pdev)) + 1, GFP_KERNEL); |
3919 | if (!hw) { | 3921 | if (!hw) { |
3920 | dev_err(&pdev->dev, "cannot allocate hardware struct\n"); | 3922 | dev_err(&pdev->dev, "cannot allocate hardware struct\n"); |
@@ -4010,7 +4012,8 @@ static void __devexit skge_remove(struct pci_dev *pdev) | |||
4010 | 4012 | ||
4011 | flush_scheduled_work(); | 4013 | flush_scheduled_work(); |
4012 | 4014 | ||
4013 | if ((dev1 = hw->dev[1])) | 4015 | dev1 = hw->dev[1]; |
4016 | if (dev1) | ||
4014 | unregister_netdev(dev1); | 4017 | unregister_netdev(dev1); |
4015 | dev0 = hw->dev[0]; | 4018 | dev0 = hw->dev[0]; |
4016 | unregister_netdev(dev0); | 4019 | unregister_netdev(dev0); |