[Lldb-commits] [lldb] r359120 - [lldb] Use local definition of get_cpuid_count
Joseph Tremoulet via lldb-commits
lldb-commits at lists.llvm.org
Wed Apr 24 11:00:13 PDT 2019
Author: josepht
Date: Wed Apr 24 11:00:12 2019
New Revision: 359120
URL: http://llvm.org/viewvc/llvm-project?rev=359120&view=rev
Log:
[lldb] Use local definition of get_cpuid_count
Summary:
This is needed for gcc/cstdlib++ 5.4.0, where __get_cpuid_count is not
defined in cpuid.h.
Reviewers: labath
Reviewed By: labath
Subscribers: lldb-commits
Tags: #lldb
Differential Revision: https://reviews.llvm.org/D61036
Modified:
lldb/trunk/source/Plugins/Process/Linux/NativeRegisterContextLinux_x86_64.cpp
Modified: lldb/trunk/source/Plugins/Process/Linux/NativeRegisterContextLinux_x86_64.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/Process/Linux/NativeRegisterContextLinux_x86_64.cpp?rev=359120&r1=359119&r2=359120&view=diff
==============================================================================
--- lldb/trunk/source/Plugins/Process/Linux/NativeRegisterContextLinux_x86_64.cpp (original)
+++ lldb/trunk/source/Plugins/Process/Linux/NativeRegisterContextLinux_x86_64.cpp Wed Apr 24 11:00:12 2019
@@ -21,6 +21,23 @@
#include <cpuid.h>
#include <linux/elf.h>
+// Newer toolchains define __get_cpuid_count in cpuid.h, but some
+// older-but-still-supported ones (e.g. gcc 5.4.0) don't, so we
+// define it locally here, following the definition in clang/lib/Headers.
+static inline int get_cpuid_count(unsigned int __leaf,
+ unsigned int __subleaf,
+ unsigned int *__eax, unsigned int *__ebx,
+ unsigned int *__ecx, unsigned int *__edx)
+{
+ unsigned int __max_leaf = __get_cpuid_max(__leaf & 0x80000000, 0);
+
+ if (__max_leaf == 0 || __max_leaf < __leaf)
+ return 0;
+
+ __cpuid_count(__leaf, __subleaf, *__eax, *__ebx, *__ecx, *__edx);
+ return 1;
+}
+
using namespace lldb_private;
using namespace lldb_private::process_linux;
@@ -269,7 +286,7 @@ static std::size_t GetXSTATESize() {
return sizeof(FPR);
// Then fetch the maximum size of the area.
- if (!__get_cpuid_count(0x0d, 0, &eax, &ebx, &ecx, &edx))
+ if (!get_cpuid_count(0x0d, 0, &eax, &ebx, &ecx, &edx))
return sizeof(FPR);
return std::max<std::size_t>(ecx, sizeof(FPR));
}
More information about the lldb-commits
mailing list