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
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.
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/
.
-
Configure your debugger to load Voltron when it starts by sourcing the
dbgentry.py
entry point script. The full path will be inside thevoltron
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. -
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 meansvoltron 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
-
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'
-
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
-
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
See the wiki on github.
See the issue tracker on github.
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.
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.