BUG: string concatenation may cause arithmetic overflow, leading

to a buffer overflow.
This commit is contained in:
Roberto Ierusalimschy 2004-06-08 13:23:58 -03:00
parent 2b2d8ecd7a
commit 9b854e6dbc
2 changed files with 40 additions and 3 deletions

36
bugs
View File

@ -633,3 +633,39 @@ patch = [[
]], ]],
} }
-----------------------------------------------------------------
-- Lua 5.0.2
Bug{
what = [[string concatenation may cause arithmetic overflow, leading
to a buffer overflow]],
report = [[Rici Lake, 20/05/2004]],
example = [[
longs = string.rep("\0", 2^25)
function catter(i)
return assert(loadstring(
string.format("return function(a) return a%s end",
string.rep("..a", i-1))))()
end
rep129 = catter(129)
rep129(longs)
]],
patch = [[
* lvm.c:
329c329,331
< tl += tsvalue(top-n-1)->tsv.len;
---
> size_t l = tsvalue(top-n-1)->tsv.len;
> if (l >= MAX_SIZET - tl) luaG_runerror(L, "string length overflow");
> tl += l;
332d333
< if (tl > MAX_SIZET) luaG_runerror(L, "string size overflow");
]]
}

7
lvm.c
View File

@ -1,5 +1,5 @@
/* /*
** $Id: lvm.c,v 2.7 2004/05/31 18:51:50 roberto Exp roberto $ ** $Id: lvm.c,v 2.8 2004/06/02 19:07:55 roberto Exp roberto $
** Lua virtual machine ** Lua virtual machine
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -308,10 +308,11 @@ void luaV_concat (lua_State *L, int total, int last) {
char *buffer; char *buffer;
int i; int i;
while (n < total && tostring(L, top-n-1)) { /* collect total length */ while (n < total && tostring(L, top-n-1)) { /* collect total length */
tl += tsvalue(top-n-1)->len; size_t l = tsvalue(top-n-1)->len;
if (l >= MAX_SIZET - tl) luaG_runerror(L, "string length overflow");
tl += l;
n++; n++;
} }
if (tl > MAX_SIZET) luaG_runerror(L, "string size overflow");
buffer = luaZ_openspace(L, &G(L)->buff, tl); buffer = luaZ_openspace(L, &G(L)->buff, tl);
tl = 0; tl = 0;
for (i=n; i>0; i--) { /* concat all strings */ for (i=n; i>0; i--) { /* concat all strings */