FS-5431: --resolve fix socket creation loop for mod_skinny to avoid segfault
This commit is contained in:
parent
5556731b64
commit
514fc941c0
|
@ -1543,7 +1543,7 @@ static void *SWITCH_THREAD_FUNC skinny_profile_run(switch_thread_t *thread, void
|
|||
}
|
||||
|
||||
new_socket:
|
||||
while(globals.running) {
|
||||
while(globals.running && !profile->sock) {
|
||||
char *listening_ip = NULL;
|
||||
switch_clear_flag_locked(profile, PFLAG_RESPAWN);
|
||||
rv = switch_sockaddr_info_get(&sa, profile->ip, SWITCH_UNSPEC, profile->port, 0, tmp_pool);
|
||||
|
@ -1570,6 +1570,10 @@ new_socket:
|
|||
break;
|
||||
sock_fail:
|
||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Socket Error! Could not listen on %s:%u\n", profile->ip, profile->port);
|
||||
if (profile->sock) {
|
||||
close_socket(&profile->sock, profile);
|
||||
profile->sock = NULL;
|
||||
}
|
||||
switch_yield(100000);
|
||||
}
|
||||
|
||||
|
@ -1582,6 +1586,8 @@ sock_fail:
|
|||
goto fail;
|
||||
}
|
||||
|
||||
assert(profile->sock);
|
||||
|
||||
if ((rv = switch_socket_accept(&inbound_socket, profile->sock, listener_pool))) {
|
||||
if (!globals.running) {
|
||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_NOTICE, "Shutting Down\n");
|
||||
|
|
Loading…
Reference in New Issue