| /* |
| * Copyright (c) 2003 ARM Limited |
| * Copyright (c) u-boot contributors |
| * Copyright (c) 2012 Pavel Machek <pavel@denx.de> |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 as |
| * published by the Free Software Foundation. |
| */ |
| #include <linux/linkage.h> |
| #include <linux/init.h> |
| |
| .arch armv7-a |
| |
| ENTRY(secondary_trampoline) |
| movw r2, #:lower16:cpu1start_addr |
| movt r2, #:upper16:cpu1start_addr |
| |
| /* The socfpga VT cannot handle a 0xC0000000 page offset when loading |
| the cpu1start_addr, we bit clear it. Tested on HW and VT. */ |
| bic r2, r2, #0x40000000 |
| |
| ldr r0, [r2] |
| ldr r1, [r0] |
| bx r1 |
| |
| ENTRY(secondary_trampoline_end) |
| |
| ENTRY(socfpga_secondary_startup) |
| bl v7_invalidate_l1 |
| b secondary_startup |
| ENDPROC(socfpga_secondary_startup) |