These changes are the raw update to linux-4.4.6-rt14. Kernel sources
[kvmfornfv.git] / kernel / arch / arm / mach-socfpga / headsmp.S
1 /*
2  *  Copyright (c) 2003 ARM Limited
3  *  Copyright (c) u-boot contributors
4  *  Copyright (c) 2012 Pavel Machek <pavel@denx.de>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation.
9  */
10 #include <linux/linkage.h>
11 #include <linux/init.h>
12 #include <asm/memory.h>
13 #include <asm/assembler.h>
14
15         .arch   armv7-a
16
17 ENTRY(secondary_trampoline)
18         /* CPU1 will always fetch from 0x0 when it is brought out of reset.
19          * Thus, we can just subtract the PAGE_OFFSET to get the physical
20          * address of &cpu1start_addr. This would not work for platforms
21          * where the physical memory does not start at 0x0.
22         */
23 ARM_BE8(setend  be)
24         adr     r0, 1f
25         ldmia   r0, {r1, r2}
26         sub     r2, r2, #PAGE_OFFSET
27         ldr     r3, [r2]
28         ldr     r4, [r3]
29 ARM_BE8(rev     r4, r4)
30         bx      r4
31
32         .align
33 1:      .long   .
34         .long   socfpga_cpu1start_addr
35 ENTRY(secondary_trampoline_end)