Skip to content
  1. Apr 22, 2011
    • Greg Clayton's avatar
      Did some work on the "register read" command to only show the first register · 385aa28c
      Greg Clayton authored
      set by default when dumping registers. If you want to see all of the register
      sets you can use the "--all" option:
      
      (lldb) register read --all
      
      If you want to just see some register sets, you can currently specify them
      by index:
      
      (lldb) register read --set 0 --set 2
      
      We need to get shorter register set names soon so we can specify the register
      sets by name without having to type too much. I will make this change soon.
      
      You can also have any integer encoded registers resolve the address values
      back to any code or data from the object files using the "--lookup" option.
      Below is sample output when stopped in the libc function "puts" with some
      const strings in registers:
      
      Process 8973 stopped
      * thread #1: tid = 0x2c03, 0x00007fff828fa30f libSystem.B.dylib`puts + 1, stop reason = instruction step into
        frame #0: 0x00007fff828fa30f libSystem.B.dylib`puts + 1
      (lldb) register read --lookup 
      General Purpose Registers:
        rax          = 0x0000000100000e98  "----------------------------------------------------------------------"
        rbx          = 0x0000000000000000
        rcx          = 0x0000000000000001  
        rdx          = 0x0000000000000000
        rdi          = 0x0000000100000e98  "----------------------------------------------------------------------"
        rsi          = 0x0000000100800000
        rbp          = 0x00007fff5fbff710
        rsp          = 0x00007fff5fbff280
        r8           = 0x0000000000000040  
        r9           = 0x0000000000000000
        r10          = 0x0000000000000000
        r11          = 0x0000000000000246  
        r12          = 0x0000000000000000
        r13          = 0x0000000000000000
        r14          = 0x0000000000000000
        r15          = 0x0000000000000000
        rip          = 0x00007fff828fa30f  libSystem.B.dylib`puts + 1
        rflags       = 0x0000000000000246  
        cs           = 0x0000000000000027  
        fs           = 0x0000000000000000
        gs           = 0x0000000000000000
      
      As we can see, we see two constant strings and the PC (register "rip") is 
      showing the code it resolves to.
      
      I fixed the register "--format" option to work as expected.
      
      Added a setting to disable skipping the function prologue when setting 
      breakpoints as a target settings variable:
      
      (lldb) settings set target.skip-prologue false
      
      Updated the user settings controller boolean value handler funciton to be able
      to take the default value so it can correctly respond to the eVarSetOperationClear
      operation.
      
      Did some usability work on the OptionValue classes.
      
      Fixed the "image lookup" command to correctly respond to the "--verbose" 
      option and display the detailed symbol context information when looking up
      line table entries and functions by name. This previously was only working
      for address lookups.
      
      llvm-svn: 129977
      385aa28c
  2. Apr 21, 2011
  3. Apr 20, 2011
    • Greg Clayton's avatar
      Fixed an issue where breakpoint were being displayed when using the "source list" · 3300d778
      Greg Clayton authored
      command when the file was implicit or found from a symbol.
      
      llvm-svn: 129867
      3300d778
    • Greg Clayton's avatar
      Added the ability for users to create new regex commands. · de164aaa
      Greg Clayton authored
      To do this currently, it must be done in multi-line mode:
      
      (lldb) commands regex --help "Help text for command" --syntax "syntax for command" <cmd-name>
      
      Any example that would use "f" for "finish" when there are no arguments,
      and "f <num>" to do a "frame select <num>" would be:
      (lldb) commands regex f
      Enter multiple regular expressions in the form s/find/replace/ then terminate with an empty line:
      s/^$/finish/
      s/([0-9]+)/frame select %1/
      
      (lldb) f 11
      frame select 12
      ...
      (lldb) f
      finish
      ...
      
      Also added the string version of the OptionValue as OptionValueString.
      
      llvm-svn: 129855
      de164aaa
    • Greg Clayton's avatar
      Added the start of a new option value system that we can use for many things · 45fa8b36
      Greg Clayton authored
      around the debugger. The class isn't hooked into anything yet, but it will be
      soon. 
      
      llvm-svn: 129843
      45fa8b36
    • Caroline Tice's avatar
      · 3ac6711a
      Caroline Tice authored
      Add the infrastructure to test instruction emulations automatically.
      The idea is that the instruction to be emulated is actually executed
      on the hardware to be emulated, with the before and after state of the
      hardware being captured and 'freeze-dried' into .dat files.  The
      emulation testing code then loads the before & after state from the
      .dat file, emulates the instruction using the before state, and
      compares the resulting state to the 'after' state.  If they match, the
      emulation is accurate, otherwise there is a problem.
      
      The final format of the .dat files needs a bit more work; the plan is
      to generalize them a bit and to convert the plain values to key-value pairs. 
      But I wanted to get this first pass committed.
      
      This commit adds arm instruction emulation testing to the testsuite, along with
      many initial .dat files.
      
      It also fixes a bug in the llvm disassembler, where 32-bit thumb opcodes
      were getting their upper & lower 16-bits reversed.
      
      There is a new Instruction sub-class, that is intended to be loaded
      from a .dat file rather than read from an executable.  There is also a
      new EmulationStateARM class, for handling the before & after states.
      EmulationStates for other architetures can be added later when we
      emulate their instructions.
      
      llvm-svn: 129832
      3ac6711a
    • Greg Clayton's avatar
      General cleanup on the UserSettingsController stuff. There were 5 different · 4c20717a
      Greg Clayton authored
      places that were dumping values for the settings. Centralized all of the
      value dumping into a single place. When dumping values that aren't strings
      we no longer surround the value with single quotes. When dumping values that
      are strings, surround the string value with double quotes. When dumping array
      values, assume they are always string values, and don't put quotes around
      dictionary values.
      
      llvm-svn: 129826
      4c20717a
  4. Apr 19, 2011
    • Greg Clayton's avatar
      Added a new option to the "source list" command that allows us to see where · 176761e5
      Greg Clayton authored
      line tables specify breakpoints can be set in the source. When dumping the
      source, the number of breakpoints that can be set on a source line are shown
      as a prefix:
      
      (lldb) source list -f test.c -l1 -c222 -b
             1   	#include <stdio.h>
             2   	#include <sys/fcntl.h>
             3   	#include <unistd.h>
             4   	int
             5   	sleep_loop (const int num_secs)
      [2]    6   	{
             7   	    int i;
      [1]    8   	    for (i=0; i<num_secs; ++i)
             9   	    {
      [1]    10  	        printf("%d of %i - sleep(1);\n", i, num_secs);
      [1]    11  	        sleep(1);       
             12  	    }
             13  	    return 0;
      [1]    14  	}
             15  	
             16  	int 
             17  	main (int argc, char const* argv[])
      [1]    18  	{
      [1]    19  	    printf("Process: %i\n\n", getpid());
      [1]    20  	    puts("Press any key to continue..."); getchar();
      [1]    21  	    sleep_loop (20);
             22  	    return 12;
      [1]    23  	}
      
      Above we can see there are two breakpoints for line 6 and one breakpoint for
      lines 8, 10, 11, 14, 18, 19, 20, 21 and 23. All other lines have no line table
      entries for them. This helps visualize the data provided in the debug 
      information without having to manually dump all line tables. It also includes
      all inline breakpoint that may result for a given file which can also be very
      handy to see.
      
      llvm-svn: 129747
      176761e5
    • Greg Clayton's avatar
      Fixed an issue where if you specify an architecture from the command line like: · 431ce678
      Greg Clayton authored
      $ lldb --arch i386-unknown-unknown a.out
      
      It would then create a target with only the "i386" part due to 
      SBDebugger::GetDefaultArchitecture(...) truncating the arch triple due to the
      way things used to be.
      
      llvm-svn: 129731
      431ce678
    • Johnny Chen's avatar
      Rename some variables, no functionality change. · a6ca9fb4
      Johnny Chen authored
      llvm-svn: 129724
      a6ca9fb4
  5. Apr 18, 2011
    • Johnny Chen's avatar
    • Greg Clayton's avatar
      Centralized a lot of the status information for processes, · 7260f620
      Greg Clayton authored
      threads, and stack frame down in the lldb_private::Process,
      lldb_private::Thread, lldb_private::StackFrameList and the 
      lldb_private::StackFrame classes. We had some command line
      commands that had duplicate versions of the process status
      output ("thread list" and "process status" for example). 
      
      Removed the "file" command and placed it where it should
      have been: "target create". Made an alias for "file" to
      "target create" so we stay compatible with GDB commands.
      
      We can now have multple usable targets in lldb at the
      same time. This is nice for comparing two runs of a program
      or debugging more than one binary at the same time. The
      new command is "target select <target-idx>" and also to see
      a list of the current targets you can use the new "target list"
      command. The flow in a debug session can be:
      
      (lldb) target create /path/to/exe/a.out
      (lldb) breakpoint set --name main
      (lldb) run
      ... hit breakpoint
      (lldb) target create /bin/ls
      (lldb) run /tmp
      Process 36001 exited with status = 0 (0x00000000) 
      (lldb) target list
      Current targets:
        target #0: /tmp/args/a.out ( arch=x86_64-apple-darwin, platform=localhost, pid=35999, state=stopped )
      * target #1: /bin/ls ( arch=x86_64-apple-darwin, platform=localhost, pid=36001, state=exited )
      (lldb) target select 0
      Current targets:
      * target #0: /tmp/args/a.out ( arch=x86_64-apple-darwin, platform=localhost, pid=35999, state=stopped )
        target #1: /bin/ls ( arch=x86_64-apple-darwin, platform=localhost, pid=36001, state=exited )
      (lldb) bt
      * thread #1: tid = 0x2d03, 0x0000000100000b9a a.out`main + 42 at main.c:16, stop reason = breakpoint 1.1
        frame #0: 0x0000000100000b9a a.out`main + 42 at main.c:16
        frame #1: 0x0000000100000b64 a.out`start + 52
      
      Above we created a target for "a.out" and ran and hit a
      breakpoint at "main". Then we created a new target for /bin/ls
      and ran it. Then we listed the targest and selected our original
      "a.out" program, so we showed two concurent debug sessions
      going on at the same time.
      
      llvm-svn: 129695
      7260f620
  6. Apr 16, 2011
  7. Apr 15, 2011
    • Johnny Chen's avatar
      Get rid the of set membership test (log(m)) and, instead, use an index variable 'i' · b57edcab
      Johnny Chen authored
      which advances when src collides with a purged slot.
      Hi Stephen, you're welcome to overwrite/or improve upon this version.  Thanks.
      
      llvm-svn: 129611
      b57edcab
    • Johnny Chen's avatar
      Update both the src and dst pointers at the end of the loop. · fec280e7
      Johnny Chen authored
      Stephen Wilson is working on a better performing patch in the meantime.
      
      llvm-svn: 129605
      fec280e7
    • Johnny Chen's avatar
      Optimize address range coalescing. · d2ddabac
      Johnny Chen authored
      DWARFDebugAranges::Sort() calls std::stable_sort() over a set of address ranges
      and then proceeds to collapse neighboring ranges together.
      
      One problem with the current implementation is that it does an incomplete job.
      When a pair of ranges are merged the next pair considered does not include the
      just-merged range.  IOW, three consecutive ranges are never collapsed into one.
      
      Another problem is that for each range merged we are calling
      std::vector::erase() which "shifts" all remaining elements of the vector by one
      position on every merge.  The end result (in the worst case) is a quadratic
      algorithm -- not good when the input vector is large.
      
      The following patch merges all consecutive ranges and removes the quadratic
      behavior.  The implementation uses an auxiliary vector of indices in order to
      remember all ranges that can be dropped, then performs the coalescing of ranges
      in a single pass.
      
      Patch from Stephen Wilson with some minor modification by me.
      
      llvm-svn: 129595
      d2ddabac
  8. Apr 14, 2011
    • Sean Callanan's avatar
      Updated LLVM to pick up fixes to the ARM instruction · 1b1bf6e9
      Sean Callanan authored
      tables.
      
      llvm-svn: 129500
      1b1bf6e9
    • Greg Clayton's avatar
      Added auto completion for architecture names and for platforms. · ab65b34f
      Greg Clayton authored
      Modified the OptionGroupOptions to be able to specify only some of the options
      that should be appended by using the usage_mask in the group defintions and
      also provided a way to remap them to a new usage mask after the copy. This 
      allows options to be re-used and also targetted for specific option groups.
      
      Modfied the CommandArgumentType to have a new eArgTypePlatform enumeration.
      Taught the option parser to be able to automatically use the appropriate
      auto completion for a given options if nothing is explicitly specified
      in the option definition. So you don't have to specify it in the option
      definition tables.
      
      Renamed the default host platform name to "host", and the default platform
      hostname to be "localhost".
      
      Modified the "file" and "platform select" commands to make sure all options
      and args are good prior to creating a new platform. Also defer the computation
      of the architecture in the file command until all options are parsed and the
      platform has either not been specified or reset to a new value to avoid
      computing the arch more than once.
      
      Switch the PluginManager code over to using llvm::StringRef for string
      comparisons and got rid of all the AccessorXXX functions in lieu of the newer
      mutex + collection singleton accessors.
      
      llvm-svn: 129483
      ab65b34f
  9. Apr 13, 2011
    • Caroline Tice's avatar
      · 17f5fa2b
      Caroline Tice authored
      Fix bug where source & target registers were swapped in an
      emulation function.
      
      llvm-svn: 129474
      17f5fa2b
    • Caroline Tice's avatar
      · 69955f6c
      Caroline Tice authored
      Fix various minor bugs in the ARM instruction emulation code.
      
      llvm-svn: 129422
      69955f6c
    • Greg Clayton's avatar
      Added two new classes for command options: · f6b8b581
      Greg Clayton authored
          lldb_private::OptionGroup
          lldb_private::OptionGroupOptions
      
      OptionGroup lets you define a class that encapsulates settings that you want
      to reuse in multiple commands. It contains only the option definitions and the
      ability to set the option values, but it doesn't directly interface with the
      lldb_private::Options class that is the front end to all of the CommandObject
      option parsing. For that the OptionGroupOptions class can be used. It aggregates
      one or more OptionGroup objects and directs the option setting to the 
      appropriate OptionGroup class. For an example of this, take a look at the 
      CommandObjectFile and how it uses its "m_option_group" object shown below
      to be able to set values in both the FileOptionGroup and PlatformOptionGroup
      classes. The members used in CommandObjectFile are:
      
          OptionGroupOptions m_option_group;
          FileOptionGroup m_file_options;
          PlatformOptionGroup m_platform_options;
      
      Then in the constructor for CommandObjectFile you can combine the option
      settings. The code below shows a simplified version of the constructor:
      
      CommandObjectFile::CommandObjectFile(CommandInterpreter &interpreter) :
          CommandObject (...),
          m_option_group (interpreter),
          m_file_options (),
          m_platform_options(true)
      {
          m_option_group.Append (&m_file_options);
          m_option_group.Append (&m_platform_options);
          m_option_group.Finalize();
      }
      
      We append the m_file_options and then the m_platform_options and then tell
      the option group the finalize the results. This allows the m_option_group to
      become the organizer of our prefs and after option parsing we end up with
      valid preference settings in both the m_file_options and m_platform_options
      objects. This also allows any other commands to use the FileOptionGroup and
      PlatformOptionGroup classes to implement options for their commands.
      
      Renamed:
          virtual void Options::ResetOptionValues();
      to:
          virtual void Options::OptionParsingStarting();
      
      And implemented a new callback named:
      
          virtual Error Options::OptionParsingFinished();
          
      This allows Options subclasses to verify that the options all go together
      after all of the options have been specified and gives the chance for the
      command object to return an error. It also gives a chance to take all of the
      option values and produce or initialize objects after all options have
      completed parsing.
      
      Modfied:
      
          virtual Error
          SetOptionValue (int option_idx, const char *option_arg) = 0;
          
      to be:
      
          virtual Error
          SetOptionValue (uint32_t option_idx, const char *option_arg) = 0;
      
      (option_idx is now unsigned).
      
      llvm-svn: 129415
      f6b8b581
  10. Apr 12, 2011
    • Greg Clayton's avatar
      Moved the execution context that was in the Debugger into · 8b82f087
      Greg Clayton authored
      the CommandInterpreter where it was always being used.
      
      Make sure that Modules can track their object file offsets correctly to
      allow opening of sub object files (like the "__commpage" on darwin).
      
      Modified the Platforms to be able to launch processes. The first part of this
      move is the platform soon will become the entity that launches your program
      and when it does, it uses a new ProcessLaunchInfo class which encapsulates
      all process launching settings. This simplifies the internal APIs needed for
      launching. I want to slowly phase out process launching from the process
      classes, so for now we can still launch just as we used to, but eventually
      the platform is the object that should do the launching.
      
      Modified the Host::LaunchProcess in the MacOSX Host.mm to correctly be able
      to launch processes with all of the new eLaunchFlag settings. Modified any
      code that was manually launching processes to use the Host::LaunchProcess
      functions.
      
      Fixed an issue where lldb_private::Args had implicitly defined copy 
      constructors that could do the wrong thing. This has now been fixed by adding
      an appropriate copy constructor and assignment operator.
      
      Make sure we don't add empty ModuleSP entries to a module list.
      
      Fixed the commpage module creation on MacOSX, but we still need to train
      the MacOSX dynamic loader to not get rid of it when it doesn't have an entry
      in the all image infos.
      
      Abstracted many more calls from in ProcessGDBRemote down into the 
      GDBRemoteCommunicationClient subclass to make the classes cleaner and more
      efficient.
      
      Fixed the default iOS ARM register context to be correct and also added support
      for targets that don't support the qThreadStopInfo packet by selecting the
      current thread (only if needed) and then sending a stop reply packet.
      
      Debugserver can now start up with a --unix-socket (-u for short) and can 
      then bind to port zero and send the port it bound to to a listening process
      on the other end. This allows the GDB remote platform to spawn new GDB server
      instances (debugserver) to allow platform debugging.
      
      llvm-svn: 129351
      8b82f087
  11. Apr 11, 2011
    • Stephen Wilson's avatar
      Order of initialization lists. · 71c21d18
      Stephen Wilson authored
          
      This patch fixes all of the warnings due to unordered initialization lists.
      
      Patch by Marco Minutoli.
      
      llvm-svn: 129290
      71c21d18
    • Caroline Tice's avatar
      · 88544c5f
      Caroline Tice authored
      Implement ARM emulation function to handle "SUBS PC, LR and related instructions".
      
      llvm-svn: 129279
      88544c5f
  12. Apr 09, 2011
    • Caroline Tice's avatar
      · 25d61ac2
      Caroline Tice authored
      Fix various things in the instruction emulation code:
      
          - Add ability to control whether or not the emulator advances the
          PC register (in the emulation state), if the instruction itself
          does not change the pc value..
      
          - Fix a few typos in asm description strings.
      
          - Fix bug in the carry flag calculation.
      
      llvm-svn: 129168
      25d61ac2
    • Johnny Chen's avatar
      Really fix the test suite crasher this time. · f16066e8
      Johnny Chen authored
      llvm-svn: 129165
      f16066e8
    • Johnny Chen's avatar
      Fix a test suite crasher. · 1f1b269b
      Johnny Chen authored
      llvm-svn: 129161
      1f1b269b
  13. Apr 08, 2011
    • Stephen Wilson's avatar
      Add missing headers. · 8acdbb8a
      Stephen Wilson authored
      Something changed in commit r129112 where a few standard headers vanished from
      the include chain when building on Linux.  Fix up by including limits.h for
      INT_MAX and PATH_MAX where needed, and stdio.h for printf().
      
      llvm-svn: 129130
      8acdbb8a
    • Stephen Wilson's avatar
      Add the ARM instruction emulation makefile. · 05459c82
      Stephen Wilson authored
      I forgot to 'svn add' this file in r129119.
      
      llvm-svn: 129120
      05459c82
    • Stephen Wilson's avatar
      Add makefile support for the ARM instruction emulation plugin. · d5adc918
      Stephen Wilson authored
      llvm-svn: 129119
      d5adc918
    • Stephen Wilson's avatar
      linux: add missing arguments to FindFirstModuleForFileSpec · 3f588d3f
      Stephen Wilson authored
      Specifying the new arguments as NULL is appropriate for now as this is
      backwards-compatible with the old invocation. 
      
      llvm-svn: 129118
      3f588d3f
    • Greg Clayton's avatar
      Modified the ArchSpec to take an optional "Platform *" when setting the triple. · eb0103f2
      Greg Clayton authored
      This allows you to have a platform selected, then specify a triple using
      "i386" and have the remaining triple items (vendor, os, and environment) set
      automatically.
      
      Many interpreter commands take the "--arch" option to specify an architecture
      triple, so now the command options needed to be able to get to the current
      platform, so the Options class now take a reference to the interpreter on
      construction.
      
      Modified the build LLVM building in the Xcode project to use the new
      Xcode project level user definitions:
      
      LLVM_BUILD_DIR - a path to the llvm build directory
      LLVM_SOURCE_DIR - a path to the llvm sources for the llvm that will be used to build lldb
      LLVM_CONFIGURATION - the configuration that lldb is built for (Release, 
      Release+Asserts, Debug, Debug+Asserts).
      
      I also changed the LLVM build to not check if "lldb/llvm" is a symlink and
      then assume it is a real llvm build directory versus the unzipped llvm.zip
      package, so now you can actually have a "lldb/llvm" directory in your lldb
      sources.
      
      llvm-svn: 129112
      eb0103f2
  14. Apr 07, 2011
    • Stephen Wilson's avatar
      Removed use of NSEC_PER_SEC. · f6e25904
      Stephen Wilson authored
      NSEC_PER_SEC is not defined in sys/time.h on Linux. Replaced that macro with a
      static constant inside TimeValue.
      
      Patch by Marco Minutoli.
      
      llvm-svn: 129071
      f6e25904
Loading