X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmini%2Ftasklets.c;h=e767f63125a6914d68d7258c3742ce08b2c4bed6;hb=d295ab661864a5dee77a97d298bf2dde09c94de1;hp=08deb0c00f2913bf8c8fdccf4173ec7d5e8d768f;hpb=15fedcada9e4cbad652c623e9d5bb4fd591d457b;p=mono.git diff --git a/mono/mini/tasklets.c b/mono/mini/tasklets.c index 08deb0c00f2..e767f63125a 100644 --- a/mono/mini/tasklets.c +++ b/mono/mini/tasklets.c @@ -1,3 +1,6 @@ +/** + * \file + */ #include "config.h" #include "tasklets.h" @@ -47,7 +50,7 @@ continuation_mark_frame (MonoContinuation *cont) if (cont->domain) return mono_get_exception_argument ("cont", "Already marked"); - jit_tls = (MonoJitTlsData *)mono_native_tls_get_value (mono_jit_tls_id); + jit_tls = (MonoJitTlsData *)mono_tls_get_jit_tls (); lmf = mono_get_lmf(); cont->domain = mono_domain_get (); cont->thread_id = mono_native_thread_id_get (); @@ -150,6 +153,57 @@ void mono_tasklets_cleanup (void) { } +#else +static +void continuations_not_supported (void) +{ + mono_set_pending_exception (mono_get_exception_not_implemented ("Tasklets are not implemented on this platform.")); +} + +static void* +continuation_alloc (void) +{ + continuations_not_supported (); + return NULL; +} + +static void +continuation_free (MonoContinuation *cont) +{ + continuations_not_supported (); +} + +static MonoException* +continuation_mark_frame (MonoContinuation *cont) +{ + continuations_not_supported (); + return NULL; +} + +static int +continuation_store (MonoContinuation *cont, int state, MonoException **e) +{ + continuations_not_supported (); + return 0; +} + +static MonoException* +continuation_restore (MonoContinuation *cont, int state) +{ + continuations_not_supported (); + return NULL; +} + +void +mono_tasklets_init(void) +{ + mono_add_internal_call ("Mono.Tasklets.Continuation::alloc", continuation_alloc); + mono_add_internal_call ("Mono.Tasklets.Continuation::free", continuation_free); + mono_add_internal_call ("Mono.Tasklets.Continuation::mark", continuation_mark_frame); + mono_add_internal_call ("Mono.Tasklets.Continuation::store", continuation_store); + mono_add_internal_call ("Mono.Tasklets.Continuation::restore", continuation_restore); + +} #endif