diff options
| author | Brian Anderson <banderson@mozilla.com> | 2012-02-08 20:47:52 -0800 |
|---|---|---|
| committer | Brian Anderson <banderson@mozilla.com> | 2012-02-09 19:00:15 -0800 |
| commit | ae8ea4a78b113f67ade93152dc3dee1ded81a219 (patch) | |
| tree | 14a2a25ade42291bace7ad46516b6a959c04714e /src/rt/rust_task.cpp | |
| parent | b98df86c098ad3bb80c794fd0c2ead6ff1f608e7 (diff) | |
| download | rust-ae8ea4a78b113f67ade93152dc3dee1ded81a219.tar.gz rust-ae8ea4a78b113f67ade93152dc3dee1ded81a219.zip | |
rt: Add constructors and destructors for stacks
Diffstat (limited to 'src/rt/rust_task.cpp')
| -rw-r--r-- | src/rt/rust_task.cpp | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/rt/rust_task.cpp b/src/rt/rust_task.cpp index dc8b911778a..32245c5d9cd 100644 --- a/src/rt/rust_task.cpp +++ b/src/rt/rust_task.cpp @@ -538,7 +538,7 @@ void rust_task::free_stack(stk_seg *stk) { LOGPTR(thread, "freeing stk segment", (uintptr_t)stk); total_stack_sz -= user_stack_size(stk); - free(stk); + destroy_stack(this, stk); } void @@ -581,8 +581,8 @@ rust_task::new_stack(size_t requested_sz) { fail(); } - size_t sz = sizeof(stk_seg) + rust_stk_sz + RED_ZONE_SIZE; - stk_seg *new_stk = (stk_seg *)malloc(sz, "stack"); + size_t sz = rust_stk_sz + RED_ZONE_SIZE; + stk_seg *new_stk = create_stack(this, sz); LOGPTR(thread, "new stk", (uintptr_t)new_stk); memset(new_stk, 0, sizeof(stk_seg)); add_stack_canary(new_stk); |
