phy: Change mii_bus id field to a string

Having the id field be an int was making more complex bus topologies
excessively difficult.  For now, just convert it to a string, and
change all instances of "bus->id = val" to
snprintf(id, MII_BUS_ID_LEN, "%x", val).

Signed-off-by: Andy Fleming <afleming@freescale.com>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
This commit is contained in:
Andy Fleming 2008-04-09 19:38:13 -05:00 committed by Jeff Garzik
parent d080cd6301
commit 9d9326d3bc
21 changed files with 36 additions and 32 deletions

View File

@ -138,7 +138,7 @@ static int __devinit ep8248e_mdio_probe(struct of_device *ofdev,
bus->name = "ep8248e-mdio-bitbang"; bus->name = "ep8248e-mdio-bitbang";
bus->dev = &ofdev->dev; bus->dev = &ofdev->dev;
bus->id = res.start; snprintf(bus->id, MII_BUS_ID_SIZE, "%x", res.start);
return mdiobus_register(bus); return mdiobus_register(bus);
} }

View File

@ -241,7 +241,7 @@ static int __devinit gpio_mdio_probe(struct of_device *ofdev,
new_bus->reset = &gpio_mdio_reset; new_bus->reset = &gpio_mdio_reset;
prop = of_get_property(np, "reg", NULL); prop = of_get_property(np, "reg", NULL);
new_bus->id = *prop; snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", *prop);
new_bus->priv = priv; new_bus->priv = priv;
new_bus->phy_mask = 0; new_bus->phy_mask = 0;

View File

@ -341,7 +341,7 @@ static int __init gfar_of_init(void)
goto unreg; goto unreg;
} }
gfar_data.bus_id = 0; snprintf(gfar_data.bus_id, MII_BUS_ID_SIZE, "0");
gfar_data.phy_id = fixed_link[0]; gfar_data.phy_id = fixed_link[0];
} else { } else {
phy = of_find_node_by_phandle(*ph); phy = of_find_node_by_phandle(*ph);
@ -362,7 +362,8 @@ static int __init gfar_of_init(void)
} }
gfar_data.phy_id = *id; gfar_data.phy_id = *id;
gfar_data.bus_id = res.start; snprintf(gfar_data.bus_id, MII_BUS_ID_SIZE, "%x",
res.start);
of_node_put(phy); of_node_put(phy);
of_node_put(mdio); of_node_put(mdio);

View File

@ -701,7 +701,7 @@ static struct net_device * au1000_probe(int port_num)
aup->mii_bus.write = mdiobus_write; aup->mii_bus.write = mdiobus_write;
aup->mii_bus.reset = mdiobus_reset; aup->mii_bus.reset = mdiobus_reset;
aup->mii_bus.name = "au1000_eth_mii"; aup->mii_bus.name = "au1000_eth_mii";
aup->mii_bus.id = aup->mac_id; snprintf(aup->mii_bus.id, MII_BUS_ID_SIZE, "%x", aup->mac_id);
aup->mii_bus.irq = kmalloc(sizeof(int)*PHY_MAX_ADDR, GFP_KERNEL); aup->mii_bus.irq = kmalloc(sizeof(int)*PHY_MAX_ADDR, GFP_KERNEL);
for(i = 0; i < PHY_MAX_ADDR; ++i) for(i = 0; i < PHY_MAX_ADDR; ++i)
aup->mii_bus.irq[i] = PHY_POLL; aup->mii_bus.irq[i] = PHY_POLL;
@ -709,11 +709,11 @@ static struct net_device * au1000_probe(int port_num)
/* if known, set corresponding PHY IRQs */ /* if known, set corresponding PHY IRQs */
#if defined(AU1XXX_PHY_STATIC_CONFIG) #if defined(AU1XXX_PHY_STATIC_CONFIG)
# if defined(AU1XXX_PHY0_IRQ) # if defined(AU1XXX_PHY0_IRQ)
if (AU1XXX_PHY0_BUSID == aup->mii_bus.id) if (AU1XXX_PHY0_BUSID == aup->mac_id)
aup->mii_bus.irq[AU1XXX_PHY0_ADDR] = AU1XXX_PHY0_IRQ; aup->mii_bus.irq[AU1XXX_PHY0_ADDR] = AU1XXX_PHY0_IRQ;
# endif # endif
# if defined(AU1XXX_PHY1_IRQ) # if defined(AU1XXX_PHY1_IRQ)
if (AU1XXX_PHY1_BUSID == aup->mii_bus.id) if (AU1XXX_PHY1_BUSID == aup->mac_id)
aup->mii_bus.irq[AU1XXX_PHY1_ADDR] = AU1XXX_PHY1_IRQ; aup->mii_bus.irq[AU1XXX_PHY1_ADDR] = AU1XXX_PHY1_IRQ;
# endif # endif
#endif #endif

