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
/
transmit.c
diff --git
a/src/transmit.c
b/src/transmit.c
index e91250ab2895cb05267882949f9c124921fe664e..67a55b42a4d4328a9d24daf3faf26eccb6dd3d05 100644
(file)
--- a/
src/transmit.c
+++ b/
src/transmit.c
@@
-120,6
+120,7
@@
adns_status adns__mkquery(adns_state ads, vbuf *vb, int *id_r,
const char *p, *pe;
adns_status st;
const char *p, *pe;
adns_status st;
+ if (!((type^adns_r_addr) & adns_rrt_reprmask)) ads->nextid++;
st= mkquery_header(ads,vb,id_r,ol+2); if (st) return st;
MKQUERY_START(vb);
st= mkquery_header(ads,vb,id_r,ol+2); if (st) return st;
MKQUERY_START(vb);
@@
-155,6
+156,7
@@
adns_status adns__mkquery_frdgram(adns_state ads, vbuf *vb, int *id_r,
int lablen, labstart;
adns_status st;
int lablen, labstart;
adns_status st;
+ if (!((type^adns_r_addr) & adns_rrt_reprmask)) ads->nextid++;
st= mkquery_header(ads,vb,id_r,qd_dglen); if (st) return st;
MKQUERY_START(vb);
st= mkquery_header(ads,vb,id_r,qd_dglen); if (st) return st;
MKQUERY_START(vb);
@@
-241,9
+243,9
@@
static void query_usetcp(adns_query qu, struct timeval now) {
}
void adns__query_send(adns_query qu, struct timeval now) {
}
void adns__query_send(adns_query qu, struct timeval now) {
- struct sockaddr_in servaddr;
int serv, r;
adns_state ads;
int serv, r;
adns_state ads;
+ adns_rr_addr *addr;
assert(qu->state == query_tosend);
if ((qu->flags & adns_qf_usevc) || (qu->query_dglen > DNS_MAXUDP)) {
assert(qu->state == query_tosend);
if ((qu->flags & adns_qf_usevc) || (qu->query_dglen > DNS_MAXUDP)) {
@@
-256,16
+258,12
@@
void adns__query_send(adns_query qu, struct timeval now) {
return;
}
return;
}
- serv= qu->udpnextserver;
- memset(&servaddr,0,sizeof(servaddr));
-
ads= qu->ads;
ads= qu->ads;
- servaddr.sin_family= AF_INET;
- servaddr.sin_addr= ads->servers[serv].addr;
- servaddr.sin_port= htons(DNS_PORT);
+ serv= qu->udpnextserver;
+ addr= &ads->servers[serv];
r= sendto(ads->udpsocket,qu->query_dgram,qu->query_dglen,0,
r= sendto(ads->udpsocket,qu->query_dgram,qu->query_dglen,0,
-
(const struct sockaddr*)&servaddr,sizeof(servaddr)
);
+
&addr->addr.sa,addr->len
);
if (r<0 && errno == EMSGSIZE) {
qu->retries= 0;
query_usetcp(qu,now);
if (r<0 && errno == EMSGSIZE) {
qu->retries= 0;
query_usetcp(qu,now);