FS-6680 #resolve

This commit is contained in:
Brian West 2014-07-23 11:26:23 -05:00
parent 03c4014d0e
commit f11c40d889
1 changed files with 5 additions and 22 deletions

View File

@ -151,11 +151,7 @@ static int get_pmp_pubaddr(char *pub_addr)
char *pubaddr = NULL;
natpmp_t natpmp;
const char *err = NULL;
switch_pollfd_t *pollfd = NULL;
switch_socket_t *sock = NULL;
switch_memory_pool_t *pool;
int32_t num = 0;
switch_status_t status = SWITCH_STATUS_SUCCESS;
int pflags;
if ((r = initnatpmp(&natpmp)) < 0) {
err = "init failed";
@ -167,15 +163,6 @@ static int get_pmp_pubaddr(char *pub_addr)
goto end;
}
switch_core_new_memory_pool(&pool);
switch_os_sock_put(&sock, &natpmp.s, pool);
if (switch_socket_create_pollset(&pollfd, sock, SWITCH_POLLIN | SWITCH_POLLERR, pool) != SWITCH_STATUS_SUCCESS) {
err = "cannot create pollset";
goto end;
}
do {
struct timeval timeout = { 1, 0 };
i++;
@ -186,15 +173,13 @@ static int get_pmp_pubaddr(char *pub_addr)
goto end;
}
status = switch_poll(pollfd, 1, &num, switch_interval_time_from_timeval(&timeout));
pflags = switch_wait_sock(natpmp.s, 100, SWITCH_POLL_READ | SWITCH_POLL_ERROR | SWITCH_POLL_HUP);
if (!(status == SWITCH_STATUS_SUCCESS || status == SWITCH_STATUS_TIMEOUT)) {
err = "poll failed";
if ((pflags & SWITCH_POLL_ERROR) || (pflags & SWITCH_POLL_HUP)) {
err = "wait sock failed";
goto end;
}
r = readnatpmpresponseorretry(&natpmp, &response);
} while (r == NATPMP_TRYAGAIN && i < max);
if (r < 0) {
@ -210,8 +195,6 @@ static int get_pmp_pubaddr(char *pub_addr)
end:
switch_core_destroy_memory_pool(&pool);
if (err) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Error checking for PMP [%s]\n", err);
}