|
21 | 21 | #include <android-base/stringprintf.h>
|
22 | 22 | #include <android-base/strings.h>
|
23 | 23 |
|
24 |
| -static ArchType current_arch = GetBuildArch(); |
| 24 | +ArchType ScopedCurrentArch::current_arch = GetBuildArch(); |
25 | 25 |
|
26 |
| -ArchType GetCurrentArch() { |
27 |
| - return current_arch; |
28 |
| -} |
29 |
| - |
30 |
| -bool SetCurrentArch(const std::string& arch) { |
| 26 | +ArchType GetArchType(const std::string& arch) { |
31 | 27 | if (arch == "x86" || arch == "i686") {
|
32 |
| - current_arch = ARCH_X86_32; |
| 28 | + return ARCH_X86_32; |
33 | 29 | } else if (arch == "x86_64") {
|
34 |
| - current_arch = ARCH_X86_64; |
| 30 | + return ARCH_X86_64; |
35 | 31 | } else if (arch == "aarch64") {
|
36 |
| - current_arch = ARCH_ARM64; |
| 32 | + return ARCH_ARM64; |
37 | 33 | } else if (android::base::StartsWith(arch, "arm")) {
|
38 |
| - current_arch = ARCH_ARM; |
39 |
| - } else { |
40 |
| - LOG(ERROR) << "unsupported arch: " << arch; |
41 |
| - return false; |
| 34 | + return ARCH_ARM; |
42 | 35 | }
|
43 |
| - return true; |
| 36 | + LOG(ERROR) << "unsupported arch: " << arch; |
| 37 | + return ARCH_UNSUPPORTED; |
44 | 38 | }
|
45 | 39 |
|
46 |
| -uint64_t GetSupportedRegMask() { |
47 |
| - switch (GetCurrentArch()) { |
| 40 | +uint64_t GetSupportedRegMask(ArchType arch) { |
| 41 | + switch (arch) { |
48 | 42 | case ARCH_X86_32:
|
49 | 43 | return ((1ULL << PERF_REG_X86_32_MAX) - 1);
|
50 | 44 | case ARCH_X86_64:
|
@@ -78,10 +72,10 @@ static std::unordered_map<size_t, std::string> arm64_reg_map = {
|
78 | 72 | {PERF_REG_ARM64_LR, "lr"}, {PERF_REG_ARM64_SP, "sp"}, {PERF_REG_ARM64_PC, "pc"},
|
79 | 73 | };
|
80 | 74 |
|
81 |
| -std::string GetRegName(size_t regno) { |
| 75 | +std::string GetRegName(size_t regno, ArchType arch) { |
82 | 76 | // Cast regno to int type to avoid -Werror=type-limits.
|
83 | 77 | int reg = static_cast<int>(regno);
|
84 |
| - switch (GetCurrentArch()) { |
| 78 | + switch (arch) { |
85 | 79 | case ARCH_X86_64: {
|
86 | 80 | if (reg >= PERF_REG_X86_R8 && reg <= PERF_REG_X86_R15) {
|
87 | 81 | return android::base::StringPrintf("r%d", reg - PERF_REG_X86_R8 + 8);
|
@@ -133,18 +127,23 @@ bool GetRegValue(const RegSet& regs, size_t regno, uint64_t* value) {
|
133 | 127 | return false;
|
134 | 128 | }
|
135 | 129 |
|
136 |
| -bool GetSpRegValue(const RegSet& regs, uint64_t* value) { |
| 130 | +bool GetSpRegValue(const RegSet& regs, ArchType arch, uint64_t* value) { |
137 | 131 | size_t regno;
|
138 |
| -#if defined(__i386__) |
139 |
| - regno = PERF_REG_X86_SP; |
140 |
| -#elif defined(__x86_64__) |
141 |
| - regno = PERF_REG_X86_SP; |
142 |
| -#elif defined(__aarch64__) |
143 |
| - regno = PERF_REG_ARM64_SP; |
144 |
| -#elif defined(__arm__) |
145 |
| - regno = PERF_REG_ARM_SP; |
146 |
| -#else |
147 |
| - return false; |
148 |
| -#endif |
| 132 | + switch (arch) { |
| 133 | + case ARCH_X86_32: |
| 134 | + regno = PERF_REG_X86_SP; |
| 135 | + break; |
| 136 | + case ARCH_X86_64: |
| 137 | + regno = PERF_REG_X86_SP; |
| 138 | + break; |
| 139 | + case ARCH_ARM: |
| 140 | + regno = PERF_REG_ARM_SP; |
| 141 | + break; |
| 142 | + case ARCH_ARM64: |
| 143 | + regno = PERF_REG_ARM64_SP; |
| 144 | + break; |
| 145 | + default: |
| 146 | + return false; |
| 147 | + } |
149 | 148 | return GetRegValue(regs, regno, value);
|
150 | 149 | }
|
0 commit comments