Skip to content
  1. Sep 14, 2010
    • Greg Clayton's avatar
      Fixed the implementation of "bool Block::Contains (const Block *block) const" · 6f00abd5
      Greg Clayton authored
      to return the correct result.
      
      Fixed "bool Variable::IsInScope (StackFrame *frame)" to return the correct
      result when there are no location lists.
      
      Modified the "frame variable" command such that:
      - if no arguments are given (dump all frame variables), then we only show
        variables that are currently in scope
      - if some arguments are given, we show an error if the variable is out of 
        scope
      
      llvm-svn: 113830
      6f00abd5
    • Greg Clayton's avatar
      Looking at some of the test suite failures in DWARF in .o files with the · 016a95eb
      Greg Clayton authored
      debug map showed that the location lists in the .o files needed some 
      refactoring in order to work. The case that was failing was where a function
      that was in the "__TEXT.__textcoal_nt" in the .o file, and in the 
      "__TEXT.__text" section in the main executable. This made symbol lookup fail
      due to the way we were finding a real address in the debug map which was
      by finding the section that the function was in in the .o file and trying to
      find this in the main executable. Now the section list supports finding a
      linked address in a section or any child sections. After fixing this, we ran
      into issue that were due to DWARF and how it represents locations lists. 
      DWARF makes a list of address ranges and expressions that go along with those
      address ranges. The location addresses are expressed in terms of a compile
      unit address + offset. This works fine as long as nothing moves around. When
      stuff moves around and offsets change between the remapped compile unit base
      address and the new function address, then we can run into trouble. To deal
      with this, we now store supply a location list slide amount to any location
      list expressions that will allow us to make the location list addresses into
      zero based offsets from the object that owns the location list (always a
      function in our case). 
      
      With these fixes we can now re-link random address ranges inside the debugger
      for use with our DWARF + debug map, incremental linking, and more.
      
      Another issue that arose when doing the DWARF in the .o files was that GCC
      4.2 emits a ".debug_aranges" that only mentions functions that are externally
      visible. This makes .debug_aranges useless to us and we now generate a real
      address range lookup table in the DWARF parser at the same time as we index
      the name tables (that are needed because .debug_pubnames is just as useless).
      llvm-gcc doesn't generate a .debug_aranges section, though this could be 
      fixed, we aren't going to rely upon it.
      
      Renamed a bunch of "UINT_MAX" to "UINT32_MAX".
      
      llvm-svn: 113829
      016a95eb
  2. Sep 13, 2010
    • Greg Clayton's avatar
      Added the summary values for function pointers so we can show where they · 737b9329
      Greg Clayton authored
      point to.
      
      llvm-svn: 113735
      737b9329
    • Greg Clayton's avatar
      Fixed a crash that would happen when using "frame variables" on any struct, · 83ff3898
      Greg Clayton authored
      union, or class that contained an enumeration type. When I was creating
      the clang enumeration decl, I wasn't calling "EnumDecl::setIntegerType (QualType)" 
      which means that if the enum decl was ever asked to figure out it's bit width
      (getTypeInfo()) it would crash. We didn't run into this with enum types that 
      weren't inside classes because the DWARF already told us how big the type was
      and when we printed an enum we would never need to calculate the size, we
      would use the pre-cached byte size we got from the DWARF. When the enum was 
      in a struct/union/class and we tried to layout the struct, the layout code
      would attempt to get the type info and segfault.
      
      llvm-svn: 113729
      83ff3898
  3. Sep 12, 2010
    • Greg Clayton's avatar
      Bug #: 8408441 · fd269157
      Greg Clayton authored
      Fixed an issue where LLDB would fail to set a breakpoint by
      file and line if the DWARF line table has multiple file entries
      in the support files for a source file.
      
      llvm-svn: 113721
      fd269157
    • Greg Clayton's avatar
      Fixed an issue I found in the mach-o symbol table parsing where · 0c38b0de
      Greg Clayton authored
      we cached remapping information using the old nlist index to the
      new symbol index, yet we tried to lookup the symbol stubs that
      were for symbols that had been remapped by ID instead of using
      the new symbol index. This is now fixed and the mach-o symbol tables
      are fixed.
      
      Use the delta between two vector entries to determine the stride
      in case any padding is inserted by compilers for bsearch calls
      on symbol tables when finding symbols by their original ID.
      
      llvm-svn: 113719
      0c38b0de
  4. Sep 11, 2010
    • Greg Clayton's avatar
      Remove the eSymbolTypeFunction, eSymbolTypeGlobal, and eSymbolTypeStatic. · bcf2cfbd
      Greg Clayton authored
      They will now be represented as:
      eSymbolTypeFunction: eSymbolTypeCode with IsDebug() == true
        eSymbolTypeGlobal: eSymbolTypeData with IsDebug() == true and IsExternal() == true
        eSymbolTypeStatic: eSymbolTypeData with IsDebug() == true and IsExternal() == false
      
      This simplifies the logic when dealing with symbols and allows for symbols
      to be coalesced into a single symbol most of the time.
      
      Enabled the minimal symbol table for mach-o again after working out all the
      kinks. We now get nice concise symbol tables and debugging with DWARF in the
      .o files with a debug map in the binary works well again. There were issues
      where the SymbolFileDWARFDebugMap symbol file parser was using symbol IDs and
      symbol indexes interchangeably. Now that all those issues are resolved 
      debugging is working nicely.
      
      llvm-svn: 113678
      bcf2cfbd
    • Greg Clayton's avatar
      Make sure the address passed into SymbolContext::DumpStopContext() is valid... · 40b8d8a4
      Greg Clayton authored
      Make sure the address passed into SymbolContext::DumpStopContext() is valid before trying to calculate any offsets.
      
      llvm-svn: 113645
      40b8d8a4
  5. Sep 10, 2010
    • Jason Molenda's avatar
      The first part of an lldb native stack unwinder. · fbcb7f2c
      Jason Molenda authored
      The Unwind and RegisterContext subclasses still need
      to be finished; none of this code is used by lldb at
      this point (unless you call into it by hand).
      
      The ObjectFile class now has an UnwindTable object.
      
      The UnwindTable object has a series of FuncUnwinders
      objects (Function Unwinders) -- one for each function
      in that ObjectFile we've backtraced through during this
      debug session.
      
      The FuncUnwinders object has a few different UnwindPlans.
      UnwindPlans are a generic way of describing how to find
      the canonical address of a given function's stack frame
      (the CFA idea from DWARF/eh_frame) and how to restore the
      caller frame's register values, if they have been saved
      by this function.
      
      UnwindPlans are created from different sources.  One source is the
      eh_frame exception handling information generated by the compiler
      for unwinding an exception throw.  Another source is an assembly
      language inspection class (UnwindAssemblyProfiler, uses the Plugin
      architecture) which looks at the instructions in the funciton
      prologue and describes the stack movements/register saves that are
      done.
      
      Two additional types of UnwindPlans that are worth noting are
      the "fast" stack UnwindPlan which is useful for making a first
      pass over a thread's stack, determining how many stack frames there
      are and retrieving the pc and CFA values for each frame (enough
      to create StackFrameIDs).  Only a minimal set of registers is
      recovered during a fast stack walk.  
      
      The final UnwindPlan is an architectural default unwind plan.
      These are provided by the ArchDefaultUnwindPlan class (which uses
      the plugin architecture).  When no symbol/function address range can
      be found for a given pc value -- when we have no eh_frame information
      and when we don't have a start address so we can't examine the assembly
      language instrucitons -- we have to make a best guess about how to 
      unwind.  That's when we use the architectural default UnwindPlan.
      On x86_64, this would be to assume that rbp is used as a stack pointer
      and we can use that to find the caller's frame pointer and pc value.
      It's a last-ditch best guess about how to unwind out of a frame.
      
      There are heuristics about when to use one UnwindPlan versues the other --
      this will all happen in the still-begin-written UnwindLLDB subclass of
      Unwind which runs the UnwindPlans.
      
      llvm-svn: 113581
      fbcb7f2c
    • Greg Clayton's avatar
      Cleaned up the output of "image lookup --address <ADDR>" which involved · c9800667
      Greg Clayton authored
      cleaning up the output of many GetDescription objects that are part of a 
      symbol context. This fixes an issue where no ranges were being printed out
      for functions, blocks and symbols.
      
      llvm-svn: 113571
      c9800667
  6. Sep 07, 2010
    • Greg Clayton's avatar
      Added Symtab::FindSymbolByID() in preparation for enabling the minimal · 49bd1c84
      Greg Clayton authored
      symbol tables. Minimal symbol tables enable us to merge two symbols, one
      debug symbol and one linker symbol, into a single symbol that can carry
      just as much information and will avoid duplicate symbols in the symbol
      table.
      
      llvm-svn: 113223
      49bd1c84
    • Greg Clayton's avatar
      Added more API to lldb::SBBlock to allow getting the block · 95897c6a
      Greg Clayton authored
      parent, sibling and first child block, and access to the
      inline function information.
      
      Added an accessor the StackFrame:
      
      	Block * lldb_private::StackFrame::GetFrameBlock();
      	
      LLDB represents inline functions as lexical blocks that have
      inlined function information in them. The function above allows
      us to easily get the top most lexical block that defines a stack
      frame. When there are no inline functions in function, the block
      returned ends up being the top most block for the function. When
      the PC is in an inlined funciton for a frame, this will return the
      first parent block that has inlined function information. The
      other accessor: StackFrame::GetBlock() will return the deepest block
      that matches the frame's PC value. Since most debuggers want to display
      all variables in the current frame, the Block returned by
      StackFrame::GetFrameBlock can be used to retrieve all variables for
      the current frame.
      
      Fixed the lldb_private::Block::DumpStopContext(...) to properly
      display inline frames a block should display all of its inlined
      functions. Prior to this fix, one of the call sites was being skipped.
      This is a separate code path from the current default where inlined
      functions get their own frames.
      
      Fixed an issue where a block would always grab variables for any
      child inline function blocks.
      
      llvm-svn: 113195
      95897c6a
  7. Sep 02, 2010
    • Greg Clayton's avatar
      Added a new bool parameter to many of the DumpStopContext() methods that · 6dadd508
      Greg Clayton authored
      might dump file paths that allows the dumping of full paths or just the
      basenames. Switched the stack frame dumping code to use just the basenames for
      the files instead of the full path.
      
      Modified the StackID class to no rely on needing the start PC for the current
      function/symbol since we can use the SymbolContextScope to uniquely identify
      that, unless there is no symbol context scope. In that case we can rely upon
      the current PC value. This saves the StackID from having to calculate the 
      start PC when the StackFrame::GetStackID() accessor is called.
      
      Also improved the StackID less than operator to correctly handle inlined stack
      frames in the same stack.
      
      llvm-svn: 112867
      6dadd508
    • Greg Clayton's avatar
      StackFrame objects now own ValueObjects for any frame variables (locals, args, · 288bdf9c
      Greg Clayton authored
      function statics, file globals and static variables) that a frame contains. 
      The StackFrame objects can give out ValueObjects instances for
      each variable which allows us to track when a variable changes and doesn't
      depend on variable names when getting value objects.
      
      StackFrame::GetVariableList now takes a boolean to indicate if we want to
      get the frame compile unit globals and static variables.
      
      The value objects in the stack frames can now correctly track when they have
      been modified. There are a few more tweaks needed to complete this work. The
      biggest issue is when stepping creates partial stacks (just frame zero usually)
      and causes previous stack frames not to match up with the current stack frames
      because the previous frames only has frame zero. We don't really want to 
      require that all previous frames be complete since stepping often must check
      stack frames to complete their jobs. I will fix this issue tomorrow.
      
      llvm-svn: 112800
      288bdf9c
  8. Aug 30, 2010
    • Greg Clayton's avatar
      Clarified the intent of the SymbolContextScope class in the header · 59e8fc1c
      Greg Clayton authored
      documentation. Symbol now inherits from the symbol
      context scope so that the StackID can use a "SymbolContextScope *"
      instead of a blockID (which could have been the same as some other
      blockID from another symbol file). 
      
      Modified the stacks that are created on subsequent stops to reuse
      the previous stack frame objects which will allow for some internal
      optimization using pointer comparisons during stepping. 
      
      llvm-svn: 112495
      59e8fc1c
  9. Aug 24, 2010
    • Greg Clayton's avatar
      Got a lot of the kinks worked out in the inline support after debugging more · 9da7bd07
      Greg Clayton authored
      complex inlined examples.
      
      StackFrame classes don't have a "GetPC" anymore, they have "GetFrameCodeAddress()".
      This is because inlined frames will have a PC value that is the same as the 
      concrete frame that owns the inlined frame, yet the code locations for the
      frame can be different. We also need to be able to get the real PC value for
      a given frame so that variables evaluate correctly. To get the actual PC
      value for a frame you can use:
      
          addr_t pc = frame->GetRegisterContext()->GetPC();
      
      Some issues with the StackFrame stomping on its own symbol context were 
      resolved which were causing the information to change for a frame when the
      stack ID was calculated. Also the StackFrame will now correctly store the
      symbol context resolve flags for any extra bits of information that were 
      looked up (if you ask for a block only and you find one, you will alwasy have
      the compile unit and function).
      
      llvm-svn: 111964
      9da7bd07
    • Greg Clayton's avatar
      Added support for inlined stack frames being represented as real stack frames · 1b72fcb7
      Greg Clayton authored
      which is now on by default. Frames are gotten from the unwinder as concrete
      frames, then if inline frames are to be shown, extra information to track
      and reconstruct these frames is cached with each Thread and exanded as needed.
      
      I added an inline height as part of the lldb_private::StackID class, the class
      that helps us uniquely identify stack frames. This allows for two frames to
      shared the same call frame address, yet differ only in inline height.
      
      Fixed setting breakpoint by address to not require addresses to resolve.
      
      A quick example:
      
      % cat main.cpp
      
      % ./build/Debug/lldb test/stl/a.out 
      Current executable set to 'test/stl/a.out' (x86_64).
      (lldb) breakpoint set --address 0x0000000100000d31
      Breakpoint created: 1: address = 0x0000000100000d31, locations = 1
      (lldb) r
      Launching 'a.out'  (x86_64)
      (lldb) Process 38031 Stopped
      * thread #1: tid = 0x2e03, pc = 0x0000000100000d31, where = a.out`main [inlined] std::string::_M_data() const at /usr/include/c++/4.2.1/bits/basic_string.h:280, stop reason = breakpoint 1.1, queue = com.apple.main-thread
       277   	
       278   	      _CharT*
       279   	      _M_data() const
       280 ->	      { return  _M_dataplus._M_p; }
       281   	
       282   	      _CharT*
       283   	      _M_data(_CharT* __p)
      (lldb) bt
      thread #1: tid = 0x2e03, stop reason = breakpoint 1.1, queue = com.apple.main-thread
        frame #0: pc = 0x0000000100000d31, where = a.out`main [inlined] std::string::_M_data() const at /usr/include/c++/4.2.1/bits/basic_string.h:280
        frame #1: pc = 0x0000000100000d31, where = a.out`main [inlined] std::string::_M_rep() const at /usr/include/c++/4.2.1/bits/basic_string.h:288
        frame #2: pc = 0x0000000100000d31, where = a.out`main [inlined] std::string::size() const at /usr/include/c++/4.2.1/bits/basic_string.h:606
        frame #3: pc = 0x0000000100000d31, where = a.out`main [inlined] operator<< <char, std::char_traits<char>, std::allocator<char> > at /usr/include/c++/4.2.1/bits/basic_string.h:2414
        frame #4: pc = 0x0000000100000d31, where = a.out`main + 33 at /Volumes/work/gclayton/Documents/src/lldb/test/stl/main.cpp:14
        frame #5: pc = 0x0000000100000d08, where = a.out`start + 52
      
      Each inline frame contains only the variables that they contain and each inlined
      stack frame is treated as a single entity.
      
      llvm-svn: 111877
      1b72fcb7
  10. Aug 21, 2010
    • Greg Clayton's avatar
      Modified the host process monitor callback function Host::StartMonitoringChildProcess · 0b76a2c2
      Greg Clayton authored
      to spawn a thread for each process that is being monitored. Previously
      LLDB would spawn a single thread that would wait for any child process which
      isn't ok to do as a shared library (LLDB.framework on Mac OSX, or lldb.so on
      linux). The old single thread used to call wait4() with a pid of -1 which 
      could cause it to reap child processes that it shouldn't have.
      
      Re-wrote the way Function blocks are handles. Previously I attempted to keep
      all blocks in a single memory allocation (in a std::vector). This made the
      code somewhat efficient, but hard to work with. I got rid of the old BlockList
      class, and went to a straight parent with children relationship. This new 
      approach will allow for partial parsing of the blocks within a function.
      
      llvm-svn: 111706
      0b76a2c2
  11. Aug 20, 2010
  12. Aug 18, 2010
  13. Aug 10, 2010
  14. Aug 05, 2010
  15. Aug 04, 2010
    • Sean Callanan's avatar
      Added support for accessing members of C++ objects, · 5666b674
      Sean Callanan authored
      including superclass members.  This involved ensuring
      that access control was ignored, and ensuring that
      the operands of BitCasts were properly scanned for
      variables that needed importing.
      
      Also laid the groundwork for declaring objects of
      custom types; however, this functionality is disabled
      for now because of a potential loop in ASTImporter.
      
      llvm-svn: 110174
      5666b674
  16. Aug 03, 2010
    • Greg Clayton's avatar
      Added support for objective C built-in types: id, Class, and SEL. This · b0b9fe61
      Greg Clayton authored
      involved watching for the objective C built-in types in DWARF and making sure
      when we convert the DWARF types into clang types that we use the appropriate
      ASTContext types.
      
      Added a way to find and dump types in lldb (something equivalent to gdb's 
      "ptype" command):
      
          image lookup --type <TYPENAME>
      
      This only works for looking up types by name and won't work with variables.
      It also currently dumps out verbose internal information. I will modify it
      to dump more appropriate user level info in my next submission.
      
      Hookup up the "FindTypes()" functions in the SymbolFile and SymbolVendor so
      we can lookup types by name in one or more images.
      
      Fixed "image lookup --address <ADDRESS>" to be able to correctly show all
      symbol context information, but it will only show this extra information when
      the new "--verbose" flag is used.
      
      Updated to latest LLVM to get a few needed fixes.
      
      llvm-svn: 110089
      b0b9fe61
  17. Jul 30, 2010
  18. Jul 29, 2010
  19. Jul 28, 2010
    • Greg Clayton's avatar
      Created lldb::LanguageType by moving an enumeration from the · 9e40956a
      Greg Clayton authored
      lldb_private::Language class into the enumerations header so it can be freely
      used by other interfaces.
      
      Added correct objective C class support to the DWARF symbol parser. Prior to
      this fix we were parsing objective C classes as C++ classes and now that the
      expression parser is ready to call functions we need to make sure the objective
      C classes have correct AST types.
      
      llvm-svn: 109574
      9e40956a
  20. Jul 27, 2010
    • Sean Callanan's avatar
      Changed SymbolContext so when you search for functions · 8ade104a
      Sean Callanan authored
      it returns a list of functions as a SymbolContextList.
      
      Rewrote the clients of SymbolContext to use this
      SymbolContextList.
      
      Rewrote some of the providers of the data to SymbolContext
      to make them respect preferences as to whether the list
      should be cleared first; propagated that change out.
      
      ClangExpressionDeclMap and ClangASTSource use this new
      function list to properly generate function definitions -
      even for functions that don't have a prototype in the
      debug information.
      
      llvm-svn: 109476
      8ade104a
  21. Jul 23, 2010
  22. Jul 22, 2010
    • Greg Clayton's avatar
      Added a new enumeration named "ClangASTContext::AccessType" that abstracts the... · 8cf0593c
      Greg Clayton authored
      Added a new enumeration named "ClangASTContext::AccessType" that abstracts the type creation from the various access enumerations in Clang. Currently there are clang::AccessSpecifier and the objective C ivars have their own enumeration. So I added a new enumeration that will allow a consistent interface when creating types through ClangASTContext.
      
      I also added new functions to create an Objective C class, ivar and set an objective C superclass. They aren't hooked up in the DWARF parser yet. That is the next step, though I am unsure if I will do this in the DWARF parser or try and do it generically in the existing Record manipulation functions.
      
      llvm-svn: 109130
      8cf0593c
    • Greg Clayton's avatar
      Change over to using the definitions for mach-o types and defines to the · e1a916a7
      Greg Clayton authored
      defines that are in "llvm/Support/MachO.h". This should allow ObjectFileMachO
      and ObjectContainerUniversalMachO to be able to be cross compiled in Linux.
      
      Also did some cleanup on the ASTType by renaming it to ClangASTType and
      renaming the header file. Moved a lot of "AST * + opaque clang type *"
      functionality from lldb_private::Type over into ClangASTType.
      
      llvm-svn: 109046
      e1a916a7
  23. Jul 21, 2010
  24. Jul 20, 2010
  25. Jul 16, 2010
  26. Jul 14, 2010
Loading