aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul Mundt <lethal@linux-sh.org>2009-08-04 05:06:01 -0400
committerPaul Mundt <lethal@linux-sh.org>2009-08-04 05:06:01 -0400
commit817425275271f2514f0dc6952182aa057ce80973 (patch)
tree09c32a42c4700bc0cf7ea31a232a17c45d1e0824
parentd14d751ff9234595639a16e53b3cf0c575946bde (diff)
sh: Split out SH-4 __flush_xxx_region() ops.
This splits out the SH-4 __flush_xxx_region() functions and defines them as weak symbols. This allows us to provide optimized versions without having to ifdef cache-sh4.c to death. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
-rw-r--r--arch/sh/mm/Makefile_322
-rw-r--r--arch/sh/mm/cache-sh4.c60
-rw-r--r--arch/sh/mm/flush-sh4.c63
3 files changed, 64 insertions, 61 deletions
diff --git a/arch/sh/mm/Makefile_32 b/arch/sh/mm/Makefile_32
index 62e280734dc..17b02522214 100644
--- a/arch/sh/mm/Makefile_32
+++ b/arch/sh/mm/Makefile_32
@@ -8,7 +8,7 @@ ifndef CONFIG_CACHE_OFF
8cache-$(CONFIG_CPU_SH2) := cache-sh2.o 8cache-$(CONFIG_CPU_SH2) := cache-sh2.o
9cache-$(CONFIG_CPU_SH2A) := cache-sh2a.o 9cache-$(CONFIG_CPU_SH2A) := cache-sh2a.o
10cache-$(CONFIG_CPU_SH3) := cache-sh3.o 10cache-$(CONFIG_CPU_SH3) := cache-sh3.o
11cache-$(CONFIG_CPU_SH4) := cache-sh4.o 11cache-$(CONFIG_CPU_SH4) := cache-sh4.o flush-sh4.o
12cache-$(CONFIG_SH7705_CACHE_32KB) += cache-sh7705.o 12cache-$(CONFIG_SH7705_CACHE_32KB) += cache-sh7705.o
13endif 13endif
14 14
diff --git a/arch/sh/mm/cache-sh4.c b/arch/sh/mm/cache-sh4.c
index c3a09b27f8d..dfc1d037947 100644
--- a/arch/sh/mm/cache-sh4.c
+++ b/arch/sh/mm/cache-sh4.c
@@ -119,66 +119,6 @@ void __init p3_cache_init(void)
119} 119}
120 120
121/* 121/*
122 * Write back the dirty D-caches, but not invalidate them.
123 *
124 * START: Virtual Address (U0, P1, or P3)
125 * SIZE: Size of the region.
126 */
127void __flush_wback_region(void *start, int size)
128{
129 unsigned long v;
130 unsigned long begin, end;
131
132 begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
133 end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
134 & ~(L1_CACHE_BYTES-1);
135 for (v = begin; v < end; v+=L1_CACHE_BYTES) {
136 asm volatile("ocbwb %0"
137 : /* no output */
138 : "m" (__m(v)));
139 }
140}
141
142/*
143 * Write back the dirty D-caches and invalidate them.
144 *
145 * START: Virtual Address (U0, P1, or P3)
146 * SIZE: Size of the region.
147 */
148void __flush_purge_region(void *start, int size)
149{
150 unsigned long v;
151 unsigned long begin, end;
152
153 begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
154 end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
155 & ~(L1_CACHE_BYTES-1);
156 for (v = begin; v < end; v+=L1_CACHE_BYTES) {
157 asm volatile("ocbp %0"
158 : /* no output */
159 : "m" (__m(v)));
160 }
161}
162
163/*
164 * No write back please
165 */
166void __flush_invalidate_region(void *start, int size)
167{
168 unsigned long v;
169 unsigned long begin, end;
170
171 begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
172 end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
173 & ~(L1_CACHE_BYTES-1);
174 for (v = begin; v < end; v+=L1_CACHE_BYTES) {
175 asm volatile("ocbi %0"
176 : /* no output */
177 : "m" (__m(v)));
178 }
179}
180
181/*
182 * Write back the range of D-cache, and purge the I-cache. 122 * Write back the range of D-cache, and purge the I-cache.
183 * 123 *
184 * Called from kernel/module.c:sys_init_module and routine for a.out format, 124 * Called from kernel/module.c:sys_init_module and routine for a.out format,
diff --git a/arch/sh/mm/flush-sh4.c b/arch/sh/mm/flush-sh4.c
new file mode 100644
index 00000000000..e6d918f6ec0
--- /dev/null
+++ b/arch/sh/mm/flush-sh4.c
@@ -0,0 +1,63 @@
1#include <linux/mm.h>
2#include <asm/mmu_context.h>
3#include <asm/cacheflush.h>
4
5/*
6 * Write back the dirty D-caches, but not invalidate them.
7 *
8 * START: Virtual Address (U0, P1, or P3)
9 * SIZE: Size of the region.
10 */
11void __weak __flush_wback_region(void *start, int size)
12{
13 unsigned long v;
14 unsigned long begin, end;
15
16 begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
17 end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
18 & ~(L1_CACHE_BYTES-1);
19 for (v = begin; v < end; v+=L1_CACHE_BYTES) {
20 asm volatile("ocbwb %0"
21 : /* no output */
22 : "m" (__m(v)));
23 }
24}
25
26/*
27 * Write back the dirty D-caches and invalidate them.
28 *
29 * START: Virtual Address (U0, P1, or P3)
30 * SIZE: Size of the region.
31 */
32void __weak __flush_purge_region(void *start, int size)
33{
34 unsigned long v;
35 unsigned long begin, end;
36
37 begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
38 end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
39 & ~(L1_CACHE_BYTES-1);
40 for (v = begin; v < end; v+=L1_CACHE_BYTES) {
41 asm volatile("ocbp %0"
42 : /* no output */
43 : "m" (__m(v)));
44 }
45}
46
47/*
48 * No write back please
49 */
50void __weak __flush_invalidate_region(void *start, int size)
51{
52 unsigned long v;
53 unsigned long begin, end;
54
55 begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
56 end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
57 & ~(L1_CACHE_BYTES-1);
58 for (v = begin; v < end; v+=L1_CACHE_BYTES) {
59 asm volatile("ocbi %0"
60 : /* no output */
61 : "m" (__m(v)));
62 }
63}