mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-02 23:30:04 +00:00
sh: Partially unroll the SH-4 __flush_xxx_region() flushers.
This does a bit of unrolling for the SH-4 region flushers. Based on an earlier patch by SUGIOKA Toshinobu. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
This commit is contained in:
parent
8174252752
commit
0837f52463
@ -10,16 +10,37 @@
|
|||||||
*/
|
*/
|
||||||
void __weak __flush_wback_region(void *start, int size)
|
void __weak __flush_wback_region(void *start, int size)
|
||||||
{
|
{
|
||||||
unsigned long v;
|
unsigned long v, cnt, end;
|
||||||
unsigned long begin, end;
|
|
||||||
|
|
||||||
begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
|
v = (unsigned long)start & ~(L1_CACHE_BYTES-1);
|
||||||
end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
|
end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
|
||||||
& ~(L1_CACHE_BYTES-1);
|
& ~(L1_CACHE_BYTES-1);
|
||||||
for (v = begin; v < end; v+=L1_CACHE_BYTES) {
|
cnt = (end - v) / L1_CACHE_BYTES;
|
||||||
asm volatile("ocbwb %0"
|
|
||||||
: /* no output */
|
while (cnt >= 8) {
|
||||||
: "m" (__m(v)));
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
cnt -= 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (cnt) {
|
||||||
|
asm volatile("ocbwb @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
cnt--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -31,16 +52,36 @@ void __weak __flush_wback_region(void *start, int size)
|
|||||||
*/
|
*/
|
||||||
void __weak __flush_purge_region(void *start, int size)
|
void __weak __flush_purge_region(void *start, int size)
|
||||||
{
|
{
|
||||||
unsigned long v;
|
unsigned long v, cnt, end;
|
||||||
unsigned long begin, end;
|
|
||||||
|
|
||||||
begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
|
v = (unsigned long)start & ~(L1_CACHE_BYTES-1);
|
||||||
end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
|
end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
|
||||||
& ~(L1_CACHE_BYTES-1);
|
& ~(L1_CACHE_BYTES-1);
|
||||||
for (v = begin; v < end; v+=L1_CACHE_BYTES) {
|
cnt = (end - v) / L1_CACHE_BYTES;
|
||||||
asm volatile("ocbp %0"
|
|
||||||
: /* no output */
|
while (cnt >= 8) {
|
||||||
: "m" (__m(v)));
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
cnt -= 8;
|
||||||
|
}
|
||||||
|
while (cnt) {
|
||||||
|
asm volatile("ocbp @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
cnt--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -49,15 +90,36 @@ void __weak __flush_purge_region(void *start, int size)
|
|||||||
*/
|
*/
|
||||||
void __weak __flush_invalidate_region(void *start, int size)
|
void __weak __flush_invalidate_region(void *start, int size)
|
||||||
{
|
{
|
||||||
unsigned long v;
|
unsigned long v, cnt, end;
|
||||||
unsigned long begin, end;
|
|
||||||
|
|
||||||
begin = (unsigned long)start & ~(L1_CACHE_BYTES-1);
|
v = (unsigned long)start & ~(L1_CACHE_BYTES-1);
|
||||||
end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
|
end = ((unsigned long)start + size + L1_CACHE_BYTES-1)
|
||||||
& ~(L1_CACHE_BYTES-1);
|
& ~(L1_CACHE_BYTES-1);
|
||||||
for (v = begin; v < end; v+=L1_CACHE_BYTES) {
|
cnt = (end - v) / L1_CACHE_BYTES;
|
||||||
asm volatile("ocbi %0"
|
|
||||||
: /* no output */
|
while (cnt >= 8) {
|
||||||
: "m" (__m(v)));
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
cnt -= 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (cnt) {
|
||||||
|
asm volatile("ocbi @%0" : : "r" (v));
|
||||||
|
v += L1_CACHE_BYTES;
|
||||||
|
cnt--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user