This file contains functions to assist the iterator module. More...
Data Structures | |
struct | iter_hints |
Iterator hints structure. More... | |
struct | iter_hints_stub |
Iterator hints for a particular stub. More... | |
Functions | |
struct iter_hints * | hints_create (void) |
Create hints. More... | |
void | hints_delete (struct iter_hints *hints) |
Delete hints. More... | |
int | hints_apply_cfg (struct iter_hints *hints, struct config_file *cfg) |
Process hints config. More... | |
struct delegpt * | hints_find (struct iter_hints *hints, uint8_t *qname, uint16_t qclass, int nolock) |
Find hints for the given class. More... | |
struct delegpt * | hints_find_root (struct iter_hints *hints, uint16_t qclass, int nolock) |
Same as hints_lookup, but for the root only. More... | |
int | hints_next_root (struct iter_hints *hints, uint16_t *qclass, int nolock) |
Find next root hints (to cycle through all root hints). More... | |
struct iter_hints_stub * | hints_lookup_stub (struct iter_hints *hints, uint8_t *qname, uint16_t qclass, struct delegpt *dp, int nolock) |
Given a qname/qclass combination, and the delegation point from the cache for this qname/qclass, determine if this combination indicates that a stub hint exists and must be primed. More... | |
size_t | hints_get_mem (struct iter_hints *hints) |
Get memory in use by hints Locks and unlocks the structure. More... | |
int | hints_add_stub (struct iter_hints *hints, uint16_t c, struct delegpt *dp, int noprime, int nolock) |
Add stub to hints structure. More... | |
void | hints_delete_stub (struct iter_hints *hints, uint16_t c, uint8_t *nm, int nolock) |
Remove stub from hints structure. More... | |
This file contains functions to assist the iterator module.
Keep track of stub and root hints, and read those from config.
struct iter_hints* hints_create | ( | void | ) |
Create hints.
References iter_hints::lock, and iter_hints::tree.
Referenced by check_hints(), and context_finalize().
void hints_delete | ( | struct iter_hints * | hints | ) |
Delete hints.
hints | to delete. |
References iter_hints::lock.
Referenced by daemon_cleanup().
int hints_apply_cfg | ( | struct iter_hints * | hints, |
struct config_file * | cfg | ||
) |
Process hints config.
Sets default values for root hints if no config.
hints | where to store. |
cfg | config options. |
References iter_hints::lock.
Referenced by check_hints(), and context_finalize().
struct delegpt* hints_find | ( | struct iter_hints * | hints, |
uint8_t * | qname, | ||
uint16_t | qclass, | ||
int | nolock | ||
) |
Find hints for the given class.
The return value is contents of the hints structure. Caller should lock and unlock a readlock on the hints structure if nolock is set. Otherwise caller should unlock the readlock on the hints structure if a value was returned.
hints | hint storage. |
qname | the qname that generated the delegation point. |
qclass | class for which root hints are requested. host order. |
nolock | Skip locking, locking is handled by the caller. |
References dname_count_size_labels(), iter_hints_stub::dp, iter_hints::lock, name_tree_find(), and iter_hints::tree.
Referenced by hints_find_root().
struct delegpt* hints_find_root | ( | struct iter_hints * | hints, |
uint16_t | qclass, | ||
int | nolock | ||
) |
Same as hints_lookup, but for the root only.
hints | hint storage. |
qclass | class for which root hints are requested. host order. |
nolock | Skip locking, locking is handled by the caller. |
References hints_find().
Referenced by prime_root().
int hints_next_root | ( | struct iter_hints * | hints, |
uint16_t * | qclass, | ||
int | nolock | ||
) |
Find next root hints (to cycle through all root hints).
Handles its own locking unless nolock is set. In that case the caller should lock and unlock a readlock on the hints structure.
hints | hint storage |
qclass | class for which root hints are sought. 0 means give the first available root hints class. x means, give class x or a higher class if any. returns the found class in this variable. |
nolock | Skip locking, locking is handled by the caller. |
References iter_hints::lock, name_tree_next_root(), and iter_hints::tree.
Referenced by iter_get_next_root().
struct iter_hints_stub* hints_lookup_stub | ( | struct iter_hints * | hints, |
uint8_t * | qname, | ||
uint16_t | qclass, | ||
struct delegpt * | dp, | ||
int | nolock | ||
) |
Given a qname/qclass combination, and the delegation point from the cache for this qname/qclass, determine if this combination indicates that a stub hint exists and must be primed.
The return value is contents of the hints structure. Caller should lock and unlock a readlock on the hints structure if nolock is set. Otherwise caller should unlock the readlock on the hints structure if a value was returned.
hints | hint storage. |
qname | The qname that generated the delegation point. |
qclass | The qclass that generated the delegation point. |
dp | The cache generated delegation point. |
nolock | Skip locking, locking is handled by the caller. |
References dname_count_size_labels(), dname_strict_subdomain(), iter_hints_stub::dp, iter_hints::lock, delegpt::name, name_tree_lookup(), delegpt::namelabs, iter_hints_stub::noprime, query_dname_compare(), and iter_hints::tree.
Referenced by iter_stub_fwd_no_cache(), and prime_stub().
size_t hints_get_mem | ( | struct iter_hints * | hints | ) |
Get memory in use by hints Locks and unlocks the structure.
hints | hint storage. |
References delegpt_get_mem(), iter_hints_stub::dp, iter_hints::lock, RBTREE_FOR, and iter_hints::tree.
int hints_add_stub | ( | struct iter_hints * | hints, |
uint16_t | c, | ||
struct delegpt * | dp, | ||
int | noprime, | ||
int | nolock | ||
) |
Add stub to hints structure.
For external use since it recalcs the tree parents. Handles its own locking unless nolock is set. In that case the caller should lock and unlock a writelock on the hints structure.
hints | the hints data structure |
c | class of zone |
dp | delegation point with name and target nameservers for new hints stub. malloced. |
noprime | set noprime option to true or false on new hint stub. |
nolock | Skip locking, locking is handled by the caller. |
References iter_hints_stub::dp, iter_hints::lock, delegpt::name, name_tree_find(), delegpt::namelabs, delegpt::namelen, iter_hints_stub::node, rbtree_delete(), and iter_hints::tree.
void hints_delete_stub | ( | struct iter_hints * | hints, |
uint16_t | c, | ||
uint8_t * | nm, | ||
int | nolock | ||
) |
Remove stub from hints structure.
For external use since it recalcs the tree parents. Handles its own locking unless nolock is set. In that case the caller should lock and unlock a writelock on the hints structure.
hints | the hints data structure |
c | class of stub zone |
nm | name of stub zone (in uncompressed wireformat). |
nolock | Skip locking, locking is handled by the caller. |
References dname_count_size_labels(), iter_hints::lock, name_tree_find(), iter_hints_stub::node, rbtree_delete(), and iter_hints::tree.