ARM: OMAP3+: am33xx id: Add new am33xx specific function to check dev_feature
authorVaibhav Hiremath <hvaibhav@ti.com>
Fri, 17 May 2013 10:13:41 +0000 (15:43 +0530)
committerTony Lindgren <tony@atomide.com>
Tue, 18 Jun 2013 10:04:07 +0000 (03:04 -0700)
Layout of DEV_FEATURE register (offset = 0x604) is different
between TI81xx and AM33xx device, so create separate function
which will check for features available on specific AM33xx SoC
and set the flags accordingly.

Signed-off-by: Vaibhav Hiremath <hvaibhav@ti.com>
Reviewed-by: Kevin Hilman <khilman@linaro.org>
Signed-off-by: Tony Lindgren <tony@atomide.com>
arch/arm/mach-omap2/control.h
arch/arm/mach-omap2/id.c
arch/arm/mach-omap2/io.c
arch/arm/mach-omap2/soc.h

index 35d17a6ec06bd460be465612d24cd379e068fea8..f7d7c2ef1b40f252c72f8ecdd87511168190d273 100644 (file)
 #define AM33XX_PWMSS1_TBCLKEN_SHIFT                    1
 #define AM33XX_PWMSS2_TBCLKEN_SHIFT                    2
 
+/* DEV Feature register to identify AM33XX features */
+#define AM33XX_DEV_FEATURE             0x604
+#define AM33XX_SGX_MASK                        BIT(29)
+
 /* CONTROL OMAP STATUS register to identify OMAP3 features */
 #define OMAP3_CONTROL_OMAP_STATUS      0x044c
 
index 9e5c7cb4a81a7c0264e3aa2ff95af1ce57fd34b8..7335eb2bf3fa2b6c2897c41ed87c6b6195c0112d 100644 (file)
@@ -304,6 +304,19 @@ void __init ti81xx_check_features(void)
        omap3_cpuinfo();
 }
 
+void __init am33xx_check_features(void)
+{
+       u32 status;
+
+       omap_features = OMAP3_HAS_NEON;
+
+       status = omap_ctrl_readl(AM33XX_DEV_FEATURE);
+       if (status & AM33XX_SGX_MASK)
+               omap_features |= OMAP3_HAS_SGX;
+
+       omap3_cpuinfo();
+}
+
 void __init omap3xxx_check_revision(void)
 {
        const char *cpu_rev;
index f96215075b92ab28c845376aa4c9f6cb0ef98b22..4c7367404b89fa055de5548c45a233aaf550a00c 100644 (file)
@@ -576,7 +576,7 @@ void __init am33xx_init_early(void)
        omap2_set_globals_prm(AM33XX_L4_WK_IO_ADDRESS(AM33XX_PRCM_BASE));
        omap2_set_globals_cm(AM33XX_L4_WK_IO_ADDRESS(AM33XX_PRCM_BASE), NULL);
        omap3xxx_check_revision();
-       ti81xx_check_features();
+       am33xx_check_features();
        am33xx_voltagedomains_init();
        am33xx_powerdomains_init();
        am33xx_clockdomains_init();
index 9cd9414a0afd418d4449b1611732fafdf1d17dda..8c616e436bc7bcf0ff1d4ac2ac11eb9497535ce4 100644 (file)
@@ -449,6 +449,7 @@ void omap4xxx_check_revision(void);
 void omap5xxx_check_revision(void);
 void omap3xxx_check_features(void);
 void ti81xx_check_features(void);
+void am33xx_check_features(void);
 void omap4xxx_check_features(void);
 
 /*