export via param the phy_addr and the phy_id detected Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@xxxxxxxxxxxx> --- Hi, this is need to fix the calao board support since the introduction of the gigabit phy detection support Best Regards, J. drivers/net/miidev.c | 76 ++++++++++++++++++++++++++++++++++++++++++++++---- include/miidev.h | 2 ++ 2 files changed, 72 insertions(+), 6 deletions(-) diff --git a/drivers/net/miidev.c b/drivers/net/miidev.c index b49944b..ab1811d 100644 --- a/drivers/net/miidev.c +++ b/drivers/net/miidev.c @@ -236,18 +236,82 @@ static struct file_operations miidev_ops = { .lseek = dev_lseek_default, }; +static int get_phy_id(struct mii_device *mdev, int phy_addr, + uint32_t *phy_id) +{ + int val; + + val = mii_read(mdev, phy_addr, MII_PHYSID1); + if (val < 0) + return -EIO; + *phy_id = (val & 0xffff) << 16; + val = mii_read(mdev, phy_addr, MII_PHYSID2); + if (val < 0) + return -EIO; + *phy_id |= (val & 0xffff); + + return 0; +} + +static int phy_detect_one(struct mii_device *mdev, int phy_addr, + uint32_t *phy_id) +{ + uint32_t _phy_id; + int ret; + + ret = get_phy_id(mdev, phy_addr, &_phy_id); + + if (ret) + return ret; + + /* If the phy_id is mostly Fs, there is no device there */ + if ((_phy_id & 0x1fffffff) == 0x1fffffff) + return -EIO; + + *phy_id = _phy_id; + + return 0; +} + +static int phy_detect(struct mii_device *mdev) +{ + int phy_addr; + + for (phy_addr = 0; phy_addr <= 0x1f; phy_addr++) { + if (!phy_detect_one(mdev, phy_addr, &mdev->phy_id)) + return phy_addr; + } + + return -EIO; +} + static int miidev_probe(struct device_d *dev) { struct mii_device *mdev = dev->priv; int val; int caps = 0; + char str[11]; + + if (mdev->address < 0) { + int phy_addr; + + phy_addr = phy_detect(mdev); + + if (phy_addr < 0) { + dev_err(dev, "cannot detect PHY\n"); + return -ENODEV; + } + mdev->address = phy_addr; + } else { + if (phy_detect_one(mdev, mdev->address, &mdev->phy_id) < 0) + goto err_out; + } + + sprintf(str, "%u", mdev->address); + dev_add_param_fixed(dev, "phy_addr", str); + sprintf(str, "0x%08x", mdev->phy_id); + dev_add_param_fixed(dev, "phy_id", str); - val = mii_read(mdev, mdev->address, MII_PHYSID1); - if (val < 0 || val == 0xffff) - goto err_out; - val = mii_read(mdev, mdev->address, MII_PHYSID2); - if (val < 0 || val == 0xffff) - goto err_out; val = mii_read(mdev, mdev->address, MII_BMSR); if (val < 0) goto err_out; diff --git a/include/miidev.h b/include/miidev.h index 4bbf94c..2f39234 100644 --- a/include/miidev.h +++ b/include/miidev.h @@ -38,6 +38,8 @@ struct mii_device { struct device_d *parent; int address; /* The address the phy has on the bus */ + uint32_t phy_id; /* The phy id */ + int (*read) (struct mii_device *dev, int addr, int reg); int (*write) (struct mii_device *dev, int addr, int reg, int value); -- 1.7.10.4 _______________________________________________ barebox mailing list barebox@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/barebox