From 5d8ce82d8c7dca45f33a21967e0b8c5406b5ca9f Mon Sep 17 00:00:00 2001 From: Manuel Novoa III Date: Sun, 2 Nov 2003 08:29:10 +0000 Subject: If realloc failed, we'd lose the pointer to the exit function table. --- libc/stdlib/atexit.c | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) (limited to 'libc/stdlib/atexit.c') diff --git a/libc/stdlib/atexit.c b/libc/stdlib/atexit.c index 8b04e8a04..ab124a09f 100644 --- a/libc/stdlib/atexit.c +++ b/libc/stdlib/atexit.c @@ -96,13 +96,14 @@ int atexit(aefuncp func) #ifdef __UCLIBC_DYNAMIC_ATEXIT__ /* If we are out of function table slots, make some more */ if (__exit_slots < __exit_count+1) { - __exit_function_table=realloc(__exit_function_table, - (__exit_slots+20)*sizeof(struct exit_function)); - if (__exit_function_table==NULL) { + efp=realloc(__exit_function_table, + (__exit_slots+20)*sizeof(struct exit_function)); + if (efp==NULL) { UNLOCK; __set_errno(ENOMEM); return -1; } + __exit_function_table = efp; __exit_slots+=20; } #else @@ -138,13 +139,14 @@ int on_exit(oefuncp func, void *arg) #ifdef __UCLIBC_DYNAMIC_ATEXIT__ /* If we are out of function table slots, make some more */ if (__exit_slots < __exit_count+1) { - __exit_function_table=realloc(__exit_function_table, - (__exit_slots+20)*sizeof(struct exit_function)); - if (__exit_function_table==NULL) { + efp=realloc(__exit_function_table, + (__exit_slots+20)*sizeof(struct exit_function)); + if (efp==NULL) { UNLOCK; __set_errno(ENOMEM); return -1; } + __exit_function_table=efp; __exit_slots+=20; } #else -- cgit v1.2.3