From: Robert Haas Date: Tue, 3 Apr 2012 12:38:24 +0000 (-0400) Subject: Arrange for on_exit_nicely to be thread-safe. X-Git-Tag: REL9_2_BETA1~194 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=5e86c61a7eec0fdc6961493a150159fa8fc63b1c;p=postgresql Arrange for on_exit_nicely to be thread-safe. Extracted from Joachim Wieland's parallel pg_dump patch, with some additional comments by me. --- diff --git a/src/bin/pg_dump/dumputils.c b/src/bin/pg_dump/dumputils.c index 9b30629515..c1a35b2ce8 100644 --- a/src/bin/pg_dump/dumputils.c +++ b/src/bin/pg_dump/dumputils.c @@ -1319,16 +1319,18 @@ on_exit_nicely(on_exit_nicely_callback function, void *arg) on_exit_nicely_index++; } -/* Run accumulated on_exit_nicely callbacks and then exit quietly. */ +/* + * Run accumulated on_exit_nicely callbacks in reverse order and then exit + * quietly. This needs to be thread-safe. + */ void exit_nicely(int code) { - while (--on_exit_nicely_index >= 0) - (*on_exit_nicely_list[on_exit_nicely_index].function)(code, - on_exit_nicely_list[on_exit_nicely_index].arg); -#ifdef WIN32 - if (parallel_init_done && GetCurrentThreadId() != mainThreadId) - ExitThread(code); -#endif + int i; + + for (i = on_exit_nicely_index - 1; i >= 0; i--) + (*on_exit_nicely_list[i].function)(code, + on_exit_nicely_list[i].arg); + exit(code); }