blob: cef402678f42b77728b749530387ce8f45267d50 [file] [log] [blame]
Paul Mundt81742522009-08-04 18:06:01 +09001#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 */
Paul Mundt37443ef2009-08-15 12:29:49 +090011static void sh4__flush_wback_region(void *start, int size)
Paul Mundt81742522009-08-04 18:06:01 +090012{
Paul Mundt43bc61d2009-08-15 01:57:36 +090013 reg_size_t aligned_start, v, cnt, end;
Paul Mundt81742522009-08-04 18:06:01 +090014
Paul Mundt43bc61d2009-08-15 01:57:36 +090015 aligned_start = register_align(start);
16 v = aligned_start & ~(L1_CACHE_BYTES-1);
17 end = (aligned_start + size + L1_CACHE_BYTES-1)
Paul Mundt81742522009-08-04 18:06:01 +090018 & ~(L1_CACHE_BYTES-1);
Paul Mundt0837f522009-08-04 18:09:54 +090019 cnt = (end - v) / L1_CACHE_BYTES;
20
21 while (cnt >= 8) {
Paul Mundt94ecd222009-08-16 01:50:17 +090022 __ocbwb(v); v += L1_CACHE_BYTES;
23 __ocbwb(v); v += L1_CACHE_BYTES;
24 __ocbwb(v); v += L1_CACHE_BYTES;
25 __ocbwb(v); v += L1_CACHE_BYTES;
26 __ocbwb(v); v += L1_CACHE_BYTES;
27 __ocbwb(v); v += L1_CACHE_BYTES;
28 __ocbwb(v); v += L1_CACHE_BYTES;
29 __ocbwb(v); v += L1_CACHE_BYTES;
Paul Mundt0837f522009-08-04 18:09:54 +090030 cnt -= 8;
31 }
32
33 while (cnt) {
Paul Mundt94ecd222009-08-16 01:50:17 +090034 __ocbwb(v); v += L1_CACHE_BYTES;
Paul Mundt0837f522009-08-04 18:09:54 +090035 cnt--;
Paul Mundt81742522009-08-04 18:06:01 +090036 }
37}
38
39/*
40 * Write back the dirty D-caches and invalidate them.
41 *
42 * START: Virtual Address (U0, P1, or P3)
43 * SIZE: Size of the region.
44 */
Paul Mundt37443ef2009-08-15 12:29:49 +090045static void sh4__flush_purge_region(void *start, int size)
Paul Mundt81742522009-08-04 18:06:01 +090046{
Paul Mundt43bc61d2009-08-15 01:57:36 +090047 reg_size_t aligned_start, v, cnt, end;
Paul Mundt81742522009-08-04 18:06:01 +090048
Paul Mundt43bc61d2009-08-15 01:57:36 +090049 aligned_start = register_align(start);
50 v = aligned_start & ~(L1_CACHE_BYTES-1);
51 end = (aligned_start + size + L1_CACHE_BYTES-1)
Paul Mundt81742522009-08-04 18:06:01 +090052 & ~(L1_CACHE_BYTES-1);
Paul Mundt0837f522009-08-04 18:09:54 +090053 cnt = (end - v) / L1_CACHE_BYTES;
54
55 while (cnt >= 8) {
Paul Mundt94ecd222009-08-16 01:50:17 +090056 __ocbp(v); v += L1_CACHE_BYTES;
57 __ocbp(v); v += L1_CACHE_BYTES;
58 __ocbp(v); v += L1_CACHE_BYTES;
59 __ocbp(v); v += L1_CACHE_BYTES;
60 __ocbp(v); v += L1_CACHE_BYTES;
61 __ocbp(v); v += L1_CACHE_BYTES;
62 __ocbp(v); v += L1_CACHE_BYTES;
63 __ocbp(v); v += L1_CACHE_BYTES;
Paul Mundt0837f522009-08-04 18:09:54 +090064 cnt -= 8;
65 }
66 while (cnt) {
Paul Mundt94ecd222009-08-16 01:50:17 +090067 __ocbp(v); v += L1_CACHE_BYTES;
Paul Mundt0837f522009-08-04 18:09:54 +090068 cnt--;
Paul Mundt81742522009-08-04 18:06:01 +090069 }
70}
71
72/*
73 * No write back please
74 */
Paul Mundt37443ef2009-08-15 12:29:49 +090075static void sh4__flush_invalidate_region(void *start, int size)
Paul Mundt81742522009-08-04 18:06:01 +090076{
Paul Mundt43bc61d2009-08-15 01:57:36 +090077 reg_size_t aligned_start, v, cnt, end;
Paul Mundt81742522009-08-04 18:06:01 +090078
Paul Mundt43bc61d2009-08-15 01:57:36 +090079 aligned_start = register_align(start);
80 v = aligned_start & ~(L1_CACHE_BYTES-1);
81 end = (aligned_start + size + L1_CACHE_BYTES-1)
Paul Mundt81742522009-08-04 18:06:01 +090082 & ~(L1_CACHE_BYTES-1);
Paul Mundt0837f522009-08-04 18:09:54 +090083 cnt = (end - v) / L1_CACHE_BYTES;
84
85 while (cnt >= 8) {
Paul Mundt94ecd222009-08-16 01:50:17 +090086 __ocbi(v); v += L1_CACHE_BYTES;
87 __ocbi(v); v += L1_CACHE_BYTES;
88 __ocbi(v); v += L1_CACHE_BYTES;
89 __ocbi(v); v += L1_CACHE_BYTES;
90 __ocbi(v); v += L1_CACHE_BYTES;
91 __ocbi(v); v += L1_CACHE_BYTES;
92 __ocbi(v); v += L1_CACHE_BYTES;
93 __ocbi(v); v += L1_CACHE_BYTES;
Paul Mundt0837f522009-08-04 18:09:54 +090094 cnt -= 8;
95 }
96
97 while (cnt) {
Paul Mundt94ecd222009-08-16 01:50:17 +090098 __ocbi(v); v += L1_CACHE_BYTES;
Paul Mundt0837f522009-08-04 18:09:54 +090099 cnt--;
Paul Mundt81742522009-08-04 18:06:01 +0900100 }
101}
Paul Mundt37443ef2009-08-15 12:29:49 +0900102
103void __init sh4__flush_region_init(void)
104{
105 __flush_wback_region = sh4__flush_wback_region;
106 __flush_invalidate_region = sh4__flush_invalidate_region;
107 __flush_purge_region = sh4__flush_purge_region;
108}