From e43c5bdc6b47e8dd5e2ddcd6cf57fec79388523a Mon Sep 17 00:00:00 2001 From: Brian Anderson Date: Sun, 13 Jan 2013 16:53:13 -0800 Subject: Rewrite the exchange allocator to work without an active scheduler. #4457 --- src/rt/rust_stack.cpp | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) (limited to 'src/rt/rust_stack.cpp') diff --git a/src/rt/rust_stack.cpp b/src/rt/rust_stack.cpp index 466399bd5b5..3bcda8adf40 100644 --- a/src/rt/rust_stack.cpp +++ b/src/rt/rust_stack.cpp @@ -53,6 +53,8 @@ check_stack_canary(stk_seg *stk) { assert(stk->canary == canary_value && "Somebody killed the canary"); } +// XXX: Duplication here between the local and exchange heap constructors + stk_seg * create_stack(memory_region *region, size_t sz) { size_t total_sz = sizeof(stk_seg) + sz; @@ -69,3 +71,20 @@ destroy_stack(memory_region *region, stk_seg *stk) { deregister_valgrind_stack(stk); region->free(stk); } + +stk_seg * +create_exchange_stack(rust_exchange_alloc *exchange, size_t sz) { + size_t total_sz = sizeof(stk_seg) + sz; + stk_seg *stk = (stk_seg *)exchange->malloc(total_sz, false); + memset(stk, 0, sizeof(stk_seg)); + stk->end = (uintptr_t) &stk->data[sz]; + add_stack_canary(stk); + register_valgrind_stack(stk); + return stk; +} + +void +destroy_exchange_stack(rust_exchange_alloc *exchange, stk_seg *stk) { + deregister_valgrind_stack(stk); + exchange->free(stk); +} -- cgit 1.4.1-3-g733a5