diff options
Diffstat (limited to 'drivers/net/mv643xx_eth.c')
-rw-r--r-- | drivers/net/mv643xx_eth.c | 32 |
1 files changed, 20 insertions, 12 deletions
diff --git a/drivers/net/mv643xx_eth.c b/drivers/net/mv643xx_eth.c index 634008154480..d25a30251139 100644 --- a/drivers/net/mv643xx_eth.c +++ b/drivers/net/mv643xx_eth.c | |||
@@ -250,7 +250,7 @@ struct mv643xx_eth_shared_private { | |||
250 | /* | 250 | /* |
251 | * Provides access to local SMI interface. | 251 | * Provides access to local SMI interface. |
252 | */ | 252 | */ |
253 | struct mii_bus smi_bus; | 253 | struct mii_bus *smi_bus; |
254 | 254 | ||
255 | /* | 255 | /* |
256 | * If we have access to the error interrupt pin (which is | 256 | * If we have access to the error interrupt pin (which is |
@@ -2363,15 +2363,19 @@ static int mv643xx_eth_shared_probe(struct platform_device *pdev) | |||
2363 | * Set up and register SMI bus. | 2363 | * Set up and register SMI bus. |
2364 | */ | 2364 | */ |
2365 | if (pd == NULL || pd->shared_smi == NULL) { | 2365 | if (pd == NULL || pd->shared_smi == NULL) { |
2366 | msp->smi_bus.priv = msp; | 2366 | msp->smi_bus = mdiobus_alloc(); |
2367 | msp->smi_bus.name = "mv643xx_eth smi"; | 2367 | if (msp->smi_bus == NULL) |
2368 | msp->smi_bus.read = smi_bus_read; | ||
2369 | msp->smi_bus.write = smi_bus_write, | ||
2370 | snprintf(msp->smi_bus.id, MII_BUS_ID_SIZE, "%d", pdev->id); | ||
2371 | msp->smi_bus.parent = &pdev->dev; | ||
2372 | msp->smi_bus.phy_mask = 0xffffffff; | ||
2373 | if (mdiobus_register(&msp->smi_bus) < 0) | ||
2374 | goto out_unmap; | 2368 | goto out_unmap; |
2369 | |||
2370 | msp->smi_bus->priv = msp; | ||
2371 | msp->smi_bus->name = "mv643xx_eth smi"; | ||
2372 | msp->smi_bus->read = smi_bus_read; | ||
2373 | msp->smi_bus->write = smi_bus_write, | ||
2374 | snprintf(msp->smi_bus->id, MII_BUS_ID_SIZE, "%d", pdev->id); | ||
2375 | msp->smi_bus->parent = &pdev->dev; | ||
2376 | msp->smi_bus->phy_mask = 0xffffffff; | ||
2377 | if (mdiobus_register(msp->smi_bus) < 0) | ||
2378 | goto out_free_mii_bus; | ||
2375 | msp->smi = msp; | 2379 | msp->smi = msp; |
2376 | } else { | 2380 | } else { |
2377 | msp->smi = platform_get_drvdata(pd->shared_smi); | 2381 | msp->smi = platform_get_drvdata(pd->shared_smi); |
@@ -2411,6 +2415,8 @@ static int mv643xx_eth_shared_probe(struct platform_device *pdev) | |||
2411 | 2415 | ||
2412 | return 0; | 2416 | return 0; |
2413 | 2417 | ||
2418 | out_free_mii_bus: | ||
2419 | mdiobus_free(msp->smi_bus); | ||
2414 | out_unmap: | 2420 | out_unmap: |
2415 | iounmap(msp->base); | 2421 | iounmap(msp->base); |
2416 | out_free: | 2422 | out_free: |
@@ -2424,8 +2430,10 @@ static int mv643xx_eth_shared_remove(struct platform_device *pdev) | |||
2424 | struct mv643xx_eth_shared_private *msp = platform_get_drvdata(pdev); | 2430 | struct mv643xx_eth_shared_private *msp = platform_get_drvdata(pdev); |
2425 | struct mv643xx_eth_shared_platform_data *pd = pdev->dev.platform_data; | 2431 | struct mv643xx_eth_shared_platform_data *pd = pdev->dev.platform_data; |
2426 | 2432 | ||
2427 | if (pd == NULL || pd->shared_smi == NULL) | 2433 | if (pd == NULL || pd->shared_smi == NULL) { |
2428 | mdiobus_unregister(&msp->smi_bus); | 2434 | mdiobus_free(msp->smi_bus); |
2435 | mdiobus_unregister(msp->smi_bus); | ||
2436 | } | ||
2429 | if (msp->err_interrupt != NO_IRQ) | 2437 | if (msp->err_interrupt != NO_IRQ) |
2430 | free_irq(msp->err_interrupt, msp); | 2438 | free_irq(msp->err_interrupt, msp); |
2431 | iounmap(msp->base); | 2439 | iounmap(msp->base); |
@@ -2493,7 +2501,7 @@ static void set_params(struct mv643xx_eth_private *mp, | |||
2493 | static struct phy_device *phy_scan(struct mv643xx_eth_private *mp, | 2501 | static struct phy_device *phy_scan(struct mv643xx_eth_private *mp, |
2494 | int phy_addr) | 2502 | int phy_addr) |
2495 | { | 2503 | { |
2496 | struct mii_bus *bus = &mp->shared->smi->smi_bus; | 2504 | struct mii_bus *bus = mp->shared->smi->smi_bus; |
2497 | struct phy_device *phydev; | 2505 | struct phy_device *phydev; |
2498 | int start; | 2506 | int start; |
2499 | int num; | 2507 | int num; |