View File

@ -969,7 +969,7 @@ static int __init bf537mac_probe(struct net_device *dev)
lp->mii_bus.write = mdiobus_write; lp->mii_bus.write = mdiobus_write;
lp->mii_bus.reset = mdiobus_reset; lp->mii_bus.reset = mdiobus_reset;
lp->mii_bus.name = "bfin_mac_mdio"; lp->mii_bus.name = "bfin_mac_mdio";
lp->mii_bus.id = 0; snprintf(lp->mii_bus.id, MII_BUS_ID_SIZE, "0");
lp->mii_bus.irq = kmalloc(sizeof(int)*PHY_MAX_ADDR, GFP_KERNEL); lp->mii_bus.irq = kmalloc(sizeof(int)*PHY_MAX_ADDR, GFP_KERNEL);
for (i = 0; i < PHY_MAX_ADDR; ++i) for (i = 0; i < PHY_MAX_ADDR; ++i)
lp->mii_bus.irq[i] = PHY_POLL; lp->mii_bus.irq[i] = PHY_POLL;

View File

@ -987,7 +987,7 @@ static int external_switch;
static int __devinit cpmac_probe(struct platform_device *pdev) static int __devinit cpmac_probe(struct platform_device *pdev)
{ {
int rc, phy_id, i; int rc, phy_id, i;
int mdio_bus_id = cpmac_mii.id; char *mdio_bus_id = "0";
struct resource *mem; struct resource *mem;
struct cpmac_priv *priv; struct cpmac_priv *priv;
struct net_device *dev; struct net_device *dev;
@ -1008,8 +1008,6 @@ static int __devinit cpmac_probe(struct platform_device *pdev)
if (external_switch || dumb_switch) { if (external_switch || dumb_switch) {
struct fixed_phy_status status = {}; struct fixed_phy_status status = {};
mdio_bus_id = 0;
/* /*
* FIXME: this should be in the platform code! * FIXME: this should be in the platform code!
* Since there is not platform code at all (that is, * Since there is not platform code at all (that is,
@ -1143,6 +1141,7 @@ int __devinit cpmac_init(void)
} }
cpmac_mii.phy_mask = ~(mask | 0x80000000); cpmac_mii.phy_mask = ~(mask | 0x80000000);
snprintf(cpmac_mii.id, MII_BUS_ID_SIZE, "0");
res = mdiobus_register(&cpmac_mii); res = mdiobus_register(&cpmac_mii);
if (res) if (res)

View File

@ -198,7 +198,7 @@ static int mpc52xx_fec_init_phy(struct net_device *dev)
struct phy_device *phydev; struct phy_device *phydev;
char phy_id[BUS_ID_SIZE]; char phy_id[BUS_ID_SIZE];
snprintf(phy_id, BUS_ID_SIZE, PHY_ID_FMT, snprintf(phy_id, BUS_ID_SIZE, "%x:%02x",
(unsigned int)dev->base_addr, priv->phy_addr); (unsigned int)dev->base_addr, priv->phy_addr);
priv->link = PHY_DOWN; priv->link = PHY_DOWN;

View File

@ -124,7 +124,7 @@ static int mpc52xx_fec_mdio_probe(struct of_device *of, const struct of_device_i
goto out_free; goto out_free;
} }
bus->id = res.start; snprintf(bus->id, MII_BUS_ID_SIZE, "%x", res.start);
bus->priv = priv; bus->priv = priv;
bus->dev = dev; bus->dev = dev;

View File

@ -1178,7 +1178,7 @@ static int __devinit find_phy(struct device_node *np,
data = of_get_property(np, "fixed-link", NULL); data = of_get_property(np, "fixed-link", NULL);
if (data) { if (data) {
snprintf(fpi->bus_id, 16, PHY_ID_FMT, 0, *data); snprintf(fpi->bus_id, 16, "%x:%02x", 0, *data);
return 0; return 0;
} }
@ -1202,7 +1202,7 @@ static int __devinit find_phy(struct device_node *np,
if (!data || len != 4) if (!data || len != 4)
goto out_put_mdio; goto out_put_mdio;
snprintf(fpi->bus_id, 16, PHY_ID_FMT, res.start, *data); snprintf(fpi->bus_id, 16, "%x:%02x", res.start, *data);
out_put_mdio: out_put_mdio:
of_node_put(mdionode); of_node_put(mdionode);

View File

@ -130,7 +130,7 @@ static int __devinit fs_mii_bitbang_init(struct mii_bus *bus,
* we get is an int, and the odds of multiple bitbang mdio buses * we get is an int, and the odds of multiple bitbang mdio buses
* is low enough that it's not worth going too crazy. * is low enough that it's not worth going too crazy.
*/ */
bus->id = res.start; snprintf(bus->id, MII_BUS_ID_SIZE, "%x", res.start);
data = of_get_property(np, "fsl,mdio-pin", &len); data = of_get_property(np, "fsl,mdio-pin", &len);
if (!data || len != 4) if (!data || len != 4)
@ -307,7 +307,7 @@ static int __devinit fs_enet_mdio_probe(struct device *dev)
return -ENOMEM; return -ENOMEM;
new_bus->name = "BB MII Bus", new_bus->name = "BB MII Bus",
new_bus->id = pdev->id; snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", pdev->id);
new_bus->phy_mask = ~0x9; new_bus->phy_mask = ~0x9;
pdata = (struct fs_mii_bb_platform_info *)pdev->dev.platform_data; pdata = (struct fs_mii_bb_platform_info *)pdev->dev.platform_data;

View File

@ -196,7 +196,7 @@ static int __devinit fs_enet_mdio_probe(struct of_device *ofdev,
if (ret) if (ret)
return ret; return ret;
new_bus->id = res.start; snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", res.start);
fec->fecp = ioremap(res.start, res.end - res.start + 1); fec->fecp = ioremap(res.start, res.end - res.start + 1);
if (!fec->fecp) if (!fec->fecp)
@ -309,7 +309,7 @@ static int __devinit fs_enet_fec_mdio_probe(struct device *dev)
new_bus->read = &fs_enet_fec_mii_read, new_bus->read = &fs_enet_fec_mii_read,
new_bus->write = &fs_enet_fec_mii_write, new_bus->write = &fs_enet_fec_mii_write,
new_bus->reset = &fs_enet_fec_mii_reset, new_bus->reset = &fs_enet_fec_mii_reset,
new_bus->id = pdev->id; snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", pdev->id);
pdata = (struct fs_mii_fec_platform_info *)pdev->dev.platform_data; pdata = (struct fs_mii_fec_platform_info *)pdev->dev.platform_data;

View File

@ -173,7 +173,7 @@ int gfar_mdio_probe(struct device *dev)
new_bus->read = &gfar_mdio_read, new_bus->read = &gfar_mdio_read,
new_bus->write = &gfar_mdio_write, new_bus->write = &gfar_mdio_write,
new_bus->reset = &gfar_mdio_reset, new_bus->reset = &gfar_mdio_reset,
new_bus->id = pdev->id; snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", pdev->id);
pdata = (struct gianfar_mdio_data *)pdev->dev.platform_data; pdata = (struct gianfar_mdio_data *)pdev->dev.platform_data;

View File

@ -246,7 +246,7 @@ static int macb_mii_init(struct macb *bp)
bp->mii_bus.read = &macb_mdio_read; bp->mii_bus.read = &macb_mdio_read;
bp->mii_bus.write = &macb_mdio_write; bp->mii_bus.write = &macb_mdio_write;
bp->mii_bus.reset = &macb_mdio_reset; bp->mii_bus.reset = &macb_mdio_reset;
bp->mii_bus.id = bp->pdev->id; snprintf(bp->mii_bus.id, MII_BUS_ID_SIZE, "%x", bp->pdev->id);
bp->mii_bus.priv = bp; bp->mii_bus.priv = bp;
bp->mii_bus.dev = &bp->dev->dev; bp->mii_bus.dev = &bp->dev->dev;
pdata = bp->pdev->dev.platform_data; pdata = bp->pdev->dev.platform_data;

View File

@ -1012,7 +1012,7 @@ static int pasemi_mac_phy_init(struct net_device *dev)
goto err; goto err;
phy_id = *prop; phy_id = *prop;
snprintf(mac->phy_id, BUS_ID_SIZE, PHY_ID_FMT, (int)r.start, phy_id); snprintf(mac->phy_id, BUS_ID_SIZE, "%x:%02x", (int)r.start, phy_id);
of_node_put(phy_dn); of_node_put(phy_dn);

View File

@ -213,7 +213,7 @@ static int __init fixed_mdio_bus_init(void)
goto err_pdev; goto err_pdev;
} }
fmb->mii_bus.id = 0; snprintf(fmb->mii_bus.id, MII_BUS_ID_SIZE, "0");
fmb->mii_bus.name = "Fixed MDIO Bus"; fmb->mii_bus.name = "Fixed MDIO Bus";
fmb->mii_bus.dev = &pdev->dev; fmb->mii_bus.dev = &pdev->dev;
fmb->mii_bus.read = &fixed_mdio_read; fmb->mii_bus.read = &fixed_mdio_read;

View File

@ -2374,7 +2374,7 @@ static int sbmac_init(struct platform_device *pldev, long long base)
dev->name, base, print_mac(mac, eaddr)); dev->name, base, print_mac(mac, eaddr));
sc->mii_bus.name = sbmac_mdio_string; sc->mii_bus.name = sbmac_mdio_string;
sc->mii_bus.id = idx; snprintf(sc->mii_bus.id, MII_BUS_ID_SIZE, "%x", idx);
sc->mii_bus.priv = sc; sc->mii_bus.priv = sc;
sc->mii_bus.read = sbmac_mii_read; sc->mii_bus.read = sbmac_mii_read;
sc->mii_bus.write = sbmac_mii_write; sc->mii_bus.write = sbmac_mii_write;

View File

@ -3954,7 +3954,7 @@ static int ucc_geth_probe(struct of_device* ofdev, const struct of_device_id *ma
if (err) if (err)
return -1; return -1;
ug_info->mdio_bus = res.start; snprintf(ug_info->mdio_bus, MII_BUS_ID_SIZE, "%x", res.start);
} }
/* get the phy interface type, or default to MII */ /* get the phy interface type, or default to MII */

