Commit 8f4e4a31 authored by Alexander Viro's avatar Alexander Viro Committed by Linus Torvalds

[PATCH] (6/27) tulip ethtool conversion

parent 2820689b
...@@ -830,30 +830,18 @@ static struct net_device_stats *tulip_get_stats(struct net_device *dev) ...@@ -830,30 +830,18 @@ static struct net_device_stats *tulip_get_stats(struct net_device *dev)
} }
static int netdev_ethtool_ioctl(struct net_device *dev, void __user *useraddr) static void tulip_get_drvinfo(struct net_device *dev, struct ethtool_drvinfo *info)
{ {
struct tulip_private *np = netdev_priv(dev); struct tulip_private *np = netdev_priv(dev);
u32 ethcmd; strcpy(info->driver, DRV_NAME);
strcpy(info->version, DRV_VERSION);
if (copy_from_user(&ethcmd, useraddr, sizeof(ethcmd))) strcpy(info->bus_info, pci_name(np->pdev));
return -EFAULT;
switch (ethcmd) {
case ETHTOOL_GDRVINFO: {
struct ethtool_drvinfo info = {ETHTOOL_GDRVINFO};
strcpy(info.driver, DRV_NAME);
strcpy(info.version, DRV_VERSION);
strcpy(info.bus_info, pci_name(np->pdev));
if (copy_to_user(useraddr, &info, sizeof(info)))
return -EFAULT;
return 0;
}
}
return -EOPNOTSUPP;
} }
static struct ethtool_ops ops = {
.get_drvinfo = tulip_get_drvinfo
};
/* Provide ioctl() calls to examine the MII xcvr state. */ /* Provide ioctl() calls to examine the MII xcvr state. */
static int private_ioctl (struct net_device *dev, struct ifreq *rq, int cmd) static int private_ioctl (struct net_device *dev, struct ifreq *rq, int cmd)
{ {
...@@ -865,9 +853,6 @@ static int private_ioctl (struct net_device *dev, struct ifreq *rq, int cmd) ...@@ -865,9 +853,6 @@ static int private_ioctl (struct net_device *dev, struct ifreq *rq, int cmd)
unsigned int regnum = data->reg_num; unsigned int regnum = data->reg_num;
switch (cmd) { switch (cmd) {
case SIOCETHTOOL:
return netdev_ethtool_ioctl(dev, rq->ifr_data);
case SIOCGMIIPHY: /* Get address of MII PHY in use. */ case SIOCGMIIPHY: /* Get address of MII PHY in use. */
if (tp->mii_cnt) if (tp->mii_cnt)
data->phy_id = phy; data->phy_id = phy;
...@@ -1644,6 +1629,7 @@ static int __devinit tulip_init_one (struct pci_dev *pdev, ...@@ -1644,6 +1629,7 @@ static int __devinit tulip_init_one (struct pci_dev *pdev,
#ifdef CONFIG_NET_POLL_CONTROLLER #ifdef CONFIG_NET_POLL_CONTROLLER
dev->poll_controller = &poll_tulip; dev->poll_controller = &poll_tulip;
#endif #endif
SET_ETHTOOL_OPS(dev, &ops);
if (register_netdev(dev)) if (register_netdev(dev))
goto err_out_free_ring; goto err_out_free_ring;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment