Skip to content

Commit

Permalink
1.Fix the bug that after calling zsys_shutdown() for the first time, …
Browse files Browse the repository at this point in the history
…s_mutex is not available even if zsys_init() is called again.

2.Fix the bug that caused the exit callback function table to be full after calling zsys_init() and zsys_shutdown() multiple times.
  • Loading branch information
ZhuXxxx committed Sep 20, 2023
1 parent 899f819 commit 69ec583
Showing 1 changed file with 16 additions and 1 deletion.
17 changes: 16 additions & 1 deletion src/zsys.c
Original file line number Diff line number Diff line change
Expand Up @@ -161,10 +161,16 @@ s_zsys_vprintf_hint (int hint, const char *format, va_list argptr);
// mutex for pthread_once to run the init function only once in a process
static pthread_once_t init_all_mutex_var = PTHREAD_ONCE_INIT;

// handler to destroy s_mutex
static void zsys_destroy_mutex() {
ZMUTEX_DESTROY(s_mutex);
}

// handler to initialize mutexes one time in multi threaded env
static void zsys_initialize_mutex() {
ZMUTEX_INIT (s_mutex);
ZMUTEX_INIT (s_init_mutex);
atexit (zsys_destroy_mutex);
}

// handler to detect fork condition and cleanup the stale context inherited from parent process
Expand All @@ -175,6 +181,13 @@ static void zsys_pthread_at_fork_handler(void) {
// call cleanup
zsys_cleanup();
}

// mutex for pthread_once to register the atexit function only once in a process
static pthread_once_t register_atexit_shutdown = PTHREAD_ONCE_INIT;
// handler to register the atexit function one time in multi threaded env
static void zsys_register_atexit_shutdown(void) {
atexit (zsys_shutdown);
}
#endif

void *
Expand Down Expand Up @@ -279,7 +292,7 @@ zsys_init (void)
s_initialized = true;

#if defined (__UNIX__)
atexit (zsys_shutdown);
pthread_once(&register_atexit_shutdown, zsys_register_atexit_shutdown);
pthread_atfork(NULL, NULL, &zsys_pthread_at_fork_handler);
//don't hold the lock because some of the function will call zsys_init again
ZMUTEX_UNLOCK(s_init_mutex);
Expand Down Expand Up @@ -407,7 +420,9 @@ zsys_shutdown (void)
else
zsys_error ("dangling sockets: cannot terminate ZMQ safely");

#if !defined (__UNIX__)
ZMUTEX_DESTROY (s_mutex);
#endif

// Free dynamically allocated properties
freen (s_interface);
Expand Down

0 comments on commit 69ec583

Please sign in to comment.