diff --git a/asterisk.c b/asterisk.c index dedf23e6902b4af8522d815d2253d94eae78c792..fe28615334bc7d0f29f803c0f25b3383de9cfa14 100755 --- a/asterisk.c +++ b/asterisk.c @@ -674,7 +674,7 @@ static void set_icon(char *text) fprintf(stdout, "\033]1;%s\007", text); } -static int set_priority(int pri) +int ast_set_priority(int pri) { struct sched_param sched; memset(&sched, 0, sizeof(sched)); @@ -1940,7 +1940,7 @@ int main(int argc, char *argv[]) ast_verbose("[ Reading Master Configuration ]"); ast_readconfig(); - if (set_priority(option_highpriority)) { + if (ast_set_priority(option_highpriority)) { exit(1); } diff --git a/include/asterisk.h b/include/asterisk.h index 708d503a40282e8147018a3177f9b19d79f19876..e10200bbdbd8e285271b14a2067a30f3d8228086 100755 --- a/include/asterisk.h +++ b/include/asterisk.h @@ -37,6 +37,8 @@ extern char ast_config_AST_CTL_OWNER[AST_CONFIG_MAX_PATH]; extern char ast_config_AST_CTL_GROUP[AST_CONFIG_MAX_PATH]; extern char ast_config_AST_CTL[AST_CONFIG_MAX_PATH]; +/* Provided by asterisk.c */ +extern int ast_set_priority(int); /* Provided by module.c */ extern int load_modules(const int preload_only); /* Provided by pbx.c */ diff --git a/res/res_agi.c b/res/res_agi.c index 9dd62fba74d9dbdbedf92b598b25484bf2acbee9..89b25e7626a415619b68e9a24c94ef2c8846c7fa 100755 --- a/res/res_agi.c +++ b/res/res_agi.c @@ -279,6 +279,9 @@ static int launch_script(char *script, char *argv[], int *fds, int *efd, int *op for (x=STDERR_FILENO + 2;x<1024;x++) close(x); + /* Don't run AGI scripts with realtime priority -- it causes audio stutter */ + ast_set_priority(0); + /* Execute script */ execv(script, argv); /* Can't use ast_log since FD's are closed */