Current Path: > > usr > include > bind9 > isc >
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
aes.h | File | 1080 bytes | February 20 2025 09:05:24. | |
app.h | File | 10478 bytes | February 20 2025 09:05:24. | |
assertions.h | File | 2907 bytes | February 20 2025 09:05:24. | |
atomic.h | File | 4168 bytes | February 20 2025 09:05:24. | |
backtrace.h | File | 3891 bytes | February 20 2025 09:05:24. | |
base32.h | File | 4453 bytes | February 20 2025 09:05:24. | |
base64.h | File | 2866 bytes | February 20 2025 09:05:24. | |
bind9.h | File | 830 bytes | February 20 2025 09:05:24. | |
boolean.h | File | 594 bytes | February 20 2025 09:05:24. | |
buffer.h | File | 26268 bytes | February 20 2025 09:05:24. | |
bufferlist.h | File | 1452 bytes | February 20 2025 09:05:24. | |
cmocka.h | File | 1383 bytes | February 20 2025 09:05:24. | |
commandline.h | File | 1713 bytes | February 20 2025 09:05:24. | |
condition.h | File | 1478 bytes | February 20 2025 09:05:24. | |
counter.h | File | 1926 bytes | February 20 2025 09:05:24. | |
crc64.h | File | 998 bytes | February 20 2025 09:05:24. | |
deprecated.h | File | 623 bytes | February 20 2025 09:05:24. | |
dir.h | File | 1598 bytes | February 20 2025 09:05:24. | |
endian.h | File | 4778 bytes | February 20 2025 09:05:24. | |
entropy.h | File | 10373 bytes | February 20 2025 09:05:24. | |
errno.h | File | 659 bytes | February 20 2025 09:05:24. | |
errno2result.h | File | 902 bytes | February 20 2025 09:05:37. | |
error.h | File | 1430 bytes | February 20 2025 09:05:24. | |
event.h | File | 3053 bytes | February 20 2025 09:05:24. | |
eventclass.h | File | 1381 bytes | February 20 2025 09:05:24. | |
file.h | File | 11667 bytes | February 20 2025 09:05:24. | |
formatcheck.h | File | 893 bytes | February 20 2025 09:05:24. | |
fsaccess.h | File | 7442 bytes | February 20 2025 09:05:24. | |
hash.h | File | 7662 bytes | February 20 2025 09:05:24. | |
heap.h | File | 5264 bytes | February 20 2025 09:05:24. | |
hex.h | File | 2806 bytes | February 20 2025 09:05:24. | |
hmacmd5.h | File | 1787 bytes | February 20 2025 09:05:24. | |
hmacsha.h | File | 4511 bytes | February 20 2025 09:05:24. | |
ht.h | File | 4396 bytes | February 20 2025 09:05:24. | |
httpd.h | File | 2318 bytes | February 20 2025 09:05:24. | |
int.h | File | 1088 bytes | February 20 2025 09:05:24. | |
interfaceiter.h | File | 3120 bytes | February 20 2025 09:05:24. | |
iterated_hash.h | File | 1046 bytes | February 20 2025 09:05:24. | |
json.h | File | 1459 bytes | February 20 2025 09:05:24. | |
keyboard.h | File | 989 bytes | February 20 2025 09:05:24. | |
lang.h | File | 637 bytes | February 20 2025 09:05:24. | |
lex.h | File | 9771 bytes | February 20 2025 09:05:24. | |
lfsr.h | File | 2958 bytes | February 20 2025 09:05:24. | |
lib.h | File | 1068 bytes | February 20 2025 09:05:24. | |
likely.h | File | 818 bytes | February 20 2025 09:05:24. | |
list.h | File | 5751 bytes | February 20 2025 09:05:24. | |
log.h | File | 28734 bytes | February 20 2025 09:05:24. | |
magic.h | File | 994 bytes | February 20 2025 09:05:24. | |
md5.h | File | 2380 bytes | February 20 2025 09:05:24. | |
mem.h | File | 21110 bytes | February 20 2025 09:05:24. | |
meminfo.h | File | 710 bytes | February 20 2025 09:05:24. | |
msgcat.h | File | 2726 bytes | February 20 2025 09:05:24. | |
msgs.h | File | 8422 bytes | February 20 2025 09:05:24. | |
mutex.h | File | 3524 bytes | February 20 2025 09:05:24. | |
mutexblock.h | File | 1375 bytes | February 20 2025 09:05:24. | |
net.h | File | 10534 bytes | February 20 2025 09:05:24. | |
netaddr.h | File | 4590 bytes | February 20 2025 09:05:24. | |
netdb.h | File | 863 bytes | February 20 2025 09:05:24. | |
netscope.h | File | 967 bytes | February 20 2025 09:05:24. | |
offset.h | File | 700 bytes | February 20 2025 09:05:24. | |
once.h | File | 983 bytes | February 20 2025 09:05:24. | |
ondestroy.h | File | 2799 bytes | February 20 2025 09:05:24. | |
os.h | File | 671 bytes | February 20 2025 09:05:24. | |
parseint.h | File | 1542 bytes | February 20 2025 09:05:24. | |
platform.h | File | 9717 bytes | February 20 2025 09:05:24. | |
pool.h | File | 3502 bytes | February 20 2025 09:05:24. | |
portset.h | File | 3295 bytes | February 20 2025 09:05:24. | |
print.h | File | 2475 bytes | February 20 2025 09:05:24. | |
queue.h | File | 5204 bytes | February 20 2025 09:05:24. | |
quota.h | File | 2440 bytes | February 20 2025 09:05:24. | |
radix.h | File | 6491 bytes | February 20 2025 09:05:24. | |
random.h | File | 3582 bytes | February 20 2025 09:05:24. | |
ratelimiter.h | File | 3497 bytes | February 20 2025 09:05:24. | |
refcount.h | File | 8193 bytes | February 20 2025 09:05:24. | |
regex.h | File | 767 bytes | February 20 2025 09:05:24. | |
region.h | File | 2034 bytes | February 20 2025 09:05:24. | |
resource.h | File | 2862 bytes | February 20 2025 09:05:24. | |
result.h | File | 4982 bytes | February 20 2025 09:05:24. | |
resultclass.h | File | 1599 bytes | February 20 2025 09:05:24. | |
rwlock.h | File | 3807 bytes | February 20 2025 09:05:24. | |
safe.h | File | 1352 bytes | February 20 2025 09:05:24. | |
serial.h | File | 1368 bytes | February 20 2025 09:05:24. | |
sha1.h | File | 1556 bytes | February 20 2025 09:05:24. | |
sha2.h | File | 5733 bytes | February 20 2025 09:05:24. | |
siphash.h | File | 734 bytes | February 20 2025 09:05:24. | |
sockaddr.h | File | 6039 bytes | February 20 2025 09:05:24. | |
socket.h | File | 36655 bytes | February 20 2025 09:05:24. | |
stat.h | File | 806 bytes | February 20 2025 09:05:24. | |
stats.h | File | 3709 bytes | February 20 2025 09:05:24. | |
stdatomic.h | File | 5250 bytes | February 20 2025 09:05:24. | |
stdio.h | File | 1787 bytes | February 20 2025 09:05:24. | |
stdlib.h | File | 704 bytes | February 20 2025 09:05:24. | |
stdtime.h | File | 1065 bytes | February 20 2025 09:05:24. | |
strerror.h | File | 777 bytes | February 20 2025 09:05:24. | |
string.h | File | 6019 bytes | February 20 2025 09:05:24. | |
symtab.h | File | 4326 bytes | February 20 2025 09:05:24. | |
syslog.h | File | 844 bytes | February 20 2025 09:05:24. | |
task.h | File | 21544 bytes | February 20 2025 09:05:24. | |
taskpool.h | File | 3709 bytes | February 20 2025 09:05:24. | |
thread.h | File | 1506 bytes | February 20 2025 09:05:24. | |
time.h | File | 8876 bytes | February 20 2025 09:05:24. | |
timer.h | File | 10795 bytes | February 20 2025 09:05:24. | |
tm.h | File | 895 bytes | February 20 2025 09:05:24. | |
types.h | File | 5780 bytes | February 20 2025 09:05:24. | |
utf8.h | File | 928 bytes | February 20 2025 09:05:24. | |
util.h | File | 10537 bytes | February 20 2025 09:05:24. | |
version.h | File | 689 bytes | February 20 2025 09:05:24. | |
xml.h | File | 1094 bytes | February 20 2025 09:05:24. |
/* * Copyright (C) Internet Systems Consortium, Inc. ("ISC") * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, you can obtain one at https://mozilla.org/MPL/2.0/. * * See the COPYRIGHT file distributed with this work for additional * information regarding copyright ownership. */ #include <stdbool.h> #include <isc/magic.h> #include <isc/types.h> #include <isc/mutex.h> #include <isc/net.h> #include <isc/refcount.h> #include <string.h> #ifndef _RADIX_H #define _RADIX_H #define NETADDR_TO_PREFIX_T(na,pt,bits,is_ecs) \ do { \ const void *p = na; \ memset(&(pt), 0, sizeof(pt)); \ if (p != NULL) { \ (pt).family = (na)->family; \ (pt).bitlen = (bits); \ if ((pt).family == AF_INET6) { \ memmove(&(pt).add.sin6, &(na)->type.in6, \ ((bits)+7)/8); \ } else \ memmove(&(pt).add.sin, &(na)->type.in, \ ((bits)+7)/8); \ } else { \ (pt).family = AF_UNSPEC; \ (pt).bitlen = 0; \ } \ (pt).ecs = is_ecs; \ isc_refcount_init(&(pt).refcount, 0); \ } while(0) typedef struct isc_prefix { isc_mem_t *mctx; unsigned int family; /* AF_INET | AF_INET6, or AF_UNSPEC for "any" */ unsigned int bitlen; /* 0 for "any" */ bool ecs; /* true for an EDNS client subnet address */ isc_refcount_t refcount; union { struct in_addr sin; struct in6_addr sin6; } add; } isc_prefix_t; typedef void (*isc_radix_destroyfunc_t)(void *); typedef void (*isc_radix_processfunc_t)(isc_prefix_t *, void **); #define isc_prefix_tochar(prefix) ((char *)&(prefix)->add.sin) #define isc_prefix_touchar(prefix) ((u_char *)&(prefix)->add.sin) /* * We need "first match" when we search the radix tree to preserve * compatibility with the existing ACL implementation. Radix trees * naturally lend themselves to "best match". In order to get "first match" * behavior, we keep track of the order in which entries are added to the * tree--and when a search is made, we find all matching entries, and * return the one that was added first. * * An IPv4 prefix and an IPv6 prefix may share a radix tree node if they * have the same length and bit pattern (e.g., 127/8 and 7f::/8). Also, * a node that matches a client address may also match an EDNS client * subnet address. To disambiguate between these, node_num and data * are four-element arrays; * * - node_num[0] and data[0] are used for IPv4 client addresses * - node_num[1] and data[1] for IPv4 client subnet addresses * - node_num[2] and data[2] are used for IPv6 client addresses * - node_num[3] and data[3] for IPv6 client subnet addresses * * A prefix of 0/0 (aka "any" or "none"), is always stored as IPv4, * but matches IPv6 addresses too, as well as all client subnet * addresses. */ #define RADIX_NOECS 0 #define RADIX_ECS 2 #define RADIX_V4 0 #define RADIX_V6 1 #define RADIX_V4_ECS 2 #define RADIX_V6_ECS 3 #define RADIX_FAMILIES 4 #define ISC_RADIX_FAMILY(p) \ ((((p)->family == AF_INET6) ? RADIX_V6 : RADIX_V4) + \ ((p)->ecs ? RADIX_ECS : RADIX_NOECS)) typedef struct isc_radix_node { isc_mem_t *mctx; uint32_t bit; /* bit length of the prefix */ isc_prefix_t *prefix; /* who we are in radix tree */ struct isc_radix_node *l, *r; /* left and right children */ struct isc_radix_node *parent; /* may be used */ void *data[RADIX_FAMILIES]; /* pointers to IPv4 and IPV6 data */ int node_num[RADIX_FAMILIES]; /* which node this was in the tree, or -1 for glue nodes */ } isc_radix_node_t; #define RADIX_TREE_MAGIC ISC_MAGIC('R','d','x','T'); #define RADIX_TREE_VALID(a) ISC_MAGIC_VALID(a, RADIX_TREE_MAGIC); typedef struct isc_radix_tree { unsigned int magic; isc_mem_t *mctx; isc_radix_node_t *head; uint32_t maxbits; /* for IP, 32 bit addresses */ int num_active_node; /* for debugging purposes */ int num_added_node; /* total number of nodes */ } isc_radix_tree_t; isc_result_t isc_radix_search(isc_radix_tree_t *radix, isc_radix_node_t **target, isc_prefix_t *prefix); /*%< * Search 'radix' for the best match to 'prefix'. * Return the node found in '*target'. * * Requires: * \li 'radix' to be valid. * \li 'target' is not NULL and "*target" is NULL. * \li 'prefix' to be valid. * * Returns: * \li ISC_R_NOTFOUND * \li ISC_R_SUCCESS */ isc_result_t isc_radix_insert(isc_radix_tree_t *radix, isc_radix_node_t **target, isc_radix_node_t *source, isc_prefix_t *prefix); /*%< * Insert 'source' or 'prefix' into the radix tree 'radix'. * Return the node added in 'target'. * * Requires: * \li 'radix' to be valid. * \li 'target' is not NULL and "*target" is NULL. * \li 'prefix' to be valid or 'source' to be non NULL and contain * a valid prefix. * * Returns: * \li ISC_R_NOMEMORY * \li ISC_R_SUCCESS */ void isc_radix_remove(isc_radix_tree_t *radix, isc_radix_node_t *node); /*%< * Remove the node 'node' from the radix tree 'radix'. * * Requires: * \li 'radix' to be valid. * \li 'node' to be valid. */ isc_result_t isc_radix_create(isc_mem_t *mctx, isc_radix_tree_t **target, int maxbits); /*%< * Create a radix tree with a maximum depth of 'maxbits'; * * Requires: * \li 'mctx' to be valid. * \li 'target' to be non NULL and '*target' to be NULL. * \li 'maxbits' to be less than or equal to RADIX_MAXBITS. * * Returns: * \li ISC_R_NOMEMORY * \li ISC_R_SUCCESS */ void isc_radix_destroy(isc_radix_tree_t *radix, isc_radix_destroyfunc_t func); /*%< * Destroy a radix tree optionally calling 'func' to clean up node data. * * Requires: * \li 'radix' to be valid. */ void isc_radix_process(isc_radix_tree_t *radix, isc_radix_processfunc_t func); /*%< * Walk a radix tree calling 'func' to process node data. * * Requires: * \li 'radix' to be valid. * \li 'func' to point to a function. */ #define RADIX_MAXBITS 128 #define RADIX_NBIT(x) (0x80 >> ((x) & 0x7f)) #define RADIX_NBYTE(x) ((x) >> 3) #define RADIX_WALK(Xhead, Xnode) \ do { \ isc_radix_node_t *Xstack[RADIX_MAXBITS+1]; \ isc_radix_node_t **Xsp = Xstack; \ isc_radix_node_t *Xrn = (Xhead); \ while ((Xnode = Xrn)) { \ if (Xnode->prefix) #define RADIX_WALK_END \ if (Xrn->l) { \ if (Xrn->r) { \ *Xsp++ = Xrn->r; \ } \ Xrn = Xrn->l; \ } else if (Xrn->r) { \ Xrn = Xrn->r; \ } else if (Xsp != Xstack) { \ Xrn = *(--Xsp); \ } else { \ Xrn = (isc_radix_node_t *) 0; \ } \ } \ } while (0) #endif /* _RADIX_H */
SILENT KILLER Tool