|
@@ -171,6 +171,87 @@ cpu_v7_name:
|
|
|
.ascii "ARMv7 Processor"
|
|
|
.align
|
|
|
|
|
|
+ /*
|
|
|
+ * Memory region attributes with SCTLR.TRE=1
|
|
|
+ *
|
|
|
+ * n = TEX[0],C,B
|
|
|
+ * TR = PRRR[2n+1:2n] - memory type
|
|
|
+ * IR = NMRR[2n+1:2n] - inner cacheable property
|
|
|
+ * OR = NMRR[2n+17:2n+16] - outer cacheable property
|
|
|
+ *
|
|
|
+ * n TR IR OR
|
|
|
+ * UNCACHED 000 00
|
|
|
+ * BUFFERABLE 001 10 00 00
|
|
|
+ * WRITETHROUGH 010 10 10 10
|
|
|
+ * WRITEBACK 011 10 11 11
|
|
|
+ * reserved 110
|
|
|
+ * WRITEALLOC 111 10 01 01
|
|
|
+ * DEV_SHARED 100 01
|
|
|
+ * DEV_NONSHARED 100 01
|
|
|
+ * DEV_WC 001 10
|
|
|
+ * DEV_CACHED 011 10
|
|
|
+ *
|
|
|
+ * Other attributes:
|
|
|
+ *
|
|
|
+ * DS0 = PRRR[16] = 0 - device shareable property
|
|
|
+ * DS1 = PRRR[17] = 1 - device shareable property
|
|
|
+ * NS0 = PRRR[18] = 0 - normal shareable property
|
|
|
+ * NS1 = PRRR[19] = 1 - normal shareable property
|
|
|
+ * NOS = PRRR[24+n] = 1 - not outer shareable
|
|
|
+ */
|
|
|
+.equ PRRR, 0xff0a81a8
|
|
|
+.equ NMRR, 0x40e040e0
|
|
|
+
|
|
|
+/* Suspend/resume support: derived from arch/arm/mach-s5pv210/sleep.S */
|
|
|
+.globl cpu_v7_suspend_size
|
|
|
+.equ cpu_v7_suspend_size, 4 * 8
|
|
|
+#ifdef CONFIG_PM
|
|
|
+ENTRY(cpu_v7_do_suspend)
|
|
|
+ stmfd sp!, {r4 - r11, lr}
|
|
|
+ mrc p15, 0, r4, c13, c0, 0 @ FCSE/PID
|
|
|
+ mrc p15, 0, r5, c13, c0, 1 @ Context ID
|
|
|
+ mrc p15, 0, r6, c3, c0, 0 @ Domain ID
|
|
|
+ mrc p15, 0, r7, c2, c0, 0 @ TTB 0
|
|
|
+ mrc p15, 0, r8, c2, c0, 1 @ TTB 1
|
|
|
+ mrc p15, 0, r9, c1, c0, 0 @ Control register
|
|
|
+ mrc p15, 0, r10, c1, c0, 1 @ Auxiliary control register
|
|
|
+ mrc p15, 0, r11, c1, c0, 2 @ Co-processor access control
|
|
|
+ stmia r0, {r4 - r11}
|
|
|
+ ldmfd sp!, {r4 - r11, pc}
|
|
|
+ENDPROC(cpu_v7_do_suspend)
|
|
|
+
|
|
|
+ENTRY(cpu_v7_do_resume)
|
|
|
+ mov ip, #0
|
|
|
+ mcr p15, 0, ip, c8, c7, 0 @ invalidate TLBs
|
|
|
+ mcr p15, 0, ip, c7, c5, 0 @ invalidate I cache
|
|
|
+ ldmia r0, {r4 - r11}
|
|
|
+ mcr p15, 0, r4, c13, c0, 0 @ FCSE/PID
|
|
|
+ mcr p15, 0, r5, c13, c0, 1 @ Context ID
|
|
|
+ mcr p15, 0, r6, c3, c0, 0 @ Domain ID
|
|
|
+ mcr p15, 0, r7, c2, c0, 0 @ TTB 0
|
|
|
+ mcr p15, 0, r8, c2, c0, 1 @ TTB 1
|
|
|
+ mcr p15, 0, ip, c2, c0, 2 @ TTB control register
|
|
|
+ mcr p15, 0, r10, c1, c0, 1 @ Auxillary control register
|
|
|
+ mcr p15, 0, r11, c1, c0, 2 @ Co-processor access control
|
|
|
+ ldr r4, =PRRR @ PRRR
|
|
|
+ ldr r5, =NMRR @ NMRR
|
|
|
+ mcr p15, 0, r4, c10, c2, 0 @ write PRRR
|
|
|
+ mcr p15, 0, r5, c10, c2, 1 @ write NMRR
|
|
|
+ isb
|
|
|
+ mov r0, r9 @ control register
|
|
|
+ mov r2, r7, lsr #14 @ get TTB0 base
|
|
|
+ mov r2, r2, lsl #14
|
|
|
+ ldr r3, cpu_resume_l1_flags
|
|
|
+ b cpu_resume_mmu
|
|
|
+ENDPROC(cpu_v7_do_resume)
|
|
|
+cpu_resume_l1_flags:
|
|
|
+ ALT_SMP(.long PMD_TYPE_SECT | PMD_SECT_AP_WRITE | PMD_FLAGS_SMP)
|
|
|
+ ALT_UP(.long PMD_TYPE_SECT | PMD_SECT_AP_WRITE | PMD_FLAGS_UP)
|
|
|
+#else
|
|
|
+#define cpu_v7_do_suspend 0
|
|
|
+#define cpu_v7_do_resume 0
|
|
|
+#endif
|
|
|
+
|
|
|
__CPUINIT
|
|
|
|
|
|
/*
|
|
@@ -276,36 +357,8 @@ __v7_setup:
|
|
|
ALT_SMP(orr r4, r4, #TTB_FLAGS_SMP)
|
|
|
ALT_UP(orr r4, r4, #TTB_FLAGS_UP)
|
|
|
mcr p15, 0, r4, c2, c0, 1 @ load TTB1
|
|
|
- /*
|
|
|
- * Memory region attributes with SCTLR.TRE=1
|
|
|
- *
|
|
|
- * n = TEX[0],C,B
|
|
|
- * TR = PRRR[2n+1:2n] - memory type
|
|
|
- * IR = NMRR[2n+1:2n] - inner cacheable property
|
|
|
- * OR = NMRR[2n+17:2n+16] - outer cacheable property
|
|
|
- *
|
|
|
- * n TR IR OR
|
|
|
- * UNCACHED 000 00
|
|
|
- * BUFFERABLE 001 10 00 00
|
|
|
- * WRITETHROUGH 010 10 10 10
|
|
|
- * WRITEBACK 011 10 11 11
|
|
|
- * reserved 110
|
|
|
- * WRITEALLOC 111 10 01 01
|
|
|
- * DEV_SHARED 100 01
|
|
|
- * DEV_NONSHARED 100 01
|
|
|
- * DEV_WC 001 10
|
|
|
- * DEV_CACHED 011 10
|
|
|
- *
|
|
|
- * Other attributes:
|
|
|
- *
|
|
|
- * DS0 = PRRR[16] = 0 - device shareable property
|
|
|
- * DS1 = PRRR[17] = 1 - device shareable property
|
|
|
- * NS0 = PRRR[18] = 0 - normal shareable property
|
|
|
- * NS1 = PRRR[19] = 1 - normal shareable property
|
|
|
- * NOS = PRRR[24+n] = 1 - not outer shareable
|
|
|
- */
|
|
|
- ldr r5, =0xff0a81a8 @ PRRR
|
|
|
- ldr r6, =0x40e040e0 @ NMRR
|
|
|
+ ldr r5, =PRRR @ PRRR
|
|
|
+ ldr r6, =NMRR @ NMRR
|
|
|
mcr p15, 0, r5, c10, c2, 0 @ write PRRR
|
|
|
mcr p15, 0, r6, c10, c2, 1 @ write NMRR
|
|
|
#endif
|
|
@@ -351,6 +404,9 @@ ENTRY(v7_processor_functions)
|
|
|
.word cpu_v7_dcache_clean_area
|
|
|
.word cpu_v7_switch_mm
|
|
|
.word cpu_v7_set_pte_ext
|
|
|
+ .word 0
|
|
|
+ .word 0
|
|
|
+ .word 0
|
|
|
.size v7_processor_functions, . - v7_processor_functions
|
|
|
|
|
|
.section ".rodata"
|