commit cdbacf2: [Fix] Fix hang when close is used
Vsevolod Stakhov
vsevolod at rspamd.com
Wed Oct 5 22:21:03 UTC 2022
Author: Vsevolod Stakhov
Date: 2022-10-05 23:12:04 +0100
URL: https://github.com/rspamd/rspamd/commit/cdbacf2b135fc49a84df1d0790c2ba77d6d763b7 (HEAD -> master)
[Fix] Fix hang when close is used
---
src/lua/lua_tcp.c | 18 ++++++++++++++++++
1 file changed, 18 insertions(+)
diff --git a/src/lua/lua_tcp.c b/src/lua/lua_tcp.c
index 05c9de7a2..643978a49 100644
--- a/src/lua/lua_tcp.c
+++ b/src/lua/lua_tcp.c
@@ -602,6 +602,12 @@ lua_tcp_push_error (struct lua_tcp_cbdata *cbd, gboolean is_fatal,
TCP_RELEASE (cbd);
+ if ((cbd->flags & (LUA_TCP_FLAG_FINISHED|LUA_TCP_FLAG_CONNECTED)) ==
+ (LUA_TCP_FLAG_FINISHED|LUA_TCP_FLAG_CONNECTED)) {
+ /* A callback has called `close` method, so we need to release a refcount */
+ TCP_RELEASE (cbd);
+ }
+
callback_called = TRUE;
}
@@ -694,6 +700,12 @@ lua_tcp_push_data (struct lua_tcp_cbdata *cbd, const guint8 *str, gsize len)
lua_settop (L, top);
TCP_RELEASE (cbd);
+
+ if ((cbd->flags & (LUA_TCP_FLAG_FINISHED|LUA_TCP_FLAG_CONNECTED)) ==
+ (LUA_TCP_FLAG_FINISHED|LUA_TCP_FLAG_CONNECTED)) {
+ /* A callback has called `close` method, so we need to release a refcount */
+ TCP_RELEASE (cbd);
+ }
}
lua_thread_pool_restore_callback (&cbs);
@@ -1134,6 +1146,12 @@ lua_tcp_handler (int fd, short what, gpointer ud)
lua_settop (L, top);
TCP_RELEASE (cbd);
lua_thread_pool_restore_callback (&cbs);
+
+ if ((cbd->flags & (LUA_TCP_FLAG_FINISHED|LUA_TCP_FLAG_CONNECTED)) ==
+ (LUA_TCP_FLAG_FINISHED|LUA_TCP_FLAG_CONNECTED)) {
+ /* A callback has called `close` method, so we need to release a refcount */
+ TCP_RELEASE (cbd);
+ }
}
}
}
More information about the Commits
mailing list