xref: /linux/arch/csky/abiv2/inc/abi/entry.h (revision b8d312aa075f33282565467662c4628dae0a2aff)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 // Copyright (C) 2018 Hangzhou C-SKY Microsystems co.,ltd.
3 
4 #ifndef __ASM_CSKY_ENTRY_H
5 #define __ASM_CSKY_ENTRY_H
6 
7 #include <asm/setup.h>
8 #include <abi/regdef.h>
9 
10 #define LSAVE_PC	8
11 #define LSAVE_PSR	12
12 #define LSAVE_A0	24
13 #define LSAVE_A1	28
14 #define LSAVE_A2	32
15 #define LSAVE_A3	36
16 
17 #define KSPTOUSP
18 #define USPTOKSP
19 
20 #define usp cr<14, 1>
21 
22 .macro SAVE_ALL epc_inc
23 	subi    sp, 152
24 	stw	tls, (sp, 0)
25 	stw	lr, (sp, 4)
26 
27 	mfcr	lr, epc
28 	movi	tls, \epc_inc
29 	add	lr, tls
30 	stw	lr, (sp, 8)
31 
32 	mfcr	lr, epsr
33 	stw	lr, (sp, 12)
34 	mfcr	lr, usp
35 	stw	lr, (sp, 16)
36 
37 	stw     a0, (sp, 20)
38 	stw     a0, (sp, 24)
39 	stw     a1, (sp, 28)
40 	stw     a2, (sp, 32)
41 	stw     a3, (sp, 36)
42 
43 	addi	sp, 40
44 	stm	r4-r13, (sp)
45 
46 	addi    sp, 40
47 	stm     r16-r30, (sp)
48 #ifdef CONFIG_CPU_HAS_HILO
49 	mfhi	lr
50 	stw	lr, (sp, 60)
51 	mflo	lr
52 	stw	lr, (sp, 64)
53 	mfcr	lr, cr14
54 	stw	lr, (sp, 68)
55 #endif
56 	subi	sp, 80
57 .endm
58 
59 .macro	RESTORE_ALL
60 	psrclr  ie
61 	ldw	tls, (sp, 0)
62 	ldw	lr, (sp, 4)
63 	ldw	a0, (sp, 8)
64 	mtcr	a0, epc
65 	ldw	a0, (sp, 12)
66 	mtcr	a0, epsr
67 	ldw	a0, (sp, 16)
68 	mtcr	a0, usp
69 
70 #ifdef CONFIG_CPU_HAS_HILO
71 	ldw	a0, (sp, 140)
72 	mthi	a0
73 	ldw	a0, (sp, 144)
74 	mtlo	a0
75 	ldw	a0, (sp, 148)
76 	mtcr	a0, cr14
77 #endif
78 
79 	ldw     a0, (sp, 24)
80 	ldw     a1, (sp, 28)
81 	ldw     a2, (sp, 32)
82 	ldw     a3, (sp, 36)
83 
84 	addi	sp, 40
85 	ldm	r4-r13, (sp)
86 	addi    sp, 40
87 	ldm     r16-r30, (sp)
88 	addi    sp, 72
89 	rte
90 .endm
91 
92 .macro SAVE_SWITCH_STACK
93 	subi    sp, 64
94 	stm	r4-r11, (sp)
95 	stw	lr,  (sp, 32)
96 	stw	r16, (sp, 36)
97 	stw	r17, (sp, 40)
98 	stw	r26, (sp, 44)
99 	stw	r27, (sp, 48)
100 	stw	r28, (sp, 52)
101 	stw	r29, (sp, 56)
102 	stw	r30, (sp, 60)
103 #ifdef CONFIG_CPU_HAS_HILO
104 	subi	sp, 16
105 	mfhi	lr
106 	stw	lr, (sp, 0)
107 	mflo	lr
108 	stw	lr, (sp, 4)
109 	mfcr	lr, cr14
110 	stw	lr, (sp, 8)
111 #endif
112 .endm
113 
114 .macro RESTORE_SWITCH_STACK
115 #ifdef CONFIG_CPU_HAS_HILO
116 	ldw	lr, (sp, 0)
117 	mthi	lr
118 	ldw	lr, (sp, 4)
119 	mtlo	lr
120 	ldw	lr, (sp, 8)
121 	mtcr	lr, cr14
122 	addi	sp, 16
123 #endif
124 	ldm	r4-r11, (sp)
125 	ldw	lr,  (sp, 32)
126 	ldw	r16, (sp, 36)
127 	ldw	r17, (sp, 40)
128 	ldw	r26, (sp, 44)
129 	ldw	r27, (sp, 48)
130 	ldw	r28, (sp, 52)
131 	ldw	r29, (sp, 56)
132 	ldw	r30, (sp, 60)
133 	addi	sp, 64
134 .endm
135 
136 /* MMU registers operators. */
137 .macro RD_MIR rx
138 	mfcr	\rx, cr<0, 15>
139 .endm
140 
141 .macro RD_MEH rx
142 	mfcr	\rx, cr<4, 15>
143 .endm
144 
145 .macro RD_MCIR rx
146 	mfcr	\rx, cr<8, 15>
147 .endm
148 
149 .macro RD_PGDR rx
150 	mfcr	\rx, cr<29, 15>
151 .endm
152 
153 .macro RD_PGDR_K rx
154 	mfcr	\rx, cr<28, 15>
155 .endm
156 
157 .macro WR_MEH rx
158 	mtcr	\rx, cr<4, 15>
159 .endm
160 
161 .macro WR_MCIR rx
162 	mtcr	\rx, cr<8, 15>
163 .endm
164 
165 .macro SETUP_MMU
166 	/* Init psr and enable ee */
167 	lrw	r6, DEFAULT_PSR_VALUE
168 	mtcr    r6, psr
169 	psrset  ee
170 
171 	/* Invalid I/Dcache BTB BHT */
172 	movi	r6, 7
173 	lsli	r6, 16
174 	addi	r6, (1<<4) | 3
175 	mtcr	r6, cr17
176 
177 	/* Invalid all TLB */
178 	bgeni   r6, 26
179 	mtcr	r6, cr<8, 15> /* Set MCIR */
180 
181 	/* Check MMU on/off */
182 	mfcr	r6, cr18
183 	btsti	r6, 0
184 	bt	1f
185 
186 	/* MMU off: setup mapping tlb entry */
187 	movi	r6, 0
188 	mtcr	r6, cr<6, 15> /* Set MPR with 4K page size */
189 
190 	grs	r6, 1f /* Get current pa by PC */
191 	bmaski  r7, (PAGE_SHIFT + 1) /* r7 = 0x1fff */
192 	andn    r6, r7
193 	mtcr	r6, cr<4, 15> /* Set MEH */
194 
195 	mov	r8, r6
196 	movi    r7, 0x00000006
197 	or      r8, r7
198 	mtcr	r8, cr<2, 15> /* Set MEL0 */
199 	movi    r7, 0x00001006
200 	or      r8, r7
201 	mtcr	r8, cr<3, 15> /* Set MEL1 */
202 
203 	bgeni   r8, 28
204 	mtcr	r8, cr<8, 15> /* Set MCIR to write TLB */
205 
206 	br	2f
207 1:
208 	/*
209 	 * MMU on: use origin MSA value from bootloader
210 	 *
211 	 * cr<30/31, 15> MSA register format:
212 	 * 31 - 29 | 28 - 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0
213 	 *   BA     Reserved  SH  WA  B   SO SEC  C   D   V
214 	 */
215 	mfcr	r6, cr<30, 15> /* Get MSA0 */
216 2:
217 	lsri	r6, 28
218 	lsli	r6, 28
219 	addi	r6, 0x1ce
220 	mtcr	r6, cr<30, 15> /* Set MSA0 */
221 
222 	lsri	r6, 28
223 	addi	r6, 2
224 	lsli	r6, 28
225 	addi	r6, 0x1ce
226 	mtcr	r6, cr<31, 15> /* Set MSA1 */
227 
228 	/* enable MMU */
229 	mfcr    r6, cr18
230 	bseti	r6, 0
231 	mtcr    r6, cr18
232 
233 	jmpi	3f /* jump to va */
234 3:
235 .endm
236 
237 .macro ANDI_R3 rx, imm
238 	lsri	\rx, 3
239 	andi	\rx, (\imm >> 3)
240 .endm
241 #endif /* __ASM_CSKY_ENTRY_H */
242