]> pd.if.org Git - pdclib/blobdiff - functions/stdlib/exit.c
Fallback to static array as pre-main malloc() created problems. (_start calls atexit...
[pdclib] / functions / stdlib / exit.c
index 969b795f7100fa92de5b503f225060c5de92493f..0d816a3bba1a6ecd9b9b867bfc0fbe4ab0d22479 100644 (file)
    functions that had already been called at the time it was registered.
 */
 
-struct _PDCLIB_exitfunc_t * regstack = NULL;
+/* TODO: 32 is guaranteed. This should be dynamic but ATM gives problems
+   with my malloc.
+*/
+#define NUMBER_OF_SLOTS 40
+
+void (*_PDCLIB_regstack[ NUMBER_OF_SLOTS ])( void );
+size_t _PDCLIB_regptr = NUMBER_OF_SLOTS;
 
 void exit( int status )
 {
-    struct _PDCLIB_exitfunc_t * next = regstack;
-    while ( next != NULL )
+    while ( _PDCLIB_regptr < NUMBER_OF_SLOTS )
     {
-        next->func();
-        regstack = next->next;
-        free( next );
-        next = regstack;
+        _PDCLIB_regstack[ _PDCLIB_regptr++ ]();
     }
     _Exit( status );
 }