Skip to content

Commit 2bd6470

Browse files
petkomanolovdavem330
authored andcommitted
drivers: net: usb: pegasus: read/write_mii_word optimised
Duplicated code in routines reading and writing MII registers is now packed in __mii_op(). Signed-off-by: Petko Manolov <petkan@nucleusys.com> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 313a58e commit 2bd6470

File tree

1 file changed

+35
-50
lines changed

1 file changed

+35
-50
lines changed

drivers/net/usb/pegasus.c

Lines changed: 35 additions & 50 deletions
Original file line numberDiff line numberDiff line change
@@ -323,36 +323,50 @@ static int update_eth_regs_async(pegasus_t *pegasus)
323323
return ret;
324324
}
325325

326-
/* Returns 0 on success, error on failure */
327-
static int read_mii_word(pegasus_t *pegasus, __u8 phy, __u8 indx, __u16 *regd)
326+
static int __mii_op(pegasus_t *p, __u8 phy, __u8 indx, __u16 *regd, __u8 cmd)
328327
{
329328
int i;
330329
__u8 data[4] = { phy, 0, 0, indx };
331330
__le16 regdi;
332-
int ret;
331+
int ret = -ETIMEDOUT;
333332

334-
set_register(pegasus, PhyCtrl, 0);
335-
set_registers(pegasus, PhyAddr, sizeof(data), data);
336-
set_register(pegasus, PhyCtrl, (indx | PHY_READ));
333+
if (cmd & PHY_WRITE) {
334+
__le16 *t = (__le16 *) & data[1];
335+
*t = cpu_to_le16(*regd);
336+
}
337+
set_register(p, PhyCtrl, 0);
338+
set_registers(p, PhyAddr, sizeof(data), data);
339+
set_register(p, PhyCtrl, (indx | cmd));
337340
for (i = 0; i < REG_TIMEOUT; i++) {
338-
ret = get_registers(pegasus, PhyCtrl, 1, data);
339-
if (ret == -ESHUTDOWN)
341+
ret = get_registers(p, PhyCtrl, 1, data);
342+
if (ret < 0)
340343
goto fail;
341344
if (data[0] & PHY_DONE)
342345
break;
343346
}
344-
345347
if (i >= REG_TIMEOUT)
346348
goto fail;
347-
348-
ret = get_registers(pegasus, PhyData, 2, &regdi);
349-
*regd = le16_to_cpu(regdi);
349+
if (cmd & PHY_READ) {
350+
ret = get_registers(p, PhyData, 2, &regdi);
351+
*regd = le16_to_cpu(regdi);
352+
return ret;
353+
}
354+
return 0;
355+
fail:
356+
netif_dbg(p, drv, p->net, "%s failed\n", __func__);
350357
return ret;
358+
}
351359

352-
fail:
353-
netif_warn(pegasus, drv, pegasus->net, "%s failed\n", __func__);
360+
/* Returns non-negative int on success, error on failure */
361+
static int read_mii_word(pegasus_t *pegasus, __u8 phy, __u8 indx, __u16 *regd)
362+
{
363+
return __mii_op(pegasus, phy, indx, regd, PHY_READ);
364+
}
354365

355-
return ret;
366+
/* Returns zero on success, error on failure */
367+
static int write_mii_word(pegasus_t *pegasus, __u8 phy, __u8 indx, __u16 *regd)
368+
{
369+
return __mii_op(pegasus, phy, indx, regd, PHY_WRITE);
356370
}
357371

358372
static int mdio_read(struct net_device *dev, int phy_id, int loc)
@@ -364,40 +378,11 @@ static int mdio_read(struct net_device *dev, int phy_id, int loc)
364378
return (int)res;
365379
}
366380

