ar71xx: init get_mac_revision on AR9330 rev 1
[openwrt/svn-archive/archive.git] / target / linux / ar71xx / files / arch / mips / ar71xx / dev-ar9xxx-wmac.c
index ade61e46c711f9b705b1b5857237b998ca7616ae..d4104726b68a09fb93748389f4bf815d88e0449e 100644 (file)
@@ -63,6 +63,23 @@ static void ar913x_wmac_init(void)
        ar9xxx_wmac_resources[0].end = AR91XX_WMAC_BASE + AR91XX_WMAC_SIZE - 1;
 }
 
+static int ar933x_r1_get_wmac_revision(void)
+{
+       return ar71xx_soc_rev;
+}
+
+static void ar933x_wmac_init(void)
+{
+       ar9xxx_wmac_device.name = "ar933x_wmac";
+       ar9xxx_wmac_resources[0].start = AR933X_WMAC_BASE;
+       ar9xxx_wmac_resources[0].end = AR933X_WMAC_BASE + AR933X_WMAC_SIZE - 1;
+       if (ar71xx_ref_freq == MHZ_25)
+               ar9xxx_wmac_data.is_clk_25mhz = true;
+
+       if (ar71xx_soc_rev == 1)
+               ar9xxx_wmac_data.get_mac_revision = ar933x_r1_get_wmac_revision;
+}
+
 static void ar934x_wmac_init(void)
 {
        ar9xxx_wmac_device.name = "ar934x_wmac";
@@ -80,6 +97,11 @@ void __init ar9xxx_add_device_wmac(u8 *cal_data, u8 *mac_addr)
                ar913x_wmac_init();
                break;
 
+       case AR71XX_SOC_AR9330:
+       case AR71XX_SOC_AR9331:
+               ar933x_wmac_init();
+               break;
+
        case AR71XX_SOC_AR9341:
        case AR71XX_SOC_AR9342:
        case AR71XX_SOC_AR9344: