Skip to content

Commit

Permalink
Use explicit linker generated high/low symbols to determine stack bound.
Browse files Browse the repository at this point in the history
  • Loading branch information
sbc100 committed Oct 13, 2022
1 parent 264b61d commit 6cb654f
Show file tree
Hide file tree
Showing 5 changed files with 16 additions and 13 deletions.
6 changes: 3 additions & 3 deletions emscripten.py
Original file line number Diff line number Diff line change
Expand Up @@ -209,8 +209,8 @@ def compile_settings():
def set_memory(static_bump):
stack_low = align_memory(settings.GLOBAL_BASE + static_bump)
stack_high = align_memory(stack_low + settings.TOTAL_STACK)
settings.STACK_BASE = stack_high
settings.STACK_MAX = stack_low
settings.STACK_HIGH = stack_high
settings.STACK_LOW = stack_low
settings.HEAP_BASE = align_memory(stack_high)


Expand Down Expand Up @@ -353,7 +353,7 @@ def emscript(in_wasm, out_wasm, outfile_js, memfile):
dylink_sec = webassembly.parse_dylink_section(in_wasm)
static_bump = align_memory(dylink_sec.mem_size)
set_memory(static_bump)
logger.debug('stack_base: %d, stack_max: %d, heap_base: %d', settings.STACK_BASE, settings.STACK_MAX, settings.HEAP_BASE)
logger.debug('stack_low: %d, stack_high: %d, heap_base: %d', settings.STACK_LOW, settings.STACK_LOW, settings.HEAP_BASE)

# When building relocatable output (e.g. MAIN_MODULE) the reported table
# size does not include the reserved slot at zero for the null pointer.
Expand Down
4 changes: 3 additions & 1 deletion src/library.js
Original file line number Diff line number Diff line change
Expand Up @@ -3600,7 +3600,7 @@ mergeInto(LibraryManager.library, {
#if RELOCATABLE
// Globals that are normally exported from the wasm module but in relocatable
// mode are created here and imported by the module.
__stack_pointer: "new WebAssembly.Global({'value': '{{{ POINTER_WASM_TYPE }}}', 'mutable': true}, {{{ to64(STACK_BASE) }}})",
__stack_pointer: "new WebAssembly.Global({'value': '{{{ POINTER_WASM_TYPE }}}', 'mutable': true}, {{{ to64(STACK_HIGH) }}})",
// tell the memory segments where to place themselves
__memory_base: "new WebAssembly.Global({'value': '{{{ POINTER_WASM_TYPE }}}', 'mutable': false}, {{{ to64(GLOBAL_BASE) }}})",
// the wasm backend reserves slot 0 for the NULL function pointer
Expand All @@ -3617,6 +3617,8 @@ mergeInto(LibraryManager.library, {
// have __heap_base hardcoded into it - it receives it from JS as an extern
// global, basically).
__heap_base: '{{{ HEAP_BASE }}}',
__stack_high: '{{{ STACK_HIGH }}}',
__stack_low: '{{{ STACK_LOW }}}',
__global_base: '{{{ GLOBAL_BASE }}}',
#if WASM_EXCEPTIONS
// In dynamic linking we define tags here and feed them to each module
Expand Down
2 changes: 1 addition & 1 deletion src/postamble.js
Original file line number Diff line number Diff line change
Expand Up @@ -222,7 +222,7 @@ function stackCheckInit() {
assert(!ENVIRONMENT_IS_PTHREAD);
#endif
#if RELOCATABLE
_emscripten_stack_set_limits({{{ STACK_BASE }}} , {{{ STACK_MAX }}});
_emscripten_stack_set_limits({{{ STACK_HIGH }}} , {{{ STACK_LOW }}});
#else
_emscripten_stack_init();
#endif
Expand Down
4 changes: 2 additions & 2 deletions src/settings_internal.js
Original file line number Diff line number Diff line change
Expand Up @@ -215,8 +215,8 @@ var GENERATE_DWARF = false;

// Memory layout. These are only used/set in RELOCATABLE builds. Otherwise
// memory layout is fixed in the wasm binary at link time.
var STACK_BASE = 0;
var STACK_MAX = 0;
var STACK_HIGH = 0;
var STACK_LOW = 0;
var HEAP_BASE = 0;

// Used internally. set when there is a main() function.
Expand Down
13 changes: 7 additions & 6 deletions system/lib/compiler-rt/stack_limits.S
Original file line number Diff line number Diff line change
Expand Up @@ -39,19 +39,20 @@ emscripten_stack_init:
# emscripten_stack_get_base, or emscripten_stack_get_free are called
.functype emscripten_stack_init () -> ()

# The heap base is where the stack grown down from.
# What llvm calls __stack_high is the high address from where is grows
# downwards. We call this the stack base here in emscripten.
#ifdef __PIC__
global.get __heap_base@GOT
global.get __stack_high@GOT
#else
PTR.const __heap_base
PTR.const __stack_high
#endif
global.set __stack_base

# The end of stack data is the limit of the stack growth
# What llvm calles __stack_low is that end of the stack
#ifdef __PIC__
global.get __data_end@GOT
global.get __stack_low@GOT
#else
PTR.const __data_end
PTR.const __stack_low
#endif
# Align up to 16 bytes
PTR.const 0xf
Expand Down

0 comments on commit 6cb654f

Please sign in to comment.