wrap fork so we can drop priority in child processes

This commit is contained in:
Anthony Minessale 2012-10-01 12:14:30 -05:00
parent 0995d133a6
commit 52eff9451c
8 changed files with 31 additions and 11 deletions

View File

@ -2368,6 +2368,9 @@ SWITCH_DECLARE(void) switch_core_recovery_untrack(switch_core_session_t *session
SWITCH_DECLARE(void) switch_core_recovery_track(switch_core_session_t *session);
SWITCH_DECLARE(void) switch_core_recovery_flush(const char *technology, const char *profile_name);
SWITCH_DECLARE(pid_t) switch_fork(void);
SWITCH_END_EXTERN_C
#endif
/* For Emacs:

View File

@ -1185,7 +1185,7 @@ int celliax_serial_getstatus_AT(struct celliax_pvt *p)
NOTICA("incoming SMS message:>>>%s<<<\n", CELLIAX_P_LOG, p->sms_message);
pipe(fd1);
pid1 = fork();
pid1 = switch_fork();
if (pid1 == 0) { //child
int err;
@ -1735,7 +1735,7 @@ int celliax_serial_read_AT(struct celliax_pvt *p, int look_for_ack, int timeout_
NOTICA("incoming SMS message:>>>%s<<<\n", CELLIAX_P_LOG, p->sms_message);
pipe(fd1);
pid1 = fork();
pid1 = switch_fork();
if (pid1 == 0) { //child
int err;

View File

@ -3101,7 +3101,7 @@ int gsmopen_serial_getstatus_AT(private_t *tech_pvt)
DEBUGA_AT("incoming SMS message:---%s---\n", GSMOPEN_P_LOG, p->sms_message);
pipe(fd1);
pid1 = fork();
pid1 = switch_fork();
if (pid1 == 0) { //child
int err;

View File

@ -108,7 +108,7 @@ static switch_status_t shell_stream_file_open(switch_file_handle_t *handle, cons
if (pipe(context->fds)) {
goto error;
} else { /* good to go */
context->pid = fork();
context->pid = switch_fork();
if (context->pid < 0) { /* ok maybe not */
goto error;

View File

@ -65,7 +65,7 @@ $SIG{CHLD} = "IGNORE";
while (my $request = $scgi->accept) {
# fork every new req into its own process (optional)
my $pid = fork();
my $pid = switch_fork();
if ($pid) {
$request->close();

View File

@ -262,7 +262,7 @@ static void daemonize(int do_wait)
}
}
pid = fork();
pid = switch_fork();
switch (pid) {
case 0: /* child process */

View File

@ -2731,15 +2731,33 @@ SWITCH_DECLARE(void) switch_close_extra_files(int *keep, int keep_ttl)
}
#ifdef WIN32
static int switch_system_fork(const char *cmd, switch_bool_t wait)
{
return switch_system_thread(cmd, wait);
}
SWITCH_DECLARE(pid_t) switch_fork(void)
{
return -1;
}
#else
SWITCH_DECLARE(pid_t) switch_fork(void)
{
int i = fork();
if (!i) {
set_low_priority();
}
return i;
}
static int switch_system_fork(const char *cmd, switch_bool_t wait)
{
int pid;
@ -2747,7 +2765,7 @@ static int switch_system_fork(const char *cmd, switch_bool_t wait)
switch_core_set_signal_handlers();
pid = fork();
pid = switch_fork();
if (pid) {
if (wait) {
@ -2757,7 +2775,6 @@ static int switch_system_fork(const char *cmd, switch_bool_t wait)
} else {
switch_close_extra_files(NULL, 0);
set_low_priority();
if (system(dcmd) == -1) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Failed to execute because of a command error : %s\n", dcmd);
}
@ -2793,7 +2810,7 @@ SWITCH_DECLARE(int) switch_stream_system_fork(const char *cmd, switch_stream_han
if (pipe(fds)) {
goto end;
} else { /* good to go */
pid = fork();
pid = switch_fork();
if (pid < 0) { /* ok maybe not */
close(fds[0]);

View File

@ -1238,7 +1238,7 @@ static FILE *preprocess_exec(const char *cwd, const char *command, FILE *write_f
if (pipe(fds)) {
goto end;
} else { /* good to go */
pid = fork();
pid = switch_fork();
if (pid < 0) { /* ok maybe not */
close(fds[0]);