chiark
/
gitweb
/
~mdw
/
adns
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
src/addrfam.c (adns_addr2text): Don't print junk in debugging output.
[adns]
/
src
/
event.c
diff --git
a/src/event.c
b/src/event.c
index ad5861ec65c578a571a27e45d8497b9bf767200d..433a4d084c09e69beb3870bc8747d5ec5e60b434 100644
(file)
--- a/
src/event.c
+++ b/
src/event.c
@@
-43,9
+43,6
@@
/* TCP connection management. */
static void tcp_close(adns_state ads) {
/* TCP connection management. */
static void tcp_close(adns_state ads) {
- int serv;
-
- serv= ads->tcpserver;
close(ads->tcpsocket);
ads->tcpsocket= -1;
ads->tcprecv.used= ads->tcprecv_skip= ads->tcpsend.used= 0;
close(ads->tcpsocket);
ads->tcpsocket= -1;
ads->tcprecv.used= ads->tcprecv_skip= ads->tcpsend.used= 0;
@@
-99,7
+96,7
@@
static void tcp_broken_events(adns_state ads) {
void adns__tcp_tryconnect(adns_state ads, struct timeval now) {
int r, fd, tries;
void adns__tcp_tryconnect(adns_state ads, struct timeval now) {
int r, fd, tries;
-
struct sockaddr_in
addr;
+
adns_rr_addr *
addr;
struct protoent *proto;
for (tries=0; tries<ads->nservers; tries++) {
struct protoent *proto;
for (tries=0; tries<ads->nservers; tries++) {
@@
-123,7
+120,8
@@
void adns__tcp_tryconnect(adns_state ads, struct timeval now) {
adns__diag(ads,-1,0,"unable to find protocol no. for TCP !");
return;
}
adns__diag(ads,-1,0,"unable to find protocol no. for TCP !");
return;
}
- fd= socket(AF_INET,SOCK_STREAM,proto->p_proto);
+ addr = &ads->servers[ads->tcpserver];
+ fd= socket(addr->addr.sa.sa_family, SOCK_STREAM, proto->p_proto);
if (fd<0) {
adns__diag(ads,-1,0,"cannot create TCP socket: %s",strerror(errno));
return;
if (fd<0) {
adns__diag(ads,-1,0,"cannot create TCP socket: %s",strerror(errno));
return;
@@
-135,11
+133,7
@@
void adns__tcp_tryconnect(adns_state ads, struct timeval now) {
close(fd);
return;
}
close(fd);
return;
}
- memset(&addr,0,sizeof(addr));
- addr.sin_family= AF_INET;
- addr.sin_port= htons(DNS_PORT);
- addr.sin_addr= ads->servers[ads->tcpserver].addr;
- r= connect(fd,(const struct sockaddr*)&addr,sizeof(addr));
+ r= connect(fd,&addr->addr.sa,addr->len);
ads->tcpsocket= fd;
ads->tcpstate= server_connecting;
if (r==0) { tcp_connected(ads,now); return; }
ads->tcpsocket= fd;
ads->tcpstate= server_connecting;
if (r==0) { tcp_connected(ads,now); return; }
@@
-421,7
+415,8
@@
int adns_processreadable(adns_state ads, int fd, const struct timeval *now) {
}
for (serv= 0;
serv < ads->nservers &&
}
for (serv= 0;
serv < ads->nservers &&
- ads->servers[serv].addr.s_addr != udpaddr.sin_addr.s_addr;
+ !adns__sockaddr_equal_p(&ads->servers[serv].addr.sa,
+ (const struct sockaddr *)&udpaddr);
serv++);
if (serv >= ads->nservers) {
adns__warn(ads,-1,0,"datagram received from unknown nameserver %s",
serv++);
if (serv >= ads->nservers) {
adns__warn(ads,-1,0,"datagram received from unknown nameserver %s",