X7ROOT File Manager
Current Path:
/usr/include/bind9/isc
usr
/
include
/
bind9
/
isc
/
📁
..
📄
aes.h
(1.05 KB)
📄
app.h
(10.23 KB)
📄
assertions.h
(2.84 KB)
📄
atomic.h
(4.07 KB)
📄
backtrace.h
(3.8 KB)
📄
base32.h
(4.35 KB)
📄
base64.h
(2.8 KB)
📄
bind9.h
(830 B)
📄
boolean.h
(594 B)
📄
buffer.h
(25.65 KB)
📄
bufferlist.h
(1.42 KB)
📄
cmocka.h
(1.35 KB)
📄
commandline.h
(1.67 KB)
📄
condition.h
(1.44 KB)
📄
counter.h
(1.88 KB)
📄
crc64.h
(998 B)
📄
deprecated.h
(623 B)
📄
dir.h
(1.56 KB)
📄
endian.h
(4.67 KB)
📄
entropy.h
(10.13 KB)
📄
errno.h
(659 B)
📄
errno2result.h
(902 B)
📄
error.h
(1.4 KB)
📄
event.h
(2.98 KB)
📄
eventclass.h
(1.35 KB)
📄
file.h
(11.39 KB)
📄
formatcheck.h
(893 B)
📄
fsaccess.h
(7.27 KB)
📄
hash.h
(7.48 KB)
📄
heap.h
(5.14 KB)
📄
hex.h
(2.74 KB)
📄
hmacmd5.h
(1.75 KB)
📄
hmacsha.h
(4.41 KB)
📄
ht.h
(4.29 KB)
📄
httpd.h
(2.26 KB)
📄
int.h
(1.06 KB)
📄
interfaceiter.h
(3.05 KB)
📄
iterated_hash.h
(1.02 KB)
📄
json.h
(1.42 KB)
📄
keyboard.h
(989 B)
📄
lang.h
(637 B)
📄
lex.h
(9.54 KB)
📄
lfsr.h
(2.89 KB)
📄
lib.h
(1.04 KB)
📄
likely.h
(818 B)
📄
list.h
(5.62 KB)
📄
log.h
(28.06 KB)
📄
magic.h
(994 B)
📄
md5.h
(2.32 KB)
📄
mem.h
(20.62 KB)
📄
meminfo.h
(710 B)
📄
msgcat.h
(2.66 KB)
📄
msgs.h
(8.22 KB)
📄
mutex.h
(3.44 KB)
📄
mutexblock.h
(1.34 KB)
📄
net.h
(10.29 KB)
📄
netaddr.h
(4.48 KB)
📄
netdb.h
(863 B)
📄
netscope.h
(967 B)
📄
offset.h
(700 B)
📄
once.h
(983 B)
📄
ondestroy.h
(2.73 KB)
📄
os.h
(671 B)
📄
parseint.h
(1.51 KB)
📄
platform.h
(9.49 KB)
📄
pool.h
(3.42 KB)
📄
portset.h
(3.22 KB)
📄
print.h
(2.42 KB)
📄
queue.h
(5.08 KB)
📄
quota.h
(2.38 KB)
📄
radix.h
(6.34 KB)
📄
random.h
(3.5 KB)
📄
ratelimiter.h
(3.42 KB)
📄
refcount.h
(8 KB)
📄
regex.h
(767 B)
📄
region.h
(1.99 KB)
📄
resource.h
(2.79 KB)
📄
result.h
(4.87 KB)
📄
resultclass.h
(1.56 KB)
📄
rwlock.h
(3.72 KB)
📄
safe.h
(1.32 KB)
📄
serial.h
(1.34 KB)
📄
sha1.h
(1.52 KB)
📄
sha2.h
(5.6 KB)
📄
siphash.h
(734 B)
📄
sockaddr.h
(5.9 KB)
📄
socket.h
(35.8 KB)
📄
stat.h
(806 B)
📄
stats.h
(3.62 KB)
📄
stdatomic.h
(5.13 KB)
📄
stdio.h
(1.75 KB)
📄
stdlib.h
(704 B)
📄
stdtime.h
(1.04 KB)
📄
strerror.h
(777 B)
📄
string.h
(5.88 KB)
📄
symtab.h
(4.22 KB)
📄
syslog.h
(844 B)
📄
task.h
(21.04 KB)
📄
taskpool.h
(3.62 KB)
📄
thread.h
(1.47 KB)
📄
time.h
(8.67 KB)
📄
timer.h
(10.54 KB)
📄
tm.h
(895 B)
📄
types.h
(5.64 KB)
📄
utf8.h
(928 B)
📄
util.h
(10.29 KB)
📄
version.h
(689 B)
📄
xml.h
(1.07 KB)
Editing: random.h
/* * 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. */ #ifndef ISC_RANDOM_H #define ISC_RANDOM_H 1 #include <isc/lang.h> #include <isc/types.h> #include <isc/entropy.h> #include <isc/mem.h> #include <isc/mutex.h> /*! \file isc/random.h * \brief Implements pseudo random number generators. * * Two pseudo-random number generators are implemented, in isc_random_* * and isc_rng_*. Neither one is very strong; they should not be used * in cryptography functions. * * isc_random_* is based on arc4random if it is available on the system. * Otherwise it is based on the posix srand() and rand() functions. * It is useful for jittering values a bit here and there, such as * timeouts, etc, but should not be relied upon to generate * unpredictable sequences (for example, when choosing transaction IDs). * * isc_rng_* is based on ChaCha20, and is seeded and stirred from the * system entropy source. It is stronger than isc_random_* and can * be used for generating unpredictable sequences. It is still not as * good as using system entropy directly (see entropy.h) and should not * be used for cryptographic functions such as key generation. */ ISC_LANG_BEGINDECLS typedef struct isc_rng isc_rng_t; /*%< * Opaque type */ void isc_random_seed(uint32_t seed); /*%< * Set the initial seed of the random state. */ void isc_random_get(uint32_t *val); /*%< * Get a random value. * * Requires: * val != NULL. */ uint32_t isc_random_jitter(uint32_t max, uint32_t jitter); /*%< * Get a random value between (max - jitter) and (max). * This is useful for jittering timer values. */ isc_result_t isc_rng_create(isc_mem_t *mctx, isc_entropy_t *entropy, isc_rng_t **rngp); /*%< * Creates and initializes a pseudo random number generator. The * returned RNG can be used to generate pseudo random numbers. * * The reference count of the returned RNG is set to 1. * * Requires: * \li mctx is a pointer to a valid memory context. * \li entropy is an optional entopy source (can be NULL) * \li rngp != NULL && *rngp == NULL is where a pointer to the RNG is * returned. * * Ensures: *\li If result is ISC_R_SUCCESS: * *rngp points to a valid RNG. * *\li If result is failure: * *rngp does not point to a valid RNG. * * Returns: *\li #ISC_R_SUCCESS Success *\li #ISC_R_NOMEMORY Resource limit: Out of Memory */ void isc_rng_attach(isc_rng_t *source, isc_rng_t **targetp); /*%< * Increments a reference count on the passed RNG. * * Requires: * \li source the RNG struct to attach to (is refcount is incremented) * \li targetp != NULL && *targetp == NULL where a pointer to the * reference incremented RNG is returned. */ void isc_rng_detach(isc_rng_t **rngp); /*%< * Decrements a reference count on the passed RNG. If the reference * count reaches 0, the RNG is destroyed. * * Requires: * \li rngp != NULL the RNG struct to decrement reference for */ uint16_t isc_rng_random(isc_rng_t *rngctx); /*%< * Returns a pseudo random 16-bit unsigned integer. */ uint16_t isc_rng_uniformrandom(isc_rng_t *rngctx, uint16_t upper_bound); /*%< * Returns a uniformly distributed pseudo-random 16-bit unsigned integer * less than 'upper_bound'. */ ISC_LANG_ENDDECLS #endif /* ISC_RANDOM_H */
Upload File
Create Folder