]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
ARC: Eliminate some ARCv2 specific code for ARCompact build
authorVineet Gupta <vgupta@synopsys.com>
Fri, 21 Aug 2015 09:36:43 +0000 (15:06 +0530)
committerVineet Gupta <vgupta@synopsys.com>
Fri, 21 Aug 2015 09:36:43 +0000 (15:06 +0530)
Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
arch/arc/mm/cache.c
arch/arc/mm/dma.c

index 5c825c8ebe10fb862844dbff78e1e8072d21c7f3..0d1a6e96839fbfc6636f324f6d05fb483d97dcea 100644 (file)
@@ -52,6 +52,9 @@ char *arc_cache_mumbojumbo(int c, char *buf, int len)
        PR_CACHE(&cpuinfo_arc700[c].icache, CONFIG_ARC_HAS_ICACHE, "I-Cache");
        PR_CACHE(&cpuinfo_arc700[c].dcache, CONFIG_ARC_HAS_DCACHE, "D-Cache");
 
+       if (!is_isa_arcv2())
+                return buf;
+
        p = &cpuinfo_arc700[c].slc;
        if (p->ver)
                n += scnprintf(buf + n, len - n,
@@ -70,18 +73,9 @@ char *arc_cache_mumbojumbo(int c, char *buf, int len)
  * the cpuinfo structure for later use.
  * No Validation done here, simply read/convert the BCRs
  */
-void read_decode_cache_bcr(void)
+static void read_decode_cache_bcr_arcv2(int cpu)
 {
-       struct cpuinfo_arc_cache *p_ic, *p_dc, *p_slc;
-       unsigned int cpu = smp_processor_id();
-       struct bcr_cache {
-#ifdef CONFIG_CPU_BIG_ENDIAN
-               unsigned int pad:12, line_len:4, sz:4, config:4, ver:8;
-#else
-               unsigned int ver:8, config:4, sz:4, line_len:4, pad:12;
-#endif
-       } ibcr, dbcr;
-
+       struct cpuinfo_arc_cache *p_slc = &cpuinfo_arc700[cpu].slc;
        struct bcr_generic sbcr;
 
        struct bcr_slc_cfg {
@@ -100,6 +94,31 @@ void read_decode_cache_bcr(void)
 #endif
        } cbcr;
 
+       READ_BCR(ARC_REG_SLC_BCR, sbcr);
+       if (sbcr.ver) {
+               READ_BCR(ARC_REG_SLC_CFG, slc_cfg);
+               p_slc->ver = sbcr.ver;
+               p_slc->sz_k = 128 << slc_cfg.sz;
+               l2_line_sz = p_slc->line_len = (slc_cfg.lsz == 0) ? 128 : 64;
+       }
+
+       READ_BCR(ARC_REG_CLUSTER_BCR, cbcr);
+       if (cbcr.c && ioc_enable)
+               ioc_exists = 1;
+}
+
+void read_decode_cache_bcr(void)
+{
+       struct cpuinfo_arc_cache *p_ic, *p_dc;
+       unsigned int cpu = smp_processor_id();
+       struct bcr_cache {
+#ifdef CONFIG_CPU_BIG_ENDIAN
+               unsigned int pad:12, line_len:4, sz:4, config:4, ver:8;
+#else
+               unsigned int ver:8, config:4, sz:4, line_len:4, pad:12;
+#endif
+       } ibcr, dbcr;
+
        p_ic = &cpuinfo_arc700[cpu].icache;
        READ_BCR(ARC_REG_IC_BCR, ibcr);
 
@@ -142,21 +161,8 @@ dc_chk:
        p_dc->ver = dbcr.ver;
 
 slc_chk:
-       if (!is_isa_arcv2())
-               return;
-
-       p_slc = &cpuinfo_arc700[cpu].slc;
-       READ_BCR(ARC_REG_SLC_BCR, sbcr);
-       if (sbcr.ver) {
-               READ_BCR(ARC_REG_SLC_CFG, slc_cfg);
-               p_slc->ver = sbcr.ver;
-               p_slc->sz_k = 128 << slc_cfg.sz;
-               l2_line_sz = p_slc->line_len = (slc_cfg.lsz == 0) ? 128 : 64;
-       }
-
-       READ_BCR(ARC_REG_CLUSTER_BCR, cbcr);
-       if (cbcr.c && ioc_enable)
-               ioc_exists = 1;
+       if (is_isa_arcv2())
+                read_decode_cache_bcr_arcv2(cpu);
 }
 
 /*
index e039fac163f80aa95d77d468816d928adc7806cc..29a46bb198ccaf834398212b25c3a1c670ba2763 100644 (file)
@@ -65,7 +65,7 @@ void *dma_alloc_coherent(struct device *dev, size_t size,
         *   -For coherent data, Read/Write to buffers terminate early in cache
         *   (vs. always going to memory - thus are faster)
         */
-       if (ioc_exists)
+       if (is_isa_arcv2() && ioc_exists)
                return dma_alloc_noncoherent(dev, size, dma_handle, gfp);
 
        /* This is linear addr (0x8000_0000 based) */
@@ -100,7 +100,7 @@ EXPORT_SYMBOL(dma_alloc_coherent);
 void dma_free_coherent(struct device *dev, size_t size, void *kvaddr,
                       dma_addr_t dma_handle)
 {
-       if (ioc_exists)
+       if (is_isa_arcv2() && ioc_exists)
                return dma_free_noncoherent(dev, size, kvaddr, dma_handle);
 
        iounmap((void __force __iomem *)kvaddr);