X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~mdw/git/adns/blobdiff_plain/4218fb9a803f42d5cef3772e56f3220ef8df90af..ebf4877a99a025de95a78591445677e8014679da:/src/reply.c diff --git a/src/reply.c b/src/reply.c index fbc2c83..8da0bf2 100644 --- a/src/reply.c +++ b/src/reply.c @@ -26,7 +26,7 @@ #include "internal.h" void adns__procdgram(adns_state ads, const byte *dgram, int dglen, - int serv, struct timeval now) { + int serv, int viatcp, struct timeval now) { int cbyte, rrstart, wantedrrs, rri, foundsoa, foundns, cname_here; int id, f1, f2, qdcount, ancount, nscount, arcount; int flg_ra, flg_rd, flg_tc, flg_qr, opcode; @@ -89,6 +89,12 @@ void adns__procdgram(adns_state ads, const byte *dgram, int dglen, dgram+DNS_HDRSIZE, qu->query_dglen-DNS_HDRSIZE)) continue; + if (viatcp) { + if (qu->state != query_tcpsent) continue; + } else { + if (qu->state != query_tosend) continue; + if (!(qu->udpsent & (1<flags |= adns_qf_usevc; x_restartquery: - if (qu->cname_dgram) { st= adns__mkquery_frdgram(qu->ads,&qu->vb,&qu->id, qu->cname_dgram, qu->cname_dglen, qu->cname_begin, @@ -335,6 +340,7 @@ void adns__procdgram(adns_state ads, const byte *dgram, int dglen, memcpy(newquery,qu->vb.buf,qu->vb.used); } + if (qu->state == query_tcpsent) qu->state= query_tosend; adns__reset_preserved(qu); - adns__query_udp(qu,now); + adns__query_send(qu,now); }