[Lldb-commits] [lldb] r199134 - This is a macosx specific test case for stepping & setting breakpoints on indirect
Jim Ingham
jingham at apple.com
Mon Jan 13 12:44:26 PST 2014
Author: jingham
Date: Mon Jan 13 14:44:26 2014
New Revision: 199134
URL: http://llvm.org/viewvc/llvm-project?rev=199134&view=rev
Log:
This is a macosx specific test case for stepping & setting breakpoints on indirect
and re-exported symbols. I don't know if Linux has the latter, if it does, we could
probably make this a generic test. Somebody who knows how to make these gadgets on
Linux can maybe take a look...
Added:
lldb/trunk/test/macosx/indirect_symbol/
lldb/trunk/test/macosx/indirect_symbol/Makefile
lldb/trunk/test/macosx/indirect_symbol/TestIndirectSymbols.py
lldb/trunk/test/macosx/indirect_symbol/alias.list
lldb/trunk/test/macosx/indirect_symbol/indirect.c
lldb/trunk/test/macosx/indirect_symbol/main.c
lldb/trunk/test/macosx/indirect_symbol/reexport.c
Added: lldb/trunk/test/macosx/indirect_symbol/Makefile
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/macosx/indirect_symbol/Makefile?rev=199134&view=auto
==============================================================================
--- lldb/trunk/test/macosx/indirect_symbol/Makefile (added)
+++ lldb/trunk/test/macosx/indirect_symbol/Makefile Mon Jan 13 14:44:26 2014
@@ -0,0 +1,48 @@
+CC ?= clang
+ifeq "$(ARCH)" ""
+ ARCH = x86_64
+endif
+
+ifeq "$(OS)" ""
+ OS = $(shell uname -s)
+endif
+
+CFLAGS ?= -g -O0
+CWD := $(shell pwd)
+
+LIB_PREFIX := lib
+
+ifeq "$(OS)" "Darwin"
+ CFLAGS += -arch $(ARCH)
+ DS := dsymutil
+ LD_FLAGS := -dynamiclib
+ LIB_INDIRECT := $(LIB_PREFIX)indirect.dylib
+ LIB_REEXPORT := $(LIB_PREFIX)reexport.dylib
+ EXEC_PATH := "@executable_path"
+ EXEC_PATH_INDIRECT := -install_name $(EXEC_PATH)/$(LIB_INDIRECT)
+ EXEC_PATH_REEXPORT := -install_name $(EXEC_PATH)/$(LIB_REEXPORT)
+endif
+
+all: a.out $(LIB_INDIRECT) $(LIB_REEXPORT)
+
+a.out: main.o $(LIB_INDIRECT) $(LIB_REEXPORT)
+ $(CC) $(CFLAGS) -o a.out main.o -L. $(LIB_INDIRECT) $(LIB_REEXPORT)
+
+main.o: main.c
+ $(CC) $(CFLAGS) -c main.c
+
+$(LIB_INDIRECT): indirect.o
+ $(CC) $(CFLAGS) $(LD_FLAGS) $(EXEC_PATH_INDIRECT) -o $(LIB_INDIRECT) indirect.o
+ if [ "$(OS)" = "Darwin" ]; then dsymutil $(LIB_INDIRECT); fi
+
+indirect.o: indirect.c
+ $(CC) $(CFLAGS) -c indirect.c
+
+$(LIB_REEXPORT): reexport.o $(LIB_INDIRECT)
+ $(CC) $(CFLAGS) $(LD_FLAGS) $(EXEC_PATH_REEXPORT) -o $(LIB_REEXPORT) reexport.o -L. -lindirect -Wl,-alias_list,$(CWD)/alias.list
+ if [ "$(OS)" = "Darwin" ]; then dsymutil $(LIB_REEXPORT); fi
+
+reexport.o: reexport.c
+ $(CC) $(CFLAGS) -c reexport.c
+clean:
+ rm -rf *.o *~ *.dylib *.so a.out *.dSYM
Added: lldb/trunk/test/macosx/indirect_symbol/TestIndirectSymbols.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/macosx/indirect_symbol/TestIndirectSymbols.py?rev=199134&view=auto
==============================================================================
--- lldb/trunk/test/macosx/indirect_symbol/TestIndirectSymbols.py (added)
+++ lldb/trunk/test/macosx/indirect_symbol/TestIndirectSymbols.py Mon Jan 13 14:44:26 2014
@@ -0,0 +1,106 @@
+"""Test stepping and setting breakpoints in indirect and re-exported symbols."""
+
+import os, time
+import unittest2
+import lldb
+import lldbutil
+from lldbtest import *
+
+class TestObjCStepping(TestBase):
+
+ mydir = TestBase.compute_mydir(__file__)
+
+ @unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
+ @python_api_test
+ @dsym_test
+ def test_with_dsym_and_python_api(self):
+ """Test stepping and setting breakpoints in indirect and re-exported symbols."""
+ self.buildDsym()
+ self.indirect_stepping()
+
+ @unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
+ @python_api_test
+ @dwarf_test
+ def test_with_dwarf_and_python_api(self):
+ """Test stepping and setting breakpoints in indirect and re-exported symbols."""
+ self.buildDwarf()
+ self.indirect_stepping()
+
+ def setUp(self):
+ # Call super's setUp().
+ TestBase.setUp(self)
+ # Find the line numbers that we will step to in main:
+ self.main_source = "main.c"
+
+ def indirect_stepping(self):
+ """Test stepping and setting breakpoints in indirect and re-exported symbols."""
+ exe = os.path.join(os.getcwd(), "a.out")
+
+ target = self.dbg.CreateTarget(exe)
+ self.assertTrue(target, VALID_TARGET)
+
+ self.main_source_spec = lldb.SBFileSpec (self.main_source)
+
+ break1 = target.BreakpointCreateBySourceRegex ("Set breakpoint here to step in indirect.", self.main_source_spec)
+ self.assertTrue(break1, VALID_BREAKPOINT)
+
+ break2 = target.BreakpointCreateBySourceRegex ("Set breakpoint here to step in reexported.", self.main_source_spec)
+ self.assertTrue(break2, VALID_BREAKPOINT)
+
+ # Now launch the process, and do not stop at entry point.
+ process = target.LaunchSimple (None, None, self.get_process_working_directory())
+
+ self.assertTrue(process, PROCESS_IS_VALID)
+
+ # The stop reason of the thread should be breakpoint.
+ threads = lldbutil.get_threads_stopped_at_breakpoint (process, break1)
+ if len(threads) != 1:
+ self.fail ("Failed to stop at breakpoint 1.")
+
+ thread = threads[0]
+
+ # Now do a step-into, and we should end up in the hidden target of this indirect function.
+ thread.StepInto()
+ curr_function = thread.GetFrameAtIndex(0).GetFunctionName()
+ self.assertTrue (curr_function == "call_through_indirect_hidden", "Stepped into indirect symbols.")
+
+ # Now set a breakpoint using the indirect symbol name, and make sure we get to that:
+ break_indirect = target.BreakpointCreateByName ("call_through_indirect");
+ self.assertTrue (break_indirect, VALID_BREAKPOINT)
+
+ # Now continue should take us to the second call through the indirect symbol:
+
+ threads = lldbutil.continue_to_breakpoint (process, break_indirect)
+ self.assertTrue (len(threads) == 1, "Stopped at breakpoint in indirect function.")
+ curr_function = thread.GetFrameAtIndex(0).GetFunctionName()
+ self.assertTrue (curr_function == "call_through_indirect_hidden", "Stepped into indirect symbols.")
+
+ # Delete this breakpoint so it won't get in the way:
+ target.BreakpointDelete (break_indirect.GetID())
+
+ # Now continue to the site of the first re-exported function call in main:
+ threads = lldbutil.continue_to_breakpoint (process, break2)
+
+ # This is stepping Into through a re-exported symbol to an indirect symbol:
+ thread.StepInto()
+ curr_function = thread.GetFrameAtIndex(0).GetFunctionName()
+ self.assertTrue (curr_function == "call_through_indirect_hidden", "Stepped into indirect symbols.")
+
+ # And the last bit is to set a breakpoint on the re-exported symbol and make sure we are again in out target function.
+ break_reexported = target.BreakpointCreateByName ("reexport_to_indirect");
+ self.assertTrue (break_reexported, VALID_BREAKPOINT)
+
+ # Now continue should take us to the second call through the indirect symbol:
+
+ threads = lldbutil.continue_to_breakpoint (process, break_reexported)
+ self.assertTrue (len(threads) == 1, "Stopped at breakpoint in reexported function target.")
+ curr_function = thread.GetFrameAtIndex(0).GetFunctionName()
+ self.assertTrue (curr_function == "call_through_indirect_hidden", "Stepped into indirect symbols.")
+
+
+
+if __name__ == '__main__':
+ import atexit
+ lldb.SBDebugger.Initialize()
+ atexit.register(lambda: lldb.SBDebugger.Terminate())
+ unittest2.main()
Added: lldb/trunk/test/macosx/indirect_symbol/alias.list
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/macosx/indirect_symbol/alias.list?rev=199134&view=auto
==============================================================================
--- lldb/trunk/test/macosx/indirect_symbol/alias.list (added)
+++ lldb/trunk/test/macosx/indirect_symbol/alias.list Mon Jan 13 14:44:26 2014
@@ -0,0 +1 @@
+_call_through_indirect _reexport_to_indirect
\ No newline at end of file
Added: lldb/trunk/test/macosx/indirect_symbol/indirect.c
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/macosx/indirect_symbol/indirect.c?rev=199134&view=auto
==============================================================================
--- lldb/trunk/test/macosx/indirect_symbol/indirect.c (added)
+++ lldb/trunk/test/macosx/indirect_symbol/indirect.c Mon Jan 13 14:44:26 2014
@@ -0,0 +1,14 @@
+#define MakeResolver(name) \
+ void * name ## Resolver(void) __asm__("_" #name); \
+ void * name ## Resolver(void) { \
+ __asm__(".symbol_resolver _" #name); \
+ return name ## _hidden; \
+ }
+
+int
+call_through_indirect_hidden(int arg)
+{
+ return arg + 5;
+}
+
+MakeResolver(call_through_indirect)
Added: lldb/trunk/test/macosx/indirect_symbol/main.c
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/macosx/indirect_symbol/main.c?rev=199134&view=auto
==============================================================================
--- lldb/trunk/test/macosx/indirect_symbol/main.c (added)
+++ lldb/trunk/test/macosx/indirect_symbol/main.c Mon Jan 13 14:44:26 2014
@@ -0,0 +1,14 @@
+extern int call_through_indirect(int);
+extern int call_through_reexport(int);
+
+int
+main ()
+{
+ int indirect_result = call_through_indirect(20); // Set breakpoint here to step in indirect.
+ indirect_result = call_through_indirect(30);
+
+ int reexport_result = reexport_to_indirect (20); // Set breakpoint here to step in reexported.
+ reexport_result = reexport_to_indirect (30);
+
+ return 0;
+}
Added: lldb/trunk/test/macosx/indirect_symbol/reexport.c
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/macosx/indirect_symbol/reexport.c?rev=199134&view=auto
==============================================================================
--- lldb/trunk/test/macosx/indirect_symbol/reexport.c (added)
+++ lldb/trunk/test/macosx/indirect_symbol/reexport.c Mon Jan 13 14:44:26 2014
@@ -0,0 +1,7 @@
+extern int call_through_indirect(int);
+
+int
+fake_call_through_reexport(int value)
+{
+ return value + 10;
+}
More information about the lldb-commits
mailing list