[Lldb-commits] [lldb] r201005 - Added a test case for variables in registers, with

Sean Callanan scallanan at apple.com
Fri Feb 7 15:04:57 PST 2014


Author: spyffe
Date: Fri Feb  7 17:04:57 2014
New Revision: 201005

URL: http://llvm.org/viewvc/llvm-project?rev=201005&view=rev
Log:
Added a test case for variables in registers, with
clang -O1.

<rdar://problem/15767528>

Added:
    lldb/trunk/test/lang/c/register_variables/
    lldb/trunk/test/lang/c/register_variables/Makefile
    lldb/trunk/test/lang/c/register_variables/TestRegisterVariables.py
    lldb/trunk/test/lang/c/register_variables/test.c

Added: lldb/trunk/test/lang/c/register_variables/Makefile
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/lang/c/register_variables/Makefile?rev=201005&view=auto
==============================================================================
--- lldb/trunk/test/lang/c/register_variables/Makefile (added)
+++ lldb/trunk/test/lang/c/register_variables/Makefile Fri Feb  7 17:04:57 2014
@@ -0,0 +1,7 @@
+LEVEL = ../../../make
+
+C_SOURCES := test.c
+
+CFLAGS ?= -g -O1
+
+include $(LEVEL)/Makefile.rules

Added: lldb/trunk/test/lang/c/register_variables/TestRegisterVariables.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/lang/c/register_variables/TestRegisterVariables.py?rev=201005&view=auto
==============================================================================
--- lldb/trunk/test/lang/c/register_variables/TestRegisterVariables.py (added)
+++ lldb/trunk/test/lang/c/register_variables/TestRegisterVariables.py Fri Feb  7 17:04:57 2014
@@ -0,0 +1,86 @@
+"""Check that compiler-generated register values work correctly"""
+
+import os, time
+import unittest2
+import lldb
+from lldbtest import *
+import lldbutil
+
+class RegisterVariableTestCase(TestBase):
+
+    mydir = TestBase.compute_mydir(__file__)
+
+    @dsym_test
+    def test_with_dsym_and_run_command(self):
+        """Test expressions on register values."""
+        self.buildDsym()
+        self.const_variable()
+
+    @skipIfLinux # This test works with gcc, but fails with newer version of clang on Linux due to a clang issue. Fails for icc as well. Bug number TDB.
+    @dwarf_test
+    def test_with_dwarf_and_run_command(self):
+        """Test expressions on register values."""
+        self.buildDwarf()
+        self.const_variable()
+
+    def setUp(self):
+        # Call super's setUp().
+        TestBase.setUp(self)
+
+    def const_variable(self):
+        """Test expressions on register values."""
+        exe = os.path.join(os.getcwd(), "a.out")
+        self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
+
+        # Break inside the main.
+        lldbutil.run_break_set_by_source_regexp(self, "break", num_expected_locations=2)
+
+        ####################
+        # First breakpoint
+
+        self.runCmd("run", RUN_SUCCEEDED)
+
+        # The stop reason of the thread should be breakpoint.
+        self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
+            substrs = ['stopped',
+                       'stop reason = breakpoint'])
+
+        # The breakpoint should have a hit count of 1.
+        self.expect("breakpoint list -f", BREAKPOINT_HIT_ONCE,
+            substrs = [' resolved, hit count = 1'])
+
+        # Try some variables that should be visible
+        self.expect("expr a", VARIABLES_DISPLAYED_CORRECTLY,
+            substrs = ['(int) $0 = 2'])
+
+        self.expect("expr b->m1", VARIABLES_DISPLAYED_CORRECTLY,
+            substrs = ['(int) $1 = 3'])
+
+        #####################
+        # Second breakpoint
+
+        self.runCmd("continue")
+
+        # The stop reason of the thread should be breakpoint.
+        self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
+            substrs = ['stopped',
+                       'stop reason = breakpoint'])
+
+        # The breakpoint should have a hit count of 1.
+        self.expect("breakpoint list -f", BREAKPOINT_HIT_ONCE,
+            substrs = [' resolved, hit count = 1'])
+
+        # Try some variables that should be visible
+        self.expect("expr b->m2", VARIABLES_DISPLAYED_CORRECTLY,
+            substrs = ['(int) $2 = 5'])
+
+        self.expect("expr c", VARIABLES_DISPLAYED_CORRECTLY,
+            substrs = ['(int) $3 = 5'])
+
+        self.runCmd("kill")
+
+if __name__ == '__main__':
+    import atexit
+    lldb.SBDebugger.Initialize()
+    atexit.register(lambda: lldb.SBDebugger.Terminate())
+    unittest2.main()

Added: lldb/trunk/test/lang/c/register_variables/test.c
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/lang/c/register_variables/test.c?rev=201005&view=auto
==============================================================================
--- lldb/trunk/test/lang/c/register_variables/test.c (added)
+++ lldb/trunk/test/lang/c/register_variables/test.c Fri Feb  7 17:04:57 2014
@@ -0,0 +1,27 @@
+#include <stdio.h>
+
+struct bar {
+  int m1;
+  int m2;
+};
+
+void f1(int a, struct bar *b) __attribute__ ((noinline));
+void f1(int a, struct bar *b)
+{
+  b->m2 = b->m1 + a; // set breakpoint here
+}
+
+void f2(struct bar *b) __attribute__ ((noinline));
+void f2(struct bar *b)
+{
+  int c = b->m2;
+  printf("%d\n", c); // set breakpoint here
+}
+
+int main()
+{
+  struct bar myBar = { 3, 4 };
+  f1(2, &myBar);
+  f2(&myBar);
+  return 0;
+}





More information about the lldb-commits mailing list