about summary refs log tree commit diff
path: root/src/rt/rust_upcall.cpp
diff options
context:
space:
mode:
authorPatrick Walton <pcwalton@mimiga.net>2013-03-29 16:55:04 -0700
committerPatrick Walton <pcwalton@mimiga.net>2013-04-19 11:53:31 -0700
commitf903ae9e72ec02539373da22fd4d025422af7554 (patch)
treeccaf3a5daf113fc468c2e2a00ee10e6034a8ceb5 /src/rt/rust_upcall.cpp
parent1a36b0f17ef0b59411981fdd25ac9ce4ba7e20e0 (diff)
downloadrust-f903ae9e72ec02539373da22fd4d025422af7554.tar.gz
rust-f903ae9e72ec02539373da22fd4d025422af7554.zip
librustc: Implement fast-ffi and use it in various places
Diffstat (limited to 'src/rt/rust_upcall.cpp')
-rw-r--r--src/rt/rust_upcall.cpp15
1 files changed, 15 insertions, 0 deletions
diff --git a/src/rt/rust_upcall.cpp b/src/rt/rust_upcall.cpp
index 9f39e1433fc..e524e6de859 100644
--- a/src/rt/rust_upcall.cpp
+++ b/src/rt/rust_upcall.cpp
@@ -191,6 +191,14 @@ rust_upcall_malloc(type_desc *td, uintptr_t size) {
     return upcall_malloc(td, size);
 }
 
+extern "C" CDECL uintptr_t
+rust_upcall_malloc_noswitch(type_desc *td, uintptr_t size) {
+    rust_task *task = rust_get_current_task();
+    s_malloc_args args = {task, 0, td, size};
+    upcall_s_malloc(&args);
+    return args.retval;
+}
+
 /**********************************************************************
  * Called whenever an object in the task-local heap is freed.
  */
@@ -231,6 +239,13 @@ rust_upcall_free(void* ptr) {
     upcall_free(ptr);
 }
 
+extern "C" CDECL void
+rust_upcall_free_noswitch(void* ptr) {
+    rust_task *task = rust_get_current_task();
+    s_free_args args = {task,ptr};
+    upcall_s_free(&args);
+}
+
 /**********************************************************************/
 
 extern "C" _Unwind_Reason_Code