diff options
Diffstat (limited to 'arch/arm/mach-prima2/headsmp.S')
| -rw-r--r-- | arch/arm/mach-prima2/headsmp.S | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/arch/arm/mach-prima2/headsmp.S b/arch/arm/mach-prima2/headsmp.S new file mode 100644 index 000000000000..5b8a408d8921 --- /dev/null +++ b/arch/arm/mach-prima2/headsmp.S | |||
| @@ -0,0 +1,40 @@ | |||
| 1 | /* | ||
| 2 | * Entry of the second core for CSR Marco dual-core SMP SoCs | ||
| 3 | * | ||
| 4 | * Copyright (c) 2012 Cambridge Silicon Radio Limited, a CSR plc group company. | ||
| 5 | * | ||
| 6 | * Licensed under GPLv2 or later. | ||
| 7 | */ | ||
| 8 | |||
| 9 | #include <linux/linkage.h> | ||
| 10 | #include <linux/init.h> | ||
| 11 | |||
| 12 | __CPUINIT | ||
| 13 | |||
| 14 | /* | ||
| 15 | * SIRFSOC specific entry point for secondary CPUs. This provides | ||
| 16 | * a "holding pen" into which all secondary cores are held until we're | ||
| 17 | * ready for them to initialise. | ||
| 18 | */ | ||
| 19 | ENTRY(sirfsoc_secondary_startup) | ||
| 20 | bl v7_invalidate_l1 | ||
| 21 | mrc p15, 0, r0, c0, c0, 5 | ||
| 22 | and r0, r0, #15 | ||
| 23 | adr r4, 1f | ||
| 24 | ldmia r4, {r5, r6} | ||
| 25 | sub r4, r4, r5 | ||
| 26 | add r6, r6, r4 | ||
| 27 | pen: ldr r7, [r6] | ||
| 28 | cmp r7, r0 | ||
| 29 | bne pen | ||
| 30 | |||
| 31 | /* | ||
| 32 | * we've been released from the holding pen: secondary_stack | ||
| 33 | * should now contain the SVC stack for this core | ||
| 34 | */ | ||
| 35 | b secondary_startup | ||
| 36 | ENDPROC(sirfsoc_secondary_startup) | ||
| 37 | |||
| 38 | .align | ||
| 39 | 1: .long . | ||
| 40 | .long pen_release | ||
