summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/common/demangle.cpp14
-rw-r--r--src/core/arm/arm_interface.cpp4
2 files changed, 9 insertions, 9 deletions
diff --git a/src/common/demangle.cpp b/src/common/demangle.cpp
index 17abdb85e..f4246f666 100644
--- a/src/common/demangle.cpp
+++ b/src/common/demangle.cpp
@@ -2,6 +2,7 @@
2// SPDX-License-Identifier: GPL-2.0-or-later 2// SPDX-License-Identifier: GPL-2.0-or-later
3 3
4#include "common/demangle.h" 4#include "common/demangle.h"
5#include "common/scope_exit.h"
5 6
6namespace llvm { 7namespace llvm {
7char* itaniumDemangle(const char* mangled_name, char* buf, size_t* n, int* status); 8char* itaniumDemangle(const char* mangled_name, char* buf, size_t* n, int* status);
@@ -13,10 +14,16 @@ std::string DemangleSymbol(const std::string& mangled) {
13 auto is_itanium = [](const std::string& name) -> bool { 14 auto is_itanium = [](const std::string& name) -> bool {
14 // A valid Itanium encoding requires 1-4 leading underscores, followed by 'Z'. 15 // A valid Itanium encoding requires 1-4 leading underscores, followed by 'Z'.
15 auto pos = name.find_first_not_of('_'); 16 auto pos = name.find_first_not_of('_');
16 return pos > 0 && pos <= 4 && name[pos] == 'Z'; 17 return pos > 0 && pos <= 4 && pos < name.size() && name[pos] == 'Z';
17 }; 18 };
18 19
20 if (mangled.empty()) {
21 return mangled;
22 }
23
19 char* demangled = nullptr; 24 char* demangled = nullptr;
25 SCOPE_EXIT({ std::free(demangled); });
26
20 if (is_itanium(mangled)) { 27 if (is_itanium(mangled)) {
21 demangled = llvm::itaniumDemangle(mangled.c_str(), nullptr, nullptr, nullptr); 28 demangled = llvm::itaniumDemangle(mangled.c_str(), nullptr, nullptr, nullptr);
22 } 29 }
@@ -24,10 +31,7 @@ std::string DemangleSymbol(const std::string& mangled) {
24 if (!demangled) { 31 if (!demangled) {
25 return mangled; 32 return mangled;
26 } 33 }
27 34 return demangled;
28 std::string ret = demangled;
29 std::free(demangled);
30 return ret;
31} 35}
32 36
33} // namespace Common 37} // namespace Common
diff --git a/src/core/arm/arm_interface.cpp b/src/core/arm/arm_interface.cpp
index a34200539..8aa7b9641 100644
--- a/src/core/arm/arm_interface.cpp
+++ b/src/core/arm/arm_interface.cpp
@@ -1,10 +1,6 @@
1// SPDX-FileCopyrightText: Copyright 2018 yuzu Emulator Project 1// SPDX-FileCopyrightText: Copyright 2018 yuzu Emulator Project
2// SPDX-License-Identifier: GPL-2.0-or-later 2// SPDX-License-Identifier: GPL-2.0-or-later
3 3
4#ifndef _MSC_VER
5#include <cxxabi.h>
6#endif
7
8#include <map> 4#include <map>
9#include <optional> 5#include <optional>
10 6