From 1130aa078f6e1a877345d6e78fcd1a97e75a6a0c Mon Sep 17 00:00:00 2001 From: juhosg Date: Thu, 8 Mar 2012 10:21:08 +0000 Subject: [PATCH] generic: ar8216: simplify ar8216_config_init git-svn-id: svn://svn.openwrt.org/openwrt/trunk@30853 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../generic/files/drivers/net/phy/ar8216.c | 39 ++++++++----------- 1 file changed, 16 insertions(+), 23 deletions(-) diff --git a/target/linux/generic/files/drivers/net/phy/ar8216.c b/target/linux/generic/files/drivers/net/phy/ar8216.c index 3b7937d72..8e84e9d70 100644 --- a/target/linux/generic/files/drivers/net/phy/ar8216.c +++ b/target/linux/generic/files/drivers/net/phy/ar8216.c @@ -892,34 +892,24 @@ ar8216_config_init(struct phy_device *pdev) swdev->vlans = AR8216_NUM_VLANS; } - if ((ret = register_switch(&priv->dev, pdev->attached_dev)) < 0) { - kfree(priv); - goto done; - } + ret = register_switch(&priv->dev, pdev->attached_dev); + if (ret) + goto err_free_priv; priv->init = true; - if (priv->chip == AR8316) { - ret = ar8316_hw_init(priv); - if (ret) { - kfree(priv); - goto done; - } - } - - if (priv->chip == AR8236) { + ret = 0; + if (priv->chip == AR8236) ret = ar8236_hw_init(priv); - if (ret) { - kfree(priv); - goto done; - } - } + else if (priv->chip == AR8316) + ret = ar8316_hw_init(priv); + + if (ret) + goto err_free_priv; ret = ar8216_reset_switch(&priv->dev); - if (ret) { - kfree(priv); - goto done; - } + if (ret) + goto err_free_priv; dev->phy_ptr = priv; @@ -936,7 +926,10 @@ ar8216_config_init(struct phy_device *pdev) priv->init = false; -done: + return 0; + +err_free_priv: + kfree(priv); return ret; }