diff options
Diffstat (limited to 'src/resolve')
| -rw-r--r-- | src/resolve/resolved-dns-transaction.c | 7 | ||||
| -rw-r--r-- | src/resolve/resolved-dns-transaction.h | 2 | 
2 files changed, 5 insertions, 4 deletions
| diff --git a/src/resolve/resolved-dns-transaction.c b/src/resolve/resolved-dns-transaction.c index b0f40303d9..2eb1675c5b 100644 --- a/src/resolve/resolved-dns-transaction.c +++ b/src/resolve/resolved-dns-transaction.c @@ -421,6 +421,8 @@ static int dns_transaction_open_tcp(DnsTransaction *t) {          if (t->scope->link)                  t->stream->ifindex = t->scope->link->ifindex; +        t->tried_stream = true; +          return 0;  } @@ -826,13 +828,10 @@ static usec_t transaction_get_resend_timeout(DnsTransaction *t) {  }  static int dns_transaction_prepare(DnsTransaction *t, usec_t ts) { -        bool had_stream;          int r;          assert(t); -        had_stream = !!t->stream; -          dns_transaction_stop(t);          if (t->n_attempts >= TRANSACTION_ATTEMPTS_MAX(t->scope->protocol)) { @@ -840,7 +839,7 @@ static int dns_transaction_prepare(DnsTransaction *t, usec_t ts) {                  return 0;          } -        if (t->scope->protocol == DNS_PROTOCOL_LLMNR && had_stream) { +        if (t->scope->protocol == DNS_PROTOCOL_LLMNR && t->tried_stream) {                  /* If we already tried via a stream, then we don't                   * retry on LLMNR. See RFC 4795, Section 2.7. */                  dns_transaction_complete(t, DNS_TRANSACTION_ATTEMPTS_MAX_REACHED); diff --git a/src/resolve/resolved-dns-transaction.h b/src/resolve/resolved-dns-transaction.h index eebb6ec631..a351a5043b 100644 --- a/src/resolve/resolved-dns-transaction.h +++ b/src/resolve/resolved-dns-transaction.h @@ -69,6 +69,8 @@ struct DnsTransaction {          uint16_t id; +        bool tried_stream:1; +          bool initial_jitter_scheduled:1;          bool initial_jitter_elapsed:1; | 
