/lua-gdb

gdb extension for lua5.3+

Primary LanguagePython

Lua-gdb

gdb extension for lua5.3+.

tested on GNU gdb (Ubuntu 7.11.1-0ubuntu1~16.5) 7.11.1.

Features

Pretty printer

  • struct TValue
  • struct TString
  • struct Table
  • struct LClosure
  • struct CClosure
  • struct lua_State

Command

  • luacoroutines [L]

List all coroutines. Without arguments, uses the current value of "L" as the lua_State*. You can provide an alternate lua_State as the first argument.

  • luastack [L]

Prints values on the Lua C stack. Without arguments, uses the current value of "L" as the lua_State*. You can provide an alternate lua_State as the first argument.

  • luatraceback [L]

Dumps Lua execution stack, as debug.traceback() does. Without arguments, uses the current value of "L" as the lua_State*. You can provide an alternate lua_State as the first argument.

  • luagetlocal [L [f]]

Print all variables of the function at level 'f' of the stack 'coroutine'. With no arguments, Dump all variables of the current funtion in the stack of 'L'.

Usage (step by step)

  • compile lua with debug symbols
cd lua-5.3.4
make linux CFLAGS=-g
  • start gdb
gdb lua-5.3.4/src/lua
  • set a breakpoint
(gdb) break os_time
Breakpoint 1 at 0x42c9fe: file loslib.c, line 324.
  • run examples/dbg.lua
(gdb) run examples/dbg.lua
Starting program: /usr/local/bin/lua examples/dbg.lua

Breakpoint 1, os_time (L=0x64b9c8) at loslib.c:324
324     static int os_time (lua_State *L) {

will hit the breakpoint os_time.

  • load the extension
(gdb) source lua-gdb.py
Loading Lua Runtime support.
  • list all coroutines
(gdb) luacoroutines
m <coroutine 0x645018> = {[source] = [C]:-1, [func] = 0x427ff9 <luaB_coresume>}
  <coroutine 0x64b9c8> = {[source] = [C]:-1, [func] = 0x42c9f2 <os_time>}
  <coroutine 0x645638> = {[source] = [C]:-1, [func] = ?}
  • dump stack
(gdb) luastack 0x64b9c8
#0      0x64bb30        <os_time>
#1      0x64bb20        2
#2      0x64bb10        5
#3      0x64bb00        10
#4      0x64baf0        "kkk"
#5      0x64bae0        1
#6      0x64bad0        "nil"
#7      0x64bac0        "nil"
#8      0x64bab0        <lclosure 0x64b920> = {[file] = "@examples/dbg.lua", [linestart] = 17, [lineend] = 20, [nupvalues] = 1 '\001'}
  • dump traceback
(gdb) luatraceback 0x64b9c8
stack traceback:
        [C]:-1: in 0x42c9f2 <os_time>
        "@examples/dbg.lua":19: in ?
  • list all variables of a closure in the traceback
(gdb) luagetlocal 0x64b9c8 1
call info: "@examples/dbg.lua":19: in ?
        upval _ENV = 3.2627937150349253e-317
        ..... (*vararg) = 1
        ..... (*vararg) = "kkk"
        local x = 10
        local i = 5
        local n = 2
  • enjoy it!