Linux premium71.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
LiteSpeed
Server IP : 198.187.29.8 & Your IP : 3.144.206.193
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
include /
bind9 /
isc /
Delete
Unzip
Name
Size
Permission
Date
Action
aes.h
1.05
KB
-rw-r--r--
2025-02-20 09:05
app.h
10.23
KB
-rw-r--r--
2025-02-20 09:05
assertions.h
2.84
KB
-rw-r--r--
2025-02-20 09:05
atomic.h
4.07
KB
-rw-r--r--
2025-02-20 09:05
backtrace.h
3.8
KB
-rw-r--r--
2025-02-20 09:05
base32.h
4.35
KB
-rw-r--r--
2025-02-20 09:05
base64.h
2.8
KB
-rw-r--r--
2025-02-20 09:05
bind9.h
830
B
-rw-r--r--
2025-02-20 09:05
boolean.h
594
B
-rw-r--r--
2025-02-20 09:05
buffer.h
25.65
KB
-rw-r--r--
2025-02-20 09:05
bufferlist.h
1.42
KB
-rw-r--r--
2025-02-20 09:05
cmocka.h
1.35
KB
-rw-r--r--
2025-02-20 09:05
commandline.h
1.67
KB
-rw-r--r--
2025-02-20 09:05
condition.h
1.44
KB
-rw-r--r--
2025-02-20 09:05
counter.h
1.88
KB
-rw-r--r--
2025-02-20 09:05
crc64.h
998
B
-rw-r--r--
2025-02-20 09:05
deprecated.h
623
B
-rw-r--r--
2025-02-20 09:05
dir.h
1.56
KB
-rw-r--r--
2025-02-20 09:05
endian.h
4.67
KB
-rw-r--r--
2025-02-20 09:05
entropy.h
10.13
KB
-rw-r--r--
2025-02-20 09:05
errno.h
659
B
-rw-r--r--
2025-02-20 09:05
errno2result.h
902
B
-rw-r--r--
2025-02-20 09:05
error.h
1.4
KB
-rw-r--r--
2025-02-20 09:05
event.h
2.98
KB
-rw-r--r--
2025-02-20 09:05
eventclass.h
1.35
KB
-rw-r--r--
2025-02-20 09:05
file.h
11.39
KB
-rw-r--r--
2025-02-20 09:05
formatcheck.h
893
B
-rw-r--r--
2025-02-20 09:05
fsaccess.h
7.27
KB
-rw-r--r--
2025-02-20 09:05
hash.h
7.48
KB
-rw-r--r--
2025-02-20 09:05
heap.h
5.14
KB
-rw-r--r--
2025-02-20 09:05
hex.h
2.74
KB
-rw-r--r--
2025-02-20 09:05
hmacmd5.h
1.75
KB
-rw-r--r--
2025-02-20 09:05
hmacsha.h
4.41
KB
-rw-r--r--
2025-02-20 09:05
ht.h
4.29
KB
-rw-r--r--
2025-02-20 09:05
httpd.h
2.26
KB
-rw-r--r--
2025-02-20 09:05
int.h
1.06
KB
-rw-r--r--
2025-02-20 09:05
interfaceiter.h
3.05
KB
-rw-r--r--
2025-02-20 09:05
iterated_hash.h
1.02
KB
-rw-r--r--
2025-02-20 09:05
json.h
1.42
KB
-rw-r--r--
2025-02-20 09:05
keyboard.h
989
B
-rw-r--r--
2025-02-20 09:05
lang.h
637
B
-rw-r--r--
2025-02-20 09:05
lex.h
9.54
KB
-rw-r--r--
2025-02-20 09:05
lfsr.h
2.89
KB
-rw-r--r--
2025-02-20 09:05
lib.h
1.04
KB
-rw-r--r--
2025-02-20 09:05
likely.h
818
B
-rw-r--r--
2025-02-20 09:05
list.h
5.62
KB
-rw-r--r--
2025-02-20 09:05
log.h
28.06
KB
-rw-r--r--
2025-02-20 09:05
magic.h
994
B
-rw-r--r--
2025-02-20 09:05
md5.h
2.32
KB
-rw-r--r--
2025-02-20 09:05
mem.h
20.62
KB
-rw-r--r--
2025-02-20 09:05
meminfo.h
710
B
-rw-r--r--
2025-02-20 09:05
msgcat.h
2.66
KB
-rw-r--r--
2025-02-20 09:05
msgs.h
8.22
KB
-rw-r--r--
2025-02-20 09:05
mutex.h
3.44
KB
-rw-r--r--
2025-02-20 09:05
mutexblock.h
1.34
KB
-rw-r--r--
2025-02-20 09:05
net.h
10.29
KB
-rw-r--r--
2025-02-20 09:05
netaddr.h
4.48
KB
-rw-r--r--
2025-02-20 09:05
netdb.h
863
B
-rw-r--r--
2025-02-20 09:05
netscope.h
967
B
-rw-r--r--
2025-02-20 09:05
offset.h
700
B
-rw-r--r--
2025-02-20 09:05
once.h
983
B
-rw-r--r--
2025-02-20 09:05
ondestroy.h
2.73
KB
-rw-r--r--
2025-02-20 09:05
os.h
671
B
-rw-r--r--
2025-02-20 09:05
parseint.h
1.51
KB
-rw-r--r--
2025-02-20 09:05
platform.h
9.49
KB
-rw-r--r--
2025-02-20 09:05
pool.h
3.42
KB
-rw-r--r--
2025-02-20 09:05
portset.h
3.22
KB
-rw-r--r--
2025-02-20 09:05
print.h
2.42
KB
-rw-r--r--
2025-02-20 09:05
queue.h
5.08
KB
-rw-r--r--
2025-02-20 09:05
quota.h
2.38
KB
-rw-r--r--
2025-02-20 09:05
radix.h
6.34
KB
-rw-r--r--
2025-02-20 09:05
random.h
3.5
KB
-rw-r--r--
2025-02-20 09:05
ratelimiter.h
3.42
KB
-rw-r--r--
2025-02-20 09:05
refcount.h
8
KB
-rw-r--r--
2025-02-20 09:05
regex.h
767
B
-rw-r--r--
2025-02-20 09:05
region.h
1.99
KB
-rw-r--r--
2025-02-20 09:05
resource.h
2.79
KB
-rw-r--r--
2025-02-20 09:05
result.h
4.87
KB
-rw-r--r--
2025-02-20 09:05
resultclass.h
1.56
KB
-rw-r--r--
2025-02-20 09:05
rwlock.h
3.72
KB
-rw-r--r--
2025-02-20 09:05
safe.h
1.32
KB
-rw-r--r--
2025-02-20 09:05
serial.h
1.34
KB
-rw-r--r--
2025-02-20 09:05
sha1.h
1.52
KB
-rw-r--r--
2025-02-20 09:05
sha2.h
5.6
KB
-rw-r--r--
2025-02-20 09:05
siphash.h
734
B
-rw-r--r--
2025-02-20 09:05
sockaddr.h
5.9
KB
-rw-r--r--
2025-02-20 09:05
socket.h
35.8
KB
-rw-r--r--
2025-02-20 09:05
stat.h
806
B
-rw-r--r--
2025-02-20 09:05
stats.h
3.62
KB
-rw-r--r--
2025-02-20 09:05
stdatomic.h
5.13
KB
-rw-r--r--
2025-02-20 09:05
stdio.h
1.75
KB
-rw-r--r--
2025-02-20 09:05
stdlib.h
704
B
-rw-r--r--
2025-02-20 09:05
stdtime.h
1.04
KB
-rw-r--r--
2025-02-20 09:05
strerror.h
777
B
-rw-r--r--
2025-02-20 09:05
string.h
5.88
KB
-rw-r--r--
2025-02-20 09:05
symtab.h
4.22
KB
-rw-r--r--
2025-02-20 09:05
syslog.h
844
B
-rw-r--r--
2025-02-20 09:05
task.h
21.04
KB
-rw-r--r--
2025-02-20 09:05
taskpool.h
3.62
KB
-rw-r--r--
2025-02-20 09:05
thread.h
1.47
KB
-rw-r--r--
2025-02-20 09:05
time.h
8.67
KB
-rw-r--r--
2025-02-20 09:05
timer.h
10.54
KB
-rw-r--r--
2025-02-20 09:05
tm.h
895
B
-rw-r--r--
2025-02-20 09:05
types.h
5.64
KB
-rw-r--r--
2025-02-20 09:05
utf8.h
928
B
-rw-r--r--
2025-02-20 09:05
util.h
10.29
KB
-rw-r--r--
2025-02-20 09:05
version.h
689
B
-rw-r--r--
2025-02-20 09:05
xml.h
1.07
KB
-rw-r--r--
2025-02-20 09:05
Save
Rename
/* * 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. */ /* * This is a generic implementation of a two-lock concurrent queue. * There are built-in mutex locks for the head and tail of the queue, * allowing elements to be safely added and removed at the same time. * * NULL is "end of list" * -1 is "not linked" */ #ifndef ISC_QUEUE_H #define ISC_QUEUE_H 1 #include <stdbool.h> #include <isc/assertions.h> #include <isc/mutex.h> #ifdef ISC_QUEUE_CHECKINIT #define ISC_QLINK_INSIST(x) ISC_INSIST(x) #else #define ISC_QLINK_INSIST(x) (void)0 #endif #define ISC_QLINK(type) struct { type *prev, *next; } #define ISC_QLINK_INIT(elt, link) \ do { \ (elt)->link.next = (elt)->link.prev = (void *)(-1); \ } while(0) #define ISC_QLINK_LINKED(elt, link) ((void*)(elt)->link.next != (void*)(-1)) #define ISC_QUEUE(type) struct { \ type *head, *tail; \ isc_mutex_t headlock, taillock; \ } #define ISC_QUEUE_INIT(queue, link) \ do { \ (void) isc_mutex_init(&(queue).taillock); \ (void) isc_mutex_init(&(queue).headlock); \ (queue).tail = (queue).head = NULL; \ } while (0) #define ISC_QUEUE_EMPTY(queue) ((queue).head == NULL) #define ISC_QUEUE_DESTROY(queue) \ do { \ ISC_QLINK_INSIST(ISC_QUEUE_EMPTY(queue)); \ (void) isc_mutex_destroy(&(queue).taillock); \ (void) isc_mutex_destroy(&(queue).headlock); \ } while (0) /* * queues are meant to separate the locks at either end. For best effect, that * means keeping the ends separate - i.e. non-empty queues work best. * * a push to an empty queue has to take the pop lock to update * the pop side of the queue. * Popping the last entry has to take the push lock to update * the push side of the queue. * * The order is (pop, push), because a pop is presumably in the * latency path and a push is when we're done. * * We do an MT hot test in push to see if we need both locks, so we can * acquire them in order. Hopefully that makes the case where we get * the push lock and find we need the pop lock (and have to release it) rare. * * > 1 entry - no collision, push works on one end, pop on the other * 0 entry - headlock race * pop wins - return(NULL), push adds new as both head/tail * push wins - updates head/tail, becomes 1 entry case. * 1 entry - taillock race * pop wins - return(pop) sets head/tail NULL, becomes 0 entry case * push wins - updates {head,tail}->link.next, pop updates head * with new ->link.next and doesn't update tail * */ #define ISC_QUEUE_PUSH(queue, elt, link) \ do { \ bool headlocked = false; \ ISC_QLINK_INSIST(!ISC_QLINK_LINKED(elt, link)); \ LOCK(&(queue).taillock); \ if ((queue).tail == NULL) { \ UNLOCK(&(queue).taillock); \ LOCK(&(queue).headlock); \ LOCK(&(queue).taillock); \ headlocked = true; \ } \ (elt)->link.prev = (queue).tail; \ (elt)->link.next = NULL; \ if ((queue).tail != NULL) \ (queue).tail->link.next = (elt); \ (queue).tail = (elt); \ UNLOCK(&(queue).taillock); \ if (headlocked) { \ if ((queue).head == NULL) \ (queue).head = (elt); \ UNLOCK(&(queue).headlock); \ } \ } while (0) #define ISC_QUEUE_POP(queue, link, ret) \ do { \ LOCK(&(queue).headlock); \ ret = (queue).head; \ while (ret != NULL) { \ if (ret->link.next == NULL) { \ LOCK(&(queue).taillock); \ if (ret->link.next == NULL) { \ (queue).head = (queue).tail = NULL; \ UNLOCK(&(queue).taillock); \ break; \ }\ UNLOCK(&(queue).taillock); \ } \ (queue).head = ret->link.next; \ (queue).head->link.prev = NULL; \ break; \ } \ UNLOCK(&(queue).headlock); \ if (ret != NULL) \ (ret)->link.next = (ret)->link.prev = (void *)(-1); \ } while(0) #define ISC_QUEUE_UNLINK(queue, elt, link) \ do { \ ISC_QLINK_INSIST(ISC_QLINK_LINKED(elt, link)); \ LOCK(&(queue).headlock); \ LOCK(&(queue).taillock); \ if ((elt)->link.prev == NULL) \ (queue).head = (elt)->link.next; \ else \ (elt)->link.prev->link.next = (elt)->link.next; \ if ((elt)->link.next == NULL) \ (queue).tail = (elt)->link.prev; \ else \ (elt)->link.next->link.prev = (elt)->link.prev; \ UNLOCK(&(queue).taillock); \ UNLOCK(&(queue).headlock); \ (elt)->link.next = (elt)->link.prev = (void *)(-1); \ } while(0) #define ISC_QUEUE_UNLINKIFLINKED(queue, elt, link) \ do { \ LOCK(&(queue).headlock); \ LOCK(&(queue).taillock); \ if (ISC_QLINK_LINKED(elt, link)) { \ if ((elt)->link.prev == NULL) \ (queue).head = (elt)->link.next; \ else \ (elt)->link.prev->link.next = (elt)->link.next; \ if ((elt)->link.next == NULL) \ (queue).tail = (elt)->link.prev; \ else \ (elt)->link.next->link.prev = (elt)->link.prev; \ } \ UNLOCK(&(queue).taillock); \ UNLOCK(&(queue).headlock); \ (elt)->link.next = (elt)->link.prev = (void *)(-1); \ } while(0) #endif /* ISC_QUEUE_H */