367-
static int write_mii_word(pegasus_t *pegasus, __u8 phy, __u8 indx, __u16 regd)
368-
{
369-
int i;
370-
__u8 data[4] = { phy, 0, 0, indx };
371-
int ret;
372-
373-
data[1] = (u8) regd;
374-
data[2] = (u8) (regd >> 8);
375-
set_register(pegasus, PhyCtrl, 0);
376-
set_registers(pegasus, PhyAddr, sizeof(data), data);
377-
set_register(pegasus, PhyCtrl, (indx | PHY_WRITE));
378-
for (i = 0; i < REG_TIMEOUT; i++) {
379-
ret = get_registers(pegasus, PhyCtrl, 1, data);
380-
if (ret == -ESHUTDOWN)
381-
goto fail;
382-
if (data[0] & PHY_DONE)
383-
break;
384-
}
385-
386-
if (i >= REG_TIMEOUT)
387-
goto fail;
388-
389-
return ret;
390-
391-
fail:
392-
netif_warn(pegasus, drv, pegasus->net, "%s failed\n", __func__);
393-
return -ETIMEDOUT;
394-
}
395-
396381
static void mdio_write(struct net_device *dev, int phy_id, int loc, int val)
397382
{
398383
pegasus_t *pegasus = netdev_priv(dev);
399384

400-
write_mii_word(pegasus, phy_id, loc, val);
385+
write_mii_word(pegasus, phy_id, loc, (__u16 *)&val);
401386
}
402387

403388
static int read_eprom_word(pegasus_t *pegasus, __u8 index, __u16 *retdata)
@@ -434,7 +419,6 @@ static int read_eprom_word(pegasus_t *pegasus, __u8 index, __u16 *retdata)
434419
static inline void enable_eprom_write(pegasus_t *pegasus)
435420
{
436421
__u8 tmp;
437-
int ret;
438422

439423
get_registers(pegasus, EthCtrl2, 1, &tmp);
440424
set_register(pegasus, EthCtrl2, tmp | EPROM_WR_ENABLE);
@@ -443,7 +427,6 @@ static inline void enable_eprom_write(pegasus_t *pegasus)
443427
static inline void disable_eprom_write(pegasus_t *pegasus)
444428
{
445429
__u8 tmp;
446-
int ret;
447430

448431
get_registers(pegasus, EthCtrl2, 1, &tmp);
449432
set_register(pegasus, EpromCtrl, 0);
@@ -537,7 +520,8 @@ static inline int reset_mac(pegasus_t *pegasus)
537520
if (usb_dev_id[pegasus->dev_index].vendor == VENDOR_ELCON) {
538521
__u16 auxmode;
539522
read_mii_word(pegasus, 3, 0x1b, &auxmode);
540-
write_mii_word(pegasus, 3, 0x1b, auxmode | 4);
523+
auxmode |= 4;
524+
write_mii_word(pegasus, 3, 0x1b, &auxmode);
541525
}
542526

543527
return 0;
@@ -569,7 +553,8 @@ static int enable_net_traffic(struct net_device *dev, struct usb_device *usb)
569553
usb_dev_id[pegasus->dev_index].vendor == VENDOR_DLINK) {
570554
u16 auxmode;
571555
read_mii_word(pegasus, 0, 0x1b, &auxmode);
572-
write_mii_word(pegasus, 0, 0x1b, auxmode | 4);
556+
auxmode |= 4;
557+
write_mii_word(pegasus, 0, 0x1b, &auxmode);
573558
}
574559

575560
return ret;
@@ -1144,7 +1129,7 @@ static int pegasus_ioctl(struct net_device *net, struct ifreq *rq, int cmd)
11441129
case SIOCDEVPRIVATE + 2:
11451130
if (!capable(CAP_NET_ADMIN))
11461131
return -EPERM;
1147-
write_mii_word(pegasus, pegasus->phy, data[1] & 0x1f, data[2]);
1132+
write_mii_word(pegasus, pegasus->phy, data[1] & 0x1f, &data[2]);
11481133
res = 0;
11491134
break;
11501135
default:

0 commit comments

Comments
 (0)