mirror of
https://github.com/openvswitch/ovs
synced 2025-10-17 14:28:02 +00:00
Until now, fatal_signal_fork() has simply disabled all the fatal signal callback hooks. This worked fine, because a daemon process forked only once and the parent didn't do much before it exited. But upcoming commits will introduce a --monitor option, which requires processes to fork multiple times. Sometimes the parent process will fork, then run for a while, then fork again. It's not good to disable the hooks in the child process in such a case, because that prevents e.g. pidfiles from being removed at the child's exit. So this commit changes the semantics of fatal_signal_fork() to just clearing out hooks. After hooks are cleared, new hooks can be added and will be executed on process termination in the usual way. This commit also introduces a cancellation callback function so that a canceled hook can free resources.
43 lines
1.4 KiB
C
43 lines
1.4 KiB
C
/*
|
|
* Copyright (c) 2008, 2009, 2010 Nicira Networks.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at:
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef FATAL_SIGNAL_H
|
|
#define FATAL_SIGNAL_H 1
|
|
|
|
#include <stdbool.h>
|
|
|
|
/* Basic interface. */
|
|
void fatal_signal_add_hook(void (*hook_cb)(void *aux),
|
|
void (*cancel_cb)(void *aux), void *aux,
|
|
bool run_at_exit);
|
|
void fatal_signal_fork(void);
|
|
void fatal_signal_run(void);
|
|
void fatal_signal_wait(void);
|
|
|
|
/* Convenience functions for unlinking files upon termination.
|
|
*
|
|
* These functions also unlink the files upon normal process termination via
|
|
* exit(). */
|
|
void fatal_signal_add_file_to_unlink(const char *);
|
|
void fatal_signal_remove_file_to_unlink(const char *);
|
|
int fatal_signal_unlink_file_now(const char *);
|
|
|
|
/* Interface for other code that catches one of our signals and needs to pass
|
|
* it through. */
|
|
void fatal_signal_handler(int sig_nr);
|
|
|
|
#endif /* fatal-signal.h */
|