aboutsummaryrefslogtreecommitdiff
path: root/testes
diff options
context:
space:
mode:
authorRoberto Ierusalimschy <roberto@inf.puc-rio.br>2019-06-26 13:26:36 -0300
committerRoberto Ierusalimschy <roberto@inf.puc-rio.br>2019-06-26 13:26:36 -0300
commit8b7cfee26b71e66de2cef9f8db9d9e18f5439afd (patch)
tree8590bc5eba700f6c03da032bff8a925de257c726 /testes
parentc1a63c45f8ec5932993c8cec40d3c5ec0743349c (diff)
downloadlua-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.lua28
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 @@
4local debug = require "debug" 4local debug = require "debug"
5 5
6print"testing C-stack overflow detection" 6print"testing C-stack overflow detection"
7print"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
8local origlimit = debug.setCstacklimit(400) 22local origlimit = debug.setCstacklimit(400)
9print("current stack limit: " .. origlimit) 23print("default stack limit: " .. origlimit)
10debug.setCstacklimit(origlimit) 24
25-- change this value for different limits for this test suite
26local currentlimit = origlimit
27debug.setCstacklimit(currentlimit)
28print("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
17local function checkerror (msg, f, ...) 31local 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