Browse Source

net: xilinx: Use mdio_register_seq() to support multiple instances

axi_emac, emaclite and gem have the same issue with registering
multiple instances with mdio busses. mdio bus name has to be uniq but
drivers are setting up only one name for all.
Use mdio_register_seq() and pass dev->seq number to allow multiple
mdio instances registration.

Reported-by: Phani Kiran Kara <phanikiran.kara@gmail.com>
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
Series-to: u-boot
Series-cc: Phani Kiran Kara <phanikiran.kara@gmail.com>
Michal Simek 8 years ago
parent
commit
b63cb3abbc
3 changed files with 3 additions and 6 deletions
  1. 1 2
      drivers/net/xilinx_axi_emac.c
  2. 1 2
      drivers/net/xilinx_emaclite.c
  3. 1 2
      drivers/net/zynq_gem.c

+ 1 - 2
drivers/net/xilinx_axi_emac.c

@@ -648,9 +648,8 @@ static int axi_emac_probe(struct udevice *dev)
 	priv->bus->read = axiemac_miiphy_read;
 	priv->bus->read = axiemac_miiphy_read;
 	priv->bus->write = axiemac_miiphy_write;
 	priv->bus->write = axiemac_miiphy_write;
 	priv->bus->priv = priv;
 	priv->bus->priv = priv;
-	strcpy(priv->bus->name, "axi_emac");
 
 
-	ret = mdio_register(priv->bus);
+	ret = mdio_register_seq(priv->bus, dev->seq);
 	if (ret)
 	if (ret)
 		return ret;
 		return ret;
 
 

+ 1 - 2
drivers/net/xilinx_emaclite.c

@@ -566,9 +566,8 @@ static int emaclite_probe(struct udevice *dev)
 	emaclite->bus->read = emaclite_miiphy_read;
 	emaclite->bus->read = emaclite_miiphy_read;
 	emaclite->bus->write = emaclite_miiphy_write;
 	emaclite->bus->write = emaclite_miiphy_write;
 	emaclite->bus->priv = emaclite;
 	emaclite->bus->priv = emaclite;
-	strcpy(emaclite->bus->name, "emaclite");
 
 
-	ret = mdio_register(emaclite->bus);
+	ret = mdio_register_seq(emaclite->bus, dev->seq);
 	if (ret)
 	if (ret)
 		return ret;
 		return ret;
 
 

+ 1 - 2
drivers/net/zynq_gem.c

@@ -647,9 +647,8 @@ static int zynq_gem_probe(struct udevice *dev)
 	priv->bus->read = zynq_gem_miiphy_read;
 	priv->bus->read = zynq_gem_miiphy_read;
 	priv->bus->write = zynq_gem_miiphy_write;
 	priv->bus->write = zynq_gem_miiphy_write;
 	priv->bus->priv = priv;
 	priv->bus->priv = priv;
-	strcpy(priv->bus->name, "gem");
 
 
-	ret = mdio_register(priv->bus);
+	ret = mdio_register_seq_name(priv->bus, dev->seq);
 	if (ret)
 	if (ret)
 		return ret;
 		return ret;