From: Mark Wooding Date: Sat, 24 May 2014 13:00:03 +0000 (+0100) Subject: src/setup.c, src/transmit.c: New function finds udpsocket by AF. X-Git-Tag: wip.base.getaddrinfo~1 X-Git-Url: https://git.distorted.org.uk/~mdw/adns/commitdiff_plain/14c634e049bf7680c203b9755c349d5f575f2527 src/setup.c, src/transmit.c: New function finds udpsocket by AF. This eliminates a slightly fiddly loop from two call sites. --- diff --git a/src/internal.h b/src/internal.h index 3e85a58..bc5f542 100644 --- a/src/internal.h +++ b/src/internal.h @@ -501,6 +501,15 @@ void adns__querysend_tcp(adns_query qu, struct timeval now); * might be broken, but no reconnect will be attempted. */ +struct udpsocket *adns__udpsocket_by_af(adns_state ads, int af); +/* Find the UDP socket structure in ads which has the given address family. + * Return null if there isn't one. + * + * This is used during initialization, so ads is only partially filled in. + * The requirements are that nudp is set, and that udpsocket[i].af are + * defined for 0<=inudp = 0; for (i = 0; i < ads->nservers; i++) { - for (j = 0; j < ads->nudp; j++) { - if (ads->udpsocket[j].ai->af == ads->servers[i].addr.sa.sa_family) - goto afmatch; - } - + if (adns__udpsocket_by_af(ads, ads->servers[i].addr.sa.sa_family)) + continue; assert(ads->nudp < MAXUDP); udp = &ads->udpsocket[ads->nudp]; udp->ai = find_afinfo(ads->servers[i].addr.sa.sa_family); @@ -641,8 +638,6 @@ static int init_finish(adns_state ads) { r= adns__setnonblock(ads,udp->fd); if (r) { r= errno; goto x_closeudp; } ads->nudp++; - - afmatch:; } return 0; diff --git a/src/transmit.c b/src/transmit.c index 212c6ec..63e222c 100644 --- a/src/transmit.c +++ b/src/transmit.c @@ -222,10 +222,16 @@ static void query_usetcp(adns_query qu, struct timeval now) { adns__tcp_tryconnect(qu->ads,now); } +struct udpsocket *adns__udpsocket_by_af(adns_state ads, int af) { + int i; + for (i=0; inudp; i++) + if (ads->udpsocket[i].af == af) return &ads->udpsocket[i]; + return 0; +} + void adns__query_send(adns_query qu, struct timeval now) { int serv, r, i; adns_state ads; - int fd = -1; struct udpsocket *udp; adns_rr_addr *addr; @@ -243,13 +249,10 @@ void adns__query_send(adns_query qu, struct timeval now) { ads= qu->ads; serv= qu->udpnextserver; addr= &ads->servers[serv]; - for (i = 0; i < ads->nudp; i++) { - udp = &ads->udpsocket[i]; - if (udp->ai->af == addr->addr.sa.sa_family) { fd = udp->fd; break; } - } - assert(fd >= 0); + udp= adns__udpsocket_by_af(ads, addr->addr.sa.sa_family); + assert(udp); - r= sendto(fd,qu->query_dgram,qu->query_dglen,0, + r= sendto(udp->fd,qu->query_dgram,qu->query_dglen,0, &addr->addr.sa,addr->len); if (r<0 && errno == EMSGSIZE) { qu->retries= 0;