|
@@ -12,8 +12,9 @@
|
|
|
#include <linux/linkage.h>
|
|
|
#include <asm/assembler.h>
|
|
|
#include <asm/asm-offsets.h>
|
|
|
+#include <asm/cache.h>
|
|
|
|
|
|
-#define COPY_COUNT (PAGE_SZ/64 PLD( -1 ))
|
|
|
+#define COPY_COUNT (PAGE_SZ / (2 * L1_CACHE_BYTES) PLD( -1 ))
|
|
|
|
|
|
.text
|
|
|
.align 5
|
|
@@ -26,17 +27,16 @@
|
|
|
ENTRY(copy_page)
|
|
|
stmfd sp!, {r4, lr} @ 2
|
|
|
PLD( pld [r1, #0] )
|
|
|
- PLD( pld [r1, #32] )
|
|
|
+ PLD( pld [r1, #L1_CACHE_BYTES] )
|
|
|
mov r2, #COPY_COUNT @ 1
|
|
|
ldmia r1!, {r3, r4, ip, lr} @ 4+1
|
|
|
-1: PLD( pld [r1, #64] )
|
|
|
- PLD( pld [r1, #96] )
|
|
|
-2: stmia r0!, {r3, r4, ip, lr} @ 4
|
|
|
- ldmia r1!, {r3, r4, ip, lr} @ 4+1
|
|
|
- stmia r0!, {r3, r4, ip, lr} @ 4
|
|
|
- ldmia r1!, {r3, r4, ip, lr} @ 4+1
|
|
|
+1: PLD( pld [r1, #2 * L1_CACHE_BYTES])
|
|
|
+ PLD( pld [r1, #3 * L1_CACHE_BYTES])
|
|
|
+2:
|
|
|
+ .rept (2 * L1_CACHE_BYTES / 16 - 1)
|
|
|
stmia r0!, {r3, r4, ip, lr} @ 4
|
|
|
ldmia r1!, {r3, r4, ip, lr} @ 4
|
|
|
+ .endr
|
|
|
subs r2, r2, #1 @ 1
|
|
|
stmia r0!, {r3, r4, ip, lr} @ 4
|
|
|
ldmgtia r1!, {r3, r4, ip, lr} @ 4
|