mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-27 16:01:27 +00:00
net: phy: broadcom: add support for BCM54210E
It's Broadcom PHY simply described as single-port RGMII 10/100/1000BASE-T PHY. It requires disabling delay skew and GTXCLK bits. BCM54210E support ported from Linux kernel commit 0fc9ae1076697 ("net: phy: broadcom: add support for BCM54210E") AUX/SHD/bcm54xx_config_clock_delay update ported from Linux 6.5-rc4 commit 28e219aea0b9e ("net: phy: broadcom: drop brcm_phy_setbits() and use phy_set_bits() instead") Signed-off-by: Marek Vasut <marex@denx.de> Reviewed-by: Rafał Miłecki <rafal@milecki.pl>
This commit is contained in:
parent
fb89b69a3f
commit
cba79a1b2e
1 changed files with 100 additions and 1 deletions
|
@ -30,10 +30,87 @@
|
||||||
#define MIIM_BCM54XX_EXP_SEL_ER 0x0f00 /* Expansion register select */
|
#define MIIM_BCM54XX_EXP_SEL_ER 0x0f00 /* Expansion register select */
|
||||||
|
|
||||||
#define MIIM_BCM_AUXCNTL_SHDWSEL_MISC 0x0007
|
#define MIIM_BCM_AUXCNTL_SHDWSEL_MISC 0x0007
|
||||||
#define MIIM_BCM_AUXCNTL_ACTL_SMDSP_EN 0x0800
|
#define MIIM_BCM_AUXCNTL_SHDWSEL_MISC_WIRESPEED_EN 0x0010
|
||||||
|
#define MIIM_BCM_AUXCNTL_SHDWSEL_MISC_RGMII_EN 0x0080
|
||||||
|
#define MIIM_BCM_AUXCNTL_SHDWSEL_MISC_RGMII_SKEW_EN 0x0100
|
||||||
|
#define MIIM_BCM_AUXCNTL_MISC_FORCE_AMDIX 0x0200
|
||||||
|
#define MIIM_BCM_AUXCNTL_ACTL_SMDSP_EN 0x0800
|
||||||
|
#define MIIM_BCM_AUXCNTL_MISC_WREN 0x8000
|
||||||
|
|
||||||
#define MIIM_BCM_CHANNEL_WIDTH 0x2000
|
#define MIIM_BCM_CHANNEL_WIDTH 0x2000
|
||||||
|
|
||||||
|
#define BCM54810_SHD_CLK_CTL 0x3
|
||||||
|
#define BCM54810_SHD_CLK_CTL_GTXCLK_EN BIT(9)
|
||||||
|
|
||||||
|
static int bcm54xx_auxctl_read(struct phy_device *phydev, u16 regnum)
|
||||||
|
{
|
||||||
|
/* The register must be written to both the Shadow Register Select and
|
||||||
|
* the Shadow Read Register Selector
|
||||||
|
*/
|
||||||
|
phy_write(phydev, MDIO_DEVAD_NONE, MIIM_BCM54xx_AUXCNTL,
|
||||||
|
MIIM_BCM54xx_AUXCNTL_ENCODE(regnum));
|
||||||
|
return phy_read(phydev, MDIO_DEVAD_NONE, MIIM_BCM54xx_AUXCNTL);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int bcm54xx_auxctl_write(struct phy_device *phydev, u16 regnum, u16 val)
|
||||||
|
{
|
||||||
|
return phy_write(phydev, MDIO_DEVAD_NONE, MIIM_BCM54xx_AUXCNTL, regnum | val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int bcm_phy_read_shadow(struct phy_device *phydev, u16 shadow)
|
||||||
|
{
|
||||||
|
phy_write(phydev, MDIO_DEVAD_NONE, MIIM_BCM54XX_SHD,
|
||||||
|
MIIM_BCM54XX_SHD_VAL(shadow));
|
||||||
|
return MIIM_BCM54XX_SHD_DATA(phy_read(phydev, MDIO_DEVAD_NONE,
|
||||||
|
MIIM_BCM54XX_SHD));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int bcm_phy_write_shadow(struct phy_device *phydev, u16 shadow, u16 val)
|
||||||
|
{
|
||||||
|
return phy_write(phydev, MDIO_DEVAD_NONE, MIIM_BCM54XX_SHD,
|
||||||
|
MIIM_BCM54XX_SHD_WR_ENCODE(shadow, val));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int bcm54xx_config_clock_delay(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
int rc, val;
|
||||||
|
|
||||||
|
/* handling PHY's internal RX clock delay */
|
||||||
|
val = bcm54xx_auxctl_read(phydev, MIIM_BCM_AUXCNTL_SHDWSEL_MISC);
|
||||||
|
val |= MIIM_BCM_AUXCNTL_MISC_WREN;
|
||||||
|
if (phydev->interface == PHY_INTERFACE_MODE_RGMII ||
|
||||||
|
phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID) {
|
||||||
|
/* Disable RGMII RXC-RXD skew */
|
||||||
|
val &= ~MIIM_BCM_AUXCNTL_SHDWSEL_MISC_RGMII_SKEW_EN;
|
||||||
|
}
|
||||||
|
if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
|
||||||
|
phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID) {
|
||||||
|
/* Enable RGMII RXC-RXD skew */
|
||||||
|
val |= MIIM_BCM_AUXCNTL_SHDWSEL_MISC_RGMII_SKEW_EN;
|
||||||
|
}
|
||||||
|
rc = bcm54xx_auxctl_write(phydev, MIIM_BCM_AUXCNTL_SHDWSEL_MISC, val);
|
||||||
|
if (rc < 0)
|
||||||
|
return rc;
|
||||||
|
|
||||||
|
/* handling PHY's internal TX clock delay */
|
||||||
|
val = bcm_phy_read_shadow(phydev, BCM54810_SHD_CLK_CTL);
|
||||||
|
if (phydev->interface == PHY_INTERFACE_MODE_RGMII ||
|
||||||
|
phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID) {
|
||||||
|
/* Disable internal TX clock delay */
|
||||||
|
val &= ~BCM54810_SHD_CLK_CTL_GTXCLK_EN;
|
||||||
|
}
|
||||||
|
if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
|
||||||
|
phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID) {
|
||||||
|
/* Enable internal TX clock delay */
|
||||||
|
val |= BCM54810_SHD_CLK_CTL_GTXCLK_EN;
|
||||||
|
}
|
||||||
|
rc = bcm_phy_write_shadow(phydev, BCM54810_SHD_CLK_CTL, val);
|
||||||
|
if (rc < 0)
|
||||||
|
return rc;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void bcm_phy_write_misc(struct phy_device *phydev,
|
static void bcm_phy_write_misc(struct phy_device *phydev,
|
||||||
u16 reg, u16 chl, u16 value)
|
u16 reg, u16 chl, u16 value)
|
||||||
{
|
{
|
||||||
|
@ -62,6 +139,18 @@ static int bcm5461_config(struct phy_device *phydev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Broadcom BCM54210E */
|
||||||
|
static int bcm54210e_config(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = bcm54xx_config_clock_delay(phydev);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
return bcm5461_config(phydev);
|
||||||
|
}
|
||||||
|
|
||||||
static int bcm54xx_parse_status(struct phy_device *phydev)
|
static int bcm54xx_parse_status(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
unsigned int mii_reg;
|
unsigned int mii_reg;
|
||||||
|
@ -311,6 +400,16 @@ static int bcm5482_startup(struct phy_device *phydev)
|
||||||
return bcm54xx_parse_status(phydev);
|
return bcm54xx_parse_status(phydev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
U_BOOT_PHY_DRIVER(bcm54210e) = {
|
||||||
|
.name = "Broadcom BCM54210E",
|
||||||
|
.uid = 0x600d84a0,
|
||||||
|
.mask = 0xfffffff0,
|
||||||
|
.features = PHY_GBIT_FEATURES,
|
||||||
|
.config = &bcm54210e_config,
|
||||||
|
.startup = &bcm54xx_startup,
|
||||||
|
.shutdown = &genphy_shutdown,
|
||||||
|
};
|
||||||
|
|
||||||
U_BOOT_PHY_DRIVER(bcm5461s) = {
|
U_BOOT_PHY_DRIVER(bcm5461s) = {
|
||||||
.name = "Broadcom BCM5461S",
|
.name = "Broadcom BCM5461S",
|
||||||
.uid = 0x2060c0,
|
.uid = 0x2060c0,
|
||||||
|
|
Loading…
Add table
Reference in a new issue