A hacky debugger UI for hackers
Go to file
snare 3e9622ceb9 New screenshot 2014-10-29 18:18:30 +11:00
examples/angularview Use the LLDB lexer built for the angularjs example for the terminal 2014-10-29 02:42:56 +11:00
tests Added pointer deref in memory view/stack view 2014-10-28 04:14:54 +11:00
voltron Use LLDB lexer for GDB as well. Needs some work. 2014-10-29 03:25:40 +11:00
.gitignore .DS_Store 2013-10-30 05:16:31 +11:00
README.md New screenshot 2014-10-29 18:18:30 +11:00
dbgentry.py Fix load failure when pwd != repo :/ 2014-10-29 03:06:09 +11:00
setup.py Fixed some shit. Added TCP socket and HTTP support. 2014-07-25 00:34:42 +10:00

README.md

Voltron

Voltron is an extensible debugger UI for hackers. It allows you to attach utility views running in other terminals to your debugger (LLDB or GDB), displaying helpful information such as disassembly, stack contents, register values, etc, while still giving you the same debugger CLI you're used to. You can still have your pimped out custom prompt, macros, plugins, terminal colour scheme - whatever you're used to - but you get the added bonus of a sweet customisable heads-up display.

Voltron also provides a platform on which to build your own UI views, requesting and processing data from the debugger back end to suit your own requirements. To this end, Voltron provides (and uses internally) a JSON API available over UNIX domain sockets, TCP sockets and an HTTP server.

voltron example

Support

voltron is built primarily for LLDB, and also supports GDB version 7 and later.

The following architectures are supported:

  • x86
  • x86_64
  • armv7s
  • arm64

arm64 support is LLDB-only at this stage.

Installation

A standard python setup script is included.

# python setup.py install

This will install the voltron egg wherever that happens on your system, and an executable named voltron to /usr/local/bin/.

Quick Start

  1. Configure your debugger to load Voltron when it starts by sourcing the dbgentry.py entry point script. The full path will be inside the voltron egg. For example, on OS X it might be /Library/Python/2.7/site-packages/voltron-0.1-py2.7.egg/dbgentry.py.

    For LLDB:

     command script import /path/to/voltron/dbgentry.py
    

    For GDB:

     source /path/to/voltron/dbgentry.py
     voltron init
    

    This part can go in your .lldbinit or .gdbinit so it's automatically executed when the debugger starts.

  2. Start your debugger. On LLDB you need to call voltron init after you load the inferior, as a target must be loaded before Voltron's hooks can be installed. This means voltron init cannot be called from .lldbinit the way it can from .gdbinit. Hopefully this will be remedied with a more versatile hooking mechanism in a future version of LLDB (this has been discussed with the developers).

     $ lldb file_to_debug
     (lldb) voltron init
    
  3. In another terminal (I use iTerm panes) start one of the UI views

     $ voltron view reg -v
     $ voltron view stack
     $ voltron view disasm
     $ voltron view bt
     $ voltron view cmd 'reg read'
    
  4. Set a breakpoint and run your inferior. Once the inferior has started and the debugger has stopped (either because you interrupted it or because it hit a breakpoint) the views will update.

     (*db) b main
     (*db) run
    
  5. The debugger should hit the breakpoint and the views will be updated. A forced update can be triggered with the following command:

     (lldb) voltron stopped
    

Documentation

See the wiki on github.

Bugs

See the issue tracker on github.

License

This software is released under the "Buy snare a beer" license. If you use this and don't hate it, buy me a beer at a conference some time. This license also extends to other contributors - richo definitely deserves a few beers for his contributions.

Credits

Thanks to Azimuth Security for letting me spend time working on this.

Props to richo for all his contributions to Voltron.

fG!'s gdbinit was the original inspiration for this project.