blob: 51597f344a62aced8c98cb2035c9ec40eff55e6e [file] [log] [blame]
Vineet Gupta9d42c842013-01-18 15:12:18 +05301/*
Vineet Gupta6d1a20b2015-02-21 15:09:32 +05302 * Copyright (C) 2014-15 Synopsys, Inc. (www.synopsys.com)
Vineet Gupta9d42c842013-01-18 15:12:18 +05303 * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation.
Vineet Gupta9d42c842013-01-18 15:12:18 +05308 */
9
10#ifndef __ASM_ARC_ENTRY_H
11#define __ASM_ARC_ENTRY_H
12
Vineet Gupta9d42c842013-01-18 15:12:18 +053013#include <asm/unistd.h> /* For NR_syscalls defination */
Vineet Gupta9d42c842013-01-18 15:12:18 +053014#include <asm/arcregs.h>
15#include <asm/ptrace.h>
Vineet Gupta080c3742013-02-11 19:52:57 +053016#include <asm/processor.h> /* For VMALLOC_START */
Vineet Gupta4ffd9e22013-07-26 15:29:40 -070017#include <asm/mmu.h>
Vineet Gupta9d42c842013-01-18 15:12:18 +053018
Vineet Gupta1f6ccff2013-05-13 18:30:41 +053019#ifdef CONFIG_ISA_ARCOMPACT
Vineet Gupta6d1a20b2015-02-21 15:09:32 +053020#include <asm/entry-compact.h> /* ISA specific bits */
Vineet Gupta1f6ccff2013-05-13 18:30:41 +053021#else
22#include <asm/entry-arcv2.h>
23#endif
Vineet Gupta6d1a20b2015-02-21 15:09:32 +053024
Vineet Gupta9d42c842013-01-18 15:12:18 +053025/* Note on the LD/ST addr modes with addr reg wback
26 *
27 * LD.a same as LD.aw
28 *
29 * LD.a reg1, [reg2, x] => Pre Incr
30 * Eff Addr for load = [reg2 + x]
31 *
32 * LD.ab reg1, [reg2, x] => Post Incr
33 * Eff Addr for load = [reg2]
34 */
35
Vineet Gupta3ebedbb2013-05-28 13:24:43 +053036.macro PUSH reg
37 st.a \reg, [sp, -4]
38.endm
39
40.macro PUSHAX aux
41 lr r9, [\aux]
42 PUSH r9
43.endm
44
45.macro POP reg
46 ld.ab \reg, [sp, 4]
47.endm
48
49.macro POPAX aux
50 POP r9
51 sr r9, [\aux]
Vineet Gupta9d42c842013-01-18 15:12:18 +053052.endm
53
54/*--------------------------------------------------------------
Vineet Gupta3ebedbb2013-05-28 13:24:43 +053055 * Helpers to save/restore Scratch Regs:
56 * used by Interrupt/Exception Prologue/Epilogue
Vineet Gupta9d42c842013-01-18 15:12:18 +053057 *-------------------------------------------------------------*/
Vineet Gupta3ebedbb2013-05-28 13:24:43 +053058.macro SAVE_R0_TO_R12
59 PUSH r0
60 PUSH r1
61 PUSH r2
62 PUSH r3
63 PUSH r4
64 PUSH r5
65 PUSH r6
66 PUSH r7
67 PUSH r8
68 PUSH r9
69 PUSH r10
70 PUSH r11
71 PUSH r12
72.endm
73
74.macro RESTORE_R12_TO_R0
75 POP r12
76 POP r11
77 POP r10
78 POP r9
79 POP r8
80 POP r7
81 POP r6
82 POP r5
83 POP r4
84 POP r3
85 POP r2
86 POP r1
87 POP r0
Vineet Gupta359105b2013-05-28 13:50:41 +053088
89#ifdef CONFIG_ARC_CURR_IN_REG
90 ld r25, [sp, 12]
91#endif
Vineet Gupta3ebedbb2013-05-28 13:24:43 +053092.endm
93
94/*--------------------------------------------------------------
95 * Helpers to save/restore callee-saved regs:
96 * used by several macros below
97 *-------------------------------------------------------------*/
98.macro SAVE_R13_TO_R24
99 PUSH r13
100 PUSH r14
101 PUSH r15
102 PUSH r16
103 PUSH r17
104 PUSH r18
105 PUSH r19
106 PUSH r20
107 PUSH r21
108 PUSH r22
109 PUSH r23
110 PUSH r24
111.endm
112
113.macro RESTORE_R24_TO_R13
114 POP r24
115 POP r23
116 POP r22
117 POP r21
118 POP r20
119 POP r19
120 POP r18
121 POP r17
122 POP r16
123 POP r15
124 POP r14
125 POP r13
Vineet Gupta9d42c842013-01-18 15:12:18 +0530126.endm
127
Vineet Gupta9d42c842013-01-18 15:12:18 +0530128/*--------------------------------------------------------------
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530129 * Collect User Mode callee regs as struct callee_regs - needed by
130 * fork/do_signal/unaligned-access-emulation.
131 * (By default only scratch regs are saved on entry to kernel)
132 *
133 * Special handling for r25 if used for caching Task Pointer.
134 * It would have been saved in task->thread.user_r25 already, but to keep
135 * the interface same it is copied into regular r25 placeholder in
136 * struct callee_regs.
Vineet Gupta9d42c842013-01-18 15:12:18 +0530137 *-------------------------------------------------------------*/
138.macro SAVE_CALLEE_SAVED_USER
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530139
Vineet Gupta0d7b8852014-10-07 14:12:13 +0530140 mov r12, sp ; save SP as ref to pt_regs
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530141 SAVE_R13_TO_R24
Vineet Gupta080c3742013-02-11 19:52:57 +0530142
143#ifdef CONFIG_ARC_CURR_IN_REG
Vineet Gupta0d7b8852014-10-07 14:12:13 +0530144 ; Retrieve orig r25 and save it with rest of callee_regs
Liav Rehana86147e32016-08-16 10:55:35 +0300145 ld r12, [r12, PT_user_r25]
Vineet Gupta0d7b8852014-10-07 14:12:13 +0530146 PUSH r12
Vineet Gupta080c3742013-02-11 19:52:57 +0530147#else
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530148 PUSH r25
Vineet Gupta080c3742013-02-11 19:52:57 +0530149#endif
Vineet Gupta9d42c842013-01-18 15:12:18 +0530150
Vineet Gupta9d42c842013-01-18 15:12:18 +0530151.endm
152
153/*--------------------------------------------------------------
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530154 * Save kernel Mode callee regs at the time of Contect Switch.
155 *
156 * Special handling for r25 if used for caching Task Pointer.
157 * Kernel simply skips saving it since it will be loaded with
158 * incoming task pointer anyways
Vineet Gupta9d42c842013-01-18 15:12:18 +0530159 *-------------------------------------------------------------*/
160.macro SAVE_CALLEE_SAVED_KERNEL
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530161
162 SAVE_R13_TO_R24
163
Vineet Gupta080c3742013-02-11 19:52:57 +0530164#ifdef CONFIG_ARC_CURR_IN_REG
Vineet Gupta16f9afe2013-05-27 21:43:41 +0530165 sub sp, sp, 4
Vineet Gupta080c3742013-02-11 19:52:57 +0530166#else
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530167 PUSH r25
Vineet Gupta080c3742013-02-11 19:52:57 +0530168#endif
Vineet Gupta9d42c842013-01-18 15:12:18 +0530169.endm
170
171/*--------------------------------------------------------------
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530172 * Opposite of SAVE_CALLEE_SAVED_KERNEL
Vineet Gupta9d42c842013-01-18 15:12:18 +0530173 *-------------------------------------------------------------*/
174.macro RESTORE_CALLEE_SAVED_KERNEL
175
Vineet Gupta080c3742013-02-11 19:52:57 +0530176#ifdef CONFIG_ARC_CURR_IN_REG
Vineet Gupta16f9afe2013-05-27 21:43:41 +0530177 add sp, sp, 4 /* skip usual r25 placeholder */
Vineet Gupta080c3742013-02-11 19:52:57 +0530178#else
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530179 POP r25
Vineet Gupta080c3742013-02-11 19:52:57 +0530180#endif
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530181 RESTORE_R24_TO_R13
Vineet Gupta9d42c842013-01-18 15:12:18 +0530182.endm
183
184/*--------------------------------------------------------------
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530185 * Opposite of SAVE_CALLEE_SAVED_USER
186 *
187 * ptrace tracer or unaligned-access fixup might have changed a user mode
188 * callee reg which is saved back to usual r25 storage location
Vineet Guptac3581032013-01-18 15:12:19 +0530189 *-------------------------------------------------------------*/
190.macro RESTORE_CALLEE_SAVED_USER
191
Vineet Guptac3581032013-01-18 15:12:19 +0530192#ifdef CONFIG_ARC_CURR_IN_REG
Vineet Gupta0d7b8852014-10-07 14:12:13 +0530193 POP r12
Vineet Guptac3581032013-01-18 15:12:19 +0530194#else
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530195 POP r25
Vineet Guptac3581032013-01-18 15:12:19 +0530196#endif
Vineet Gupta3ebedbb2013-05-28 13:24:43 +0530197 RESTORE_R24_TO_R13
Vineet Gupta0d7b8852014-10-07 14:12:13 +0530198
199 ; SP is back to start of pt_regs
200#ifdef CONFIG_ARC_CURR_IN_REG
Liav Rehana86147e32016-08-16 10:55:35 +0300201 st r12, [sp, PT_user_r25]
Vineet Gupta0d7b8852014-10-07 14:12:13 +0530202#endif
Vineet Guptac3581032013-01-18 15:12:19 +0530203.endm
204
205/*--------------------------------------------------------------
Vineet Gupta9d42c842013-01-18 15:12:18 +0530206 * Super FAST Restore callee saved regs by simply re-adjusting SP
207 *-------------------------------------------------------------*/
208.macro DISCARD_CALLEE_SAVED_USER
Vineet Gupta16f9afe2013-05-27 21:43:41 +0530209 add sp, sp, SZ_CALLEE_REGS
Vineet Gupta9d42c842013-01-18 15:12:18 +0530210.endm
211
Vineet Gupta9d42c842013-01-18 15:12:18 +0530212/*-------------------------------------------------------------
213 * given a tsk struct, get to the base of it's kernel mode stack
214 * tsk->thread_info is really a PAGE, whose bottom hoists stack
215 * which grows upwards towards thread_info
216 *------------------------------------------------------------*/
217
218.macro GET_TSK_STACK_BASE tsk, out
219
220 /* Get task->thread_info (this is essentially start of a PAGE) */
221 ld \out, [\tsk, TASK_THREAD_INFO]
222
223 /* Go to end of page where stack begins (grows upwards) */
Vineet Gupta283237a2013-05-28 09:34:45 +0530224 add2 \out, \out, (THREAD_SIZE)/4
Vineet Gupta9d42c842013-01-18 15:12:18 +0530225
226.endm
227
Vineet Gupta9d42c842013-01-18 15:12:18 +0530228/*
229 * @reg [OUT] thread_info->flags of "current"
230 */
231.macro GET_CURR_THR_INFO_FLAGS reg
232 GET_CURR_THR_INFO_FROM_SP \reg
233 ld \reg, [\reg, THREAD_INFO_FLAGS]
234.endm
235
Vineet Gupta41195d22013-01-18 15:12:23 +0530236#ifdef CONFIG_SMP
237
238/*-------------------------------------------------
239 * Retrieve the current running task on this CPU
240 * 1. Determine curr CPU id.
241 * 2. Use it to index into _current_task[ ]
242 */
243.macro GET_CURR_TASK_ON_CPU reg
244 GET_CPU_ID \reg
245 ld.as \reg, [@_current_task, \reg]
246.endm
247
248/*-------------------------------------------------
249 * Save a new task as the "current" task on this CPU
250 * 1. Determine curr CPU id.
251 * 2. Use it to index into _current_task[ ]
252 *
253 * Coded differently than GET_CURR_TASK_ON_CPU (which uses LD.AS)
254 * because ST r0, [r1, offset] can ONLY have s9 @offset
255 * while LD can take s9 (4 byte insn) or LIMM (8 byte insn)
256 */
257
258.macro SET_CURR_TASK_ON_CPU tsk, tmp
259 GET_CPU_ID \tmp
260 add2 \tmp, @_current_task, \tmp
261 st \tsk, [\tmp]
262#ifdef CONFIG_ARC_CURR_IN_REG
263 mov r25, \tsk
264#endif
265
266.endm
267
268
269#else /* Uniprocessor implementation of macros */
270
Vineet Gupta9d42c842013-01-18 15:12:18 +0530271.macro GET_CURR_TASK_ON_CPU reg
272 ld \reg, [@_current_task]
273.endm
274
275.macro SET_CURR_TASK_ON_CPU tsk, tmp
276 st \tsk, [@_current_task]
Vineet Gupta080c3742013-02-11 19:52:57 +0530277#ifdef CONFIG_ARC_CURR_IN_REG
278 mov r25, \tsk
279#endif
Vineet Gupta9d42c842013-01-18 15:12:18 +0530280.endm
281
Vineet Gupta41195d22013-01-18 15:12:23 +0530282#endif /* SMP / UNI */
283
Vineet Gupta9d42c842013-01-18 15:12:18 +0530284/* ------------------------------------------------------------------
285 * Get the ptr to some field of Current Task at @off in task struct
Vineet Gupta080c3742013-02-11 19:52:57 +0530286 * -Uses r25 for Current task ptr if that is enabled
Vineet Gupta9d42c842013-01-18 15:12:18 +0530287 */
288
Vineet Gupta080c3742013-02-11 19:52:57 +0530289#ifdef CONFIG_ARC_CURR_IN_REG
290
291.macro GET_CURR_TASK_FIELD_PTR off, reg
292 add \reg, r25, \off
293.endm
294
295#else
296
Vineet Gupta9d42c842013-01-18 15:12:18 +0530297.macro GET_CURR_TASK_FIELD_PTR off, reg
298 GET_CURR_TASK_ON_CPU \reg
299 add \reg, \reg, \off
300.endm
301
Vineet Gupta080c3742013-02-11 19:52:57 +0530302#endif /* CONFIG_ARC_CURR_IN_REG */
303
Vineet Gupta9d42c842013-01-18 15:12:18 +0530304#endif /* __ASM_ARC_ENTRY_H */