blob: 7e3e4f15b0523b8f6124776a8291f07354f1dee6 [file] [log] [blame]
Guo Ren9143a932018-09-05 14:25:07 +08001/* SPDX-License-Identifier: GPL-2.0 */
2
3#include <linux/linkage.h>
4#include <linux/init.h>
5#include <asm/page.h>
6#include <abi/entry.h>
7
8__HEAD
9ENTRY(_start)
Guo Ren205353f2019-04-12 19:08:34 +080010 SETUP_MMU
Guo Ren9143a932018-09-05 14:25:07 +080011
12 /* set stack point */
Guo Ren205353f2019-04-12 19:08:34 +080013 lrw r6, init_thread_union + THREAD_SIZE
14 mov sp, r6
Guo Ren9143a932018-09-05 14:25:07 +080015
16 jmpi csky_start
17END(_start)
18
19#ifdef CONFIG_SMP
20.align 10
21ENTRY(_start_smp_secondary)
Guo Ren205353f2019-04-12 19:08:34 +080022 SETUP_MMU
Guo Ren9143a932018-09-05 14:25:07 +080023
Guo Ren0c8a32e2020-09-07 06:20:18 +000024#ifdef CONFIG_PAGE_OFFSET_80000000
25 lrw r6, secondary_msa1
Guo Renaefd9462020-03-28 19:14:37 +080026 ld.w r6, (r6, 0)
27 mtcr r6, cr<31, 15>
Guo Ren0c8a32e2020-09-07 06:20:18 +000028#endif
29
30 lrw r6, secondary_pgd
31 ld.w r6, (r6, 0)
32 mtcr r6, cr<28, 15>
33 mtcr r6, cr<29, 15>
Guo Renaefd9462020-03-28 19:14:37 +080034
Guo Ren9143a932018-09-05 14:25:07 +080035 /* set stack point */
Guo Ren205353f2019-04-12 19:08:34 +080036 lrw r6, secondary_stack
37 ld.w r6, (r6, 0)
38 mov sp, r6
Guo Ren9143a932018-09-05 14:25:07 +080039
40 jmpi csky_start_secondary
41END(_start_smp_secondary)
42#endif