diff options
Diffstat (limited to 'arch/mips/mm')
-rw-r--r-- | arch/mips/mm/Makefile | 6 | ||||
-rw-r--r-- | arch/mips/mm/c-octeon.c | 2 | ||||
-rw-r--r-- | arch/mips/mm/c-r3k.c | 8 | ||||
-rw-r--r-- | arch/mips/mm/c-r4k.c | 27 | ||||
-rw-r--r-- | arch/mips/mm/c-tx39.c | 12 | ||||
-rw-r--r-- | arch/mips/mm/cerr-sb1.c | 30 | ||||
-rw-r--r-- | arch/mips/mm/cex-gen.S | 6 | ||||
-rw-r--r-- | arch/mips/mm/cex-oct.S | 36 | ||||
-rw-r--r-- | arch/mips/mm/cex-sb1.S | 8 | ||||
-rw-r--r-- | arch/mips/mm/dma-default.c | 2 | ||||
-rw-r--r-- | arch/mips/mm/fault.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/gup.c | 2 | ||||
-rw-r--r-- | arch/mips/mm/init.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/ioremap.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/page.c | 6 | ||||
-rw-r--r-- | arch/mips/mm/pgtable-64.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/sc-ip22.c | 2 | ||||
-rw-r--r-- | arch/mips/mm/sc-r5k.c | 4 | ||||
-rw-r--r-- | arch/mips/mm/tlb-r4k.c | 2 | ||||
-rw-r--r-- | arch/mips/mm/tlbex.c | 33 | ||||
-rw-r--r-- | arch/mips/mm/uasm.c | 16 |
21 files changed, 110 insertions, 108 deletions
diff --git a/arch/mips/mm/Makefile b/arch/mips/mm/Makefile index 90ceb963aaf1..1dcec30ad1c4 100644 --- a/arch/mips/mm/Makefile +++ b/arch/mips/mm/Makefile | |||
@@ -16,9 +16,9 @@ obj-$(CONFIG_CPU_R3000) += c-r3k.o tlb-r3k.o | |||
16 | obj-$(CONFIG_CPU_R8000) += c-r4k.o cex-gen.o tlb-r8k.o | 16 | obj-$(CONFIG_CPU_R8000) += c-r4k.o cex-gen.o tlb-r8k.o |
17 | obj-$(CONFIG_CPU_SB1) += c-r4k.o cerr-sb1.o cex-sb1.o tlb-r4k.o | 17 | obj-$(CONFIG_CPU_SB1) += c-r4k.o cerr-sb1.o cex-sb1.o tlb-r4k.o |
18 | obj-$(CONFIG_CPU_TX39XX) += c-tx39.o tlb-r3k.o | 18 | obj-$(CONFIG_CPU_TX39XX) += c-tx39.o tlb-r3k.o |
19 | obj-$(CONFIG_CPU_CAVIUM_OCTEON) += c-octeon.o cex-oct.o tlb-r4k.o | 19 | obj-$(CONFIG_CPU_CAVIUM_OCTEON) += c-octeon.o cex-oct.o tlb-r4k.o |
20 | 20 | ||
21 | obj-$(CONFIG_IP22_CPU_SCACHE) += sc-ip22.o | 21 | obj-$(CONFIG_IP22_CPU_SCACHE) += sc-ip22.o |
22 | obj-$(CONFIG_R5000_CPU_SCACHE) += sc-r5k.o | 22 | obj-$(CONFIG_R5000_CPU_SCACHE) += sc-r5k.o |
23 | obj-$(CONFIG_RM7000_CPU_SCACHE) += sc-rm7k.o | 23 | obj-$(CONFIG_RM7000_CPU_SCACHE) += sc-rm7k.o |
24 | obj-$(CONFIG_MIPS_CPU_SCACHE) += sc-mips.o | 24 | obj-$(CONFIG_MIPS_CPU_SCACHE) += sc-mips.o |
diff --git a/arch/mips/mm/c-octeon.c b/arch/mips/mm/c-octeon.c index 6ec04daf4231..8557fb552863 100644 --- a/arch/mips/mm/c-octeon.c +++ b/arch/mips/mm/c-octeon.c | |||
@@ -106,7 +106,7 @@ static void octeon_flush_icache_all(void) | |||
106 | * Called to flush all memory associated with a memory | 106 | * Called to flush all memory associated with a memory |
107 | * context. | 107 | * context. |
108 | * | 108 | * |
109 | * @mm: Memory context to flush | 109 | * @mm: Memory context to flush |
110 | */ | 110 | */ |
111 | static void octeon_flush_cache_mm(struct mm_struct *mm) | 111 | static void octeon_flush_cache_mm(struct mm_struct *mm) |
112 | { | 112 | { |
diff --git a/arch/mips/mm/c-r3k.c b/arch/mips/mm/c-r3k.c index 031c4c2cdf2e..704dc735a59d 100644 --- a/arch/mips/mm/c-r3k.c +++ b/arch/mips/mm/c-r3k.c | |||
@@ -119,7 +119,7 @@ static void r3k_flush_icache_range(unsigned long start, unsigned long end) | |||
119 | write_c0_status((ST0_ISC|ST0_SWC|flags)&~ST0_IEC); | 119 | write_c0_status((ST0_ISC|ST0_SWC|flags)&~ST0_IEC); |
120 | 120 | ||
121 | for (i = 0; i < size; i += 0x080) { | 121 | for (i = 0; i < size; i += 0x080) { |
122 | asm( "sb\t$0, 0x000(%0)\n\t" | 122 | asm( "sb\t$0, 0x000(%0)\n\t" |
123 | "sb\t$0, 0x004(%0)\n\t" | 123 | "sb\t$0, 0x004(%0)\n\t" |
124 | "sb\t$0, 0x008(%0)\n\t" | 124 | "sb\t$0, 0x008(%0)\n\t" |
125 | "sb\t$0, 0x00c(%0)\n\t" | 125 | "sb\t$0, 0x00c(%0)\n\t" |
@@ -176,7 +176,7 @@ static void r3k_flush_dcache_range(unsigned long start, unsigned long end) | |||
176 | write_c0_status((ST0_ISC|flags)&~ST0_IEC); | 176 | write_c0_status((ST0_ISC|flags)&~ST0_IEC); |
177 | 177 | ||
178 | for (i = 0; i < size; i += 0x080) { | 178 | for (i = 0; i < size; i += 0x080) { |
179 | asm( "sb\t$0, 0x000(%0)\n\t" | 179 | asm( "sb\t$0, 0x000(%0)\n\t" |
180 | "sb\t$0, 0x004(%0)\n\t" | 180 | "sb\t$0, 0x004(%0)\n\t" |
181 | "sb\t$0, 0x008(%0)\n\t" | 181 | "sb\t$0, 0x008(%0)\n\t" |
182 | "sb\t$0, 0x00c(%0)\n\t" | 182 | "sb\t$0, 0x00c(%0)\n\t" |
@@ -285,13 +285,13 @@ static void r3k_flush_cache_sigtramp(unsigned long addr) | |||
285 | write_c0_status(flags&~ST0_IEC); | 285 | write_c0_status(flags&~ST0_IEC); |
286 | 286 | ||
287 | /* Fill the TLB to avoid an exception with caches isolated. */ | 287 | /* Fill the TLB to avoid an exception with caches isolated. */ |
288 | asm( "lw\t$0, 0x000(%0)\n\t" | 288 | asm( "lw\t$0, 0x000(%0)\n\t" |
289 | "lw\t$0, 0x004(%0)\n\t" | 289 | "lw\t$0, 0x004(%0)\n\t" |
290 | : : "r" (addr) ); | 290 | : : "r" (addr) ); |
291 | 291 | ||
292 | write_c0_status((ST0_ISC|ST0_SWC|flags)&~ST0_IEC); | 292 | write_c0_status((ST0_ISC|ST0_SWC|flags)&~ST0_IEC); |
293 | 293 | ||
294 | asm( "sb\t$0, 0x000(%0)\n\t" | 294 | asm( "sb\t$0, 0x000(%0)\n\t" |
295 | "sb\t$0, 0x004(%0)\n\t" | 295 | "sb\t$0, 0x004(%0)\n\t" |
296 | : : "r" (addr) ); | 296 | : : "r" (addr) ); |
297 | 297 | ||
diff --git a/arch/mips/mm/c-r4k.c b/arch/mips/mm/c-r4k.c index 0f7d788e8810..ecca559b8d7b 100644 --- a/arch/mips/mm/c-r4k.c +++ b/arch/mips/mm/c-r4k.c | |||
@@ -160,7 +160,7 @@ static void __cpuinit r4k_blast_dcache_setup(void) | |||
160 | "1:\n\t" \ | 160 | "1:\n\t" \ |
161 | ) | 161 | ) |
162 | #define CACHE32_UNROLL32_ALIGN JUMP_TO_ALIGN(10) /* 32 * 32 = 1024 */ | 162 | #define CACHE32_UNROLL32_ALIGN JUMP_TO_ALIGN(10) /* 32 * 32 = 1024 */ |
163 | #define CACHE32_UNROLL32_ALIGN2 JUMP_TO_ALIGN(11) | 163 | #define CACHE32_UNROLL32_ALIGN2 JUMP_TO_ALIGN(11) |
164 | 164 | ||
165 | static inline void blast_r4600_v1_icache32(void) | 165 | static inline void blast_r4600_v1_icache32(void) |
166 | { | 166 | { |
@@ -177,7 +177,7 @@ static inline void tx49_blast_icache32(void) | |||
177 | unsigned long end = start + current_cpu_data.icache.waysize; | 177 | unsigned long end = start + current_cpu_data.icache.waysize; |
178 | unsigned long ws_inc = 1UL << current_cpu_data.icache.waybit; | 178 | unsigned long ws_inc = 1UL << current_cpu_data.icache.waybit; |
179 | unsigned long ws_end = current_cpu_data.icache.ways << | 179 | unsigned long ws_end = current_cpu_data.icache.ways << |
180 | current_cpu_data.icache.waybit; | 180 | current_cpu_data.icache.waybit; |
181 | unsigned long ws, addr; | 181 | unsigned long ws, addr; |
182 | 182 | ||
183 | CACHE32_UNROLL32_ALIGN2; | 183 | CACHE32_UNROLL32_ALIGN2; |
@@ -208,7 +208,7 @@ static inline void tx49_blast_icache32_page_indexed(unsigned long page) | |||
208 | unsigned long end = start + PAGE_SIZE; | 208 | unsigned long end = start + PAGE_SIZE; |
209 | unsigned long ws_inc = 1UL << current_cpu_data.icache.waybit; | 209 | unsigned long ws_inc = 1UL << current_cpu_data.icache.waybit; |
210 | unsigned long ws_end = current_cpu_data.icache.ways << | 210 | unsigned long ws_end = current_cpu_data.icache.ways << |
211 | current_cpu_data.icache.waybit; | 211 | current_cpu_data.icache.waybit; |
212 | unsigned long ws, addr; | 212 | unsigned long ws, addr; |
213 | 213 | ||
214 | CACHE32_UNROLL32_ALIGN2; | 214 | CACHE32_UNROLL32_ALIGN2; |
@@ -637,7 +637,7 @@ static void r4k_dma_cache_inv(unsigned long addr, unsigned long size) | |||
637 | * for the cache instruction on MIPS processors and | 637 | * for the cache instruction on MIPS processors and |
638 | * some processors, among them the RM5200 and RM7000 | 638 | * some processors, among them the RM5200 and RM7000 |
639 | * QED processors will throw an address error for cache | 639 | * QED processors will throw an address error for cache |
640 | * hit ops with insufficient alignment. Solved by | 640 | * hit ops with insufficient alignment. Solved by |
641 | * aligning the address to cache line size. | 641 | * aligning the address to cache line size. |
642 | */ | 642 | */ |
643 | blast_inv_scache_range(addr, addr + size); | 643 | blast_inv_scache_range(addr, addr + size); |
@@ -864,7 +864,7 @@ static void __cpuinit probe_pcache(void) | |||
864 | icache_size = 1 << (12 + ((config & CONF_IC) >> 9)); | 864 | icache_size = 1 << (12 + ((config & CONF_IC) >> 9)); |
865 | c->icache.linesz = 16 << ((config & CONF_IB) >> 5); | 865 | c->icache.linesz = 16 << ((config & CONF_IB) >> 5); |
866 | c->icache.ways = 1; | 866 | c->icache.ways = 1; |
867 | c->icache.waybit = 0; /* doesn't matter */ | 867 | c->icache.waybit = 0; /* doesn't matter */ |
868 | 868 | ||
869 | dcache_size = 1 << (12 + ((config & CONF_DC) >> 6)); | 869 | dcache_size = 1 << (12 + ((config & CONF_DC) >> 6)); |
870 | c->dcache.linesz = 16 << ((config & CONF_DB) >> 4); | 870 | c->dcache.linesz = 16 << ((config & CONF_DB) >> 4); |
@@ -923,7 +923,7 @@ static void __cpuinit probe_pcache(void) | |||
923 | icache_size = 1 << (10 + ((config & CONF_IC) >> 9)); | 923 | icache_size = 1 << (10 + ((config & CONF_IC) >> 9)); |
924 | c->icache.linesz = 16 << ((config & CONF_IB) >> 5); | 924 | c->icache.linesz = 16 << ((config & CONF_IB) >> 5); |
925 | c->icache.ways = 1; | 925 | c->icache.ways = 1; |
926 | c->icache.waybit = 0; /* doesn't matter */ | 926 | c->icache.waybit = 0; /* doesn't matter */ |
927 | 927 | ||
928 | dcache_size = 1 << (10 + ((config & CONF_DC) >> 6)); | 928 | dcache_size = 1 << (10 + ((config & CONF_DC) >> 6)); |
929 | c->dcache.linesz = 16 << ((config & CONF_DB) >> 4); | 929 | c->dcache.linesz = 16 << ((config & CONF_DB) >> 4); |
@@ -986,8 +986,8 @@ static void __cpuinit probe_pcache(void) | |||
986 | c->icache.ways = 1 + ((config1 >> 16) & 7); | 986 | c->icache.ways = 1 + ((config1 >> 16) & 7); |
987 | 987 | ||
988 | icache_size = c->icache.sets * | 988 | icache_size = c->icache.sets * |
989 | c->icache.ways * | 989 | c->icache.ways * |
990 | c->icache.linesz; | 990 | c->icache.linesz; |
991 | c->icache.waybit = __ffs(icache_size/c->icache.ways); | 991 | c->icache.waybit = __ffs(icache_size/c->icache.ways); |
992 | 992 | ||
993 | if (config & 0x8) /* VI bit */ | 993 | if (config & 0x8) /* VI bit */ |
@@ -1006,8 +1006,8 @@ static void __cpuinit probe_pcache(void) | |||
1006 | c->dcache.ways = 1 + ((config1 >> 7) & 7); | 1006 | c->dcache.ways = 1 + ((config1 >> 7) & 7); |
1007 | 1007 | ||
1008 | dcache_size = c->dcache.sets * | 1008 | dcache_size = c->dcache.sets * |
1009 | c->dcache.ways * | 1009 | c->dcache.ways * |
1010 | c->dcache.linesz; | 1010 | c->dcache.linesz; |
1011 | c->dcache.waybit = __ffs(dcache_size/c->dcache.ways); | 1011 | c->dcache.waybit = __ffs(dcache_size/c->dcache.ways); |
1012 | 1012 | ||
1013 | c->options |= MIPS_CPU_PREFETCH; | 1013 | c->options |= MIPS_CPU_PREFETCH; |
@@ -1016,7 +1016,7 @@ static void __cpuinit probe_pcache(void) | |||
1016 | 1016 | ||
1017 | /* | 1017 | /* |
1018 | * Processor configuration sanity check for the R4000SC erratum | 1018 | * Processor configuration sanity check for the R4000SC erratum |
1019 | * #5. With page sizes larger than 32kB there is no possibility | 1019 | * #5. With page sizes larger than 32kB there is no possibility |
1020 | * to get a VCE exception anymore so we don't care about this | 1020 | * to get a VCE exception anymore so we don't care about this |
1021 | * misconfiguration. The case is rather theoretical anyway; | 1021 | * misconfiguration. The case is rather theoretical anyway; |
1022 | * presumably no vendor is shipping his hardware in the "bad" | 1022 | * presumably no vendor is shipping his hardware in the "bad" |
@@ -1057,6 +1057,7 @@ static void __cpuinit probe_pcache(void) | |||
1057 | break; | 1057 | break; |
1058 | 1058 | ||
1059 | case CPU_M14KC: | 1059 | case CPU_M14KC: |
1060 | case CPU_M14KEC: | ||
1060 | case CPU_24K: | 1061 | case CPU_24K: |
1061 | case CPU_34K: | 1062 | case CPU_34K: |
1062 | case CPU_74K: | 1063 | case CPU_74K: |
@@ -1088,7 +1089,7 @@ static void __cpuinit probe_pcache(void) | |||
1088 | break; | 1089 | break; |
1089 | } | 1090 | } |
1090 | 1091 | ||
1091 | #ifdef CONFIG_CPU_LOONGSON2 | 1092 | #ifdef CONFIG_CPU_LOONGSON2 |
1092 | /* | 1093 | /* |
1093 | * LOONGSON2 has 4 way icache, but when using indexed cache op, | 1094 | * LOONGSON2 has 4 way icache, but when using indexed cache op, |
1094 | * one op will act on all 4 ways | 1095 | * one op will act on all 4 ways |
@@ -1228,7 +1229,7 @@ static void __cpuinit setup_scache(void) | |||
1228 | #ifdef CONFIG_R5000_CPU_SCACHE | 1229 | #ifdef CONFIG_R5000_CPU_SCACHE |
1229 | r5k_sc_init(); | 1230 | r5k_sc_init(); |
1230 | #endif | 1231 | #endif |
1231 | return; | 1232 | return; |
1232 | 1233 | ||
1233 | case CPU_RM7000: | 1234 | case CPU_RM7000: |
1234 | #ifdef CONFIG_RM7000_CPU_SCACHE | 1235 | #ifdef CONFIG_RM7000_CPU_SCACHE |
diff --git a/arch/mips/mm/c-tx39.c b/arch/mips/mm/c-tx39.c index 87d23cada6d6..ba9da270289f 100644 --- a/arch/mips/mm/c-tx39.c +++ b/arch/mips/mm/c-tx39.c | |||
@@ -33,9 +33,9 @@ extern int r3k_have_wired_reg; /* in r3k-tlb.c */ | |||
33 | /* This sequence is required to ensure icache is disabled immediately */ | 33 | /* This sequence is required to ensure icache is disabled immediately */ |
34 | #define TX39_STOP_STREAMING() \ | 34 | #define TX39_STOP_STREAMING() \ |
35 | __asm__ __volatile__( \ | 35 | __asm__ __volatile__( \ |
36 | ".set push\n\t" \ | 36 | ".set push\n\t" \ |
37 | ".set noreorder\n\t" \ | 37 | ".set noreorder\n\t" \ |
38 | "b 1f\n\t" \ | 38 | "b 1f\n\t" \ |
39 | "nop\n\t" \ | 39 | "nop\n\t" \ |
40 | "1:\n\t" \ | 40 | "1:\n\t" \ |
41 | ".set pop" \ | 41 | ".set pop" \ |
@@ -361,7 +361,7 @@ void __cpuinit tx39_cache_init(void) | |||
361 | /* TX39/H core (writethru direct-map cache) */ | 361 | /* TX39/H core (writethru direct-map cache) */ |
362 | __flush_cache_vmap = tx39__flush_cache_vmap; | 362 | __flush_cache_vmap = tx39__flush_cache_vmap; |
363 | __flush_cache_vunmap = tx39__flush_cache_vunmap; | 363 | __flush_cache_vunmap = tx39__flush_cache_vunmap; |
364 | flush_cache_all = tx39h_flush_icache_all; | 364 | flush_cache_all = tx39h_flush_icache_all; |
365 | __flush_cache_all = tx39h_flush_icache_all; | 365 | __flush_cache_all = tx39h_flush_icache_all; |
366 | flush_cache_mm = (void *) tx39h_flush_icache_all; | 366 | flush_cache_mm = (void *) tx39h_flush_icache_all; |
367 | flush_cache_range = (void *) tx39h_flush_icache_all; | 367 | flush_cache_range = (void *) tx39h_flush_icache_all; |
@@ -409,8 +409,8 @@ void __cpuinit tx39_cache_init(void) | |||
409 | _dma_cache_inv = tx39_dma_cache_inv; | 409 | _dma_cache_inv = tx39_dma_cache_inv; |
410 | 410 | ||
411 | shm_align_mask = max_t(unsigned long, | 411 | shm_align_mask = max_t(unsigned long, |
412 | (dcache_size / current_cpu_data.dcache.ways) - 1, | 412 | (dcache_size / current_cpu_data.dcache.ways) - 1, |
413 | PAGE_SIZE - 1); | 413 | PAGE_SIZE - 1); |
414 | 414 | ||
415 | break; | 415 | break; |
416 | } | 416 | } |
diff --git a/arch/mips/mm/cerr-sb1.c b/arch/mips/mm/cerr-sb1.c index 3571090ba178..576add33bf5b 100644 --- a/arch/mips/mm/cerr-sb1.c +++ b/arch/mips/mm/cerr-sb1.c | |||
@@ -27,7 +27,7 @@ | |||
27 | 27 | ||
28 | /* | 28 | /* |
29 | * We'd like to dump the L2_ECC_TAG register on errors, but errata make | 29 | * We'd like to dump the L2_ECC_TAG register on errors, but errata make |
30 | * that unsafe... So for now we don't. (BCM1250/BCM112x erratum SOC-48.) | 30 | * that unsafe... So for now we don't. (BCM1250/BCM112x erratum SOC-48.) |
31 | */ | 31 | */ |
32 | #undef DUMP_L2_ECC_TAG_ON_ERROR | 32 | #undef DUMP_L2_ECC_TAG_ON_ERROR |
33 | 33 | ||
@@ -48,7 +48,7 @@ | |||
48 | #define CP0_CERRI_EXTERNAL (1 << 26) | 48 | #define CP0_CERRI_EXTERNAL (1 << 26) |
49 | 49 | ||
50 | #define CP0_CERRI_IDX_VALID(c) (!((c) & CP0_CERRI_EXTERNAL)) | 50 | #define CP0_CERRI_IDX_VALID(c) (!((c) & CP0_CERRI_EXTERNAL)) |
51 | #define CP0_CERRI_DATA (CP0_CERRI_DATA_PARITY) | 51 | #define CP0_CERRI_DATA (CP0_CERRI_DATA_PARITY) |
52 | 52 | ||
53 | #define CP0_CERRD_MULTIPLE (1 << 31) | 53 | #define CP0_CERRD_MULTIPLE (1 << 31) |
54 | #define CP0_CERRD_TAG_STATE (1 << 30) | 54 | #define CP0_CERRD_TAG_STATE (1 << 30) |
@@ -56,8 +56,8 @@ | |||
56 | #define CP0_CERRD_DATA_SBE (1 << 28) | 56 | #define CP0_CERRD_DATA_SBE (1 << 28) |
57 | #define CP0_CERRD_DATA_DBE (1 << 27) | 57 | #define CP0_CERRD_DATA_DBE (1 << 27) |
58 | #define CP0_CERRD_EXTERNAL (1 << 26) | 58 | #define CP0_CERRD_EXTERNAL (1 << 26) |
59 | #define CP0_CERRD_LOAD (1 << 25) | 59 | #define CP0_CERRD_LOAD (1 << 25) |
60 | #define CP0_CERRD_STORE (1 << 24) | 60 | #define CP0_CERRD_STORE (1 << 24) |
61 | #define CP0_CERRD_FILLWB (1 << 23) | 61 | #define CP0_CERRD_FILLWB (1 << 23) |
62 | #define CP0_CERRD_COHERENCY (1 << 22) | 62 | #define CP0_CERRD_COHERENCY (1 << 22) |
63 | #define CP0_CERRD_DUPTAG (1 << 21) | 63 | #define CP0_CERRD_DUPTAG (1 << 21) |
@@ -69,10 +69,10 @@ | |||
69 | (CP0_CERRD_LOAD | CP0_CERRD_STORE | CP0_CERRD_FILLWB | CP0_CERRD_COHERENCY | CP0_CERRD_DUPTAG) | 69 | (CP0_CERRD_LOAD | CP0_CERRD_STORE | CP0_CERRD_FILLWB | CP0_CERRD_COHERENCY | CP0_CERRD_DUPTAG) |
70 | #define CP0_CERRD_TYPES \ | 70 | #define CP0_CERRD_TYPES \ |
71 | (CP0_CERRD_TAG_STATE | CP0_CERRD_TAG_ADDRESS | CP0_CERRD_DATA_SBE | CP0_CERRD_DATA_DBE | CP0_CERRD_EXTERNAL) | 71 | (CP0_CERRD_TAG_STATE | CP0_CERRD_TAG_ADDRESS | CP0_CERRD_DATA_SBE | CP0_CERRD_DATA_DBE | CP0_CERRD_EXTERNAL) |
72 | #define CP0_CERRD_DATA (CP0_CERRD_DATA_SBE | CP0_CERRD_DATA_DBE) | 72 | #define CP0_CERRD_DATA (CP0_CERRD_DATA_SBE | CP0_CERRD_DATA_DBE) |
73 | 73 | ||
74 | static uint32_t extract_ic(unsigned short addr, int data); | 74 | static uint32_t extract_ic(unsigned short addr, int data); |
75 | static uint32_t extract_dc(unsigned short addr, int data); | 75 | static uint32_t extract_dc(unsigned short addr, int data); |
76 | 76 | ||
77 | static inline void breakout_errctl(unsigned int val) | 77 | static inline void breakout_errctl(unsigned int val) |
78 | { | 78 | { |
@@ -209,11 +209,11 @@ asmlinkage void sb1_cache_error(void) | |||
209 | "=r" (dpahi), "=r" (dpalo), "=r" (eepc)); | 209 | "=r" (dpahi), "=r" (dpalo), "=r" (eepc)); |
210 | 210 | ||
211 | cerr_dpa = (((uint64_t)dpahi) << 32) | dpalo; | 211 | cerr_dpa = (((uint64_t)dpahi) << 32) | dpalo; |
212 | printk(" c0_errorepc == %08x\n", eepc); | 212 | printk(" c0_errorepc == %08x\n", eepc); |
213 | printk(" c0_errctl == %08x", errctl); | 213 | printk(" c0_errctl == %08x", errctl); |
214 | breakout_errctl(errctl); | 214 | breakout_errctl(errctl); |
215 | if (errctl & CP0_ERRCTL_ICACHE) { | 215 | if (errctl & CP0_ERRCTL_ICACHE) { |
216 | printk(" c0_cerr_i == %08x", cerr_i); | 216 | printk(" c0_cerr_i == %08x", cerr_i); |
217 | breakout_cerri(cerr_i); | 217 | breakout_cerri(cerr_i); |
218 | if (CP0_CERRI_IDX_VALID(cerr_i)) { | 218 | if (CP0_CERRI_IDX_VALID(cerr_i)) { |
219 | /* Check index of EPC, allowing for delay slot */ | 219 | /* Check index of EPC, allowing for delay slot */ |
@@ -229,7 +229,7 @@ asmlinkage void sb1_cache_error(void) | |||
229 | } | 229 | } |
230 | } | 230 | } |
231 | if (errctl & CP0_ERRCTL_DCACHE) { | 231 | if (errctl & CP0_ERRCTL_DCACHE) { |
232 | printk(" c0_cerr_d == %08x", cerr_d); | 232 | printk(" c0_cerr_d == %08x", cerr_d); |
233 | breakout_cerrd(cerr_d); | 233 | breakout_cerrd(cerr_d); |
234 | if (CP0_CERRD_DPA_VALID(cerr_d)) { | 234 | if (CP0_CERRD_DPA_VALID(cerr_d)) { |
235 | printk(" c0_cerr_dpa == %010llx\n", cerr_dpa); | 235 | printk(" c0_cerr_dpa == %010llx\n", cerr_dpa); |
@@ -256,7 +256,7 @@ asmlinkage void sb1_cache_error(void) | |||
256 | /* | 256 | /* |
257 | * Calling panic() when a fatal cache error occurs scrambles the | 257 | * Calling panic() when a fatal cache error occurs scrambles the |
258 | * state of the system (and the cache), making it difficult to | 258 | * state of the system (and the cache), making it difficult to |
259 | * investigate after the fact. However, if you just stall the CPU, | 259 | * investigate after the fact. However, if you just stall the CPU, |
260 | * the other CPU may keep on running, which is typically very | 260 | * the other CPU may keep on running, which is typically very |
261 | * undesirable. | 261 | * undesirable. |
262 | */ | 262 | */ |
@@ -411,7 +411,7 @@ static uint32_t extract_ic(unsigned short addr, int data) | |||
411 | " dmfc0 $1, $28, 1\n\t" | 411 | " dmfc0 $1, $28, 1\n\t" |
412 | " dsrl32 %1, $1, 0 \n\t" | 412 | " dsrl32 %1, $1, 0 \n\t" |
413 | " sll %2, $1, 0 \n\t" | 413 | " sll %2, $1, 0 \n\t" |
414 | " .set pop \n" | 414 | " .set pop \n" |
415 | : "=r" (datahi), "=r" (insta), "=r" (instb) | 415 | : "=r" (datahi), "=r" (insta), "=r" (instb) |
416 | : "r" ((way << 13) | addr | (offset << 3))); | 416 | : "r" ((way << 13) | addr | (offset << 3))); |
417 | predecode = (datahi >> 8) & 0xff; | 417 | predecode = (datahi >> 8) & 0xff; |
@@ -441,8 +441,8 @@ static uint8_t dc_ecc(uint64_t dword) | |||
441 | { | 441 | { |
442 | uint64_t t; | 442 | uint64_t t; |
443 | uint32_t w; | 443 | uint32_t w; |
444 | uint8_t p; | 444 | uint8_t p; |
445 | int i; | 445 | int i; |
446 | 446 | ||
447 | p = 0; | 447 | p = 0; |
448 | for (i = 7; i >= 0; i--) | 448 | for (i = 7; i >= 0; i--) |
diff --git a/arch/mips/mm/cex-gen.S b/arch/mips/mm/cex-gen.S index e743622fd24d..45dff5cd4b8e 100644 --- a/arch/mips/mm/cex-gen.S +++ b/arch/mips/mm/cex-gen.S | |||
@@ -14,17 +14,17 @@ | |||
14 | #include <asm/stackframe.h> | 14 | #include <asm/stackframe.h> |
15 | 15 | ||
16 | /* | 16 | /* |
17 | * Game over. Go to the button. Press gently. Swear where allowed by | 17 | * Game over. Go to the button. Press gently. Swear where allowed by |
18 | * legislation. | 18 | * legislation. |
19 | */ | 19 | */ |
20 | LEAF(except_vec2_generic) | 20 | LEAF(except_vec2_generic) |
21 | .set noreorder | 21 | .set noreorder |
22 | .set noat | 22 | .set noat |
23 | .set mips0 | 23 | .set mips0 |
24 | /* | 24 | /* |
25 | * This is a very bad place to be. Our cache error | 25 | * This is a very bad place to be. Our cache error |
26 | * detection has triggered. If we have write-back data | 26 | * detection has triggered. If we have write-back data |
27 | * in the cache, we may not be able to recover. As a | 27 | * in the cache, we may not be able to recover. As a |
28 | * first-order desperate measure, turn off KSEG0 cacheing. | 28 | * first-order desperate measure, turn off KSEG0 cacheing. |
29 | */ | 29 | */ |
30 | mfc0 k0,CP0_CONFIG | 30 | mfc0 k0,CP0_CONFIG |
diff --git a/arch/mips/mm/cex-oct.S b/arch/mips/mm/cex-oct.S index 3db8553fcd34..9029092aa740 100644 --- a/arch/mips/mm/cex-oct.S +++ b/arch/mips/mm/cex-oct.S | |||
@@ -18,7 +18,7 @@ | |||
18 | */ | 18 | */ |
19 | LEAF(except_vec2_octeon) | 19 | LEAF(except_vec2_octeon) |
20 | 20 | ||
21 | .set push | 21 | .set push |
22 | .set mips64r2 | 22 | .set mips64r2 |
23 | .set noreorder | 23 | .set noreorder |
24 | .set noat | 24 | .set noat |
@@ -27,19 +27,19 @@ | |||
27 | /* due to an errata we need to read the COP0 CacheErr (Dcache) | 27 | /* due to an errata we need to read the COP0 CacheErr (Dcache) |
28 | * before any cache/DRAM access */ | 28 | * before any cache/DRAM access */ |
29 | 29 | ||
30 | rdhwr k0, $0 /* get core_id */ | 30 | rdhwr k0, $0 /* get core_id */ |
31 | PTR_LA k1, cache_err_dcache | 31 | PTR_LA k1, cache_err_dcache |
32 | sll k0, k0, 3 | 32 | sll k0, k0, 3 |
33 | PTR_ADDU k1, k0, k1 /* k1 = &cache_err_dcache[core_id] */ | 33 | PTR_ADDU k1, k0, k1 /* k1 = &cache_err_dcache[core_id] */ |
34 | 34 | ||
35 | dmfc0 k0, CP0_CACHEERR, 1 | 35 | dmfc0 k0, CP0_CACHEERR, 1 |
36 | sd k0, (k1) | 36 | sd k0, (k1) |
37 | dmtc0 $0, CP0_CACHEERR, 1 | 37 | dmtc0 $0, CP0_CACHEERR, 1 |
38 | 38 | ||
39 | /* check whether this is a nested exception */ | 39 | /* check whether this is a nested exception */ |
40 | mfc0 k1, CP0_STATUS | 40 | mfc0 k1, CP0_STATUS |
41 | andi k1, k1, ST0_EXL | 41 | andi k1, k1, ST0_EXL |
42 | beqz k1, 1f | 42 | beqz k1, 1f |
43 | nop | 43 | nop |
44 | j cache_parity_error_octeon_non_recoverable | 44 | j cache_parity_error_octeon_non_recoverable |
45 | nop | 45 | nop |
@@ -48,22 +48,22 @@ | |||
48 | 1: j handle_cache_err | 48 | 1: j handle_cache_err |
49 | nop | 49 | nop |
50 | 50 | ||
51 | .set pop | 51 | .set pop |
52 | END(except_vec2_octeon) | 52 | END(except_vec2_octeon) |
53 | 53 | ||
54 | /* We need to jump to handle_cache_err so that the previous handler | 54 | /* We need to jump to handle_cache_err so that the previous handler |
55 | * can fit within 0x80 bytes. We also move from 0xFFFFFFFFAXXXXXXX | 55 | * can fit within 0x80 bytes. We also move from 0xFFFFFFFFAXXXXXXX |
56 | * space (uncached) to the 0xFFFFFFFF8XXXXXXX space (cached). */ | 56 | * space (uncached) to the 0xFFFFFFFF8XXXXXXX space (cached). */ |
57 | LEAF(handle_cache_err) | 57 | LEAF(handle_cache_err) |
58 | .set push | 58 | .set push |
59 | .set noreorder | 59 | .set noreorder |
60 | .set noat | 60 | .set noat |
61 | 61 | ||
62 | SAVE_ALL | 62 | SAVE_ALL |
63 | KMODE | 63 | KMODE |
64 | jal cache_parity_error_octeon_recoverable | 64 | jal cache_parity_error_octeon_recoverable |
65 | nop | 65 | nop |
66 | j ret_from_exception | 66 | j ret_from_exception |
67 | nop | 67 | nop |
68 | 68 | ||
69 | .set pop | 69 | .set pop |
diff --git a/arch/mips/mm/cex-sb1.S b/arch/mips/mm/cex-sb1.S index 89c412bc4b64..fe1d887e8d70 100644 --- a/arch/mips/mm/cex-sb1.S +++ b/arch/mips/mm/cex-sb1.S | |||
@@ -24,9 +24,9 @@ | |||
24 | #include <asm/cacheops.h> | 24 | #include <asm/cacheops.h> |
25 | #include <asm/sibyte/board.h> | 25 | #include <asm/sibyte/board.h> |
26 | 26 | ||
27 | #define C0_ERRCTL $26 /* CP0: Error info */ | 27 | #define C0_ERRCTL $26 /* CP0: Error info */ |
28 | #define C0_CERR_I $27 /* CP0: Icache error */ | 28 | #define C0_CERR_I $27 /* CP0: Icache error */ |
29 | #define C0_CERR_D $27,1 /* CP0: Dcache error */ | 29 | #define C0_CERR_D $27,1 /* CP0: Dcache error */ |
30 | 30 | ||
31 | /* | 31 | /* |
32 | * Based on SiByte sample software cache-err/cerr.S | 32 | * Based on SiByte sample software cache-err/cerr.S |
@@ -88,7 +88,7 @@ attempt_recovery: | |||
88 | /* | 88 | /* |
89 | * k0 has C0_ERRCTL << 1, which puts 'DC' at bit 31. Any | 89 | * k0 has C0_ERRCTL << 1, which puts 'DC' at bit 31. Any |
90 | * Dcache errors we can recover from will take more extensive | 90 | * Dcache errors we can recover from will take more extensive |
91 | * processing. For now, they are considered "unrecoverable". | 91 | * processing. For now, they are considered "unrecoverable". |
92 | * Note that 'DC' becoming set (outside of ERL mode) will | 92 | * Note that 'DC' becoming set (outside of ERL mode) will |
93 | * cause 'IC' to clear; so if there's an Icache error, we'll | 93 | * cause 'IC' to clear; so if there's an Icache error, we'll |
94 | * only find out about it if we recover from this error and | 94 | * only find out about it if we recover from this error and |
diff --git a/arch/mips/mm/dma-default.c b/arch/mips/mm/dma-default.c index 3fab2046c8a4..f9ef83829a52 100644 --- a/arch/mips/mm/dma-default.c +++ b/arch/mips/mm/dma-default.c | |||
@@ -4,7 +4,7 @@ | |||
4 | * for more details. | 4 | * for more details. |
5 | * | 5 | * |
6 | * Copyright (C) 2000 Ani Joshi <ajoshi@unixbox.com> | 6 | * Copyright (C) 2000 Ani Joshi <ajoshi@unixbox.com> |
7 | * Copyright (C) 2000, 2001, 06 Ralf Baechle <ralf@linux-mips.org> | 7 | * Copyright (C) 2000, 2001, 06 Ralf Baechle <ralf@linux-mips.org> |
8 | * swiped from i386, and cloned for MIPS by Geert, polished by Ralf. | 8 | * swiped from i386, and cloned for MIPS by Geert, polished by Ralf. |
9 | */ | 9 | */ |
10 | 10 | ||
diff --git a/arch/mips/mm/fault.c b/arch/mips/mm/fault.c index ddcec1e1a0cd..0fead53d1c26 100644 --- a/arch/mips/mm/fault.c +++ b/arch/mips/mm/fault.c | |||
@@ -52,7 +52,7 @@ asmlinkage void __kprobes do_page_fault(struct pt_regs *regs, unsigned long writ | |||
52 | 52 | ||
53 | #ifdef CONFIG_KPROBES | 53 | #ifdef CONFIG_KPROBES |
54 | /* | 54 | /* |
55 | * This is to notify the fault handler of the kprobes. The | 55 | * This is to notify the fault handler of the kprobes. The |
56 | * exception code is redundant as it is also carried in REGS, | 56 | * exception code is redundant as it is also carried in REGS, |
57 | * but we pass it anyhow. | 57 | * but we pass it anyhow. |
58 | */ | 58 | */ |
@@ -216,7 +216,7 @@ bad_area_nosemaphore: | |||
216 | } | 216 | } |
217 | 217 | ||
218 | no_context: | 218 | no_context: |
219 | /* Are we prepared to handle this kernel fault? */ | 219 | /* Are we prepared to handle this kernel fault? */ |
220 | if (fixup_exception(regs)) { | 220 | if (fixup_exception(regs)) { |
221 | current->thread.cp0_baduaddr = address; | 221 | current->thread.cp0_baduaddr = address; |
222 | return; | 222 | return; |
diff --git a/arch/mips/mm/gup.c b/arch/mips/mm/gup.c index dcfd573871c1..d4ea5c9c4a93 100644 --- a/arch/mips/mm/gup.c +++ b/arch/mips/mm/gup.c | |||
@@ -249,7 +249,7 @@ int __get_user_pages_fast(unsigned long start, int nr_pages, int write, | |||
249 | * @nr_pages: number of pages from start to pin | 249 | * @nr_pages: number of pages from start to pin |
250 | * @write: whether pages will be written to | 250 | * @write: whether pages will be written to |
251 | * @pages: array that receives pointers to the pages pinned. | 251 | * @pages: array that receives pointers to the pages pinned. |
252 | * Should be at least nr_pages long. | 252 | * Should be at least nr_pages long. |
253 | * | 253 | * |
254 | * Attempt to pin user pages in memory without taking mm->mmap_sem. | 254 | * Attempt to pin user pages in memory without taking mm->mmap_sem. |
255 | * If not successful, it will fall back to taking the lock and | 255 | * If not successful, it will fall back to taking the lock and |
diff --git a/arch/mips/mm/init.c b/arch/mips/mm/init.c index be9acb2b959d..67929251286c 100644 --- a/arch/mips/mm/init.c +++ b/arch/mips/mm/init.c | |||
@@ -66,7 +66,7 @@ | |||
66 | 66 | ||
67 | /* | 67 | /* |
68 | * We have up to 8 empty zeroed pages so we can map one of the right colour | 68 | * We have up to 8 empty zeroed pages so we can map one of the right colour |
69 | * when needed. This is necessary only on R4000 / R4400 SC and MC versions | 69 | * when needed. This is necessary only on R4000 / R4400 SC and MC versions |
70 | * where we have to avoid VCED / VECI exceptions for good performance at | 70 | * where we have to avoid VCED / VECI exceptions for good performance at |
71 | * any price. Since page is never written to after the initialization we | 71 | * any price. Since page is never written to after the initialization we |
72 | * don't have to care about aliases on other CPUs. | 72 | * don't have to care about aliases on other CPUs. |
@@ -380,7 +380,7 @@ void __init mem_init(void) | |||
380 | high_memory = (void *) __va(max_low_pfn << PAGE_SHIFT); | 380 | high_memory = (void *) __va(max_low_pfn << PAGE_SHIFT); |
381 | 381 | ||
382 | totalram_pages += free_all_bootmem(); | 382 | totalram_pages += free_all_bootmem(); |
383 | totalram_pages -= setup_zero_pages(); /* Setup zeroed pages. */ | 383 | totalram_pages -= setup_zero_pages(); /* Setup zeroed pages. */ |
384 | 384 | ||
385 | reservedpages = ram = 0; | 385 | reservedpages = ram = 0; |
386 | for (tmp = 0; tmp < max_low_pfn; tmp++) | 386 | for (tmp = 0; tmp < max_low_pfn; tmp++) |
diff --git a/arch/mips/mm/ioremap.c b/arch/mips/mm/ioremap.c index cacfd31e8ec9..7f840bc08abf 100644 --- a/arch/mips/mm/ioremap.c +++ b/arch/mips/mm/ioremap.c | |||
@@ -22,7 +22,7 @@ static inline void remap_area_pte(pte_t * pte, unsigned long address, | |||
22 | phys_t end; | 22 | phys_t end; |
23 | unsigned long pfn; | 23 | unsigned long pfn; |
24 | pgprot_t pgprot = __pgprot(_PAGE_GLOBAL | _PAGE_PRESENT | __READABLE | 24 | pgprot_t pgprot = __pgprot(_PAGE_GLOBAL | _PAGE_PRESENT | __READABLE |
25 | | __WRITEABLE | flags); | 25 | | __WRITEABLE | flags); |
26 | 26 | ||
27 | address &= ~PMD_MASK; | 27 | address &= ~PMD_MASK; |
28 | end = address + size; | 28 | end = address + size; |
@@ -185,7 +185,7 @@ void __iounmap(const volatile void __iomem *addr) | |||
185 | if (!p) | 185 | if (!p) |
186 | printk(KERN_ERR "iounmap: bad address %p\n", addr); | 186 | printk(KERN_ERR "iounmap: bad address %p\n", addr); |
187 | 187 | ||
188 | kfree(p); | 188 | kfree(p); |
189 | } | 189 | } |
190 | 190 | ||
191 | EXPORT_SYMBOL(__ioremap); | 191 | EXPORT_SYMBOL(__ioremap); |
diff --git a/arch/mips/mm/page.c b/arch/mips/mm/page.c index 8e666c55f4d4..a29fba55b53e 100644 --- a/arch/mips/mm/page.c +++ b/arch/mips/mm/page.c | |||
@@ -271,7 +271,7 @@ void __cpuinit build_clear_page(void) | |||
271 | uasm_i_lui(&buf, AT, 0xa000); | 271 | uasm_i_lui(&buf, AT, 0xa000); |
272 | 272 | ||
273 | off = cache_line_size ? min(8, pref_bias_clear_store / cache_line_size) | 273 | off = cache_line_size ? min(8, pref_bias_clear_store / cache_line_size) |
274 | * cache_line_size : 0; | 274 | * cache_line_size : 0; |
275 | while (off) { | 275 | while (off) { |
276 | build_clear_pref(&buf, -off); | 276 | build_clear_pref(&buf, -off); |
277 | off -= cache_line_size; | 277 | off -= cache_line_size; |
@@ -417,13 +417,13 @@ void __cpuinit build_copy_page(void) | |||
417 | uasm_i_lui(&buf, AT, 0xa000); | 417 | uasm_i_lui(&buf, AT, 0xa000); |
418 | 418 | ||
419 | off = cache_line_size ? min(8, pref_bias_copy_load / cache_line_size) * | 419 | off = cache_line_size ? min(8, pref_bias_copy_load / cache_line_size) * |
420 | cache_line_size : 0; | 420 | cache_line_size : 0; |
421 | while (off) { | 421 | while (off) { |
422 | build_copy_load_pref(&buf, -off); | 422 | build_copy_load_pref(&buf, -off); |
423 | off -= cache_line_size; | 423 | off -= cache_line_size; |
424 | } | 424 | } |
425 | off = cache_line_size ? min(8, pref_bias_copy_store / cache_line_size) * | 425 | off = cache_line_size ? min(8, pref_bias_copy_store / cache_line_size) * |
426 | cache_line_size : 0; | 426 | cache_line_size : 0; |
427 | while (off) { | 427 | while (off) { |
428 | build_copy_store_pref(&buf, -off); | 428 | build_copy_store_pref(&buf, -off); |
429 | off -= cache_line_size; | 429 | off -= cache_line_size; |
diff --git a/arch/mips/mm/pgtable-64.c b/arch/mips/mm/pgtable-64.c index ee331bbd8f8a..e8adc0069d66 100644 --- a/arch/mips/mm/pgtable-64.c +++ b/arch/mips/mm/pgtable-64.c | |||
@@ -24,7 +24,7 @@ void pgd_init(unsigned long page) | |||
24 | entry = (unsigned long)invalid_pmd_table; | 24 | entry = (unsigned long)invalid_pmd_table; |
25 | #endif | 25 | #endif |
26 | 26 | ||
27 | p = (unsigned long *) page; | 27 | p = (unsigned long *) page; |
28 | end = p + PTRS_PER_PGD; | 28 | end = p + PTRS_PER_PGD; |
29 | 29 | ||
30 | do { | 30 | do { |
@@ -45,7 +45,7 @@ void pmd_init(unsigned long addr, unsigned long pagetable) | |||
45 | { | 45 | { |
46 | unsigned long *p, *end; | 46 | unsigned long *p, *end; |
47 | 47 | ||
48 | p = (unsigned long *) addr; | 48 | p = (unsigned long *) addr; |
49 | end = p + PTRS_PER_PMD; | 49 | end = p + PTRS_PER_PMD; |
50 | 50 | ||
51 | do { | 51 | do { |
diff --git a/arch/mips/mm/sc-ip22.c b/arch/mips/mm/sc-ip22.c index 1eb708ef75ff..c6aaed934d53 100644 --- a/arch/mips/mm/sc-ip22.c +++ b/arch/mips/mm/sc-ip22.c | |||
@@ -159,7 +159,7 @@ static inline int __init indy_sc_probe(void) | |||
159 | } | 159 | } |
160 | 160 | ||
161 | /* XXX Check with wje if the Indy caches can differenciate between | 161 | /* XXX Check with wje if the Indy caches can differenciate between |
162 | writeback + invalidate and just invalidate. */ | 162 | writeback + invalidate and just invalidate. */ |
163 | static struct bcache_ops indy_sc_ops = { | 163 | static struct bcache_ops indy_sc_ops = { |
164 | .bc_enable = indy_sc_enable, | 164 | .bc_enable = indy_sc_enable, |
165 | .bc_disable = indy_sc_disable, | 165 | .bc_disable = indy_sc_disable, |
diff --git a/arch/mips/mm/sc-r5k.c b/arch/mips/mm/sc-r5k.c index 8d90ff25b123..8bc67720e145 100644 --- a/arch/mips/mm/sc-r5k.c +++ b/arch/mips/mm/sc-r5k.c | |||
@@ -58,7 +58,7 @@ static void r5k_dma_cache_inv_sc(unsigned long addr, unsigned long size) | |||
58 | 58 | ||
59 | static void r5k_sc_enable(void) | 59 | static void r5k_sc_enable(void) |
60 | { | 60 | { |
61 | unsigned long flags; | 61 | unsigned long flags; |
62 | 62 | ||
63 | local_irq_save(flags); | 63 | local_irq_save(flags); |
64 | set_c0_config(R5K_CONF_SE); | 64 | set_c0_config(R5K_CONF_SE); |
@@ -68,7 +68,7 @@ static void r5k_sc_enable(void) | |||
68 | 68 | ||
69 | static void r5k_sc_disable(void) | 69 | static void r5k_sc_disable(void) |
70 | { | 70 | { |
71 | unsigned long flags; | 71 | unsigned long flags; |
72 | 72 | ||
73 | local_irq_save(flags); | 73 | local_irq_save(flags); |
74 | blast_r5000_scache(); | 74 | blast_r5000_scache(); |
diff --git a/arch/mips/mm/tlb-r4k.c b/arch/mips/mm/tlb-r4k.c index 2a7c9725b2a3..493131c81a29 100644 --- a/arch/mips/mm/tlb-r4k.c +++ b/arch/mips/mm/tlb-r4k.c | |||
@@ -424,7 +424,7 @@ void __cpuinit tlb_init(void) | |||
424 | write_c0_pagegrain(pg); | 424 | write_c0_pagegrain(pg); |
425 | } | 425 | } |
426 | 426 | ||
427 | /* From this point on the ARC firmware is dead. */ | 427 | /* From this point on the ARC firmware is dead. */ |
428 | local_flush_tlb_all(); | 428 | local_flush_tlb_all(); |
429 | 429 | ||
430 | /* Did I tell you that ARC SUCKS? */ | 430 | /* Did I tell you that ARC SUCKS? */ |
diff --git a/arch/mips/mm/tlbex.c b/arch/mips/mm/tlbex.c index 1c8ac49ec72c..820e6612d744 100644 --- a/arch/mips/mm/tlbex.c +++ b/arch/mips/mm/tlbex.c | |||
@@ -5,8 +5,8 @@ | |||
5 | * | 5 | * |
6 | * Synthesize TLB refill handlers at runtime. | 6 | * Synthesize TLB refill handlers at runtime. |
7 | * | 7 | * |
8 | * Copyright (C) 2004, 2005, 2006, 2008 Thiemo Seufer | 8 | * Copyright (C) 2004, 2005, 2006, 2008 Thiemo Seufer |
9 | * Copyright (C) 2005, 2007, 2008, 2009 Maciej W. Rozycki | 9 | * Copyright (C) 2005, 2007, 2008, 2009 Maciej W. Rozycki |
10 | * Copyright (C) 2006 Ralf Baechle (ralf@linux-mips.org) | 10 | * Copyright (C) 2006 Ralf Baechle (ralf@linux-mips.org) |
11 | * Copyright (C) 2008, 2009 Cavium Networks, Inc. | 11 | * Copyright (C) 2008, 2009 Cavium Networks, Inc. |
12 | * Copyright (C) 2011 MIPS Technologies, Inc. | 12 | * Copyright (C) 2011 MIPS Technologies, Inc. |
@@ -212,7 +212,7 @@ static void __cpuinit uasm_bgezl_label(struct uasm_label **l, | |||
212 | /* | 212 | /* |
213 | * pgtable bits are assigned dynamically depending on processor feature | 213 | * pgtable bits are assigned dynamically depending on processor feature |
214 | * and statically based on kernel configuration. This spits out the actual | 214 | * and statically based on kernel configuration. This spits out the actual |
215 | * values the kernel is using. Required to make sense from disassembled | 215 | * values the kernel is using. Required to make sense from disassembled |
216 | * TLB exception handlers. | 216 | * TLB exception handlers. |
217 | */ | 217 | */ |
218 | static void output_pgtable_bits_defines(void) | 218 | static void output_pgtable_bits_defines(void) |
@@ -464,8 +464,8 @@ static u32 final_handler[64] __cpuinitdata; | |||
464 | * From the IDT errata for the QED RM5230 (Nevada), processor revision 1.0: | 464 | * From the IDT errata for the QED RM5230 (Nevada), processor revision 1.0: |
465 | * 2. A timing hazard exists for the TLBP instruction. | 465 | * 2. A timing hazard exists for the TLBP instruction. |
466 | * | 466 | * |
467 | * stalling_instruction | 467 | * stalling_instruction |
468 | * TLBP | 468 | * TLBP |
469 | * | 469 | * |
470 | * The JTLB is being read for the TLBP throughout the stall generated by the | 470 | * The JTLB is being read for the TLBP throughout the stall generated by the |
471 | * previous instruction. This is not really correct as the stalling instruction | 471 | * previous instruction. This is not really correct as the stalling instruction |
@@ -476,7 +476,7 @@ static u32 final_handler[64] __cpuinitdata; | |||
476 | * The software work-around is to not allow the instruction preceding the TLBP | 476 | * The software work-around is to not allow the instruction preceding the TLBP |
477 | * to stall - make it an NOP or some other instruction guaranteed not to stall. | 477 | * to stall - make it an NOP or some other instruction guaranteed not to stall. |
478 | * | 478 | * |
479 | * Errata 2 will not be fixed. This errata is also on the R5000. | 479 | * Errata 2 will not be fixed. This errata is also on the R5000. |
480 | * | 480 | * |
481 | * As if we MIPS hackers wouldn't know how to nop pipelines happy ... | 481 | * As if we MIPS hackers wouldn't know how to nop pipelines happy ... |
482 | */ | 482 | */ |
@@ -581,6 +581,7 @@ static void __cpuinit build_tlb_write_entry(u32 **p, struct uasm_label **l, | |||
581 | case CPU_4KC: | 581 | case CPU_4KC: |
582 | case CPU_4KEC: | 582 | case CPU_4KEC: |
583 | case CPU_M14KC: | 583 | case CPU_M14KC: |
584 | case CPU_M14KEC: | ||
584 | case CPU_SB1: | 585 | case CPU_SB1: |
585 | case CPU_SB1A: | 586 | case CPU_SB1A: |
586 | case CPU_4KSC: | 587 | case CPU_4KSC: |
@@ -748,7 +749,7 @@ static __cpuinit void build_huge_update_entries(u32 **p, | |||
748 | */ | 749 | */ |
749 | small_sequence = (HPAGE_SIZE >> 7) < 0x10000; | 750 | small_sequence = (HPAGE_SIZE >> 7) < 0x10000; |
750 | 751 | ||
751 | /* We can clobber tmp. It isn't used after this.*/ | 752 | /* We can clobber tmp. It isn't used after this.*/ |
752 | if (!small_sequence) | 753 | if (!small_sequence) |
753 | uasm_i_lui(p, tmp, HPAGE_SIZE >> (7 + 16)); | 754 | uasm_i_lui(p, tmp, HPAGE_SIZE >> (7 + 16)); |
754 | 755 | ||
@@ -830,12 +831,12 @@ build_get_pmde64(u32 **p, struct uasm_label **l, struct uasm_reloc **r, | |||
830 | /* Clear lower 23 bits of context. */ | 831 | /* Clear lower 23 bits of context. */ |
831 | uasm_i_dins(p, ptr, 0, 0, 23); | 832 | uasm_i_dins(p, ptr, 0, 0, 23); |
832 | 833 | ||
833 | /* 1 0 1 0 1 << 6 xkphys cached */ | 834 | /* 1 0 1 0 1 << 6 xkphys cached */ |
834 | uasm_i_ori(p, ptr, ptr, 0x540); | 835 | uasm_i_ori(p, ptr, ptr, 0x540); |
835 | uasm_i_drotr(p, ptr, ptr, 11); | 836 | uasm_i_drotr(p, ptr, ptr, 11); |
836 | } | 837 | } |
837 | #elif defined(CONFIG_SMP) | 838 | #elif defined(CONFIG_SMP) |
838 | # ifdef CONFIG_MIPS_MT_SMTC | 839 | # ifdef CONFIG_MIPS_MT_SMTC |
839 | /* | 840 | /* |
840 | * SMTC uses TCBind value as "CPU" index | 841 | * SMTC uses TCBind value as "CPU" index |
841 | */ | 842 | */ |
@@ -955,7 +956,7 @@ build_get_pgde32(u32 **p, unsigned int tmp, unsigned int ptr) | |||
955 | 956 | ||
956 | /* 32 bit SMP has smp_processor_id() stored in CONTEXT. */ | 957 | /* 32 bit SMP has smp_processor_id() stored in CONTEXT. */ |
957 | #ifdef CONFIG_SMP | 958 | #ifdef CONFIG_SMP |
958 | #ifdef CONFIG_MIPS_MT_SMTC | 959 | #ifdef CONFIG_MIPS_MT_SMTC |
959 | /* | 960 | /* |
960 | * SMTC uses TCBind value as "CPU" index | 961 | * SMTC uses TCBind value as "CPU" index |
961 | */ | 962 | */ |
@@ -965,7 +966,7 @@ build_get_pgde32(u32 **p, unsigned int tmp, unsigned int ptr) | |||
965 | #else | 966 | #else |
966 | /* | 967 | /* |
967 | * smp_processor_id() << 3 is stored in CONTEXT. | 968 | * smp_processor_id() << 3 is stored in CONTEXT. |
968 | */ | 969 | */ |
969 | uasm_i_mfc0(p, ptr, C0_CONTEXT); | 970 | uasm_i_mfc0(p, ptr, C0_CONTEXT); |
970 | UASM_i_LA_mostly(p, tmp, pgdc); | 971 | UASM_i_LA_mostly(p, tmp, pgdc); |
971 | uasm_i_srl(p, ptr, ptr, 23); | 972 | uasm_i_srl(p, ptr, ptr, 23); |
@@ -1153,7 +1154,7 @@ build_fast_tlb_refill_handler (u32 **p, struct uasm_label **l, | |||
1153 | 1154 | ||
1154 | if (pgd_reg == -1) { | 1155 | if (pgd_reg == -1) { |
1155 | vmalloc_branch_delay_filled = 1; | 1156 | vmalloc_branch_delay_filled = 1; |
1156 | /* 1 0 1 0 1 << 6 xkphys cached */ | 1157 | /* 1 0 1 0 1 << 6 xkphys cached */ |
1157 | uasm_i_ori(p, ptr, ptr, 0x540); | 1158 | uasm_i_ori(p, ptr, ptr, 0x540); |
1158 | uasm_i_drotr(p, ptr, ptr, 11); | 1159 | uasm_i_drotr(p, ptr, ptr, 11); |
1159 | } | 1160 | } |
@@ -1171,9 +1172,9 @@ build_fast_tlb_refill_handler (u32 **p, struct uasm_label **l, | |||
1171 | uasm_l_vmalloc_done(l, *p); | 1172 | uasm_l_vmalloc_done(l, *p); |
1172 | 1173 | ||
1173 | /* | 1174 | /* |
1174 | * tmp ptr | 1175 | * tmp ptr |
1175 | * fall-through case = badvaddr *pgd_current | 1176 | * fall-through case = badvaddr *pgd_current |
1176 | * vmalloc case = badvaddr swapper_pg_dir | 1177 | * vmalloc case = badvaddr swapper_pg_dir |
1177 | */ | 1178 | */ |
1178 | 1179 | ||
1179 | if (vmalloc_branch_delay_filled) | 1180 | if (vmalloc_branch_delay_filled) |
@@ -1212,7 +1213,7 @@ build_fast_tlb_refill_handler (u32 **p, struct uasm_label **l, | |||
1212 | uasm_il_bbit1(p, r, scratch, ilog2(_PAGE_HUGE), label_tlb_huge_update); | 1213 | uasm_il_bbit1(p, r, scratch, ilog2(_PAGE_HUGE), label_tlb_huge_update); |
1213 | /* | 1214 | /* |
1214 | * The in the LWX case we don't want to do the load in the | 1215 | * The in the LWX case we don't want to do the load in the |
1215 | * delay slot. It cannot issue in the same cycle and may be | 1216 | * delay slot. It cannot issue in the same cycle and may be |
1216 | * speculative and unneeded. | 1217 | * speculative and unneeded. |
1217 | */ | 1218 | */ |
1218 | if (use_lwx_insns()) | 1219 | if (use_lwx_insns()) |
diff --git a/arch/mips/mm/uasm.c b/arch/mips/mm/uasm.c index 39b891056227..942ff6c2eba2 100644 --- a/arch/mips/mm/uasm.c +++ b/arch/mips/mm/uasm.c | |||
@@ -7,7 +7,7 @@ | |||
7 | * support a subset of instructions, and does not try to hide pipeline | 7 | * support a subset of instructions, and does not try to hide pipeline |
8 | * effects like branch delay slots. | 8 | * effects like branch delay slots. |
9 | * | 9 | * |
10 | * Copyright (C) 2004, 2005, 2006, 2008 Thiemo Seufer | 10 | * Copyright (C) 2004, 2005, 2006, 2008 Thiemo Seufer |
11 | * Copyright (C) 2005, 2007 Maciej W. Rozycki | 11 | * Copyright (C) 2005, 2007 Maciej W. Rozycki |
12 | * Copyright (C) 2006 Ralf Baechle (ralf@linux-mips.org) | 12 | * Copyright (C) 2006 Ralf Baechle (ralf@linux-mips.org) |
13 | */ | 13 | */ |
@@ -119,30 +119,30 @@ static struct insn insn_table[] __uasminitdata = { | |||
119 | { insn_ext, M(spec3_op, 0, 0, 0, 0, ext_op), RS | RT | RD | RE }, | 119 | { insn_ext, M(spec3_op, 0, 0, 0, 0, ext_op), RS | RT | RD | RE }, |
120 | { insn_ins, M(spec3_op, 0, 0, 0, 0, ins_op), RS | RT | RD | RE }, | 120 | { insn_ins, M(spec3_op, 0, 0, 0, 0, ins_op), RS | RT | RD | RE }, |
121 | { insn_j, M(j_op, 0, 0, 0, 0, 0), JIMM }, | 121 | { insn_j, M(j_op, 0, 0, 0, 0, 0), JIMM }, |
122 | { insn_jal, M(jal_op, 0, 0, 0, 0, 0), JIMM }, | 122 | { insn_jal, M(jal_op, 0, 0, 0, 0, 0), JIMM }, |
123 | { insn_j, M(j_op, 0, 0, 0, 0, 0), JIMM }, | 123 | { insn_j, M(j_op, 0, 0, 0, 0, 0), JIMM }, |
124 | { insn_jr, M(spec_op, 0, 0, 0, 0, jr_op), RS }, | 124 | { insn_jr, M(spec_op, 0, 0, 0, 0, jr_op), RS }, |
125 | { insn_ld, M(ld_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 125 | { insn_ld, M(ld_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
126 | { insn_ldx, M(spec3_op, 0, 0, 0, ldx_op, lx_op), RS | RT | RD }, | 126 | { insn_ldx, M(spec3_op, 0, 0, 0, ldx_op, lx_op), RS | RT | RD }, |
127 | { insn_lld, M(lld_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 127 | { insn_lld, M(lld_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
128 | { insn_ll, M(ll_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 128 | { insn_ll, M(ll_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
129 | { insn_lui, M(lui_op, 0, 0, 0, 0, 0), RT | SIMM }, | 129 | { insn_lui, M(lui_op, 0, 0, 0, 0, 0), RT | SIMM }, |
130 | { insn_lw, M(lw_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 130 | { insn_lw, M(lw_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
131 | { insn_lwx, M(spec3_op, 0, 0, 0, lwx_op, lx_op), RS | RT | RD }, | 131 | { insn_lwx, M(spec3_op, 0, 0, 0, lwx_op, lx_op), RS | RT | RD }, |
132 | { insn_mfc0, M(cop0_op, mfc_op, 0, 0, 0, 0), RT | RD | SET}, | 132 | { insn_mfc0, M(cop0_op, mfc_op, 0, 0, 0, 0), RT | RD | SET}, |
133 | { insn_mtc0, M(cop0_op, mtc_op, 0, 0, 0, 0), RT | RD | SET}, | 133 | { insn_mtc0, M(cop0_op, mtc_op, 0, 0, 0, 0), RT | RD | SET}, |
134 | { insn_ori, M(ori_op, 0, 0, 0, 0, 0), RS | RT | UIMM }, | 134 | { insn_ori, M(ori_op, 0, 0, 0, 0, 0), RS | RT | UIMM }, |
135 | { insn_or, M(spec_op, 0, 0, 0, 0, or_op), RS | RT | RD }, | 135 | { insn_or, M(spec_op, 0, 0, 0, 0, or_op), RS | RT | RD }, |
136 | { insn_pref, M(pref_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 136 | { insn_pref, M(pref_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
137 | { insn_rfe, M(cop0_op, cop_op, 0, 0, 0, rfe_op), 0 }, | 137 | { insn_rfe, M(cop0_op, cop_op, 0, 0, 0, rfe_op), 0 }, |
138 | { insn_rotr, M(spec_op, 1, 0, 0, 0, srl_op), RT | RD | RE }, | 138 | { insn_rotr, M(spec_op, 1, 0, 0, 0, srl_op), RT | RD | RE }, |
139 | { insn_scd, M(scd_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 139 | { insn_scd, M(scd_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
140 | { insn_sc, M(sc_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 140 | { insn_sc, M(sc_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
141 | { insn_sd, M(sd_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 141 | { insn_sd, M(sd_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
142 | { insn_sll, M(spec_op, 0, 0, 0, 0, sll_op), RT | RD | RE }, | 142 | { insn_sll, M(spec_op, 0, 0, 0, 0, sll_op), RT | RD | RE }, |
143 | { insn_sra, M(spec_op, 0, 0, 0, 0, sra_op), RT | RD | RE }, | 143 | { insn_sra, M(spec_op, 0, 0, 0, 0, sra_op), RT | RD | RE }, |
144 | { insn_srl, M(spec_op, 0, 0, 0, 0, srl_op), RT | RD | RE }, | 144 | { insn_srl, M(spec_op, 0, 0, 0, 0, srl_op), RT | RD | RE }, |
145 | { insn_subu, M(spec_op, 0, 0, 0, 0, subu_op), RS | RT | RD }, | 145 | { insn_subu, M(spec_op, 0, 0, 0, 0, subu_op), RS | RT | RD }, |
146 | { insn_sw, M(sw_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, | 146 | { insn_sw, M(sw_op, 0, 0, 0, 0, 0), RS | RT | SIMM }, |
147 | { insn_syscall, M(spec_op, 0, 0, 0, 0, syscall_op), SCIMM}, | 147 | { insn_syscall, M(spec_op, 0, 0, 0, 0, syscall_op), SCIMM}, |
148 | { insn_tlbp, M(cop0_op, cop_op, 0, 0, 0, tlbp_op), 0 }, | 148 | { insn_tlbp, M(cop0_op, cop_op, 0, 0, 0, tlbp_op), 0 }, |
@@ -345,7 +345,7 @@ Ip_u2u1msbu3(op) \ | |||
345 | } \ | 345 | } \ |
346 | UASM_EXPORT_SYMBOL(uasm_i##op); | 346 | UASM_EXPORT_SYMBOL(uasm_i##op); |
347 | 347 | ||
348 | #define I_u2u1msbdu3(op) \ | 348 | #define I_u2u1msbdu3(op) \ |
349 | Ip_u2u1msbu3(op) \ | 349 | Ip_u2u1msbu3(op) \ |
350 | { \ | 350 | { \ |
351 | build_insn(buf, insn##op, b, a, d-1, c); \ | 351 | build_insn(buf, insn##op, b, a, d-1, c); \ |