mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2025-01-25 15:03:03 +00:00
BUG/MEDIUM: debug/lua: Don't dump the lua stack if not dumpable
When we try to dump the stack of a lua context, if it is not dumpable, nothing is performed and a message is emitted instead. This happens when a lua execution was interrupted inside a non-reentrant part. This patch depends on following commit : * MEDIUM: lua: Use a per-thread counter to track some non-reentrant parts of lua Thanks to this patch, we avoid a possible deadllock if the lua is interrupted by the watchdog in the lua memory allocator, because realloc() is not async-signal-safe. Both patches must be backported as far as 2.0.
This commit is contained in:
parent
a61789a1d6
commit
83926a04fe
10
src/debug.c
10
src/debug.c
@ -264,9 +264,13 @@ void ha_task_dump(struct buffer *buf, const struct task *task, const char *pfx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (hlua && hlua->T) {
|
if (hlua && hlua->T) {
|
||||||
luaL_traceback(hlua->T, hlua->T, NULL, 0);
|
if (hlua_not_dumpable == 0) {
|
||||||
if (!append_prefixed_str(buf, lua_tostring(hlua->T, -1), pfx, '\n', 1))
|
luaL_traceback(hlua->T, hlua->T, NULL, 0);
|
||||||
b_putchr(buf, '\n');
|
if (!append_prefixed_str(buf, lua_tostring(hlua->T, -1), pfx, '\n', 1))
|
||||||
|
b_putchr(buf, '\n');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
chunk_appendf(buf, "Inside non-rentrant part, Stack traceback not available\n");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
b_putchr(buf, '\n');
|
b_putchr(buf, '\n');
|
||||||
|
Loading…
Reference in New Issue
Block a user