summaryrefslogtreecommitdiff
path: root/pjsip/src/pjsua-lib/pjsua_core.c
diff options
context:
space:
mode:
authorBenny Prijono <bennylp@teluu.com>2007-12-20 11:23:07 +0000
committerBenny Prijono <bennylp@teluu.com>2007-12-20 11:23:07 +0000
commit050af3159e072d2cde0e4354a596a5b10959cd55 (patch)
treed18b49cef4d1dbad6b33bcf0afafc88614834ddb /pjsip/src/pjsua-lib/pjsua_core.c
parentb2a057941ada78ae228da21c311347d2d5469162 (diff)
Related to Ticket #429: when bind address is specified and public address is not, the bind address should be used as the public address (thanks Arie Velthoen)
git-svn-id: http://svn.pjsip.org/repos/pjproject/trunk@1636 74dad513-b988-da41-8d7b-12977e46ad98
Diffstat (limited to 'pjsip/src/pjsua-lib/pjsua_core.c')
-rw-r--r--pjsip/src/pjsua-lib/pjsua_core.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/pjsip/src/pjsua-lib/pjsua_core.c b/pjsip/src/pjsua-lib/pjsua_core.c
index f7addbd3..985608cc 100644
--- a/pjsip/src/pjsua-lib/pjsua_core.c
+++ b/pjsip/src/pjsua-lib/pjsua_core.c
@@ -1299,11 +1299,15 @@ static pj_status_t create_sip_udp_sock(int af,
} else {
pj_bzero(p_pub_addr, sizeof(pj_sockaddr));
- status = pj_gethostip(af, p_pub_addr);
- if (status != PJ_SUCCESS) {
- pjsua_perror(THIS_FILE, "Unable to get local host IP", status);
- pj_sock_close(sock);
- return status;
+ if (pj_sockaddr_has_addr(&bind_addr)) {
+ pj_sockaddr_copy_addr(p_pub_addr, &bind_addr);
+ } else {
+ status = pj_gethostip(af, p_pub_addr);
+ if (status != PJ_SUCCESS) {
+ pjsua_perror(THIS_FILE, "Unable to get local host IP", status);
+ pj_sock_close(sock);
+ return status;
+ }
}
p_pub_addr->addr.sa_family = (pj_uint16_t)af;