generic: ar8216: add hw_init field to ar8xxx_chip
authorjuhosg <juhosg@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Sun, 18 Mar 2012 22:06:15 +0000 (22:06 +0000)
committerjuhosg <juhosg@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Sun, 18 Mar 2012 22:06:15 +0000 (22:06 +0000)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@30998 3c298f89-4303-0410-b956-a3cf2f4a3e73

target/linux/generic/files/drivers/net/phy/ar8216.c

index 038a086..3408451 100644 (file)
 #define AR8X16_MAX_VLANS       128
 #define AR8X16_PROBE_RETRIES   10
 
+struct ar8216_priv;
+
 struct ar8xxx_chip {
+       int (*hw_init)(struct ar8216_priv *priv);
 };
 
 struct ar8216_priv {
@@ -741,12 +744,15 @@ ar8216_init_port(struct ar8216_priv *priv, int port)
 }
 
 static const struct ar8xxx_chip ar8216_chip = {
+       .hw_init = ar8216_hw_init,
 };
 
 static const struct ar8xxx_chip ar8236_chip = {
+       .hw_init = ar8236_hw_init,
 };
 
 static const struct ar8xxx_chip ar8316_chip = {
+       .hw_init = ar8316_hw_init,
 };
 
 static int
@@ -943,14 +949,7 @@ ar8216_config_init(struct phy_device *pdev)
 
        priv->init = true;
 
-       ret = 0;
-       if (priv->chip_type == AR8216)
-               ret = ar8216_hw_init(priv);
-       else if (priv->chip_type == AR8236)
-               ret = ar8236_hw_init(priv);
-       else if (priv->chip_type == AR8316)
-               ret = ar8316_hw_init(priv);
-
+       ret = priv->chip->hw_init(priv);
        if (ret)
                goto err_free_priv;
 
This page took 0.024395 seconds and 4 git commands to generate.