MIPS: ath79: add SoC detection code for the QCA955X SoCs
authorGabor Juhos <juhosg@openwrt.org>
Fri, 15 Feb 2013 13:38:16 +0000 (13:38 +0000)
committerJohn Crispin <blogic@openwrt.org>
Tue, 19 Feb 2013 08:36:24 +0000 (09:36 +0100)
Also add 'soc_is_qca955[68x]' helper functions
and a Kconfig symbol for the SoC family.

Cc: Rodriguez, Luis <rodrigue@qca.qualcomm.com>
Cc: Giori, Kathy <kgiori@qca.qualcomm.com>
Cc: QCA Linux Team <qca-linux-team@qca.qualcomm.com>
Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
Patchwork: http://patchwork.linux-mips.org/patch/4943/
Signed-off-by: John Crispin <blogic@openwrt.org>
arch/mips/ath79/Kconfig
arch/mips/ath79/setup.c
arch/mips/include/asm/mach-ath79/ar71xx_regs.h
arch/mips/include/asm/mach-ath79/ath79.h

index f44feee2d67f9f506bdeffe0d5bc2d205a860d7f..cffdc8e3b63bf9334a2020e70fafb3b7aab65851 100644 (file)
@@ -88,6 +88,10 @@ config SOC_AR934X
        select PCI_AR724X if PCI
        def_bool n
 
+config SOC_QCA955X
+       select USB_ARCH_HAS_EHCI
+       def_bool n
+
 config PCI_AR724X
        def_bool n
 
index 60d212ef86290c61d51ff5135e952506834caa2d..d5b3c9057018d8ccdbd2de891d8498de3b1ca76d 100644 (file)
@@ -164,13 +164,29 @@ static void __init ath79_detect_sys_type(void)
                rev = id & AR934X_REV_ID_REVISION_MASK;
                break;
 
+       case REV_ID_MAJOR_QCA9556:
+               ath79_soc = ATH79_SOC_QCA9556;
+               chip = "9556";
+               rev = id & QCA955X_REV_ID_REVISION_MASK;
+               break;
+
+       case REV_ID_MAJOR_QCA9558:
+               ath79_soc = ATH79_SOC_QCA9558;
+               chip = "9558";
+               rev = id & QCA955X_REV_ID_REVISION_MASK;
+               break;
+
        default:
                panic("ath79: unknown SoC, id:0x%08x", id);
        }
 
        ath79_soc_rev = rev;
 
-       sprintf(ath79_sys_type, "Atheros AR%s rev %u", chip, rev);
+       if (soc_is_qca955x())
+               sprintf(ath79_sys_type, "Qualcomm Atheros QCA%s rev %u",
+                       chip, rev);
+       else
+               sprintf(ath79_sys_type, "Atheros AR%s rev %u", chip, rev);
        pr_info("SoC: %s\n", ath79_sys_type);
 }
 
index d02c2d4e600e8dac52b7972437121360c6f94532..63a9f2b600b8c0556632689f9037ad92c75e5cd1 100644 (file)
 
 #define AR934X_REV_ID_REVISION_MASK     0xf
 
+#define QCA955X_REV_ID_REVISION_MASK   0xf
+
 /*
  * SPI block
  */
index 4f248c3d7b237100e41a1bad3489d090ff8cbb29..1557934aaca973d25e4a0d2bcc97e5e1d39f926a 100644 (file)
@@ -32,6 +32,8 @@ enum ath79_soc_type {
        ATH79_SOC_AR9341,
        ATH79_SOC_AR9342,
        ATH79_SOC_AR9344,
+       ATH79_SOC_QCA9556,
+       ATH79_SOC_QCA9558,
 };
 
 extern enum ath79_soc_type ath79_soc;
@@ -98,6 +100,21 @@ static inline int soc_is_ar934x(void)
        return soc_is_ar9341() || soc_is_ar9342() || soc_is_ar9344();
 }
 
+static inline int soc_is_qca9556(void)
+{
+       return ath79_soc == ATH79_SOC_QCA9556;
+}
+
+static inline int soc_is_qca9558(void)
+{
+       return ath79_soc == ATH79_SOC_QCA9558;
+}
+
+static inline int soc_is_qca955x(void)
+{
+       return soc_is_qca9556() || soc_is_qca9558();
+}
+
 extern void __iomem *ath79_ddr_base;
 extern void __iomem *ath79_pll_base;
 extern void __iomem *ath79_reset_base;