diff options
| author | Valentina Giusti <valentina.giusti@intel.com> | 2016-10-06 15:49:10 +0000 |
|---|---|---|
| committer | Valentina Giusti <valentina.giusti@intel.com> | 2016-10-06 15:49:10 +0000 |
| commit | 0670ad14f87fafbe1b8b6fd2d5b12f3d01285ee7 (patch) | |
| tree | ad9ebdeffa85638358dc72e30bf78e24ca6178fc /lldb/packages/Python/lldbsuite | |
| parent | d03c85c02ec444cddb0d5d098e9164dbe59e5bde (diff) | |
| download | bcm5719-llvm-0670ad14f87fafbe1b8b6fd2d5b12f3d01285ee7.tar.gz bcm5719-llvm-0670ad14f87fafbe1b8b6fd2d5b12f3d01285ee7.zip | |
Improve test for Intel(R) MPX registers.
Summary:
Let the inferior test code determine if CPU and kernel support Intel(R)
MPX and cleanup test script.
Differential Revision: https://reviews.llvm.org/D25328
llvm-svn: 283461
Diffstat (limited to 'lldb/packages/Python/lldbsuite')
2 files changed, 8 insertions, 25 deletions
diff --git a/lldb/packages/Python/lldbsuite/test/functionalities/register/intel_xtended_registers/TestMPXRegisters.py b/lldb/packages/Python/lldbsuite/test/functionalities/register/intel_xtended_registers/TestMPXRegisters.py index 8bbe07751e1..96f3655542c 100644 --- a/lldb/packages/Python/lldbsuite/test/functionalities/register/intel_xtended_registers/TestMPXRegisters.py +++ b/lldb/packages/Python/lldbsuite/test/functionalities/register/intel_xtended_registers/TestMPXRegisters.py @@ -1,5 +1,5 @@ """ -Test the MPX registers. +Test the Intel(R) MPX registers. """ from __future__ import print_function @@ -21,23 +21,18 @@ class RegisterCommandsTestCase(TestBase): def setUp(self): TestBase.setUp(self) - self.has_teardown = False - - def tearDown(self): - self.dbg.GetSelectedTarget().GetProcess().Destroy() - TestBase.tearDown(self) @skipIf(compiler="clang") - @skipIf(oslist=["linux"], compiler="gcc", compiler_version=["<", "5"]) #GCC version >= 5 supports MPX. @skipIf(oslist=no_match(['linux'])) @skipIf(archs=no_match(['i386', 'x86_64'])) + @skipIf(oslist=["linux"], compiler="gcc", compiler_version=["<", "5"]) #GCC version >= 5 supports Intel(R) MPX. def test_mpx_registers_with_example_code(self): - """Test MPX registers with example code.""" + """Test Intel(R) MPX registers with example code.""" self.build() self.mpx_registers_with_example_code() def mpx_registers_with_example_code(self): - """Test MPX registers after running example code.""" + """Test Intel(R) MPX registers after running example code.""" self.line = line_number('main.cpp', '// Set a break point here.') exe = os.path.join(os.getcwd(), "a.out") @@ -50,7 +45,7 @@ class RegisterCommandsTestCase(TestBase): process = target.GetProcess() if (process.GetState() == lldb.eStateExited): - self.skipTest("HW doesn't support MPX feature.") + self.skipTest("Intel(R) MPX is not supported.") else: self.expect("thread backtrace", STOPPED_DUE_TO_BREAKPOINT, substrs = ["stop reason = breakpoint 1."]) diff --git a/lldb/packages/Python/lldbsuite/test/functionalities/register/intel_xtended_registers/main.cpp b/lldb/packages/Python/lldbsuite/test/functionalities/register/intel_xtended_registers/main.cpp index 1366d964e0f..d9adb550023 100644 --- a/lldb/packages/Python/lldbsuite/test/functionalities/register/intel_xtended_registers/main.cpp +++ b/lldb/packages/Python/lldbsuite/test/functionalities/register/intel_xtended_registers/main.cpp @@ -14,23 +14,11 @@ int main(int argc, char const *argv[]) { - unsigned int rax, rbx, rcx, rdx; - - // Check if XSAVE is enabled. - if (!__get_cpuid(1, &rax, &rbx, &rcx, &rdx) || (rcx & bit_OSXSAVE) != bit_OSXSAVE) - return -1; - - // Check if MPX is enabled. - if (__get_cpuid_max(0, NULL) > 7) - { - __cpuid_count(7, 0, rax, rbx, rcx, rdx); - if ((rbx & bit_MPX) != bit_MPX) - return -1; - } - else + // This call returns 0 only if the CPU and the kernel support Intel(R) MPX. + if (prctl(PR_MPX_ENABLE_MANAGEMENT, 0, 0, 0, 0) != 0) return -1; -// Run MPX test code. +// Run Intel(R) MPX test code. #if defined(__x86_64__) asm("mov $16, %rax\n\t" "mov $9, %rdx\n\t" |

