summaryrefslogtreecommitdiffstats
path: root/target/linux/generic/files
diff options
context:
space:
mode:
authorGabor Juhos <juhosg@openwrt.org>2013-03-15 15:50:05 +0000
committerGabor Juhos <juhosg@openwrt.org>2013-03-15 15:50:05 +0000
commitee12b1b7d5e7038950f3f3aa9db210ef06d99a5b (patch)
treeb986f2627713ff1d6c10cbdfc4a317bb7f23c1c4 /target/linux/generic/files
parentd88f66ae21fa5c5996c6b7cfa186582d4bfe7fbe (diff)
downloadmaster-31e0f0ae-ee12b1b7d5e7038950f3f3aa9db210ef06d99a5b.tar.gz
master-31e0f0ae-ee12b1b7d5e7038950f3f3aa9db210ef06d99a5b.tar.bz2
master-31e0f0ae-ee12b1b7d5e7038950f3f3aa9db210ef06d99a5b.zip
generic: ar8216: separate platform_data based AR8327 code
Move platform_data specific configuration code into a separate routine. Do it in preparation for the upcoming OF support. Signed-off-by: Gabor Juhos <juhosg@openwrt.org> SVN-Revision: 36046
Diffstat (limited to 'target/linux/generic/files')
-rw-r--r--target/linux/generic/files/drivers/net/phy/ar8216.c21
1 files changed, 16 insertions, 5 deletions
diff --git a/target/linux/generic/files/drivers/net/phy/ar8216.c b/target/linux/generic/files/drivers/net/phy/ar8216.c
index 74fecd6f85..d4ef7bd195 100644
--- a/target/linux/generic/files/drivers/net/phy/ar8216.c
+++ b/target/linux/generic/files/drivers/net/phy/ar8216.c
@@ -1039,17 +1039,14 @@ ar8327_get_port_init_status(struct ar8327_port_cfg *cfg)
}
static int
-ar8327_hw_init(struct ar8xxx_priv *priv)
+ar8327_hw_config_pdata(struct ar8xxx_priv *priv,
+ struct ar8327_platform_data *pdata)
{
- struct ar8327_platform_data *pdata;
struct ar8327_led_cfg *led_cfg;
struct ar8327_data *data;
- struct mii_bus *bus;
u32 pos, new_pos;
u32 t;
- int i;
- pdata = priv->phy->dev.platform_data;
if (!pdata)
return -EINVAL;
@@ -1086,6 +1083,20 @@ ar8327_hw_init(struct ar8xxx_priv *priv)
priv->write(priv, AR8327_REG_POWER_ON_STRIP, new_pos);
}
+ return 0;
+}
+
+static int
+ar8327_hw_init(struct ar8xxx_priv *priv)
+{
+ struct mii_bus *bus;
+ int ret;
+ int i;
+
+ ret = ar8327_hw_config_pdata(priv, priv->phy->dev.platform_data);
+ if (ret)
+ return ret;
+
bus = priv->mii_bus;
for (i = 0; i < AR8327_NUM_PHYS; i++) {
ar8327_phy_fixup(priv, i);