mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-26 23:41:50 +00:00
net: fec_mxc: get phydev before fec_probe
Signed-off-by: Troy Kisky <troy.kisky@boundarydevices.com>
This commit is contained in:
parent
4dc27eed52
commit
fe428b909b
3 changed files with 86 additions and 46 deletions
|
@ -901,12 +901,16 @@ static void fec_set_dev_name(char *dest, int dev_id)
|
||||||
sprintf(dest, (dev_id == -1) ? "FEC" : "FEC%i", dev_id);
|
sprintf(dest, (dev_id == -1) ? "FEC" : "FEC%i", dev_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int fec_probe(bd_t *bd, int dev_id, int phy_id, uint32_t base_addr)
|
#ifdef CONFIG_PHYLIB
|
||||||
|
int fec_probe(bd_t *bd, int dev_id, uint32_t base_addr,
|
||||||
|
struct mii_dev *bus, struct phy_device *phydev)
|
||||||
|
#else
|
||||||
|
static int fec_probe(bd_t *bd, int dev_id, uint32_t base_addr,
|
||||||
|
struct mii_dev *bus, int phy_id)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
struct phy_device *phydev;
|
|
||||||
struct eth_device *edev;
|
struct eth_device *edev;
|
||||||
struct fec_priv *fec;
|
struct fec_priv *fec;
|
||||||
struct mii_dev *bus;
|
|
||||||
unsigned char ethaddr[6];
|
unsigned char ethaddr[6];
|
||||||
uint32_t start;
|
uint32_t start;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
@ -953,57 +957,25 @@ static int fec_probe(bd_t *bd, int dev_id, int phy_id, uint32_t base_addr)
|
||||||
}
|
}
|
||||||
|
|
||||||
fec_reg_setup(fec);
|
fec_reg_setup(fec);
|
||||||
|
|
||||||
fec_set_dev_name(edev->name, dev_id);
|
fec_set_dev_name(edev->name, dev_id);
|
||||||
fec->dev_id = (dev_id == -1) ? 0 : dev_id;
|
fec->dev_id = (dev_id == -1) ? 0 : dev_id;
|
||||||
fec->phy_id = phy_id;
|
|
||||||
|
|
||||||
bus = mdio_alloc();
|
|
||||||
if (!bus) {
|
|
||||||
printf("mdio_alloc failed\n");
|
|
||||||
ret = -ENOMEM;
|
|
||||||
goto err3;
|
|
||||||
}
|
|
||||||
bus->read = fec_phy_read;
|
|
||||||
bus->write = fec_phy_write;
|
|
||||||
fec_set_dev_name(bus->name, dev_id);
|
|
||||||
#ifdef CONFIG_MX28
|
|
||||||
/*
|
|
||||||
* The i.MX28 has two ethernet interfaces, but they are not equal.
|
|
||||||
* Only the first one can access the MDIO bus.
|
|
||||||
*/
|
|
||||||
bus->priv = (struct ethernet_regs *)MXS_ENET0_BASE;
|
|
||||||
#else
|
|
||||||
bus->priv = fec->eth;
|
|
||||||
#endif
|
|
||||||
fec_mii_setspeed(bus->priv);
|
|
||||||
ret = mdio_register(bus);
|
|
||||||
if (ret) {
|
|
||||||
printf("mdio_register failed\n");
|
|
||||||
free(bus);
|
|
||||||
ret = -ENOMEM;
|
|
||||||
goto err3;
|
|
||||||
}
|
|
||||||
fec->bus = bus;
|
fec->bus = bus;
|
||||||
|
fec_mii_setspeed(bus->priv);
|
||||||
|
#ifdef CONFIG_PHYLIB
|
||||||
|
fec->phydev = phydev;
|
||||||
|
phy_connect_dev(phydev, edev);
|
||||||
|
/* Configure phy */
|
||||||
|
phy_config(phydev);
|
||||||
|
#else
|
||||||
|
fec->phy_id = phy_id;
|
||||||
|
#endif
|
||||||
eth_register(edev);
|
eth_register(edev);
|
||||||
|
|
||||||
if (fec_get_hwaddr(edev, dev_id, ethaddr) == 0) {
|
if (fec_get_hwaddr(edev, dev_id, ethaddr) == 0) {
|
||||||
debug("got MAC%d address from fuse: %pM\n", dev_id, ethaddr);
|
debug("got MAC%d address from fuse: %pM\n", dev_id, ethaddr);
|
||||||
memcpy(edev->enetaddr, ethaddr, 6);
|
memcpy(edev->enetaddr, ethaddr, 6);
|
||||||
}
|
}
|
||||||
/* Configure phy */
|
|
||||||
#ifdef CONFIG_PHYLIB
|
|
||||||
phydev = phy_connect(fec->bus, phy_id, edev, PHY_INTERFACE_MODE_RGMII);
|
|
||||||
if (!phydev) {
|
|
||||||
free(bus);
|
|
||||||
ret = -ENOMEM;
|
|
||||||
goto err3;
|
|
||||||
}
|
|
||||||
fec->phydev = phydev;
|
|
||||||
phy_config(phydev);
|
|
||||||
#endif
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
err3:
|
err3:
|
||||||
free(fec);
|
free(fec);
|
||||||
err2:
|
err2:
|
||||||
|
@ -1012,10 +984,71 @@ err1:
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct mii_dev *fec_get_miibus(uint32_t base_addr, int dev_id)
|
||||||
|
{
|
||||||
|
struct ethernet_regs *eth = (struct ethernet_regs *)base_addr;
|
||||||
|
struct mii_dev *bus;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
bus = mdio_alloc();
|
||||||
|
if (!bus) {
|
||||||
|
printf("mdio_alloc failed\n");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
bus->read = fec_phy_read;
|
||||||
|
bus->write = fec_phy_write;
|
||||||
|
bus->priv = eth;
|
||||||
|
fec_set_dev_name(bus->name, dev_id);
|
||||||
|
|
||||||
|
ret = mdio_register(bus);
|
||||||
|
if (ret) {
|
||||||
|
printf("mdio_register failed\n");
|
||||||
|
free(bus);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
fec_mii_setspeed(eth);
|
||||||
|
return bus;
|
||||||
|
}
|
||||||
|
|
||||||
int fecmxc_initialize_multi(bd_t *bd, int dev_id, int phy_id, uint32_t addr)
|
int fecmxc_initialize_multi(bd_t *bd, int dev_id, int phy_id, uint32_t addr)
|
||||||
{
|
{
|
||||||
|
uint32_t base_mii;
|
||||||
|
struct mii_dev *bus = NULL;
|
||||||
|
#ifdef CONFIG_PHYLIB
|
||||||
|
struct phy_device *phydev = NULL;
|
||||||
|
#endif
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
#ifdef CONFIG_MX28
|
||||||
|
/*
|
||||||
|
* The i.MX28 has two ethernet interfaces, but they are not equal.
|
||||||
|
* Only the first one can access the MDIO bus.
|
||||||
|
*/
|
||||||
|
base_mii = MXS_ENET0_BASE;
|
||||||
|
#else
|
||||||
|
base_mii = addr;
|
||||||
|
#endif
|
||||||
debug("eth_init: fec_probe(bd, %i, %i) @ %08x\n", dev_id, phy_id, addr);
|
debug("eth_init: fec_probe(bd, %i, %i) @ %08x\n", dev_id, phy_id, addr);
|
||||||
return fec_probe(bd, dev_id, phy_id, addr);
|
bus = fec_get_miibus(base_mii, dev_id);
|
||||||
|
if (!bus)
|
||||||
|
return -ENOMEM;
|
||||||
|
#ifdef CONFIG_PHYLIB
|
||||||
|
phydev = phy_find_by_mask(bus, 1 << phy_id, PHY_INTERFACE_MODE_RGMII);
|
||||||
|
if (!phydev) {
|
||||||
|
free(bus);
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
ret = fec_probe(bd, dev_id, addr, bus, phydev);
|
||||||
|
#else
|
||||||
|
ret = fec_probe(bd, dev_id, addr, bus, phy_id);
|
||||||
|
#endif
|
||||||
|
if (ret) {
|
||||||
|
#ifdef CONFIG_PHYLIB
|
||||||
|
free(phydev);
|
||||||
|
#endif
|
||||||
|
free(bus);
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_FEC_MXC_PHYADDR
|
#ifdef CONFIG_FEC_MXC_PHYADDR
|
||||||
|
|
|
@ -271,11 +271,11 @@ struct fec_priv {
|
||||||
bd_t *bd;
|
bd_t *bd;
|
||||||
uint8_t *tdb_ptr;
|
uint8_t *tdb_ptr;
|
||||||
int dev_id;
|
int dev_id;
|
||||||
int phy_id;
|
|
||||||
struct mii_dev *bus;
|
struct mii_dev *bus;
|
||||||
#ifdef CONFIG_PHYLIB
|
#ifdef CONFIG_PHYLIB
|
||||||
struct phy_device *phydev;
|
struct phy_device *phydev;
|
||||||
#else
|
#else
|
||||||
|
int phy_id;
|
||||||
int (*mii_postcall)(int);
|
int (*mii_postcall)(int);
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
|
@ -215,9 +215,16 @@ struct mv88e61xx_config {
|
||||||
int mv88e61xx_switch_initialize(struct mv88e61xx_config *swconfig);
|
int mv88e61xx_switch_initialize(struct mv88e61xx_config *swconfig);
|
||||||
#endif /* CONFIG_MV88E61XX_SWITCH */
|
#endif /* CONFIG_MV88E61XX_SWITCH */
|
||||||
|
|
||||||
|
struct mii_dev *fec_get_miibus(uint32_t base_addr, int dev_id);
|
||||||
|
#ifdef CONFIG_PHYLIB
|
||||||
|
struct phy_device;
|
||||||
|
int fec_probe(bd_t *bd, int dev_id, uint32_t base_addr,
|
||||||
|
struct mii_dev *bus, struct phy_device *phydev);
|
||||||
|
#else
|
||||||
/*
|
/*
|
||||||
* Allow FEC to fine-tune MII configuration on boards which require this.
|
* Allow FEC to fine-tune MII configuration on boards which require this.
|
||||||
*/
|
*/
|
||||||
int fecmxc_register_mii_postcall(struct eth_device *dev, int (*cb)(int));
|
int fecmxc_register_mii_postcall(struct eth_device *dev, int (*cb)(int));
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* _NETDEV_H_ */
|
#endif /* _NETDEV_H_ */
|
||||||
|
|
Loading…
Add table
Reference in a new issue