diff options
| -rw-r--r-- | src/resolve/resolved-dns-transaction.c | 7 | ||||
| -rw-r--r-- | src/resolve/resolved-dns-transaction.h | 1 | 
2 files changed, 7 insertions, 1 deletions
| diff --git a/src/resolve/resolved-dns-transaction.c b/src/resolve/resolved-dns-transaction.c index 6eec1446d7..7924b24354 100644 --- a/src/resolve/resolved-dns-transaction.c +++ b/src/resolve/resolved-dns-transaction.c @@ -814,6 +814,7 @@ int dns_transaction_go(DnsTransaction *t) {                          return r;                  t->n_attempts = 0; +                t->next_attempt_after = ts;                  t->state = DNS_TRANSACTION_PENDING;                  log_debug("Delaying %s transaction for " USEC_FMT "us.", dns_protocol_to_string(t->scope->protocol), jitter); @@ -863,16 +864,20 @@ int dns_transaction_go(DnsTransaction *t) {                  return dns_transaction_go(t);          } +        ts += transaction_get_resend_timeout(t); +          r = sd_event_add_time(                          t->scope->manager->event,                          &t->timeout_event_source,                          clock_boottime_or_monotonic(), -                        ts + transaction_get_resend_timeout(t), 0, +                        ts, 0,                          on_transaction_timeout, t);          if (r < 0)                  return r;          t->state = DNS_TRANSACTION_PENDING; +        t->next_attempt_after = ts; +          return 1;  } diff --git a/src/resolve/resolved-dns-transaction.h b/src/resolve/resolved-dns-transaction.h index e3d4b861be..af08b20e44 100644 --- a/src/resolve/resolved-dns-transaction.h +++ b/src/resolve/resolved-dns-transaction.h @@ -73,6 +73,7 @@ struct DnsTransaction {          bool answer_authenticated;          usec_t start_usec; +        usec_t next_attempt_after;          sd_event_source *timeout_event_source;          unsigned n_attempts; | 
