1
0
mirror of https://github.com/php/php-src.git synced 2026-04-10 17:43:13 +02:00
Files
archived-php-src/Zend/tests/stack_limit/stack_limit_001.phpt
Arnaud Le Blanc cf77762970 Skip tests under MSAN
Stack overflows can be detected as long as C stack frames between two
execute_ex() calls use less than zend.reserved_stack_size bytes of stack.

The default value of zend.reserved_stack_size accounts for the largest stack
users, but MSAN instrumentation increases usage considerably: php_pcre2_match
uses more than 200KiB of stack in some MSAN build, compared to 20KiB without MSAN
according to -fstack-usage.
2022-12-19 21:41:48 +01:00

82 lines
1.5 KiB
PHP

--TEST--
Stack limit 001 - Stack limit checks with max_allowed_stack_size detection
--SKIPIF--
<?php
if (getenv('SKIP_MSAN')) die("skip msan requires a considerably higher zend.reserved_stack_size due to instrumentation");
?>
--EXTENSIONS--
zend_test
--INI--
; The test may use a large amount of memory on systems with a large stack limit
memory_limit=2G
--FILE--
<?php
var_dump(zend_test_zend_call_stack_get());
class Test1 {
public function __destruct() {
new Test1;
}
}
class Test2 {
public function __clone() {
clone $this;
}
}
class Test3 {
public function __sleep()
{
serialize($this);
}
}
function replace() {
return preg_replace_callback('#.#', function () {
return replace();
}, 'x');
}
try {
new Test1;
} catch (Error $e) {
echo $e->getMessage(), "\n";
}
try {
clone new Test2;
} catch (Error $e) {
echo $e->getMessage(), "\n";
}
try {
serialize(new Test3);
} catch (Error $e) {
echo $e->getMessage(), "\n";
}
try {
replace();
} catch (Error $e) {
echo $e->getMessage(), "\n";
}
?>
--EXPECTF--
array(4) {
["base"]=>
string(%d) "0x%x"
["max_size"]=>
string(%d) "0x%x"
["position"]=>
string(%d) "0x%x"
["EG(stack_limit)"]=>
string(%d) "0x%x"
}
Maximum call stack size of %d bytes reached. Infinite recursion?
Maximum call stack size of %d bytes reached. Infinite recursion?
Maximum call stack size of %d bytes reached. Infinite recursion?
Maximum call stack size of %d bytes reached. Infinite recursion?