phy: mdio-octeon: Use devm_mdiobus_alloc_size()
authorAndrew Lunn <andrew@lunn.ch>
Wed, 6 Jan 2016 19:11:14 +0000 (20:11 +0100)
committerDavid S. Miller <davem@davemloft.net>
Thu, 7 Jan 2016 19:31:25 +0000 (14:31 -0500)
Rather than use devm_kzalloc(), use the mdio helper function.

Signed-off-by: Andrew Lunn <andrew@lunn.ch>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/phy/mdio-octeon.c

index fcf4e4d..0d5da13 100644 (file)
@@ -268,12 +268,13 @@ static int octeon_mdiobus_write(struct mii_bus *bus, int phy_id,
 static int octeon_mdiobus_probe(struct platform_device *pdev)
 {
        struct octeon_mdiobus *bus;
+       struct mii_bus *mii_bus;
        struct resource *res_mem;
        union cvmx_smix_en smi_en;
        int err = -ENOENT;
 
-       bus = devm_kzalloc(&pdev->dev, sizeof(*bus), GFP_KERNEL);
-       if (!bus)
+       mii_bus = devm_mdiobus_alloc_size(&pdev->dev, sizeof(*bus));
+       if (!mii_bus)
                return -ENOMEM;
 
        res_mem = platform_get_resource(pdev, IORESOURCE_MEM, 0);
@@ -282,6 +283,8 @@ static int octeon_mdiobus_probe(struct platform_device *pdev)
                return -ENXIO;
        }
 
+       bus = mii_bus->priv;
+       bus->mii_bus = mii_bus;
        bus->mdio_phys = res_mem->start;
        bus->regsize = resource_size(res_mem);
 
@@ -298,10 +301,6 @@ static int octeon_mdiobus_probe(struct platform_device *pdev)
                return -ENOMEM;
        }
 
-       bus->mii_bus = mdiobus_alloc();
-       if (!bus->mii_bus)
-               goto fail;
-
        smi_en.u64 = 0;
        smi_en.s.en = 1;
        oct_mdio_writeq(smi_en.u64, bus->register_base + SMI_EN);
@@ -326,7 +325,6 @@ static int octeon_mdiobus_probe(struct platform_device *pdev)
        return 0;
 fail_register:
        mdiobus_free(bus->mii_bus);
-fail:
        smi_en.u64 = 0;
        oct_mdio_writeq(smi_en.u64, bus->register_base + SMI_EN);
        return err;