blob: 323ce80235d5c6ff6237a0a9e732000a2bfffc78 [file] [log] [blame]
Christopher Ferris723cf9b2017-01-19 20:08:48 -08001/*
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
Christopher Ferris723cf9b2017-01-19 20:08:48 -080022enum 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
46enum 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
86enum 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
109enum 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