summaryrefslogtreecommitdiff
path: root/src/exit/exit.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2011-10-14 23:00:24 -0400
committerRich Felker <dalias@aerifal.cx>2011-10-14 23:00:24 -0400
commitf753049a50132a23849ef89a8af5ff86ad595c25 (patch)
tree5dbc29f298f9907948da2f9451947ebbb7b3e453 /src/exit/exit.c
parent8e8ddeff7eee6294e24c0a9a29053164f990f1b3 (diff)
downloadmusl-f753049a50132a23849ef89a8af5ff86ad595c25.tar.gz
simplify atexit and fflush-on-exit handling
Diffstat (limited to 'src/exit/exit.c')
-rw-r--r--src/exit/exit.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/src/exit/exit.c b/src/exit/exit.c
index bfdb3923..1ff19dbe 100644
--- a/src/exit/exit.c
+++ b/src/exit/exit.c
@@ -3,8 +3,11 @@
#include <stdio.h>
#include "libc.h"
-/* __overflow.c and atexit.c override these */
-static int (*const dummy)() = 0;
+static void dummy()
+{
+}
+
+/* __towrite.c and atexit.c override these */
weak_alias(dummy, __funcs_on_exit);
weak_alias(dummy, __fflush_on_exit);
@@ -16,8 +19,8 @@ void exit(int code)
LOCK(&lock);
/* Only do atexit & stdio flush if they were actually used */
- if (__funcs_on_exit) __funcs_on_exit();
- if (__fflush_on_exit) __fflush_on_exit((void *)0);
+ __funcs_on_exit();
+ __fflush_on_exit();
/* Destructor s**t is kept separate from atexit to avoid bloat */
if (libc.fini) libc.fini();