about summary refs log tree commit diff
path: root/src/rt/rust_task.cpp
diff options
context:
space:
mode:
authorBrian Anderson <banderson@mozilla.com>2012-02-08 20:47:52 -0800
committerBrian Anderson <banderson@mozilla.com>2012-02-09 19:00:15 -0800
commitae8ea4a78b113f67ade93152dc3dee1ded81a219 (patch)
tree14a2a25ade42291bace7ad46516b6a959c04714e /src/rt/rust_task.cpp
parentb98df86c098ad3bb80c794fd0c2ead6ff1f608e7 (diff)
downloadrust-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.cpp6
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);