Commit ef1b5b0c authored by Arnd Bergmann's avatar Arnd Bergmann Committed by David S. Miller

net: usb: use ndo_siocdevprivate

The pegasus and rtl8150 drivers use SIOCDEVPRIVATE ioctls
to access their MII registers, in place of the normal
commands. This is broken for all compat ioctls today.

Change to ndo_siocdevprivate to fix it.

Cc: Petko Manolov <petkan@nucleusys.com>
Cc: linux-usb@vger.kernel.org
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 043393d8
...@@ -987,7 +987,8 @@ static const struct ethtool_ops ops = { ...@@ -987,7 +987,8 @@ static const struct ethtool_ops ops = {
.set_link_ksettings = pegasus_set_link_ksettings, .set_link_ksettings = pegasus_set_link_ksettings,
}; };
static int pegasus_ioctl(struct net_device *net, struct ifreq *rq, int cmd) static int pegasus_siocdevprivate(struct net_device *net, struct ifreq *rq,
void __user *udata, int cmd)
{ {
__u16 *data = (__u16 *) &rq->ifr_ifru; __u16 *data = (__u16 *) &rq->ifr_ifru;
pegasus_t *pegasus = netdev_priv(net); pegasus_t *pegasus = netdev_priv(net);
...@@ -1245,7 +1246,7 @@ static int pegasus_resume(struct usb_interface *intf) ...@@ -1245,7 +1246,7 @@ static int pegasus_resume(struct usb_interface *intf)
static const struct net_device_ops pegasus_netdev_ops = { static const struct net_device_ops pegasus_netdev_ops = {
.ndo_open = pegasus_open, .ndo_open = pegasus_open,
.ndo_stop = pegasus_close, .ndo_stop = pegasus_close,
.ndo_do_ioctl = pegasus_ioctl, .ndo_siocdevprivate = pegasus_siocdevprivate,
.ndo_start_xmit = pegasus_start_xmit, .ndo_start_xmit = pegasus_start_xmit,
.ndo_set_rx_mode = pegasus_set_multicast, .ndo_set_rx_mode = pegasus_set_multicast,
.ndo_tx_timeout = pegasus_tx_timeout, .ndo_tx_timeout = pegasus_tx_timeout,
......
...@@ -822,7 +822,8 @@ static const struct ethtool_ops ops = { ...@@ -822,7 +822,8 @@ static const struct ethtool_ops ops = {
.get_link_ksettings = rtl8150_get_link_ksettings, .get_link_ksettings = rtl8150_get_link_ksettings,
}; };
static int rtl8150_ioctl(struct net_device *netdev, struct ifreq *rq, int cmd) static int rtl8150_siocdevprivate(struct net_device *netdev, struct ifreq *rq,
void __user *udata, int cmd)
{ {
rtl8150_t *dev = netdev_priv(netdev); rtl8150_t *dev = netdev_priv(netdev);
u16 *data = (u16 *) & rq->ifr_ifru; u16 *data = (u16 *) & rq->ifr_ifru;
...@@ -850,7 +851,7 @@ static int rtl8150_ioctl(struct net_device *netdev, struct ifreq *rq, int cmd) ...@@ -850,7 +851,7 @@ static int rtl8150_ioctl(struct net_device *netdev, struct ifreq *rq, int cmd)
static const struct net_device_ops rtl8150_netdev_ops = { static const struct net_device_ops rtl8150_netdev_ops = {
.ndo_open = rtl8150_open, .ndo_open = rtl8150_open,
.ndo_stop = rtl8150_close, .ndo_stop = rtl8150_close,
.ndo_do_ioctl = rtl8150_ioctl, .ndo_siocdevprivate = rtl8150_siocdevprivate,
.ndo_start_xmit = rtl8150_start_xmit, .ndo_start_xmit = rtl8150_start_xmit,
.ndo_tx_timeout = rtl8150_tx_timeout, .ndo_tx_timeout = rtl8150_tx_timeout,
.ndo_set_rx_mode = rtl8150_set_multicast, .ndo_set_rx_mode = rtl8150_set_multicast,
......
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