aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/kernel/head-common.S
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/kernel/head-common.S')
-rw-r--r--arch/arm/kernel/head-common.S81
1 files changed, 45 insertions, 36 deletions
diff --git a/arch/arm/kernel/head-common.S b/arch/arm/kernel/head-common.S
index b9505aa267c0..6ad24d2cb14b 100644
--- a/arch/arm/kernel/head-common.S
+++ b/arch/arm/kernel/head-common.S
@@ -145,45 +145,14 @@ ENDPROC(__error)
145 145
146 146
147/* 147/*
148 * Read processor ID register (CP#15, CR0), and look up in the linker-built 148 * This provides a C-API version of __lookup_processor_type
149 * supported processor list. Note that we can't use the absolute addresses
150 * for the __proc_info lists since we aren't running with the MMU on
151 * (and therefore, we are not in the correct address space). We have to
152 * calculate the offset.
153 *
154 * r9 = cpuid
155 * Returns:
156 * r3, r4, r6 corrupted
157 * r5 = proc_info pointer in physical address space
158 * r9 = cpuid (preserved)
159 */
160__lookup_processor_type:
161 adr r3, 3f
162 ldmia r3, {r5 - r7}
163 add r3, r3, #8
164 sub r3, r3, r7 @ get offset between virt&phys
165 add r5, r5, r3 @ convert virt addresses to
166 add r6, r6, r3 @ physical address space
1671: ldmia r5, {r3, r4} @ value, mask
168 and r4, r4, r9 @ mask wanted bits
169 teq r3, r4
170 beq 2f
171 add r5, r5, #PROC_INFO_SZ @ sizeof(proc_info_list)
172 cmp r5, r6
173 blo 1b
174 mov r5, #0 @ unknown processor
1752: mov pc, lr
176ENDPROC(__lookup_processor_type)
177
178/*
179 * This provides a C-API version of the above function.
180 */ 149 */
181ENTRY(lookup_processor_type) 150ENTRY(lookup_processor_type)
182 stmfd sp!, {r4 - r7, r9, lr} 151 stmfd sp!, {r4 - r6, r9, lr}
183 mov r9, r0 152 mov r9, r0
184 bl __lookup_processor_type 153 bl __lookup_processor_type
185 mov r0, r5 154 mov r0, r5
186 ldmfd sp!, {r4 - r7, r9, pc} 155 ldmfd sp!, {r4 - r6, r9, pc}
187ENDPROC(lookup_processor_type) 156ENDPROC(lookup_processor_type)
188 157
189/* 158/*
@@ -191,8 +160,6 @@ ENDPROC(lookup_processor_type)
191 * more information about the __proc_info and __arch_info structures. 160 * more information about the __proc_info and __arch_info structures.
192 */ 161 */
193 .align 2 162 .align 2
1943: .long __proc_info_begin
195 .long __proc_info_end
1964: .long . 1634: .long .
197 .long __arch_info_begin 164 .long __arch_info_begin
198 .long __arch_info_end 165 .long __arch_info_end
@@ -265,3 +232,45 @@ __vet_atags:
2651: mov r2, #0 2321: mov r2, #0
266 mov pc, lr 233 mov pc, lr
267ENDPROC(__vet_atags) 234ENDPROC(__vet_atags)
235
236/*
237 * Read processor ID register (CP#15, CR0), and look up in the linker-built
238 * supported processor list. Note that we can't use the absolute addresses
239 * for the __proc_info lists since we aren't running with the MMU on
240 * (and therefore, we are not in the correct address space). We have to
241 * calculate the offset.
242 *
243 * r9 = cpuid
244 * Returns:
245 * r3, r4, r6 corrupted
246 * r5 = proc_info pointer in physical address space
247 * r9 = cpuid (preserved)
248 */
249 __CPUINIT
250__lookup_processor_type:
251 adr r3, __lookup_processor_type_data
252 ldmia r3, {r4 - r6}
253 sub r3, r3, r4 @ get offset between virt&phys
254 add r5, r5, r3 @ convert virt addresses to
255 add r6, r6, r3 @ physical address space
2561: ldmia r5, {r3, r4} @ value, mask
257 and r4, r4, r9 @ mask wanted bits
258 teq r3, r4
259 beq 2f
260 add r5, r5, #PROC_INFO_SZ @ sizeof(proc_info_list)
261 cmp r5, r6
262 blo 1b
263 mov r5, #0 @ unknown processor
2642: mov pc, lr
265ENDPROC(__lookup_processor_type)
266
267/*
268 * Look in <asm/procinfo.h> for information about the __proc_info structure.
269 */
270 .align 2
271 .type __lookup_processor_type_data, %object
272__lookup_processor_type_data:
273 .long .
274 .long __proc_info_begin
275 .long __proc_info_end
276 .size __lookup_processor_type_data, . - __lookup_processor_type_data