change ipv6 tests to use getaddrinfo for better scope id % handling, inet_pton doesn't always work depending on system

This commit is contained in:
toddouska 2013-04-11 12:30:09 -07:00
parent b5c43d8ad4
commit 12f00a7acc
4 changed files with 32 additions and 13 deletions

View File

@ -60,7 +60,7 @@ m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])])
AX_CXX_COMPILER_VERSION AX_CXX_COMPILER_VERSION
AC_CHECK_FUNCS([gethostbyname]) AC_CHECK_FUNCS([gethostbyname])
AC_CHECK_FUNCS([inet_pton]) AC_CHECK_FUNCS([getaddrinfo])
AC_CHECK_FUNCS([gettimeofday]) AC_CHECK_FUNCS([gettimeofday])
AC_CHECK_FUNCS([inet_ntoa]) AC_CHECK_FUNCS([inet_ntoa])
AC_CHECK_FUNCS([memset]) AC_CHECK_FUNCS([memset])

View File

@ -332,11 +332,12 @@ static INLINE void showPeer(CYASSL* ssl)
} }
static INLINE void build_addr(SOCKADDR_IN_T* addr, static INLINE void build_addr(SOCKADDR_IN_T* addr, const char* peer,
const char* peer, word16 port) word16 port, int udp)
{ {
int useLookup = 0; int useLookup = 0;
(void)useLookup; (void)useLookup;
(void)udp;
memset(addr, 0, sizeof(SOCKADDR_IN_T)); memset(addr, 0, sizeof(SOCKADDR_IN_T));
@ -371,11 +372,29 @@ static INLINE void build_addr(SOCKADDR_IN_T* addr,
if (peer == INADDR_ANY) if (peer == INADDR_ANY)
addr->sin6_addr = in6addr_any; addr->sin6_addr = in6addr_any;
else { else {
#ifdef HAVE_INET_PTON #ifdef HAVE_GETADDRINFO
if (inet_pton(AF_INET_V, peer, &addr->sin6_addr) != 1) struct addrinfo hints;
err_sys("ipv6 lookup failed"); struct addrinfo* answer = NULL;
int ret;
char strPort[80];
memset(&hints, 0, sizeof(hints));
hints.ai_family = AF_INET_V;
hints.ai_socktype = udp ? SOCK_DGRAM : SOCK_STREAM;
hints.ai_protocol = udp ? IPPROTO_UDP : IPPROTO_TCP;
snprintf(strPort, sizeof(strPort), "%d", port);
strPort[79] = '\0';
ret = getaddrinfo(peer, strPort, &hints, &answer);
if (ret < 0 || answer == NULL)
err_sys("getaddrinfo failed");
memcpy(addr, answer->ai_addr, answer->ai_addrlen);
freeaddrinfo(answer);
#else #else
printf("no ipv6 inet_pton, loopback only tests/examples\n"); printf("no ipv6 getaddrinfo, loopback only tests/examples\n");
addr->sin6_addr = in6addr_loopback; addr->sin6_addr = in6addr_loopback;
#endif #endif
} }
@ -424,7 +443,7 @@ static INLINE void tcp_connect(SOCKET_T* sockfd, const char* ip, word16 port,
int udp) int udp)
{ {
SOCKADDR_IN_T addr; SOCKADDR_IN_T addr;
build_addr(&addr, ip, port); build_addr(&addr, ip, port, udp);
tcp_socket(sockfd, udp); tcp_socket(sockfd, udp);
if (!udp) { if (!udp) {
@ -482,7 +501,7 @@ static INLINE void tcp_listen(SOCKET_T* sockfd, int* port, int useAnyAddr,
/* don't use INADDR_ANY by default, firewall may block, make user switch /* don't use INADDR_ANY by default, firewall may block, make user switch
on */ on */
build_addr(&addr, (useAnyAddr ? INADDR_ANY : yasslIP), *port); build_addr(&addr, (useAnyAddr ? INADDR_ANY : yasslIP), *port, udp);
tcp_socket(sockfd, udp); tcp_socket(sockfd, udp);
#ifndef USE_WINDOWS_API #ifndef USE_WINDOWS_API
@ -542,7 +561,7 @@ static INLINE void udp_accept(SOCKET_T* sockfd, int* clientfd, int useAnyAddr,
SOCKADDR_IN_T addr; SOCKADDR_IN_T addr;
(void)args; (void)args;
build_addr(&addr, (useAnyAddr ? INADDR_ANY : yasslIP), port); build_addr(&addr, (useAnyAddr ? INADDR_ANY : yasslIP), port, 1);
tcp_socket(sockfd, 1); tcp_socket(sockfd, 1);

View File

@ -439,7 +439,7 @@ THREAD_RETURN CYASSL_THREAD client_test(void* args)
err_sys("unable to get SSL object"); err_sys("unable to get SSL object");
if (doDTLS) { if (doDTLS) {
SOCKADDR_IN_T addr; SOCKADDR_IN_T addr;
build_addr(&addr, host, port); build_addr(&addr, host, port, 1);
CyaSSL_dtls_set_peer(ssl, &addr, sizeof(addr)); CyaSSL_dtls_set_peer(ssl, &addr, sizeof(addr));
tcp_socket(&sockfd, 1); tcp_socket(&sockfd, 1);
} }
@ -538,7 +538,7 @@ THREAD_RETURN CYASSL_THREAD client_test(void* args)
#else #else
sleep(1); sleep(1);
#endif #endif
build_addr(&addr, host, port); build_addr(&addr, host, port, 1);
CyaSSL_dtls_set_peer(sslResume, &addr, sizeof(addr)); CyaSSL_dtls_set_peer(sslResume, &addr, sizeof(addr));
tcp_socket(&sockfd, 1); tcp_socket(&sockfd, 1);
} }

View File

@ -135,7 +135,7 @@ void echoclient_test(void* args)
if (doDTLS) { if (doDTLS) {
SOCKADDR_IN_T addr; SOCKADDR_IN_T addr;
build_addr(&addr, yasslIP, port); build_addr(&addr, yasslIP, port, 1);
CyaSSL_dtls_set_peer(ssl, &addr, sizeof(addr)); CyaSSL_dtls_set_peer(ssl, &addr, sizeof(addr));
tcp_socket(&sockfd, 1); tcp_socket(&sockfd, 1);
} }