diff options
author | Ard Biesheuvel <ard.biesheuvel@linaro.org> | 2015-03-25 02:39:21 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2015-03-29 18:11:57 -0400 |
commit | d0776aff9a38b1390cc06ffc2c4dcf6ece7c05b9 (patch) | |
tree | 79bba874404434298a52db4e494b2bafa8dcb4f3 /arch/arm/kernel/sleep.S | |
parent | 02e541db0540a2830f4af749c6f2b650abbbb77c (diff) |
ARM: 8324/1: move cpu_resume() to .text section
Move cpu_resume() to the .text section where it belongs. Change
the adr reference to sleep_save_sp to an explicit PC relative
reference so sleep_save_sp itself can remain in .data.
This helps prevent linker failure on large kernels, as the code
in the .data section may be too far away to be in range for normal
b/bl instructions.
Reviewed-by: Nicolas Pitre <nico@linaro.org>
Tested-by: Sudeep Holla <sudeep.holla@arm.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/kernel/sleep.S')
-rw-r--r-- | arch/arm/kernel/sleep.S | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/arch/arm/kernel/sleep.S b/arch/arm/kernel/sleep.S index e1e60e5a7a27..7d37bfc50830 100644 --- a/arch/arm/kernel/sleep.S +++ b/arch/arm/kernel/sleep.S | |||
@@ -116,14 +116,7 @@ cpu_resume_after_mmu: | |||
116 | ldmfd sp!, {r4 - r11, pc} | 116 | ldmfd sp!, {r4 - r11, pc} |
117 | ENDPROC(cpu_resume_after_mmu) | 117 | ENDPROC(cpu_resume_after_mmu) |
118 | 118 | ||
119 | /* | 119 | .text |
120 | * Note: Yes, part of the following code is located into the .data section. | ||
121 | * This is to allow sleep_save_sp to be accessed with a relative load | ||
122 | * while we can't rely on any MMU translation. We could have put | ||
123 | * sleep_save_sp in the .text section as well, but some setups might | ||
124 | * insist on it to be truly read-only. | ||
125 | */ | ||
126 | .data | ||
127 | .align | 120 | .align |
128 | ENTRY(cpu_resume) | 121 | ENTRY(cpu_resume) |
129 | ARM_BE8(setend be) @ ensure we are in BE mode | 122 | ARM_BE8(setend be) @ ensure we are in BE mode |
@@ -145,6 +138,8 @@ ARM_BE8(setend be) @ ensure we are in BE mode | |||
145 | compute_mpidr_hash r1, r4, r5, r6, r0, r3 | 138 | compute_mpidr_hash r1, r4, r5, r6, r0, r3 |
146 | 1: | 139 | 1: |
147 | adr r0, _sleep_save_sp | 140 | adr r0, _sleep_save_sp |
141 | ldr r2, [r0] | ||
142 | add r0, r0, r2 | ||
148 | ldr r0, [r0, #SLEEP_SAVE_SP_PHYS] | 143 | ldr r0, [r0, #SLEEP_SAVE_SP_PHYS] |
149 | ldr r0, [r0, r1, lsl #2] | 144 | ldr r0, [r0, r1, lsl #2] |
150 | 145 | ||
@@ -156,10 +151,12 @@ THUMB( bx r3 ) | |||
156 | ENDPROC(cpu_resume) | 151 | ENDPROC(cpu_resume) |
157 | 152 | ||
158 | .align 2 | 153 | .align 2 |
154 | _sleep_save_sp: | ||
155 | .long sleep_save_sp - . | ||
159 | mpidr_hash_ptr: | 156 | mpidr_hash_ptr: |
160 | .long mpidr_hash - . @ mpidr_hash struct offset | 157 | .long mpidr_hash - . @ mpidr_hash struct offset |
161 | 158 | ||
159 | .data | ||
162 | .type sleep_save_sp, #object | 160 | .type sleep_save_sp, #object |
163 | ENTRY(sleep_save_sp) | 161 | ENTRY(sleep_save_sp) |
164 | _sleep_save_sp: | ||
165 | .space SLEEP_SAVE_SP_SZ @ struct sleep_save_sp | 162 | .space SLEEP_SAVE_SP_SZ @ struct sleep_save_sp |