/* * Copyright (c) 1994 by Xerox Corporation. All rights reserved. * Copyright (c) 1996 by Silicon Graphics. All rights reserved. * Copyright (c) 1998 by Fergus Henderson. All rights reserved. * Copyright (c) 2000-2009 by Hewlett-Packard Development Company. * All rights reserved. * * THIS MATERIAL IS PROVIDED AS IS, WITH ABSOLUTELY NO WARRANTY EXPRESSED * OR IMPLIED. ANY USE IS AT YOUR OWN RISK. * * Permission is hereby granted to use or copy this program * for any purpose, provided the above notices are retained on all copies. * Permission to modify the code and to distribute modified code is granted, * provided the above notices are retained, and a notice that the code was * modified is included with the above copyright notice. */ #ifndef GC_JAVAXFC_H #define GC_JAVAXFC_H #ifndef GC_H # include "gc.h" #endif #ifdef __cplusplus extern "C" { #endif /** * Invoke all remaining finalizers that have not yet been run. (Since the * notifier is not called, this should be called from a separate thread.) * This function is needed for strict compliance with the Java standard, * which can make the runtime guarantee that all finalizers are run. * This is problematic for several reasons: * 1. It means that finalizers, and all methods called by them, must be * prepared to deal with objects that have been finalized in spite of * the fact that they are still referenced by statically allocated * pointer variables (i.e. finalizers run at this point must be * prepared to deal with a mostly broken world); * 2. The Java standard implies we have to keep running finalizers until * there are no more left, thus it may mean that we get stuck in * an infinite loop running finalizers that create new finalizable * objects, though that is probably unlikely. * Thus this is not recommended for general use. * Acquires the allocator lock (to enqueue all finalizers). */ GC_API void GC_CALL GC_finalize_all(void); #ifdef GC_THREADS /** * External thread suspension support. No thread suspension count * (so a thread which has been suspended numerous times will be resumed * with the very first call to `GC_resume_thread()`). Acquires the * allocator lock. Thread should be registered in the collector. * Unimplemented on some platforms. Not recommended for general use. */ # ifndef GC_SUSPEND_THREAD_ID # define GC_SUSPEND_THREAD_ID void * # endif GC_API void GC_CALL GC_suspend_thread(GC_SUSPEND_THREAD_ID); GC_API void GC_CALL GC_resume_thread(GC_SUSPEND_THREAD_ID); /** * Is the given thread suspended externally? The result is either * 1 (true) or 0. Acquires the allocator lock in the reader mode. * Note: returns 0 (false) if the thread is not registered in the collector. * Unimplemented on some platforms (same as `GC_suspend_thread()`). */ GC_API int GC_CALL GC_is_thread_suspended(GC_SUSPEND_THREAD_ID); #endif /* GC_THREADS */ #ifdef __cplusplus } /* extern "C" */ #endif #endif /* GC_JAVAXFC_H */