diff options
| author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2019-06-26 13:26:36 -0300 |
|---|---|---|
| committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2019-06-26 13:26:36 -0300 |
| commit | 8b7cfee26b71e66de2cef9f8db9d9e18f5439afd (patch) | |
| tree | 8590bc5eba700f6c03da032bff8a925de257c726 /testes | |
| parent | c1a63c45f8ec5932993c8cec40d3c5ec0743349c (diff) | |
| download | lua-8b7cfee26b71e66de2cef9f8db9d9e18f5439afd.tar.gz lua-8b7cfee26b71e66de2cef9f8db9d9e18f5439afd.tar.bz2 lua-8b7cfee26b71e66de2cef9f8db9d9e18f5439afd.zip | |
Small changes around C-stack limit
- Better documentation in 'testes/cstack.lua' about using
'debug.setCstacklimit' to find a good limit.
- Constant LUAI_MAXCSTACK gets added CSTACKERR (extra stack for
error handling), so that it is compatible with the argument to
'debug.setCstacklimit'.
Diffstat (limited to 'testes')
| -rw-r--r-- | testes/cstack.lua | 28 |
1 files changed, 21 insertions, 7 deletions
diff --git a/testes/cstack.lua b/testes/cstack.lua index c7aa740f..2a55ce21 100644 --- a/testes/cstack.lua +++ b/testes/cstack.lua | |||
| @@ -4,15 +4,29 @@ | |||
| 4 | local debug = require "debug" | 4 | local debug = require "debug" |
| 5 | 5 | ||
| 6 | print"testing C-stack overflow detection" | 6 | print"testing C-stack overflow detection" |
| 7 | print"If this test craches, see its file ('cstack.lua')" | ||
| 8 | |||
| 9 | -- Segmentation faults in these tests probably result from a C-stack | ||
| 10 | -- overflow. To avoid these errors, you can use the function | ||
| 11 | -- 'debug.setCstacklimit' to set a smaller limit for the use of | ||
| 12 | -- C stack by Lua. After finding a reliable limit, you might want | ||
| 13 | -- to recompile Lua with this limit as the value for | ||
| 14 | -- the constant 'LUAI_MAXCCALLS', which defines the default limit. | ||
| 15 | -- (The default limit is printed by this test.) | ||
| 16 | -- Alternatively, you can ensure a larger stack for the program. | ||
| 17 | |||
| 18 | -- For Linux, a limit up to 30_000 seems Ok. Windows cannot go much | ||
| 19 | -- higher than 2_000. | ||
| 20 | |||
| 7 | 21 | ||
| 8 | local origlimit = debug.setCstacklimit(400) | 22 | local origlimit = debug.setCstacklimit(400) |
| 9 | print("current stack limit: " .. origlimit) | 23 | print("default stack limit: " .. origlimit) |
| 10 | debug.setCstacklimit(origlimit) | 24 | |
| 25 | -- change this value for different limits for this test suite | ||
| 26 | local currentlimit = origlimit | ||
| 27 | debug.setCstacklimit(currentlimit) | ||
| 28 | print("current stack limit: " .. currentlimit) | ||
| 11 | 29 | ||
| 12 | -- Segmentation faults in these tests probably result from a C-stack | ||
| 13 | -- overflow. To avoid these errors, recompile Lua with a smaller | ||
| 14 | -- value for the constant 'LUAI_MAXCCALLS' or else ensure a larger | ||
| 15 | -- stack for the program. | ||
| 16 | 30 | ||
| 17 | local function checkerror (msg, f, ...) | 31 | local function checkerror (msg, f, ...) |
| 18 | local s, err = pcall(f, ...) | 32 | local s, err = pcall(f, ...) |
| @@ -104,7 +118,7 @@ do print("testing changes in C-stack limit") | |||
| 104 | return n | 118 | return n |
| 105 | end | 119 | end |
| 106 | 120 | ||
| 107 | assert(debug.setCstacklimit(400) == origlimit) | 121 | assert(debug.setCstacklimit(400) == currentlimit) |
| 108 | local lim400 = check() | 122 | local lim400 = check() |
| 109 | -- a very low limit (given that the several calls to arive here) | 123 | -- a very low limit (given that the several calls to arive here) |
| 110 | local lowlimit = 38 | 124 | local lowlimit = 38 |
