make switch_cmp_addr ipv6 friendly and cleanup/refactor autoadjust code in rtp

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@15289 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale
2009-10-30 14:26:17 +00:00
parent a7a909df2a
commit 10f10c5db0
2 changed files with 42 additions and 16 deletions

View File

@@ -1348,10 +1348,36 @@ SWITCH_DECLARE(int) get_addr_int(switch_sockaddr_t *sa)
SWITCH_DECLARE(int) switch_cmp_addr(switch_sockaddr_t *sa1, switch_sockaddr_t *sa2)
{
struct sockaddr_in *s1 = (struct sockaddr_in *)&sa1->sa;
struct sockaddr_in *s2 = (struct sockaddr_in *)&sa2->sa;
struct sockaddr_in *s1;
struct sockaddr_in *s2;
return (ntohs((unsigned short)s1->sin_addr.s_addr) == ntohs((unsigned short)s2->sin_addr.s_addr) && ntohs(s1->sin_port) == ntohs(s2->sin_port));
struct sockaddr_in6 *s16;
struct sockaddr_in6 *s26;
struct sockaddr *ss1;
struct sockaddr *ss2;
if (!(sa1 && sa2)) return 0;
s1 = (struct sockaddr_in *)&sa1->sa;
s2 = (struct sockaddr_in *)&sa2->sa;
s16 = (struct sockaddr_in6 *)&sa1->sa;
s26 = (struct sockaddr_in6 *)&sa2->sa;
ss1 = (struct sockaddr *)&sa1->sa;
ss2 = (struct sockaddr *)&sa2->sa;
if (ss1->sa_family != ss2->sa_family) return 0;
switch (ss1->sa_family) {
case AF_INET:
return (s1->sin_addr.s_addr == s2->sin_addr.s_addr && s1->sin_port == s2->sin_port);
case AF_INET6:
return (s16->sin6_addr.s6_addr == s26->sin6_addr.s6_addr && s16->sin6_port == s26->sin6_port);
}
return 0;
}