diff options
| author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2004-06-08 13:23:58 -0300 |
|---|---|---|
| committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2004-06-08 13:23:58 -0300 |
| commit | 9b854e6dbcf569113f68e63d87644b69eb00a228 (patch) | |
| tree | 11eb6b8f2bc3fe0e9138a7eea97ac84c343280ff /bugs | |
| parent | 2b2d8ecd7aba6cc7604532c53372db01a30618d3 (diff) | |
| download | lua-9b854e6dbcf569113f68e63d87644b69eb00a228.tar.gz lua-9b854e6dbcf569113f68e63d87644b69eb00a228.tar.bz2 lua-9b854e6dbcf569113f68e63d87644b69eb00a228.zip | |
BUG: string concatenation may cause arithmetic overflow, leading
to a buffer overflow.
Diffstat (limited to 'bugs')
| -rw-r--r-- | bugs | 36 |
1 files changed, 36 insertions, 0 deletions
| @@ -633,3 +633,39 @@ patch = [[ | |||
| 633 | ]], | 633 | ]], |
| 634 | 634 | ||
| 635 | } | 635 | } |
| 636 | |||
| 637 | |||
| 638 | |||
| 639 | ----------------------------------------------------------------- | ||
| 640 | -- Lua 5.0.2 | ||
| 641 | |||
| 642 | Bug{ | ||
| 643 | what = [[string concatenation may cause arithmetic overflow, leading | ||
| 644 | to a buffer overflow]], | ||
| 645 | |||
| 646 | report = [[Rici Lake, 20/05/2004]], | ||
| 647 | |||
| 648 | example = [[ | ||
| 649 | longs = string.rep("\0", 2^25) | ||
| 650 | function catter(i) | ||
| 651 | return assert(loadstring( | ||
| 652 | string.format("return function(a) return a%s end", | ||
| 653 | string.rep("..a", i-1))))() | ||
| 654 | end | ||
| 655 | rep129 = catter(129) | ||
| 656 | rep129(longs) | ||
| 657 | ]], | ||
| 658 | |||
| 659 | patch = [[ | ||
| 660 | * lvm.c: | ||
| 661 | 329c329,331 | ||
| 662 | < tl += tsvalue(top-n-1)->tsv.len; | ||
| 663 | --- | ||
| 664 | > size_t l = tsvalue(top-n-1)->tsv.len; | ||
| 665 | > if (l >= MAX_SIZET - tl) luaG_runerror(L, "string length overflow"); | ||
| 666 | > tl += l; | ||
| 667 | 332d333 | ||
| 668 | < if (tl > MAX_SIZET) luaG_runerror(L, "string size overflow"); | ||
| 669 | ]] | ||
| 670 | } | ||
| 671 | |||
