Skip to content

Commit 9b420ef

Browse files
hkallweitdavem330
authored andcommitted
net: phy: micrel: use phy_read_mmd and phy_write_mmd
This driver implements open-coded versions of phy_read_mmd() and phy_write_mmd() for KSZ9031. That's not needed, let's use the phylib functions directly. This is compile-tested only because I have no such hardware. Signed-off-by: Heiner Kallweit <[email protected]> Reviewed-by: Andrew Lunn <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 43deda5 commit 9b420ef

File tree

1 file changed

+11
-32
lines changed

1 file changed

+11
-32
lines changed

drivers/net/phy/micrel.c

Lines changed: 11 additions & 32 deletions
Original file line numberDiff line numberDiff line change
@@ -426,9 +426,6 @@ static int ksz9021_config_init(struct phy_device *phydev)
426426
return 0;
427427
}
428428

429-
#define MII_KSZ9031RN_MMD_CTRL_REG 0x0d
430-
#define MII_KSZ9031RN_MMD_REGDATA_REG 0x0e
431-
#define OP_DATA 1
432429
#define KSZ9031_PS_TO_REG 60
433430

434431
/* Extended registers */
@@ -446,24 +443,6 @@ static int ksz9021_config_init(struct phy_device *phydev)
446443
#define MII_KSZ9031RN_EDPD 0x23
447444
#define MII_KSZ9031RN_EDPD_ENABLE BIT(0)
448445

449-
static int ksz9031_extended_write(struct phy_device *phydev,
450-
u8 mode, u32 dev_addr, u32 regnum, u16 val)
451-
{
452-
phy_write(phydev, MII_KSZ9031RN_MMD_CTRL_REG, dev_addr);
453-
phy_write(phydev, MII_KSZ9031RN_MMD_REGDATA_REG, regnum);
454-
phy_write(phydev, MII_KSZ9031RN_MMD_CTRL_REG, (mode << 14) | dev_addr);
455-
return phy_write(phydev, MII_KSZ9031RN_MMD_REGDATA_REG, val);
456-
}
457-
458-
static int ksz9031_extended_read(struct phy_device *phydev,
459-
u8 mode, u32 dev_addr, u32 regnum)
460-
{
461-
phy_write(phydev, MII_KSZ9031RN_MMD_CTRL_REG, dev_addr);
462-
phy_write(phydev, MII_KSZ9031RN_MMD_REGDATA_REG, regnum);
463-
phy_write(phydev, MII_KSZ9031RN_MMD_CTRL_REG, (mode << 14) | dev_addr);
464-
return phy_read(phydev, MII_KSZ9031RN_MMD_REGDATA_REG);
465-
}
466-
467446
static int ksz9031_of_load_skew_values(struct phy_device *phydev,
468447
const struct device_node *of_node,
469448
u16 reg, size_t field_sz,
@@ -484,7 +463,7 @@ static int ksz9031_of_load_skew_values(struct phy_device *phydev,
484463
return 0;
485464

486465
if (matches < numfields)
487-
newval = ksz9031_extended_read(phydev, OP_DATA, 2, reg);
466+
newval = phy_read_mmd(phydev, 2, reg);
488467
else
489468
newval = 0;
490469

@@ -498,21 +477,21 @@ static int ksz9031_of_load_skew_values(struct phy_device *phydev,
498477
<< (field_sz * i));
499478
}
500479

501-
return ksz9031_extended_write(phydev, OP_DATA, 2, reg, newval);
480+
return phy_write_mmd(phydev, 2, reg, newval);
502481
}
503482

504483
/* Center KSZ9031RNX FLP timing at 16ms. */
505484
static int ksz9031_center_flp_timing(struct phy_device *phydev)
506485
{
507486
int result;
508487

509-
result = ksz9031_extended_write(phydev, OP_DATA, 0,
510-
MII_KSZ9031RN_FLP_BURST_TX_HI, 0x0006);
488+
result = phy_write_mmd(phydev, 0, MII_KSZ9031RN_FLP_BURST_TX_HI,
489+
0x0006);
511490
if (result)
512491
return result;
513492

514-
result = ksz9031_extended_write(phydev, OP_DATA, 0,
515-
MII_KSZ9031RN_FLP_BURST_TX_LO, 0x1A80);
493+
result = phy_write_mmd(phydev, 0, MII_KSZ9031RN_FLP_BURST_TX_LO,
494+
0x1A80);
516495
if (result)
517496
return result;
518497

@@ -524,11 +503,11 @@ static int ksz9031_enable_edpd(struct phy_device *phydev)
524503
{
525504
int reg;
526505

527-
reg = ksz9031_extended_read(phydev, OP_DATA, 0x1C, MII_KSZ9031RN_EDPD);
506+
reg = phy_read_mmd(phydev, 0x1C, MII_KSZ9031RN_EDPD);
528507
if (reg < 0)
529508
return reg;
530-
return ksz9031_extended_write(phydev, OP_DATA, 0x1C, MII_KSZ9031RN_EDPD,
531-
reg | MII_KSZ9031RN_EDPD_ENABLE);
509+
return phy_write_mmd(phydev, 0x1C, MII_KSZ9031RN_EDPD,
510+
reg | MII_KSZ9031RN_EDPD_ENABLE);
532511
}
533512

534513
static int ksz9031_config_init(struct phy_device *phydev)
@@ -654,7 +633,7 @@ static int ksz9131_of_load_skew_values(struct phy_device *phydev,
654633
return 0;
655634

656635
if (matches < numfields)
657-
newval = ksz9031_extended_read(phydev, OP_DATA, 2, reg);
636+
newval = phy_read_mmd(phydev, 2, reg);
658637
else
659638
newval = 0;
660639

@@ -668,7 +647,7 @@ static int ksz9131_of_load_skew_values(struct phy_device *phydev,
668647
<< (field_sz * i));
669648
}
670649

671-
return ksz9031_extended_write(phydev, OP_DATA, 2, reg, newval);
650+
return phy_write_mmd(phydev, 2, reg, newval);
672651
}
673652

674653
static int ksz9131_config_init(struct phy_device *phydev)

0 commit comments

Comments
 (0)