View File

@ -1156,7 +1156,7 @@ struct ucc_geth_info {
u16 pausePeriod; u16 pausePeriod;
u16 extensionField; u16 extensionField;
u8 phy_address; u8 phy_address;
u32 mdio_bus; char mdio_bus[MII_BUS_ID_SIZE];
u8 weightfactor[NUM_TX_QUEUES]; u8 weightfactor[NUM_TX_QUEUES];
u8 interruptcoalescingmaxvalue[NUM_RX_QUEUES]; u8 interruptcoalescingmaxvalue[NUM_RX_QUEUES];
u8 l2qt[UCC_GETH_VLAN_PRIORITY_MAX]; u8 l2qt[UCC_GETH_VLAN_PRIORITY_MAX];

View File

@ -157,7 +157,7 @@ static int uec_mdio_probe(struct of_device *ofdev, const struct of_device_id *ma
if (err) if (err)
goto reg_map_fail; goto reg_map_fail;
new_bus->id = res.start; snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", res.start);
new_bus->irq = kmalloc(32 * sizeof(int), GFP_KERNEL); new_bus->irq = kmalloc(32 * sizeof(int), GFP_KERNEL);

View File

@ -50,7 +50,7 @@ struct gianfar_platform_data {
u32 device_flags; u32 device_flags;
/* board specific information */ /* board specific information */
u32 board_flags; u32 board_flags;
u32 bus_id; char bus_id[MII_BUS_ID_SIZE];
u32 phy_id; u32 phy_id;
u8 mac_addr[6]; u8 mac_addr[6];
phy_interface_t interface; phy_interface_t interface;

View File

@ -63,8 +63,6 @@ typedef enum {
PHY_INTERFACE_MODE_RTBI PHY_INTERFACE_MODE_RTBI
} phy_interface_t; } phy_interface_t;
#define MII_BUS_MAX 4
#define PHY_INIT_TIMEOUT 100000 #define PHY_INIT_TIMEOUT 100000
#define PHY_STATE_TIME 1 #define PHY_STATE_TIME 1
@ -74,13 +72,19 @@ typedef enum {
#define PHY_MAX_ADDR 32 #define PHY_MAX_ADDR 32
/* Used when trying to connect to a specific phy (mii bus id:phy device id) */ /* Used when trying to connect to a specific phy (mii bus id:phy device id) */
#define PHY_ID_FMT "%x:%02x" #define PHY_ID_FMT "%s:%02x"
/*
* Need to be a little smaller than phydev->dev.bus_id to leave room
* for the ":%02x"
*/
#define MII_BUS_ID_SIZE (BUS_ID_SIZE - 3)
/* The Bus class for PHYs. Devices which provide access to /* The Bus class for PHYs. Devices which provide access to
* PHYs should register using this structure */ * PHYs should register using this structure */
struct mii_bus { struct mii_bus {
const char *name; const char *name;
int id; char id[MII_BUS_ID_SIZE];
void *priv; void *priv;
int (*read)(struct mii_bus *bus, int phy_id, int regnum); int (*read)(struct mii_bus *bus, int phy_id, int regnum);
int (*write)(struct mii_bus *bus, int phy_id, int regnum, u16 val); int (*write)(struct mii_bus *bus, int phy_id, int regnum, u16 val);