xref: /xnu-8792.41.9/bsd/dev/dtrace/scripts/ptrauth_arm64.d (revision 5c2921b07a2480ab43ec66f5b9e41cb872bc554f)
1*5c2921b0SApple OSS Distributions /*
2*5c2921b0SApple OSS Distributions  * Copyright (c) 2019 Apple Computer, Inc. All rights reserved.
3*5c2921b0SApple OSS Distributions  *
4*5c2921b0SApple OSS Distributions  * @APPLE_LICENSE_HEADER_START@
5*5c2921b0SApple OSS Distributions  *
6*5c2921b0SApple OSS Distributions  * The contents of this file constitute Original Code as defined in and
7*5c2921b0SApple OSS Distributions  * are subject to the Apple Public Source License Version 1.1 (the
8*5c2921b0SApple OSS Distributions  * "License").  You may not use this file except in compliance with the
9*5c2921b0SApple OSS Distributions  * License.  Please obtain a copy of the License at
10*5c2921b0SApple OSS Distributions  * http://www.apple.com/publicsource and read it before using this file.
11*5c2921b0SApple OSS Distributions  *
12*5c2921b0SApple OSS Distributions  * This Original Code and all software distributed under the License are
13*5c2921b0SApple OSS Distributions  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14*5c2921b0SApple OSS Distributions  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15*5c2921b0SApple OSS Distributions  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16*5c2921b0SApple OSS Distributions  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
17*5c2921b0SApple OSS Distributions  * License for the specific language governing rights and limitations
18*5c2921b0SApple OSS Distributions  * under the License.
19*5c2921b0SApple OSS Distributions  *
20*5c2921b0SApple OSS Distributions  * @APPLE_LICENSE_HEADER_END@
21*5c2921b0SApple OSS Distributions  */
22*5c2921b0SApple OSS Distributions 
23*5c2921b0SApple OSS Distributions enum ptrauth_key {
24*5c2921b0SApple OSS Distributions   ptrauth_key_asia = 0,
25*5c2921b0SApple OSS Distributions   ptrauth_key_asib = 1,
26*5c2921b0SApple OSS Distributions   ptrauth_key_asda = 2,
27*5c2921b0SApple OSS Distributions   ptrauth_key_asdb = 3,
28*5c2921b0SApple OSS Distributions 
29*5c2921b0SApple OSS Distributions   /* A process-independent key which can be used to sign code pointers.
30*5c2921b0SApple OSS Distributions      Signing and authenticating with this key is a no-op in processes
31*5c2921b0SApple OSS Distributions      which disable ABI pointer authentication. */
32*5c2921b0SApple OSS Distributions   ptrauth_key_process_independent_code = ptrauth_key_asia,
33*5c2921b0SApple OSS Distributions 
34*5c2921b0SApple OSS Distributions   /* A process-specific key which can be used to sign code pointers.
35*5c2921b0SApple OSS Distributions      Signing and authenticating with this key is enforced even in processes
36*5c2921b0SApple OSS Distributions      which disable ABI pointer authentication. */
37*5c2921b0SApple OSS Distributions   ptrauth_key_process_dependent_code = ptrauth_key_asib,
38*5c2921b0SApple OSS Distributions 
39*5c2921b0SApple OSS Distributions   /* A process-independent key which can be used to sign data pointers.
40*5c2921b0SApple OSS Distributions      Signing and authenticating with this key is a no-op in processes
41*5c2921b0SApple OSS Distributions      which disable ABI pointer authentication. */
42*5c2921b0SApple OSS Distributions   ptrauth_key_process_independent_data = ptrauth_key_asda,
43*5c2921b0SApple OSS Distributions 
44*5c2921b0SApple OSS Distributions   /* A process-specific key which can be used to sign data pointers.
45*5c2921b0SApple OSS Distributions      Signing and authenticating with this key is a no-op in processes
46*5c2921b0SApple OSS Distributions      which disable ABI pointer authentication. */
47*5c2921b0SApple OSS Distributions   ptrauth_key_process_dependent_data = ptrauth_key_asdb,
48*5c2921b0SApple OSS Distributions 
49*5c2921b0SApple OSS Distributions   /* The key used to sign C function pointers.
50*5c2921b0SApple OSS Distributions      The extra data is always 0. */
51*5c2921b0SApple OSS Distributions   ptrauth_key_function_pointer = ptrauth_key_process_independent_code,
52*5c2921b0SApple OSS Distributions 
53*5c2921b0SApple OSS Distributions   /* The key used to sign return addresses on the stack.
54*5c2921b0SApple OSS Distributions      The extra data is based on the storage address of the return address.
55*5c2921b0SApple OSS Distributions      On ARM64, that is always the storage address of the return address plus 8
56*5c2921b0SApple OSS Distributions      (or, in other words, the value of the stack pointer on function entry) */
57*5c2921b0SApple OSS Distributions   ptrauth_key_return_address = ptrauth_key_process_dependent_code,
58*5c2921b0SApple OSS Distributions 
59*5c2921b0SApple OSS Distributions   /* The key used to sign frame pointers on the stack.
60*5c2921b0SApple OSS Distributions      The extra data is based on the storage address of the frame pointer.
61*5c2921b0SApple OSS Distributions      On ARM64, that is always the storage address of the frame pointer plus 16
62*5c2921b0SApple OSS Distributions      (or, in other words, the value of the stack pointer on function entry) */
63*5c2921b0SApple OSS Distributions   ptrauth_key_frame_pointer = ptrauth_key_process_dependent_data,
64*5c2921b0SApple OSS Distributions 
65*5c2921b0SApple OSS Distributions   /* The key used to sign block function pointers, including:
66*5c2921b0SApple OSS Distributions        invocation functions,
67*5c2921b0SApple OSS Distributions        block object copy functions,
68*5c2921b0SApple OSS Distributions        block object destroy functions,
69*5c2921b0SApple OSS Distributions        __block variable copy functions, and
70*5c2921b0SApple OSS Distributions        __block variable destroy functions.
71*5c2921b0SApple OSS Distributions      The extra data is always the address at which the function pointer
72*5c2921b0SApple OSS Distributions      is stored.
73*5c2921b0SApple OSS Distributions 
74*5c2921b0SApple OSS Distributions      Note that block object pointers themselves (i.e. the direct
75*5c2921b0SApple OSS Distributions      representations of values of block-pointer type) are not signed. */
76*5c2921b0SApple OSS Distributions   ptrauth_key_block_function = ptrauth_key_asia,
77*5c2921b0SApple OSS Distributions 
78*5c2921b0SApple OSS Distributions   /* The key used to sign C++ v-table pointers.
79*5c2921b0SApple OSS Distributions      The extra data is always 0. */
80*5c2921b0SApple OSS Distributions   ptrauth_key_cxx_vtable_pointer = ptrauth_key_asda
81*5c2921b0SApple OSS Distributions 
82*5c2921b0SApple OSS Distributions };
83*5c2921b0SApple OSS Distributions 
84