add c11 quick_exit and at_quick_exit functions
authorRich Felker <dalias@aerifal.cx>
Sun, 26 Aug 2012 02:49:47 +0000 (22:49 -0400)
committerRich Felker <dalias@aerifal.cx>
Sun, 26 Aug 2012 02:49:47 +0000 (22:49 -0400)
include/stdlib.h
src/exit/at_quick_exit.c [new file with mode: 0644]
src/exit/quick_exit.c [new file with mode: 0644]

index 0a8de8662195ae0dadcc176609c30751cb6aa742..c1d93e71595744d521a7786f4bb2011a928298b9 100644 (file)
@@ -43,6 +43,8 @@ void abort (void);
 int atexit (void (*) (void));
 void exit (int);
 void _Exit (int);
+int at_quick_exit (void (*) (void));
+void quick_exit (int);
 
 char *getenv (const char *);
 
diff --git a/src/exit/at_quick_exit.c b/src/exit/at_quick_exit.c
new file mode 100644 (file)
index 0000000..85c3d26
--- /dev/null
@@ -0,0 +1,29 @@
+#include <stdlib.h>
+#include "libc.h"
+
+#define COUNT 32
+
+static void (*funcs[COUNT])(void);
+static int count;
+static int lock[2];
+
+void __funcs_on_quick_exit()
+{
+       void (*func)(void);
+       LOCK(lock);
+       while (count > 0) {
+               func = funcs[--count];
+               UNLOCK(lock);
+               func();
+               LOCK(lock);
+       }
+}
+
+int at_quick_exit(void (*func)(void))
+{
+       if (count == 32) return -1;
+       LOCK(lock);
+       funcs[count++] = func;
+       UNLOCK(lock);
+       return 0;
+}
diff --git a/src/exit/quick_exit.c b/src/exit/quick_exit.c
new file mode 100644 (file)
index 0000000..18d5288
--- /dev/null
@@ -0,0 +1,15 @@
+#include <stdlib.h>
+#include "syscall.h"
+#include "atomic.h"
+#include "libc.h"
+
+static void dummy() { }
+weak_alias(dummy, __funcs_on_quick_exit);
+
+void quick_exit(int code)
+{
+       static int lock;
+       while (a_swap(&lock, 1)) __syscall(SYS_pause);
+       __funcs_on_quick_exit();
+       _Exit(code);
+}