[Tarantool-patches] [PATCH] Stack use after scope

Maria Khaydich maria.khaydich at tarantool.org
Sat Nov 30 00:40:55 MSK 2019


Missed something.
 
Issue:
https://github.com/tarantool/tarantool/issues/4637
Branch:
https://github.com/tarantool/tarantool/compare/eljashm/gh-4637-json-stack-use-after-scope
  
>Суббота, 30 ноября 2019, 0:36 +03:00 от Maria <maria.khaydich at tarantool.org>:
> 
>Json decode method allocated serializer struct on stack and referenced
>it after scope.
>
>Thanks to @Korablev77 for the initial investigation.
>
>Closes #4637
>---
> third_party/lua-cjson/lua_cjson.c | 6 +++---
> 1 file changed, 3 insertions(+), 3 deletions(-)
>
>diff --git a/third_party/lua-cjson/lua_cjson.c b/third_party/lua-cjson/lua_cjson.c
>index 3d7edbf28..3d25814f3 100644
>--- a/third_party/lua-cjson/lua_cjson.c
>+++ b/third_party/lua-cjson/lua_cjson.c
>@@ -1005,10 +1005,10 @@ static int json_decode(lua_State *l)
>                   "expected 1 or 2 arguments");
> 
>     if (lua_gettop(l) == 2) {
>- struct luaL_serializer user_cfg = *luaL_checkserializer(l);
>- luaL_serializer_parse_options(l, &user_cfg);
>+ struct luaL_serializer *user_cfg = luaL_checkserializer(l);
>+ luaL_serializer_parse_options(l, user_cfg);
>         lua_pop(l, 1);
>- json.cfg = &user_cfg;
>+ json.cfg = user_cfg;
>     } else {
>         json.cfg = luaL_checkserializer(l);
>     }
>--
>2.20.1 (Apple Git-117)
>  
 
 
--
Maria Khaydich
 
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.tarantool.org/pipermail/tarantool-patches/attachments/20191130/dd0ccdb0/attachment.html>


More information about the Tarantool-patches mailing list