net: tsec: fsl_mdio: add DM MDIO support
Allow the MDIO devices to be probed based on the device tree. Signed-off-by: Madalin Bucur <madalin.bucur@oss.nxp.com> Signed-off-by: Priyanka Jain <priyanka.jain@nxp.com>
This commit is contained in:
parent
564637a360
commit
2932c5a802
|
@ -12,6 +12,12 @@
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <linux/errno.h>
|
#include <linux/errno.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_DM_MDIO
|
||||||
|
struct tsec_mdio_priv {
|
||||||
|
struct tsec_mii_mng __iomem *regs;
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
void tsec_local_mdio_write(struct tsec_mii_mng __iomem *phyregs, int port_addr,
|
void tsec_local_mdio_write(struct tsec_mii_mng __iomem *phyregs, int port_addr,
|
||||||
int dev_addr, int regnum, int value)
|
int dev_addr, int regnum, int value)
|
||||||
{
|
{
|
||||||
|
@ -56,10 +62,21 @@ int tsec_local_mdio_read(struct tsec_mii_mng __iomem *phyregs, int port_addr,
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(CONFIG_PHYLIB)
|
||||||
static int fsl_pq_mdio_reset(struct mii_dev *bus)
|
static int fsl_pq_mdio_reset(struct mii_dev *bus)
|
||||||
{
|
{
|
||||||
struct tsec_mii_mng __iomem *regs =
|
struct tsec_mii_mng __iomem *regs;
|
||||||
(struct tsec_mii_mng __iomem *)bus->priv;
|
#ifndef CONFIG_DM_MDIO
|
||||||
|
regs = (struct tsec_mii_mng __iomem *)bus->priv;
|
||||||
|
#else
|
||||||
|
struct tsec_mdio_priv *priv;
|
||||||
|
|
||||||
|
if (!bus->priv)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
priv = dev_get_priv(bus->priv);
|
||||||
|
regs = priv->regs;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Reset MII (due to new addresses) */
|
/* Reset MII (due to new addresses) */
|
||||||
out_be32(®s->miimcfg, MIIMCFG_RESET_MGMT);
|
out_be32(®s->miimcfg, MIIMCFG_RESET_MGMT);
|
||||||
|
@ -71,11 +88,22 @@ static int fsl_pq_mdio_reset(struct mii_dev *bus)
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
int tsec_phy_read(struct mii_dev *bus, int addr, int dev_addr, int regnum)
|
int tsec_phy_read(struct mii_dev *bus, int addr, int dev_addr, int regnum)
|
||||||
{
|
{
|
||||||
struct tsec_mii_mng __iomem *phyregs =
|
struct tsec_mii_mng __iomem *phyregs;
|
||||||
(struct tsec_mii_mng __iomem *)bus->priv;
|
#ifndef CONFIG_DM_MDIO
|
||||||
|
phyregs = (struct tsec_mii_mng __iomem *)bus->priv;
|
||||||
|
#else
|
||||||
|
struct tsec_mdio_priv *priv;
|
||||||
|
|
||||||
|
if (!bus->priv)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
priv = dev_get_priv(bus->priv);
|
||||||
|
phyregs = priv->regs;
|
||||||
|
#endif
|
||||||
|
|
||||||
return tsec_local_mdio_read(phyregs, addr, dev_addr, regnum);
|
return tsec_local_mdio_read(phyregs, addr, dev_addr, regnum);
|
||||||
}
|
}
|
||||||
|
@ -83,14 +111,25 @@ int tsec_phy_read(struct mii_dev *bus, int addr, int dev_addr, int regnum)
|
||||||
int tsec_phy_write(struct mii_dev *bus, int addr, int dev_addr, int regnum,
|
int tsec_phy_write(struct mii_dev *bus, int addr, int dev_addr, int regnum,
|
||||||
u16 value)
|
u16 value)
|
||||||
{
|
{
|
||||||
struct tsec_mii_mng __iomem *phyregs =
|
struct tsec_mii_mng __iomem *phyregs;
|
||||||
(struct tsec_mii_mng __iomem *)bus->priv;
|
#ifndef CONFIG_DM_MDIO
|
||||||
|
phyregs = (struct tsec_mii_mng __iomem *)bus->priv;
|
||||||
|
#else
|
||||||
|
struct tsec_mdio_priv *priv;
|
||||||
|
|
||||||
|
if (!bus->priv)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
priv = dev_get_priv(bus->priv);
|
||||||
|
phyregs = priv->regs;
|
||||||
|
#endif
|
||||||
|
|
||||||
tsec_local_mdio_write(phyregs, addr, dev_addr, regnum, value);
|
tsec_local_mdio_write(phyregs, addr, dev_addr, regnum, value);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef CONFIG_DM_MDIO
|
||||||
int fsl_pq_mdio_init(bd_t *bis, struct fsl_pq_mdio_info *info)
|
int fsl_pq_mdio_init(bd_t *bis, struct fsl_pq_mdio_info *info)
|
||||||
{
|
{
|
||||||
struct mii_dev *bus = mdio_alloc();
|
struct mii_dev *bus = mdio_alloc();
|
||||||
|
@ -109,3 +148,92 @@ int fsl_pq_mdio_init(bd_t *bis, struct fsl_pq_mdio_info *info)
|
||||||
|
|
||||||
return mdio_register(bus);
|
return mdio_register(bus);
|
||||||
}
|
}
|
||||||
|
#else /* CONFIG_DM_MDIO */
|
||||||
|
#if defined(CONFIG_PHYLIB)
|
||||||
|
static int tsec_mdio_read(struct udevice *dev, int addr, int devad, int reg)
|
||||||
|
{
|
||||||
|
struct mdio_perdev_priv *pdata = (dev) ? dev_get_uclass_priv(dev) :
|
||||||
|
NULL;
|
||||||
|
|
||||||
|
if (pdata && pdata->mii_bus)
|
||||||
|
return tsec_phy_read(pdata->mii_bus, addr, devad, reg);
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int tsec_mdio_write(struct udevice *dev, int addr, int devad, int reg,
|
||||||
|
u16 val)
|
||||||
|
{
|
||||||
|
struct mdio_perdev_priv *pdata = (dev) ? dev_get_uclass_priv(dev) :
|
||||||
|
NULL;
|
||||||
|
|
||||||
|
if (pdata && pdata->mii_bus)
|
||||||
|
return tsec_phy_write(pdata->mii_bus, addr, devad, reg, val);
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int tsec_mdio_reset(struct udevice *dev)
|
||||||
|
{
|
||||||
|
struct mdio_perdev_priv *pdata = (dev) ? dev_get_uclass_priv(dev) :
|
||||||
|
NULL;
|
||||||
|
|
||||||
|
if (pdata && pdata->mii_bus)
|
||||||
|
return fsl_pq_mdio_reset(pdata->mii_bus);
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct mdio_ops tsec_mdio_ops = {
|
||||||
|
.read = tsec_mdio_read,
|
||||||
|
.write = tsec_mdio_write,
|
||||||
|
.reset = tsec_mdio_reset,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct udevice_id tsec_mdio_ids[] = {
|
||||||
|
{ .compatible = "fsl,gianfar-tbi" },
|
||||||
|
{ .compatible = "fsl,gianfar-mdio" },
|
||||||
|
{ .compatible = "fsl,etsec2-tbi" },
|
||||||
|
{ .compatible = "fsl,etsec2-mdio" },
|
||||||
|
{ .compatible = "fsl,fman-mdio" },
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
|
||||||
|
static int tsec_mdio_probe(struct udevice *dev)
|
||||||
|
{
|
||||||
|
struct tsec_mdio_priv *priv = (dev) ? dev_get_priv(dev) : NULL;
|
||||||
|
struct mdio_perdev_priv *pdata = (dev) ? dev_get_uclass_priv(dev) :
|
||||||
|
NULL;
|
||||||
|
|
||||||
|
if (!dev) {
|
||||||
|
printf("%s dev = NULL\n", __func__);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (!priv) {
|
||||||
|
printf("dev_get_priv(dev %p) = NULL\n", dev);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
priv->regs = (void *)(uintptr_t)dev_read_addr(dev);
|
||||||
|
debug("%s priv %p @ regs %p, pdata %p\n", __func__,
|
||||||
|
priv, priv->regs, pdata);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int tsec_mdio_remove(struct udevice *dev)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
U_BOOT_DRIVER(tsec_mdio) = {
|
||||||
|
.name = "tsec_mdio",
|
||||||
|
.id = UCLASS_MDIO,
|
||||||
|
.of_match = tsec_mdio_ids,
|
||||||
|
.probe = tsec_mdio_probe,
|
||||||
|
.remove = tsec_mdio_remove,
|
||||||
|
.ops = &tsec_mdio_ops,
|
||||||
|
.priv_auto_alloc_size = sizeof(struct tsec_mdio_priv),
|
||||||
|
.platdata_auto_alloc_size = sizeof(struct mdio_perdev_priv),
|
||||||
|
};
|
||||||
|
#endif /* CONFIG_PHYLIB */
|
||||||
|
#endif /* CONFIG_DM_MDIO */
|
||||||
|
|
Loading…
Reference in New Issue