Annotation of embedaddon/ntp/lib/isc/random.c, revision 1.1

1.1     ! misho       1: /*
        !             2:  * Copyright (C) 2004, 2005, 2007  Internet Systems Consortium, Inc. ("ISC")
        !             3:  * Copyright (C) 1999-2003  Internet Software Consortium.
        !             4:  *
        !             5:  * Permission to use, copy, modify, and/or distribute this software for any
        !             6:  * purpose with or without fee is hereby granted, provided that the above
        !             7:  * copyright notice and this permission notice appear in all copies.
        !             8:  *
        !             9:  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
        !            10:  * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
        !            11:  * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
        !            12:  * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
        !            13:  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
        !            14:  * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
        !            15:  * PERFORMANCE OF THIS SOFTWARE.
        !            16:  */
        !            17: 
        !            18: /* $Id: random.c,v 1.25 2007/06/19 23:47:17 tbox Exp $ */
        !            19: 
        !            20: /*! \file */
        !            21: 
        !            22: #include <config.h>
        !            23: 
        !            24: #include <stdlib.h>
        !            25: #include <time.h>              /* Required for time(). */
        !            26: #ifdef HAVE_SYS_TYPES_H
        !            27: #include <sys/types.h>
        !            28: #endif
        !            29: #ifdef HAVE_UNISTD_H
        !            30: #include <unistd.h>
        !            31: #endif
        !            32: 
        !            33: #include <isc/mutex.h>
        !            34: #include <isc/once.h>
        !            35: #include <isc/random.h>
        !            36: #include <isc/string.h>
        !            37: #include <isc/util.h>
        !            38: 
        !            39: static isc_once_t once = ISC_ONCE_INIT;
        !            40: 
        !            41: static void
        !            42: initialize_rand(void)
        !            43: {
        !            44: #ifndef HAVE_ARC4RANDOM
        !            45:        unsigned int pid = getpid();
        !            46:        
        !            47:        /*
        !            48:         * The low bits of pid generally change faster.
        !            49:         * Xor them with the high bits of time which change slowly.
        !            50:         */
        !            51:        pid = ((pid << 16) & 0xffff0000) | ((pid >> 16) & 0xffff);
        !            52: 
        !            53:        srand(time(NULL) ^ pid);
        !            54: #endif
        !            55: }
        !            56: 
        !            57: static void
        !            58: initialize(void)
        !            59: {
        !            60:        RUNTIME_CHECK(isc_once_do(&once, initialize_rand) == ISC_R_SUCCESS);
        !            61: }
        !            62: 
        !            63: void
        !            64: isc_random_seed(isc_uint32_t seed)
        !            65: {
        !            66:        initialize();
        !            67: 
        !            68: #ifndef HAVE_ARC4RANDOM
        !            69:        srand(seed);
        !            70: #else
        !            71:        arc4random_addrandom((u_char *) &seed, sizeof(isc_uint32_t));
        !            72: #endif
        !            73: }
        !            74: 
        !            75: void
        !            76: isc_random_get(isc_uint32_t *val)
        !            77: {
        !            78:        REQUIRE(val != NULL);
        !            79: 
        !            80:        initialize();
        !            81: 
        !            82: #ifndef HAVE_ARC4RANDOM
        !            83:        /*
        !            84:         * rand()'s lower bits are not random.
        !            85:         * rand()'s upper bit is zero.
        !            86:         */
        !            87:        *val = ((rand() >> 4) & 0xffff) | ((rand() << 12) & 0xffff0000);
        !            88: #else
        !            89:        *val = arc4random();
        !            90: #endif
        !            91: }
        !            92: 
        !            93: isc_uint32_t
        !            94: isc_random_jitter(isc_uint32_t max, isc_uint32_t jitter) {
        !            95:        REQUIRE(jitter < max);
        !            96:        if (jitter == 0)
        !            97:                return (max);
        !            98:        else
        !            99: #ifndef HAVE_ARC4RANDOM
        !           100:                return (max - rand() % jitter);
        !           101: #else
        !           102:                return (max - arc4random() % jitter);
        !           103: #endif
        !           104: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>