Commit d8cd33f8 authored by Vladimír Čunát's avatar Vladimír Čunát

validate: avoid keeping KR_RANK_MISSING

If a sub-query transitions the state to QUERY_DNSSEC_INSECURE,
we didn't set correct rank.  This lead to caching with _MISSING rank
which is too low to be utilized on re-queries.  Example: query.
parent 0cd00388
......@@ -14,6 +14,9 @@ Improvements
- command line: specify ports via @ but still support # for compatibility
- policy: recognize as local addresses
- validate: fix insufficient caching for some cases (relatively rare)
Knot Resolver 1.2.6 (2017-04-24)
......@@ -585,7 +585,8 @@ static int check_signer(kr_layer_t *ctx, knot_pkt_t *pkt)
static void rank_records(kr_layer_t *ctx, uint8_t rank_to_set)
/** Change ranks of RRs from this single iteration: _INITIAL or _MISSING -> rank_to_set. */
static void rank_records(kr_layer_t *ctx, enum kr_rank rank_to_set)
struct kr_request *req = ctx->req;
struct kr_query *qry = req->current_query;
......@@ -597,7 +598,8 @@ static void rank_records(kr_layer_t *ctx, uint8_t rank_to_set)
if (entry->qry_uid != qry->uid) {
if (kr_rank_test(entry->rank, KR_RANK_INITIAL)) {
if (kr_rank_test(entry->rank, KR_RANK_INITIAL)
|| kr_rank_test(entry->rank, KR_RANK_MISSING)) {
kr_rank_set(&entry->rank, rank_to_set);
Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment