sh: Kill off the special uncached section and fixmap.
authorPaul Mundt <lethal@linux-sh.org>
Thu, 21 Jan 2010 07:05:25 +0000 (16:05 +0900)
committerPaul Mundt <lethal@linux-sh.org>
Thu, 21 Jan 2010 07:05:25 +0000 (16:05 +0900)
Now that cached_to_uncached works as advertized in 32-bit mode and we're
never going to be able to map < 16MB anyways, there's no need for the
special uncached section. Kill it off.

Signed-off-by: Paul Mundt <lethal@linux-sh.org>
15 files changed:
arch/sh/include/asm/fixmap.h
arch/sh/include/asm/system_32.h
arch/sh/include/asm/system_64.h
arch/sh/kernel/cpu/init.c
arch/sh/kernel/cpu/sh3/probe.c
arch/sh/kernel/cpu/sh4a/setup-sh7723.c
arch/sh/kernel/cpu/sh4a/setup-sh7724.c
arch/sh/kernel/vmlinux.lds.S
arch/sh/mm/cache-debugfs.c
arch/sh/mm/cache-sh4.c
arch/sh/mm/cache-sh7705.c
arch/sh/mm/init.c
arch/sh/mm/pmb.c
arch/sh/mm/tlb-pteaex.c
arch/sh/mm/tlb-sh4.c

index 38a1de866873b363046f6b5220bfb5247c2e8f14..17b22b6c10016f9a076a21488c2feaeabcc6938d 100644 (file)
@@ -55,11 +55,12 @@ enum fixed_addresses {
 #define FIX_N_COLOURS 8
        FIX_CMAP_BEGIN,
        FIX_CMAP_END = FIX_CMAP_BEGIN + (FIX_N_COLOURS * NR_CPUS) - 1,
-       FIX_UNCACHED,
+
 #ifdef CONFIG_HIGHMEM
        FIX_KMAP_BEGIN, /* reserved pte's for temporary kernel mappings */
        FIX_KMAP_END = FIX_KMAP_BEGIN+(KM_TYPE_NR*NR_CPUS)-1,
 #endif
+
        /*
         * FIX_IOREMAP entries are useful for mapping physical address
         * space before ioremap() is useable, e.g. really early in boot
@@ -68,6 +69,7 @@ enum fixed_addresses {
 #define FIX_N_IOREMAPS 32
        FIX_IOREMAP_BEGIN,
        FIX_IOREMAP_END = FIX_IOREMAP_BEGIN + FIX_N_IOREMAPS,
+
        __end_of_fixed_addresses
 };
 
index 34bd2bac9a5fce12f057465df064d6451e88ea80..51296b36770e3b1be77acefedd2476f2fd8206f3 100644 (file)
@@ -145,9 +145,6 @@ do {                                                                \
                __restore_dsp(prev);                            \
 } while (0)
 
-#define __uses_jump_to_uncached \
-       noinline __attribute__ ((__section__ (".uncached.text")))
-
 /*
  * Jump to uncached area.
  * When handling TLB or caches, we need to do it from an uncached area.
index 604ba7802cc20be82004f8428592c6c418989904..3391bb6b21d8755a41b8f11e3e25ee3d9fe38e7a 100644 (file)
@@ -33,8 +33,6 @@ do {                                                          \
                              &next->thread);                   \
 } while (0)
 
-#define __uses_jump_to_uncached
-
 #define jump_to_uncached()     do { } while (0)
 #define back_to_cached()       do { } while (0)
 
index a5bb0550bbf32ba3e48ef73a3b5cd2ba8cd42e06..05a7d2a373b62e260665b4233b270d0f0013f602 100644 (file)
@@ -98,7 +98,7 @@ static void __init expmask_init(void)
 #endif
 
 /* 2nd-level cache init */
-void __uses_jump_to_uncached __attribute__ ((weak)) l2_cache_init(void)
+void __attribute__ ((weak)) l2_cache_init(void)
 {
 }
 
@@ -106,7 +106,7 @@ void __uses_jump_to_uncached __attribute__ ((weak)) l2_cache_init(void)
  * Generic first-level cache init
  */
 #ifdef CONFIG_SUPERH32
-static void __uses_jump_to_uncached cache_init(void)
+static void cache_init(void)
 {
        unsigned long ccr, flags;
 
index f9c7df64eb010ed7dc5e80b26d2ee635e41cd56c..c2db65719f4de09ecb98d25031178e225a81893c 100644 (file)
@@ -16,7 +16,7 @@
 #include <asm/cache.h>
 #include <asm/io.h>
 
-int __uses_jump_to_uncached detect_cpu_and_cache_system(void)
+int detect_cpu_and_cache_system(void)
 {
        unsigned long addr0, addr1, data0, data1, data2, data3;
 
index 772b9265d0e475f445b30ef6a85940dd45ee2d31..9d426258aa00b8ee3edd02b56ad3d613942a1874 100644 (file)
@@ -592,7 +592,8 @@ void __init plat_early_device_setup(void)
 #define RAMCR_CACHE_L2FC       0x0002
 #define RAMCR_CACHE_L2E                0x0001
 #define L2_CACHE_ENABLE                (RAMCR_CACHE_L2E|RAMCR_CACHE_L2FC)
-void __uses_jump_to_uncached l2_cache_init(void)
+
+void l2_cache_init(void)
 {
        /* Enable L2 cache */
        ctrl_outl(L2_CACHE_ENABLE, RAMCR);
index d32f96c1cc15f9ed7d911bfd4e28474f731661d7..578e9f80271f484f77325e48872f70dea0b0f80c 100644 (file)
@@ -714,7 +714,8 @@ void __init plat_early_device_setup(void)
 #define RAMCR_CACHE_L2FC       0x0002
 #define RAMCR_CACHE_L2E                0x0001
 #define L2_CACHE_ENABLE                (RAMCR_CACHE_L2E|RAMCR_CACHE_L2FC)
-void __uses_jump_to_uncached l2_cache_init(void)
+
+void l2_cache_init(void)
 {
        /* Enable L2 cache */
        ctrl_outl(L2_CACHE_ENABLE, RAMCR);
index 9e5a5878eeaee4dec1865331fd85b0a54509a778..93e9b25a18116c3f8b03bce7c5bbf4e5fef1299e 100644 (file)
@@ -53,18 +53,6 @@ SECTIONS
 
        NOTES
        RO_DATA(PAGE_SIZE)
-
-       /*
-        * Code which must be executed uncached and the associated data
-        */
-       . = ALIGN(PAGE_SIZE);
-       .uncached : AT(ADDR(.uncached) - LOAD_OFFSET) {
-               __uncached_start = .;
-               *(.uncached.text)
-               *(.uncached.data)
-               __uncached_end = .;
-       }
-
        RW_DATA_SECTION(L1_CACHE_BYTES, PAGE_SIZE, THREAD_SIZE)
 
        _edata = .;                     /* End of data section */
index 5ba067b2659109caf9d013e79d59e91c4f5278eb..48ce82ee9fd2bb7c0b9f2950fedfee84f6db3961 100644 (file)
@@ -22,8 +22,7 @@ enum cache_type {
        CACHE_TYPE_UNIFIED,
 };
 
-static int __uses_jump_to_uncached cache_seq_show(struct seq_file *file,
-                                                 void *iter)
+static int cache_seq_show(struct seq_file *file, void *iter)
 {
        unsigned int cache_type = (unsigned int)file->private;
        struct cache_info *cache;
index a2301daeefa3edc3a02bb6f5abd16397a774649c..87115b3ee70efe01e2b327ae232f44d3bc4776ab 100644 (file)
@@ -36,7 +36,7 @@ static void __flush_cache_one(unsigned long addr, unsigned long phys,
  * Called from kernel/module.c:sys_init_module and routine for a.out format,
  * signal handler code and kprobes code
  */
-static void __uses_jump_to_uncached sh4_flush_icache_range(void *args)
+static void sh4_flush_icache_range(void *args)
 {
        struct flusher_data *data = args;
        unsigned long start, end;
@@ -124,7 +124,7 @@ static void sh4_flush_dcache_page(void *arg)
 }
 
 /* TODO: Selective icache invalidation through IC address array.. */
-static void __uses_jump_to_uncached flush_icache_all(void)
+static void flush_icache_all(void)
 {
        unsigned long flags, ccr;
 
index f527fb70fce63988b92e7c1eb0c48fc0908e49a3..870293ee539e73223709df8b8f97dad4f5864efc 100644 (file)
@@ -78,7 +78,7 @@ static void sh7705_flush_icache_range(void *args)
 /*
  * Writeback&Invalidate the D-cache of the page
  */
-static void __uses_jump_to_uncached __flush_dcache_page(unsigned long phys)
+static void __flush_dcache_page(unsigned long phys)
 {
        unsigned long ways, waysize, addrstart;
        unsigned long flags;
@@ -144,7 +144,7 @@ static void sh7705_flush_dcache_page(void *arg)
                __flush_dcache_page(__pa(page_address(page)));
 }
 
-static void __uses_jump_to_uncached sh7705_flush_cache_all(void *args)
+static void sh7705_flush_cache_all(void *args)
 {
        unsigned long flags;
 
index a28ff63c17a637f2105223d780030d492c06b0e3..dffa6c74948981bc31796b14401539f713b7acee 100644 (file)
@@ -211,9 +211,6 @@ void __init paging_init(void)
        }
 
        free_area_init_nodes(max_zone_pfns);
-
-       /* Set up the uncached fixmap */
-       set_fixmap_nocache(FIX_UNCACHED, __pa(&__uncached_start));
 }
 
 /*
index d318fa6caffe0d50463ec97591279ff1291f9c2c..3d5eece7e6d016b1cdf2f253c673034b315ccbab 100644 (file)
@@ -127,14 +127,14 @@ static void __set_pmb_entry(unsigned long vpn, unsigned long ppn,
        ctrl_outl(ppn | flags | PMB_V, mk_pmb_data(pos));
 }
 
-static void __uses_jump_to_uncached set_pmb_entry(struct pmb_entry *pmbe)
+static void set_pmb_entry(struct pmb_entry *pmbe)
 {
        jump_to_uncached();
        __set_pmb_entry(pmbe->vpn, pmbe->ppn, pmbe->flags, pmbe->entry);
        back_to_cached();
 }
 
-static void __uses_jump_to_uncached clear_pmb_entry(struct pmb_entry *pmbe)
+static void clear_pmb_entry(struct pmb_entry *pmbe)
 {
        unsigned int entry = pmbe->entry;
        unsigned long addr;
@@ -364,7 +364,7 @@ static inline int pmb_apply_legacy_mappings(void)
 }
 #endif
 
-int __uses_jump_to_uncached pmb_init(void)
+int pmb_init(void)
 {
        int i;
        unsigned long addr, data;
index 409b7c2b4b9d9485082f714150aa2db85e0f351f..32dc674c550c12ec2424adaf46c5856b90a0ea72 100644 (file)
@@ -68,8 +68,7 @@ void __update_tlb(struct vm_area_struct *vma, unsigned long address, pte_t pte)
  * in extended mode, the legacy 8-bit ASID field in address array 1 has
  * undefined behaviour.
  */
-void __uses_jump_to_uncached local_flush_tlb_one(unsigned long asid,
-                                                unsigned long page)
+void local_flush_tlb_one(unsigned long asid, unsigned long page)
 {
        jump_to_uncached();
        __raw_writel(page, MMU_UTLB_ADDRESS_ARRAY | MMU_PAGE_ASSOC_BIT);
index 8cf550e2570fde753a8405e77c722f9b5fc13032..624c1daa9f3f7a634f236e3dcd4570978242b4e7 100644 (file)
@@ -64,8 +64,7 @@ void __update_tlb(struct vm_area_struct *vma, unsigned long address, pte_t pte)
        local_irq_restore(flags);
 }
 
-void __uses_jump_to_uncached local_flush_tlb_one(unsigned long asid,
-                                                unsigned long page)
+void local_flush_tlb_one(unsigned long asid, unsigned long page)
 {
        unsigned long addr, data;