diff options
| author | juhosg <juhosg@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2009-02-12 14:06:58 +0000 | 
|---|---|---|
| committer | juhosg <juhosg@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2009-02-12 14:06:58 +0000 | 
| commit | d72c973763a344ea3ba50b7e151716409ed095a3 (patch) | |
| tree | 055d3cfbf71a8a53d81c0496408902938c54da4b /target/linux | |
| parent | 17a8d866d1db9e4573fc6a532e7522cd2d8e96dd (diff) | |
[ar71xx] pull ethernet mac out of reset before registering the mdio_bus
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@14486 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux')
| -rw-r--r-- | target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_mdio.c | 2 | ||||
| -rw-r--r-- | target/linux/ar71xx/patches-2.6.28/802-ag71xx_mdio_dynamic_mdio_bus.patch | 24 | 
2 files changed, 22 insertions, 4 deletions
| diff --git a/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_mdio.c b/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_mdio.c index 01888f110..4ff6df8fa 100644 --- a/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_mdio.c +++ b/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_mdio.c @@ -170,6 +170,8 @@ static int __init ag71xx_mdio_probe(struct platform_device *pdev)  	for (i = 0; i < PHY_MAX_ADDR; i++)  		am->mii_irq[i] = PHY_POLL; +	ag71xx_mdio_wr(am, AG71XX_REG_MAC_CFG1, 0); +  	err = mdiobus_register(&am->mii_bus);  	if (err)  		goto err_iounmap; diff --git a/target/linux/ar71xx/patches-2.6.28/802-ag71xx_mdio_dynamic_mdio_bus.patch b/target/linux/ar71xx/patches-2.6.28/802-ag71xx_mdio_dynamic_mdio_bus.patch index b7b7d58ea..fa84e5550 100644 --- a/target/linux/ar71xx/patches-2.6.28/802-ag71xx_mdio_dynamic_mdio_bus.patch +++ b/target/linux/ar71xx/patches-2.6.28/802-ag71xx_mdio_dynamic_mdio_bus.patch @@ -33,7 +33,7 @@   			break;   		}   		udelay(AG71XX_MDIO_DELAY); -@@ -154,23 +154,27 @@ static int __init ag71xx_mdio_probe(stru +@@ -154,27 +154,33 @@ static int __init ag71xx_mdio_probe(stru   		goto err_free_mdio;   	} @@ -46,8 +46,10 @@  -	am->mii_bus.parent = &pdev->dev;  -	snprintf(am->mii_bus.id, MII_BUS_ID_SIZE, "%x", 0);  +	am->mii_bus = mdiobus_alloc(); -+	if (am->mii_bus == NULL) ++	if (am->mii_bus == NULL) { ++		err = -NOMEM;  +		goto err_iounmap; ++	}  +  +	am->mii_bus->name = "ag71xx_mdio";  +	am->mii_bus->read = ag71xx_mdio_read; @@ -66,12 +68,26 @@   	for (i = 0; i < PHY_MAX_ADDR; i++)   		am->mii_irq[i] = PHY_POLL; + 	ag71xx_mdio_wr(am, AG71XX_REG_MAC_CFG1, 0); +   -	err = mdiobus_register(&am->mii_bus);  +	err = mdiobus_register(am->mii_bus);   	if (err) - 		goto err_iounmap; +-		goto err_iounmap; ++		goto err_free_bus; +  + 	ag71xx_mdio_dump_regs(am); +  +@@ -182,6 +188,8 @@ static int __init ag71xx_mdio_probe(stru + 	ag71xx_mdio_bus = am; + 	return 0; -@@ -194,7 +198,8 @@ static int __exit ag71xx_mdio_remove(str ++ err_free_bus: ++	mdiobus_free(am->mii_bus); +  err_iounmap: + 	iounmap(am->mdio_base); +  err_free_mdio: +@@ -196,7 +204,8 @@ static int __exit ag71xx_mdio_remove(str   	if (am) {   		ag71xx_mdio_bus = NULL; | 
