X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmetadata%2Fmonitor.h;h=374e331bd862e16c57bd2eeb57a3718350f6ad6e;hb=4fcd73dcb4046e1343dfc0976bd196435e3331f3;hp=4a516c207fbcd73ae5d3f7038fcc324cfeb05061;hpb=a097b5471761180c4aae2dab224ed9caeeae3e86;p=mono.git diff --git a/mono/metadata/monitor.h b/mono/metadata/monitor.h index 4a516c207fb..374e331bd86 100644 --- a/mono/metadata/monitor.h +++ b/mono/metadata/monitor.h @@ -21,8 +21,17 @@ void mono_locks_dump (gboolean include_untaken); void mono_monitor_init (void) MONO_INTERNAL; void mono_monitor_cleanup (void) MONO_INTERNAL; +void** mono_monitor_get_object_monitor_weak_link (MonoObject *object) MONO_INTERNAL; + +void mono_monitor_init_tls (void) MONO_INTERNAL; + +MonoMethod* mono_monitor_get_fast_path (MonoMethod *enter_or_exit) MONO_INTERNAL; + +void mono_monitor_threads_sync_members_offset (int *owner_offset, int *nest_offset, int *entry_count_offset) MONO_INTERNAL; +#define MONO_THREADS_SYNC_MEMBER_OFFSET(o) ((o)>>8) +#define MONO_THREADS_SYNC_MEMBER_SIZE(o) ((o)&0xff) + extern gboolean ves_icall_System_Threading_Monitor_Monitor_try_enter(MonoObject *obj, guint32 ms) MONO_INTERNAL; -extern void ves_icall_System_Threading_Monitor_Monitor_exit(MonoObject *obj) MONO_INTERNAL; extern gboolean ves_icall_System_Threading_Monitor_Monitor_test_owner(MonoObject *obj) MONO_INTERNAL; extern gboolean ves_icall_System_Threading_Monitor_Monitor_test_synchronised(MonoObject *obj) MONO_INTERNAL; extern void ves_icall_System_Threading_Monitor_Monitor_pulse(MonoObject *obj) MONO_INTERNAL;