1 /*
2  * Copyright (C) 2016 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef _LIBUNWINDSTACK_MACHINE_H
18 #define _LIBUNWINDSTACK_MACHINE_H
19 
20 #include <stdint.h>
21 
22 enum ArmReg : uint16_t {
23   ARM_REG_R0 = 0,
24   ARM_REG_R1,
25   ARM_REG_R2,
26   ARM_REG_R3,
27   ARM_REG_R4,
28   ARM_REG_R5,
29   ARM_REG_R6,
30   ARM_REG_R7,
31   ARM_REG_R8,
32   ARM_REG_R9,
33   ARM_REG_R10,
34   ARM_REG_R11,
35   ARM_REG_R12,
36   ARM_REG_R13,
37   ARM_REG_R14,
38   ARM_REG_R15,
39   ARM_REG_LAST,
40 
41   ARM_REG_SP = ARM_REG_R13,
42   ARM_REG_LR = ARM_REG_R14,
43   ARM_REG_PC = ARM_REG_R15,
44 };
45 
46 enum Arm64Reg : uint16_t {
47   ARM64_REG_R0 = 0,
48   ARM64_REG_R1,
49   ARM64_REG_R2,
50   ARM64_REG_R3,
51   ARM64_REG_R4,
52   ARM64_REG_R5,
53   ARM64_REG_R6,
54   ARM64_REG_R7,
55   ARM64_REG_R8,
56   ARM64_REG_R9,
57   ARM64_REG_R10,
58   ARM64_REG_R11,
59   ARM64_REG_R12,
60   ARM64_REG_R13,
61   ARM64_REG_R14,
62   ARM64_REG_R15,
63   ARM64_REG_R16,
64   ARM64_REG_R17,
65   ARM64_REG_R18,
66   ARM64_REG_R19,
67   ARM64_REG_R20,
68   ARM64_REG_R21,
69   ARM64_REG_R22,
70   ARM64_REG_R23,
71   ARM64_REG_R24,
72   ARM64_REG_R25,
73   ARM64_REG_R26,
74   ARM64_REG_R27,
75   ARM64_REG_R28,
76   ARM64_REG_R29,
77   ARM64_REG_R30,
78   ARM64_REG_R31,
79   ARM64_REG_PC,
80   ARM64_REG_LAST,
81 
82   ARM64_REG_SP = ARM64_REG_R31,
83   ARM64_REG_LR = ARM64_REG_R30,
84 };
85 
86 enum X86Reg : uint16_t {
87   X86_REG_EAX = 0,
88   X86_REG_ECX,
89   X86_REG_EDX,
90   X86_REG_EBX,
91   X86_REG_ESP,
92   X86_REG_EBP,
93   X86_REG_ESI,
94   X86_REG_EDI,
95   X86_REG_EIP,
96   X86_REG_EFL,
97   X86_REG_CS,
98   X86_REG_SS,
99   X86_REG_DS,
100   X86_REG_ES,
101   X86_REG_FS,
102   X86_REG_GS,
103   X86_REG_LAST,
104 
105   X86_REG_SP = X86_REG_ESP,
106   X86_REG_PC = X86_REG_EIP,
107 };
108 
109 enum X86_64Reg : uint16_t {
110   X86_64_REG_RAX = 0,
111   X86_64_REG_RDX,
112   X86_64_REG_RCX,
113   X86_64_REG_RBX,
114   X86_64_REG_RSI,
115   X86_64_REG_RDI,
116   X86_64_REG_RBP,
117   X86_64_REG_RSP,
118   X86_64_REG_R8,
119   X86_64_REG_R9,
120   X86_64_REG_R10,
121   X86_64_REG_R11,
122   X86_64_REG_R12,
123   X86_64_REG_R13,
124   X86_64_REG_R14,
125   X86_64_REG_R15,
126   X86_64_REG_RIP,
127   X86_64_REG_LAST,
128 
129   X86_64_REG_SP = X86_64_REG_RSP,
130   X86_64_REG_PC = X86_64_REG_RIP,
131 };
132 
133 #endif  // _LIBUNWINDSTACK_MACHINE_H
134