Commit 895ee682 authored by Kim Phillips's avatar Kim Phillips Committed by Jeff Garzik

phylib: add RGMII-ID mode to the Marvell m88e1111 PHY to fix broken ucc_geth

Support for configuring RGMII-ID (RGMII with internal delay) mode on the
88e1111 and 88e1145.  Ucc_geth on MPC8360EMDS(the main user of ucc_geth)
is broken after changed to use phylib.  It is fixed by adding this
internal delay.

Also renamed 88e1111s -> 88e1111 (no references to an 88e1111s part were
found), and fixed some whitespace.
Signed-off-by: default avatarKim Phillips <kim.phillips@freescale.com>
Signed-off-by: default avatarLi Yang <leoli@freescale.com>
Signed-off-by: default avatarJeff Garzik <jeff@garzik.org>
parent dec590c1
...@@ -54,6 +54,12 @@ ...@@ -54,6 +54,12 @@
#define MII_M1111_PHY_LED_CONTROL 0x18 #define MII_M1111_PHY_LED_CONTROL 0x18
#define MII_M1111_PHY_LED_DIRECT 0x4100 #define MII_M1111_PHY_LED_DIRECT 0x4100
#define MII_M1111_PHY_LED_COMBINE 0x411c #define MII_M1111_PHY_LED_COMBINE 0x411c
#define MII_M1111_PHY_EXT_CR 0x14
#define MII_M1111_RX_DELAY 0x80
#define MII_M1111_TX_DELAY 0x2
#define MII_M1111_PHY_EXT_SR 0x1b
#define MII_M1111_HWCFG_MODE_MASK 0xf
#define MII_M1111_HWCFG_MODE_RGMII 0xb
MODULE_DESCRIPTION("Marvell PHY driver"); MODULE_DESCRIPTION("Marvell PHY driver");
MODULE_AUTHOR("Andy Fleming"); MODULE_AUTHOR("Andy Fleming");
...@@ -131,6 +137,45 @@ static int marvell_config_aneg(struct phy_device *phydev) ...@@ -131,6 +137,45 @@ static int marvell_config_aneg(struct phy_device *phydev)
return err; return err;
} }
static int m88e1111_config_init(struct phy_device *phydev)
{
int err;
if ((phydev->interface == PHY_INTERFACE_MODE_RGMII) ||
(phydev->interface == PHY_INTERFACE_MODE_RGMII_ID)) {
int temp;
if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID) {
temp = phy_read(phydev, MII_M1111_PHY_EXT_CR);
if (temp < 0)
return temp;
temp |= (MII_M1111_RX_DELAY | MII_M1111_TX_DELAY);
err = phy_write(phydev, MII_M1111_PHY_EXT_CR, temp);
if (err < 0)
return err;
}
temp = phy_read(phydev, MII_M1111_PHY_EXT_SR);
if (temp < 0)
return temp;
temp &= ~(MII_M1111_HWCFG_MODE_MASK);
temp |= MII_M1111_HWCFG_MODE_RGMII;
err = phy_write(phydev, MII_M1111_PHY_EXT_SR, temp);
if (err < 0)
return err;
}
err = phy_write(phydev, MII_BMCR, BMCR_RESET);
if (err < 0)
return err;
return 0;
}
static int m88e1145_config_init(struct phy_device *phydev) static int m88e1145_config_init(struct phy_device *phydev)
{ {
int err; int err;
...@@ -152,7 +197,7 @@ static int m88e1145_config_init(struct phy_device *phydev) ...@@ -152,7 +197,7 @@ static int m88e1145_config_init(struct phy_device *phydev)
if (err < 0) if (err < 0)
return err; return err;
if (phydev->interface == PHY_INTERFACE_MODE_RGMII) { if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID) {
int temp = phy_read(phydev, MII_M1145_PHY_EXT_CR); int temp = phy_read(phydev, MII_M1145_PHY_EXT_CR);
if (temp < 0) if (temp < 0)
return temp; return temp;
...@@ -206,7 +251,7 @@ static struct phy_driver m88e1101_driver = { ...@@ -206,7 +251,7 @@ static struct phy_driver m88e1101_driver = {
.driver = {.owner = THIS_MODULE,}, .driver = {.owner = THIS_MODULE,},
}; };
static struct phy_driver m88e1111s_driver = { static struct phy_driver m88e1111_driver = {
.phy_id = 0x01410cc0, .phy_id = 0x01410cc0,
.phy_id_mask = 0xfffffff0, .phy_id_mask = 0xfffffff0,
.name = "Marvell 88E1111", .name = "Marvell 88E1111",
...@@ -216,6 +261,7 @@ static struct phy_driver m88e1111s_driver = { ...@@ -216,6 +261,7 @@ static struct phy_driver m88e1111s_driver = {
.read_status = &genphy_read_status, .read_status = &genphy_read_status,
.ack_interrupt = &marvell_ack_interrupt, .ack_interrupt = &marvell_ack_interrupt,
.config_intr = &marvell_config_intr, .config_intr = &marvell_config_intr,
.config_init = &m88e1111_config_init,
.driver = {.owner = THIS_MODULE,}, .driver = {.owner = THIS_MODULE,},
}; };
...@@ -241,9 +287,9 @@ static int __init marvell_init(void) ...@@ -241,9 +287,9 @@ static int __init marvell_init(void)
if (ret) if (ret)
return ret; return ret;
ret = phy_driver_register(&m88e1111s_driver); ret = phy_driver_register(&m88e1111_driver);
if (ret) if (ret)
goto err1111s; goto err1111;
ret = phy_driver_register(&m88e1145_driver); ret = phy_driver_register(&m88e1145_driver);
if (ret) if (ret)
...@@ -251,9 +297,9 @@ static int __init marvell_init(void) ...@@ -251,9 +297,9 @@ static int __init marvell_init(void)
return 0; return 0;
err1145: err1145:
phy_driver_unregister(&m88e1111s_driver); phy_driver_unregister(&m88e1111_driver);
err1111s: err1111:
phy_driver_unregister(&m88e1101_driver); phy_driver_unregister(&m88e1101_driver);
return ret; return ret;
} }
...@@ -261,7 +307,7 @@ static int __init marvell_init(void) ...@@ -261,7 +307,7 @@ static int __init marvell_init(void)
static void __exit marvell_exit(void) static void __exit marvell_exit(void)
{ {
phy_driver_unregister(&m88e1101_driver); phy_driver_unregister(&m88e1101_driver);
phy_driver_unregister(&m88e1111s_driver); phy_driver_unregister(&m88e1111_driver);
phy_driver_unregister(&m88e1145_driver); phy_driver_unregister(&m88e1145_driver);
} }
......
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