diff options
author | Rob Landley <rob@landley.net> | 2018-07-08 01:16:16 -0500 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2018-07-08 01:16:16 -0500 |
commit | 66d1776fb85530b446dcc1f68929231849a5ad44 (patch) | |
tree | 7d9653d2af47f4ce7d6a599316172608d9f6cc38 /lib/xwrap.c | |
parent | d2e317a622c672109ed25176044a3920a1167466 (diff) | |
download | toybox-66d1776fb85530b446dcc1f68929231849a5ad44.tar.gz |
Fix division by zero errors and double summary in ping.
Diffstat (limited to 'lib/xwrap.c')
-rw-r--r-- | lib/xwrap.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/lib/xwrap.c b/lib/xwrap.c index 26383c92..d5ec9f64 100644 --- a/lib/xwrap.c +++ b/lib/xwrap.c @@ -46,12 +46,13 @@ void xexit(void) { // Call toys.xexit functions in reverse order added. while (toys.xexit) { - // This is typecasting xexit->arg to a function pointer,then calling it. - // Using the invalid signal number 0 lets the signal handlers distinguish - // an actual signal from a regular exit. - ((void (*)(int))(toys.xexit->arg))(0); + struct arg_list *al = llist_pop(&toys.xexit); - free(llist_pop(&toys.xexit)); + // typecast xexit->arg to a function pointer, then call it using invalid + // signal 0 to let signal handlers tell actual signal from regular exit. + ((void (*)(int))(al->arg))(0); + + free(al); } if (fflush(NULL) || ferror(stdout)) if (!toys.exitval) perror_msg("write"); |