Skip to content

Commit 0fa0ee0

Browse files
Ben Hutchingsdavem330
authored andcommitted
netdev: Convert MDIO ioctl implementation to use struct mii_ioctl_data
A few drivers still access the arguments to MDIO ioctls as an array of u16. Convert them to use struct mii_ioctl_data. Signed-off-by: Ben Hutchings <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 7ab0f27 commit 0fa0ee0

File tree

5 files changed

+32
-22
lines changed

5 files changed

+32
-22
lines changed

drivers/net/ibm_newemac/core.c

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -2209,7 +2209,7 @@ static const struct ethtool_ops emac_ethtool_ops = {
22092209
static int emac_ioctl(struct net_device *ndev, struct ifreq *rq, int cmd)
22102210
{
22112211
struct emac_instance *dev = netdev_priv(ndev);
2212-
uint16_t *data = (uint16_t *) & rq->ifr_ifru;
2212+
struct mii_ioctl_data *data = if_mii(rq);
22132213

22142214
DBG(dev, "ioctl %08x" NL, cmd);
22152215

@@ -2218,14 +2218,16 @@ static int emac_ioctl(struct net_device *ndev, struct ifreq *rq, int cmd)
22182218

22192219
switch (cmd) {
22202220
case SIOCGMIIPHY:
2221-
data[0] = dev->phy.address;
2221+
data->phy_id = dev->phy.address;
22222222
/* Fall through */
22232223
case SIOCGMIIREG:
2224-
data[3] = emac_mdio_read(ndev, dev->phy.address, data[1]);
2224+
data->val_out = emac_mdio_read(ndev, dev->phy.address,
2225+
data->reg_num);
22252226
return 0;
22262227

22272228
case SIOCSMIIREG:
2228-
emac_mdio_write(ndev, dev->phy.address, data[1], data[2]);
2229+
emac_mdio_write(ndev, dev->phy.address, data->reg_num,
2230+
data->val_in);
22292231
return 0;
22302232
default:
22312233
return -EOPNOTSUPP;

drivers/net/pcmcia/3c574_cs.c

Lines changed: 8 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -85,6 +85,7 @@ earlier 3Com products.
8585
#include <linux/ioport.h>
8686
#include <linux/ethtool.h>
8787
#include <linux/bitops.h>
88+
#include <linux/mii.h>
8889

8990
#include <pcmcia/cs_types.h>
9091
#include <pcmcia/cs.h>
@@ -1096,16 +1097,16 @@ static int el3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
10961097
{
10971098
struct el3_private *lp = netdev_priv(dev);
10981099
unsigned int ioaddr = dev->base_addr;
1099-
u16 *data = (u16 *)&rq->ifr_ifru;
1100+
struct mii_ioctl_data *data = if_mii(rq);
11001101
int phy = lp->phys & 0x1f;
11011102

11021103
DEBUG(2, "%s: In ioct(%-.6s, %#4.4x) %4.4x %4.4x %4.4x %4.4x.\n",
11031104
dev->name, rq->ifr_ifrn.ifrn_name, cmd,
1104-
data[0], data[1], data[2], data[3]);
1105+
data->phy_id, data->reg_num, data->val_in, data->val_out);
11051106

11061107
switch(cmd) {
11071108
case SIOCGMIIPHY: /* Get the address of the PHY in use. */
1108-
data[0] = phy;
1109+
data->phy_id = phy;
11091110
case SIOCGMIIREG: /* Read the specified MII register. */
11101111
{
11111112
int saved_window;
@@ -1114,7 +1115,8 @@ static int el3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
11141115
spin_lock_irqsave(&lp->window_lock, flags);
11151116
saved_window = inw(ioaddr + EL3_CMD) >> 13;
11161117
EL3WINDOW(4);
1117-
data[3] = mdio_read(ioaddr, data[0] & 0x1f, data[1] & 0x1f);
1118+
data->val_out = mdio_read(ioaddr, data->phy_id & 0x1f,
1119+
data->reg_num & 0x1f);
11181120
EL3WINDOW(saved_window);
11191121
spin_unlock_irqrestore(&lp->window_lock, flags);
11201122
return 0;
@@ -1127,7 +1129,8 @@ static int el3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
11271129
spin_lock_irqsave(&lp->window_lock, flags);
11281130
saved_window = inw(ioaddr + EL3_CMD) >> 13;
11291131
EL3WINDOW(4);
1130-
mdio_write(ioaddr, data[0] & 0x1f, data[1] & 0x1f, data[2]);
1132+
mdio_write(ioaddr, data->phy_id & 0x1f,
1133+
data->reg_num & 0x1f, data->val_in);
11311134
EL3WINDOW(saved_window);
11321135
spin_unlock_irqrestore(&lp->window_lock, flags);
11331136
return 0;

drivers/net/pcmcia/axnet_cs.c

Lines changed: 5 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -37,6 +37,7 @@
3737
#include <linux/netdevice.h>
3838
#include <linux/etherdevice.h>
3939
#include <linux/crc32.h>
40+
#include <linux/mii.h>
4041
#include "../8390.h"
4142

4243
#include <pcmcia/cs_types.h>
@@ -697,16 +698,16 @@ static const struct ethtool_ops netdev_ethtool_ops = {
697698
static int axnet_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
698699
{
699700
axnet_dev_t *info = PRIV(dev);
700-
u16 *data = (u16 *)&rq->ifr_ifru;
701+
struct mii_ioctl_data *data = if_mii(rq);
701702
unsigned int mii_addr = dev->base_addr + AXNET_MII_EEP;
702703
switch (cmd) {
703704
case SIOCGMIIPHY:
704-
data[0] = info->phy_id;
705+
data->phy_id = info->phy_id;
705706
case SIOCGMIIREG: /* Read MII PHY register. */
706-
data[3] = mdio_read(mii_addr, data[0], data[1] & 0x1f);
707+
data->val_out = mdio_read(mii_addr, data->phy_id, data->reg_num & 0x1f);
707708
return 0;
708709
case SIOCSMIIREG: /* Write MII PHY register. */
709-
mdio_write(mii_addr, data[0], data[1] & 0x1f, data[2]);
710+
mdio_write(mii_addr, data->phy_id, data->reg_num & 0x1f, data->val_in);
710711
return 0;
711712
}
712713
return -EOPNOTSUPP;

drivers/net/pcmcia/pcnet_cs.c

Lines changed: 5 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -40,6 +40,7 @@
4040
#include <linux/netdevice.h>
4141
#include <linux/log2.h>
4242
#include <linux/etherdevice.h>
43+
#include <linux/mii.h>
4344
#include "../8390.h"
4445

4546
#include <pcmcia/cs_types.h>
@@ -1191,20 +1192,20 @@ static const struct ethtool_ops netdev_ethtool_ops = {
11911192
static int ei_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
11921193
{
11931194
pcnet_dev_t *info = PRIV(dev);
1194-
u16 *data = (u16 *)&rq->ifr_ifru;
1195+
struct mii_ioctl_data *data = if_mii(rq);
11951196
unsigned int mii_addr = dev->base_addr + DLINK_GPIO;
11961197

11971198
if (!(info->flags & (IS_DL10019|IS_DL10022)))
11981199
return -EINVAL;
11991200

12001201
switch (cmd) {
12011202
case SIOCGMIIPHY:
1202-
data[0] = info->phy_id;
1203+
data->phy_id = info->phy_id;
12031204
case SIOCGMIIREG: /* Read MII PHY register. */
1204-
data[3] = mdio_read(mii_addr, data[0], data[1] & 0x1f);
1205+
data->val_out = mdio_read(mii_addr, data->phy_id, data->reg_num & 0x1f);
12051206
return 0;
12061207
case SIOCSMIIREG: /* Write MII PHY register. */
1207-
mdio_write(mii_addr, data[0], data[1] & 0x1f, data[2]);
1208+
mdio_write(mii_addr, data->phy_id, data->reg_num & 0x1f, data->val_in);
12081209
return 0;
12091210
}
12101211
return -EOPNOTSUPP;

drivers/net/pcmcia/xirc2ps_cs.c

Lines changed: 8 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -80,6 +80,7 @@
8080
#include <linux/if_arp.h>
8181
#include <linux/ioport.h>
8282
#include <linux/bitops.h>
83+
#include <linux/mii.h>
8384

8485
#include <pcmcia/cs_types.h>
8586
#include <pcmcia/cs.h>
@@ -1558,24 +1559,26 @@ do_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
15581559
{
15591560
local_info_t *local = netdev_priv(dev);
15601561
unsigned int ioaddr = dev->base_addr;
1561-
u16 *data = (u16 *)&rq->ifr_ifru;
1562+
struct mii_ioctl_data *data = if_mii(rq);
15621563

15631564
DEBUG(1, "%s: ioctl(%-.6s, %#04x) %04x %04x %04x %04x\n",
15641565
dev->name, rq->ifr_ifrn.ifrn_name, cmd,
1565-
data[0], data[1], data[2], data[3]);
1566+
data->phy_id, data->reg_num, data->val_in, data->val_out);
15661567

15671568
if (!local->mohawk)
15681569
return -EOPNOTSUPP;
15691570

15701571
switch(cmd) {
15711572
case SIOCGMIIPHY: /* Get the address of the PHY in use. */
1572-
data[0] = 0; /* we have only this address */
1573+
data->phy_id = 0; /* we have only this address */
15731574
/* fall through */
15741575
case SIOCGMIIREG: /* Read the specified MII register. */
1575-
data[3] = mii_rd(ioaddr, data[0] & 0x1f, data[1] & 0x1f);
1576+
data->val_out = mii_rd(ioaddr, data->phy_id & 0x1f,
1577+
data->reg_num & 0x1f);
15761578
break;
15771579
case SIOCSMIIREG: /* Write the specified MII register */
1578-
mii_wr(ioaddr, data[0] & 0x1f, data[1] & 0x1f, data[2], 16);
1580+
mii_wr(ioaddr, data->phy_id & 0x1f, data->reg_num & 0x1f, data->val_in,
1581+
16);
15791582
break;
15801583
default:
15811584
return -EOPNOTSUPP;

0 commit comments

Comments
 (0)