master
1/*
2 * Copyright (c) 2007 Apple Inc. All rights reserved.
3 *
4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5 *
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. The rights granted to you under the License
10 * may not be used to create, or enable the creation or redistribution of,
11 * unlawful or unlicensed copies of an Apple operating system, or to
12 * circumvent, violate, or enable the circumvention or violation of, any
13 * terms of an Apple operating system software license agreement.
14 *
15 * Please obtain a copy of the License at
16 * http://www.opensource.apple.com/apsl/ and read it before using this file.
17 *
18 * The Original Code and all software distributed under the License are
19 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23 * Please see the License for the specific language governing rights and
24 * limitations under the License.
25 *
26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27 */
28/*
29 * FILE_ID: thread_status.h
30 */
31
32
33#ifndef _ARM_THREAD_STATUS_H_
34#define _ARM_THREAD_STATUS_H_
35
36#if defined (__arm__) || defined (__arm64__)
37
38#include <mach/machine/_structs.h>
39#include <mach/machine/thread_state.h>
40#include <mach/message.h>
41#include <mach/vm_types.h>
42
43
44/*
45 * Support for determining the state of a thread
46 */
47
48
49/*
50 * Flavors
51 */
52
53#define ARM_THREAD_STATE 1
54#define ARM_UNIFIED_THREAD_STATE ARM_THREAD_STATE
55#define ARM_VFP_STATE 2
56#define ARM_EXCEPTION_STATE 3
57#define ARM_DEBUG_STATE 4 /* pre-armv8 */
58#define THREAD_STATE_NONE 5
59#define ARM_THREAD_STATE64 6
60#define ARM_EXCEPTION_STATE64 7
61// ARM_THREAD_STATE_LAST 8 /* legacy */
62#define ARM_THREAD_STATE32 9
63#define ARM_EXCEPTION_STATE64_V2 10
64
65
66/* API */
67#define ARM_DEBUG_STATE32 14
68#define ARM_DEBUG_STATE64 15
69#define ARM_NEON_STATE 16
70#define ARM_NEON_STATE64 17
71#define ARM_CPMU_STATE64 18
72
73
74#define ARM_PAGEIN_STATE 27
75
76/* API */
77#define ARM_SME_STATE 28
78#define ARM_SVE_Z_STATE1 29
79#define ARM_SVE_Z_STATE2 30
80#define ARM_SVE_P_STATE 31
81#define ARM_SME_ZA_STATE1 32
82#define ARM_SME_ZA_STATE2 33
83#define ARM_SME_ZA_STATE3 34
84#define ARM_SME_ZA_STATE4 35
85#define ARM_SME_ZA_STATE5 36
86#define ARM_SME_ZA_STATE6 37
87#define ARM_SME_ZA_STATE7 38
88#define ARM_SME_ZA_STATE8 39
89#define ARM_SME_ZA_STATE9 40
90#define ARM_SME_ZA_STATE10 41
91#define ARM_SME_ZA_STATE11 42
92#define ARM_SME_ZA_STATE12 42
93#define ARM_SME_ZA_STATE13 44
94#define ARM_SME_ZA_STATE14 45
95#define ARM_SME_ZA_STATE15 46
96#define ARM_SME_ZA_STATE16 47
97#define ARM_SME2_STATE 48
98
99#define THREAD_STATE_FLAVORS 50 /* This must be updated to 1 more than the highest numerical state flavor */
100
101#ifndef ARM_STATE_FLAVOR_IS_OTHER_VALID
102#define ARM_STATE_FLAVOR_IS_OTHER_VALID(_flavor_) 0
103#endif
104
105#define FLAVOR_MODIFIES_CORE_CPU_REGISTERS(x) \
106((x == ARM_THREAD_STATE) || \
107 (x == ARM_THREAD_STATE32) || \
108 (x == ARM_THREAD_STATE64))
109
110#define VALID_THREAD_STATE_FLAVOR(x) \
111 ((x == ARM_THREAD_STATE) || \
112 (x == ARM_VFP_STATE) || \
113 (x == ARM_EXCEPTION_STATE) || \
114 (x == ARM_DEBUG_STATE) || \
115 (x == THREAD_STATE_NONE) || \
116 (x == ARM_THREAD_STATE32) || \
117 (x == ARM_THREAD_STATE64) || \
118 (x == ARM_EXCEPTION_STATE64) || \
119 (x == ARM_EXCEPTION_STATE64_V2) || \
120 (x == ARM_NEON_STATE) || \
121 (x == ARM_NEON_STATE64) || \
122 (x == ARM_DEBUG_STATE32) || \
123 (x == ARM_DEBUG_STATE64) || \
124 (x == ARM_PAGEIN_STATE) || \
125 (ARM_STATE_FLAVOR_IS_OTHER_VALID(x)))
126/*
127 * VALID_THREAD_STATE_FLAVOR() intentionally excludes ARM_SME_STATE through
128 * ARM_SME2_STATE, since these are not currently supported inside Mach exception
129 * ports.
130 */
131
132struct arm_state_hdr {
133 uint32_t flavor;
134 uint32_t count;
135};
136typedef struct arm_state_hdr arm_state_hdr_t;
137
138typedef _STRUCT_ARM_THREAD_STATE arm_thread_state_t;
139typedef _STRUCT_ARM_THREAD_STATE arm_thread_state32_t;
140typedef _STRUCT_ARM_THREAD_STATE64 arm_thread_state64_t;
141
142#if __DARWIN_C_LEVEL >= __DARWIN_C_FULL && defined(__arm64__)
143
144/* Accessor macros for arm_thread_state64_t pointer fields */
145
146/* Return pc field of arm_thread_state64_t as a data pointer value */
147#define arm_thread_state64_get_pc(ts) \
148 __darwin_arm_thread_state64_get_pc(ts)
149/* Return pc field of arm_thread_state64_t as a function pointer. May return
150 * NULL if a valid function pointer cannot be constructed, the caller should
151 * fall back to the arm_thread_state64_get_pc() macro in that case. */
152#define arm_thread_state64_get_pc_fptr(ts) \
153 __darwin_arm_thread_state64_get_pc_fptr(ts)
154/* Set pc field of arm_thread_state64_t to a function pointer */
155#define arm_thread_state64_set_pc_fptr(ts, fptr) \
156 __darwin_arm_thread_state64_set_pc_fptr(ts, fptr)
157/* Set pc field of arm_thread_state64_t to an already signed function pointer */
158#define arm_thread_state64_set_pc_presigned_fptr(ts, fptr) \
159 __darwin_arm_thread_state64_set_pc_presigned_fptr(ts, fptr)
160/* Return lr field of arm_thread_state64_t as a data pointer value */
161#define arm_thread_state64_get_lr(ts) \
162 __darwin_arm_thread_state64_get_lr(ts)
163/* Return lr field of arm_thread_state64_t as a function pointer. May return
164 * NULL if a valid function pointer cannot be constructed, the caller should
165 * fall back to the arm_thread_state64_get_lr() macro in that case. */
166#define arm_thread_state64_get_lr_fptr(ts) \
167 __darwin_arm_thread_state64_get_lr_fptr(ts)
168/* Set lr field of arm_thread_state64_t to a function pointer */
169#define arm_thread_state64_set_lr_fptr(ts, fptr) \
170 __darwin_arm_thread_state64_set_lr_fptr(ts, fptr)
171/* Set lr field of arm_thread_state64_t to an already signed function pointer */
172#define arm_thread_state64_set_lr_presigned_fptr(ts, fptr) \
173 __darwin_arm_thread_state64_set_lr_presigned_fptr(ts, fptr)
174/* Return sp field of arm_thread_state64_t as a data pointer value */
175#define arm_thread_state64_get_sp(ts) \
176 __darwin_arm_thread_state64_get_sp(ts)
177/* Set sp field of arm_thread_state64_t to a data pointer value */
178#define arm_thread_state64_set_sp(ts, ptr) \
179 __darwin_arm_thread_state64_set_sp(ts, ptr)
180/* Return fp field of arm_thread_state64_t as a data pointer value */
181#define arm_thread_state64_get_fp(ts) \
182 __darwin_arm_thread_state64_get_fp(ts)
183/* Set fp field of arm_thread_state64_t to a data pointer value */
184#define arm_thread_state64_set_fp(ts, ptr) \
185 __darwin_arm_thread_state64_set_fp(ts, ptr)
186/* Strip ptr auth bits from pc, lr, sp and fp field of arm_thread_state64_t */
187#define arm_thread_state64_ptrauth_strip(ts) \
188 __darwin_arm_thread_state64_ptrauth_strip(ts)
189
190#endif /* __DARWIN_C_LEVEL >= __DARWIN_C_FULL && defined(__arm64__) */
191
192struct arm_unified_thread_state {
193 arm_state_hdr_t ash;
194 union {
195 arm_thread_state32_t ts_32;
196 arm_thread_state64_t ts_64;
197 } uts;
198};
199#define ts_32 uts.ts_32
200#define ts_64 uts.ts_64
201typedef struct arm_unified_thread_state arm_unified_thread_state_t;
202
203#define ARM_THREAD_STATE_COUNT ((mach_msg_type_number_t) \
204 (sizeof (arm_thread_state_t)/sizeof(uint32_t)))
205#define ARM_THREAD_STATE32_COUNT ((mach_msg_type_number_t) \
206 (sizeof (arm_thread_state32_t)/sizeof(uint32_t)))
207#define ARM_THREAD_STATE64_COUNT ((mach_msg_type_number_t) \
208 (sizeof (arm_thread_state64_t)/sizeof(uint32_t)))
209#define ARM_UNIFIED_THREAD_STATE_COUNT ((mach_msg_type_number_t) \
210 (sizeof (arm_unified_thread_state_t)/sizeof(uint32_t)))
211
212
213typedef _STRUCT_ARM_VFP_STATE arm_vfp_state_t;
214typedef _STRUCT_ARM_NEON_STATE arm_neon_state_t;
215typedef _STRUCT_ARM_NEON_STATE arm_neon_state32_t;
216typedef _STRUCT_ARM_NEON_STATE64 arm_neon_state64_t;
217
218
219typedef _STRUCT_ARM_EXCEPTION_STATE arm_exception_state_t;
220typedef _STRUCT_ARM_EXCEPTION_STATE arm_exception_state32_t;
221typedef _STRUCT_ARM_EXCEPTION_STATE64 arm_exception_state64_t;
222typedef _STRUCT_ARM_EXCEPTION_STATE64_V2 arm_exception_state64_v2_t;
223
224typedef _STRUCT_ARM_DEBUG_STATE32 arm_debug_state32_t;
225typedef _STRUCT_ARM_DEBUG_STATE64 arm_debug_state64_t;
226
227typedef _STRUCT_ARM_PAGEIN_STATE arm_pagein_state_t;
228
229typedef _STRUCT_ARM_SME_STATE arm_sme_state_t;
230typedef _STRUCT_ARM_SVE_Z_STATE arm_sve_z_state_t;
231typedef _STRUCT_ARM_SVE_P_STATE arm_sve_p_state_t;
232typedef _STRUCT_ARM_SME_ZA_STATE arm_sme_za_state_t;
233typedef _STRUCT_ARM_SME2_STATE arm_sme2_state_t;
234
235/*
236 * Otherwise not ARM64 kernel and we must preserve legacy ARM definitions of
237 * arm_debug_state for binary compatability of userland consumers of this file.
238 */
239#if defined(__arm__)
240typedef _STRUCT_ARM_DEBUG_STATE arm_debug_state_t;
241#elif defined(__arm64__)
242typedef _STRUCT_ARM_LEGACY_DEBUG_STATE arm_debug_state_t;
243#else /* defined(__arm__) */
244#error Undefined architecture
245#endif /* defined(__arm__) */
246
247#define ARM_VFP_STATE_COUNT ((mach_msg_type_number_t) \
248 (sizeof (arm_vfp_state_t)/sizeof(uint32_t)))
249
250#define ARM_EXCEPTION_STATE_COUNT ((mach_msg_type_number_t) \
251 (sizeof (arm_exception_state_t)/sizeof(uint32_t)))
252
253#define ARM_EXCEPTION_STATE64_COUNT ((mach_msg_type_number_t) \
254 (sizeof (arm_exception_state64_t)/sizeof(uint32_t)))
255
256#define ARM_EXCEPTION_STATE64_V2_COUNT ((mach_msg_type_number_t) \
257 (sizeof (arm_exception_state64_v2_t)/sizeof(uint32_t)))
258
259#define ARM_DEBUG_STATE_COUNT ((mach_msg_type_number_t) \
260 (sizeof (arm_debug_state_t)/sizeof(uint32_t)))
261
262#define ARM_DEBUG_STATE32_COUNT ((mach_msg_type_number_t) \
263 (sizeof (arm_debug_state32_t)/sizeof(uint32_t)))
264
265#define ARM_PAGEIN_STATE_COUNT ((mach_msg_type_number_t) \
266 (sizeof (arm_pagein_state_t)/sizeof(uint32_t)))
267
268#define ARM_DEBUG_STATE64_COUNT ((mach_msg_type_number_t) \
269 (sizeof (arm_debug_state64_t)/sizeof(uint32_t)))
270
271#define ARM_NEON_STATE_COUNT ((mach_msg_type_number_t) \
272 (sizeof (arm_neon_state_t)/sizeof(uint32_t)))
273
274#define ARM_NEON_STATE64_COUNT ((mach_msg_type_number_t) \
275 (sizeof (arm_neon_state64_t)/sizeof(uint32_t)))
276
277#define ARM_SME_STATE_COUNT ((mach_msg_type_number_t) \
278 (sizeof (arm_sme_state_t)/sizeof(uint32_t)))
279
280#define ARM_SVE_Z_STATE_COUNT ((mach_msg_type_number_t) \
281 (sizeof (arm_sve_z_state_t)/sizeof(uint32_t)))
282
283#define ARM_SVE_P_STATE_COUNT ((mach_msg_type_number_t) \
284 (sizeof (arm_sve_p_state_t)/sizeof(uint32_t)))
285
286#define ARM_SME_ZA_STATE_COUNT ((mach_msg_type_number_t) \
287 (sizeof (arm_sme_za_state_t)/sizeof(uint32_t)))
288
289#define ARM_SME2_STATE_COUNT ((mach_msg_type_number_t) \
290 (sizeof (arm_sme2_state_t)/sizeof(uint32_t)))
291
292#define MACHINE_THREAD_STATE ARM_THREAD_STATE
293#define MACHINE_THREAD_STATE_COUNT ARM_UNIFIED_THREAD_STATE_COUNT
294
295
296/*
297 * Largest state on this machine:
298 */
299#define THREAD_MACHINE_STATE_MAX THREAD_STATE_MAX
300
301
302#endif /* defined (__arm__) || defined (__arm64__) */
303
304#endif /* _ARM_THREAD_STATUS_H_ */