aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/via-velocity.c71
1 files changed, 25 insertions, 46 deletions
diff --git a/drivers/net/via-velocity.c b/drivers/net/via-velocity.c
index 27bcd3bea133..490ec5b2775a 100644
--- a/drivers/net/via-velocity.c
+++ b/drivers/net/via-velocity.c
@@ -42,7 +42,6 @@
42 * 42 *
43 */ 43 */
44 44
45
46#include <linux/module.h> 45#include <linux/module.h>
47#include <linux/types.h> 46#include <linux/types.h>
48#include <linux/bitops.h> 47#include <linux/bitops.h>
@@ -112,7 +111,6 @@ static void mac_get_cam_mask(struct mac_regs __iomem *regs, u8 *mask)
112 BYTE_REG_BITS_SET(CAMCR_PS_MAR, CAMCR_PS1 | CAMCR_PS0, &regs->CAMCR); 111 BYTE_REG_BITS_SET(CAMCR_PS_MAR, CAMCR_PS1 | CAMCR_PS0, &regs->CAMCR);
113} 112}
114 113
115
116/** 114/**
117 * mac_set_cam_mask - Set a CAM mask 115 * mac_set_cam_mask - Set a CAM mask
118 * @regs: register block for this velocity 116 * @regs: register block for this velocity
@@ -700,7 +698,6 @@ static int velocity_mii_read(struct mac_regs __iomem *regs, u8 index, u16 *data)
700 return 0; 698 return 0;
701} 699}
702 700
703
704/** 701/**
705 * mii_check_media_mode - check media state 702 * mii_check_media_mode - check media state
706 * @regs: velocity registers 703 * @regs: velocity registers
@@ -866,8 +863,6 @@ static u32 check_connection_type(struct mac_regs __iomem *regs)
866 return status; 863 return status;
867} 864}
868 865
869
870
871/** 866/**
872 * velocity_set_media_mode - set media mode 867 * velocity_set_media_mode - set media mode
873 * @mii_status: old MII link state 868 * @mii_status: old MII link state
@@ -1262,6 +1257,7 @@ static void setup_queue_timers(struct velocity_info *vptr)
1262 writeb(rxqueue_timer, &vptr->mac_regs->RQETMR); 1257 writeb(rxqueue_timer, &vptr->mac_regs->RQETMR);
1263 } 1258 }
1264} 1259}
1260
1265/** 1261/**
1266 * setup_adaptive_interrupts - Setup interrupt suppression 1262 * setup_adaptive_interrupts - Setup interrupt suppression
1267 * 1263 *
@@ -1601,8 +1597,6 @@ static void velocity_free_rd_ring(struct velocity_info *vptr)
1601 vptr->rx.info = NULL; 1597 vptr->rx.info = NULL;
1602} 1598}
1603 1599
1604
1605
1606/** 1600/**
1607 * velocity_init_rd_ring - set up receive ring 1601 * velocity_init_rd_ring - set up receive ring
1608 * @vptr: velocity to configure 1602 * @vptr: velocity to configure
@@ -1676,7 +1670,6 @@ static void velocity_free_dma_rings(struct velocity_info *vptr)
1676 pci_free_consistent(vptr->pdev, size, vptr->rx.ring, vptr->rx.pool_dma); 1670 pci_free_consistent(vptr->pdev, size, vptr->rx.ring, vptr->rx.pool_dma);
1677} 1671}
1678 1672
1679
1680static int velocity_init_rings(struct velocity_info *vptr, int mtu) 1673static int velocity_init_rings(struct velocity_info *vptr, int mtu)
1681{ 1674{
1682 int ret; 1675 int ret;
@@ -1739,7 +1732,6 @@ static void velocity_free_tx_buf(struct velocity_info *vptr,
1739 tdinfo->skb = NULL; 1732 tdinfo->skb = NULL;
1740} 1733}
1741 1734
1742
1743/* 1735/*
1744 * FIXME: could we merge this with velocity_free_tx_buf ? 1736 * FIXME: could we merge this with velocity_free_tx_buf ?
1745 */ 1737 */
@@ -1787,7 +1779,6 @@ static void velocity_free_td_ring(struct velocity_info *vptr)
1787 } 1779 }
1788} 1780}
1789 1781
1790
1791static void velocity_free_rings(struct velocity_info *vptr) 1782static void velocity_free_rings(struct velocity_info *vptr)
1792{ 1783{
1793 velocity_free_td_ring(vptr); 1784 velocity_free_td_ring(vptr);
@@ -2025,7 +2016,6 @@ static inline void velocity_iph_realign(struct velocity_info *vptr,
2025 } 2016 }
2026} 2017}
2027 2018
2028
2029/** 2019/**
2030 * velocity_receive_frame - received packet processor 2020 * velocity_receive_frame - received packet processor
2031 * @vptr: velocity we are handling 2021 * @vptr: velocity we are handling
@@ -2097,7 +2087,6 @@ static int velocity_receive_frame(struct velocity_info *vptr, int idx)
2097 return 0; 2087 return 0;
2098} 2088}
2099 2089
2100
2101/** 2090/**
2102 * velocity_rx_srv - service RX interrupt 2091 * velocity_rx_srv - service RX interrupt
2103 * @vptr: velocity 2092 * @vptr: velocity
@@ -2405,7 +2394,6 @@ static int velocity_mii_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd
2405 return 0; 2394 return 0;
2406} 2395}
2407 2396
2408
2409/** 2397/**
2410 * velocity_ioctl - ioctl entry point 2398 * velocity_ioctl - ioctl entry point
2411 * @dev: network device 2399 * @dev: network device
@@ -2620,14 +2608,13 @@ out:
2620 return NETDEV_TX_OK; 2608 return NETDEV_TX_OK;
2621} 2609}
2622 2610
2623
2624static const struct net_device_ops velocity_netdev_ops = { 2611static const struct net_device_ops velocity_netdev_ops = {
2625 .ndo_open = velocity_open, 2612 .ndo_open = velocity_open,
2626 .ndo_stop = velocity_close, 2613 .ndo_stop = velocity_close,
2627 .ndo_start_xmit = velocity_xmit, 2614 .ndo_start_xmit = velocity_xmit,
2628 .ndo_get_stats = velocity_get_stats, 2615 .ndo_get_stats = velocity_get_stats,
2629 .ndo_validate_addr = eth_validate_addr, 2616 .ndo_validate_addr = eth_validate_addr,
2630 .ndo_set_mac_address = eth_mac_addr, 2617 .ndo_set_mac_address = eth_mac_addr,
2631 .ndo_set_multicast_list = velocity_set_multi, 2618 .ndo_set_multicast_list = velocity_set_multi,
2632 .ndo_change_mtu = velocity_change_mtu, 2619 .ndo_change_mtu = velocity_change_mtu,
2633 .ndo_do_ioctl = velocity_ioctl, 2620 .ndo_do_ioctl = velocity_ioctl,
@@ -2718,7 +2705,6 @@ static u32 velocity_get_link(struct net_device *dev)
2718 return BYTE_REG_BITS_IS_ON(PHYSR0_LINKGD, &regs->PHYSR0) ? 1 : 0; 2705 return BYTE_REG_BITS_IS_ON(PHYSR0_LINKGD, &regs->PHYSR0) ? 1 : 0;
2719} 2706}
2720 2707
2721
2722/** 2708/**
2723 * velocity_found1 - set up discovered velocity card 2709 * velocity_found1 - set up discovered velocity card
2724 * @pdev: PCI device 2710 * @pdev: PCI device
@@ -2865,7 +2851,6 @@ err_free_dev:
2865 goto out; 2851 goto out;
2866} 2852}
2867 2853
2868
2869#ifdef CONFIG_PM 2854#ifdef CONFIG_PM
2870/** 2855/**
2871 * wol_calc_crc - WOL CRC 2856 * wol_calc_crc - WOL CRC
@@ -3036,7 +3021,7 @@ static int velocity_suspend(struct pci_dev *pdev, pm_message_t state)
3036 3021
3037 spin_lock_irqsave(&vptr->lock, flags); 3022 spin_lock_irqsave(&vptr->lock, flags);
3038 pci_save_state(pdev); 3023 pci_save_state(pdev);
3039#ifdef ETHTOOL_GWOL 3024
3040 if (vptr->flags & VELOCITY_FLAGS_WOL_ENABLED) { 3025 if (vptr->flags & VELOCITY_FLAGS_WOL_ENABLED) {
3041 velocity_get_ip(vptr); 3026 velocity_get_ip(vptr);
3042 velocity_save_context(vptr, &vptr->context); 3027 velocity_save_context(vptr, &vptr->context);
@@ -3050,9 +3035,7 @@ static int velocity_suspend(struct pci_dev *pdev, pm_message_t state)
3050 pci_disable_device(pdev); 3035 pci_disable_device(pdev);
3051 pci_set_power_state(pdev, pci_choose_state(pdev, state)); 3036 pci_set_power_state(pdev, pci_choose_state(pdev, state));
3052 } 3037 }
3053#else 3038
3054 pci_set_power_state(pdev, pci_choose_state(pdev, state));
3055#endif
3056 spin_unlock_irqrestore(&vptr->lock, flags); 3039 spin_unlock_irqrestore(&vptr->lock, flags);
3057 return 0; 3040 return 0;
3058} 3041}
@@ -3133,13 +3116,13 @@ static int velocity_resume(struct pci_dev *pdev)
3133 * uses this to handle all our card discover and plugging 3116 * uses this to handle all our card discover and plugging
3134 */ 3117 */
3135static struct pci_driver velocity_driver = { 3118static struct pci_driver velocity_driver = {
3136 .name = VELOCITY_NAME, 3119 .name = VELOCITY_NAME,
3137 .id_table = velocity_id_table, 3120 .id_table = velocity_id_table,
3138 .probe = velocity_found1, 3121 .probe = velocity_found1,
3139 .remove = __devexit_p(velocity_remove1), 3122 .remove = __devexit_p(velocity_remove1),
3140#ifdef CONFIG_PM 3123#ifdef CONFIG_PM
3141 .suspend = velocity_suspend, 3124 .suspend = velocity_suspend,
3142 .resume = velocity_resume, 3125 .resume = velocity_resume,
3143#endif 3126#endif
3144}; 3127};
3145 3128
@@ -3521,28 +3504,27 @@ static void velocity_get_ethtool_stats(struct net_device *dev,
3521} 3504}
3522 3505
3523static const struct ethtool_ops velocity_ethtool_ops = { 3506static const struct ethtool_ops velocity_ethtool_ops = {
3524 .get_settings = velocity_get_settings, 3507 .get_settings = velocity_get_settings,
3525 .set_settings = velocity_set_settings, 3508 .set_settings = velocity_set_settings,
3526 .get_drvinfo = velocity_get_drvinfo, 3509 .get_drvinfo = velocity_get_drvinfo,
3527 .get_wol = velocity_ethtool_get_wol, 3510 .get_wol = velocity_ethtool_get_wol,
3528 .set_wol = velocity_ethtool_set_wol, 3511 .set_wol = velocity_ethtool_set_wol,
3529 .get_msglevel = velocity_get_msglevel, 3512 .get_msglevel = velocity_get_msglevel,
3530 .set_msglevel = velocity_set_msglevel, 3513 .set_msglevel = velocity_set_msglevel,
3531 .get_link = velocity_get_link, 3514 .get_link = velocity_get_link,
3532 .get_strings = velocity_get_strings, 3515 .get_strings = velocity_get_strings,
3533 .get_sset_count = velocity_get_sset_count, 3516 .get_sset_count = velocity_get_sset_count,
3534 .get_ethtool_stats = velocity_get_ethtool_stats, 3517 .get_ethtool_stats = velocity_get_ethtool_stats,
3535 .get_coalesce = velocity_get_coalesce, 3518 .get_coalesce = velocity_get_coalesce,
3536 .set_coalesce = velocity_set_coalesce, 3519 .set_coalesce = velocity_set_coalesce,
3537 .begin = velocity_ethtool_up, 3520 .begin = velocity_ethtool_up,
3538 .complete = velocity_ethtool_down 3521 .complete = velocity_ethtool_down
3539}; 3522};
3540 3523
3541#ifdef CONFIG_PM 3524#if defined(CONFIG_PM) && defined(CONFIG_INET)
3542#ifdef CONFIG_INET
3543static int velocity_netdev_event(struct notifier_block *nb, unsigned long notification, void *ptr) 3525static int velocity_netdev_event(struct notifier_block *nb, unsigned long notification, void *ptr)
3544{ 3526{
3545 struct in_ifaddr *ifa = (struct in_ifaddr *) ptr; 3527 struct in_ifaddr *ifa = ptr;
3546 struct net_device *dev = ifa->ifa_dev->dev; 3528 struct net_device *dev = ifa->ifa_dev->dev;
3547 3529
3548 if (dev_net(dev) == &init_net && 3530 if (dev_net(dev) == &init_net &&
@@ -3551,12 +3533,9 @@ static int velocity_netdev_event(struct notifier_block *nb, unsigned long notifi
3551 3533
3552 return NOTIFY_DONE; 3534 return NOTIFY_DONE;
3553} 3535}
3554#endif /* CONFIG_INET */
3555#endif /* CONFIG_PM */
3556 3536
3557#if defined(CONFIG_PM) && defined(CONFIG_INET)
3558static struct notifier_block velocity_inetaddr_notifier = { 3537static struct notifier_block velocity_inetaddr_notifier = {
3559 .notifier_call = velocity_netdev_event, 3538 .notifier_call = velocity_netdev_event,
3560}; 3539};
3561 3540
3562static void velocity_register_notifier(void) 3541static void velocity_register_notifier(void)