Home | History | Annotate | Line # | Download | only in rumpkern
hyperentropy.c revision 1.2.2.1
      1  1.2.2.1    tls /*	$NetBSD: hyperentropy.c,v 1.2.2.1 2014/04/07 03:37:33 tls Exp $	*/
      2      1.1  pooka 
      3      1.1  pooka /*
      4      1.1  pooka  * Copyright (c) 2014 Antti Kantee.  All Rights Reserved.
      5      1.1  pooka  *
      6      1.1  pooka  * Redistribution and use in source and binary forms, with or without
      7      1.1  pooka  * modification, are permitted provided that the following conditions
      8      1.1  pooka  * are met:
      9      1.1  pooka  * 1. Redistributions of source code must retain the above copyright
     10      1.1  pooka  *    notice, this list of conditions and the following disclaimer.
     11      1.1  pooka  * 2. Redistributions in binary form must reproduce the above copyright
     12      1.1  pooka  *    notice, this list of conditions and the following disclaimer in the
     13      1.1  pooka  *    documentation and/or other materials provided with the distribution.
     14      1.1  pooka  *
     15      1.1  pooka  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
     16      1.1  pooka  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
     17      1.1  pooka  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
     18      1.1  pooka  * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
     19      1.1  pooka  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     20      1.1  pooka  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
     21      1.1  pooka  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     22      1.1  pooka  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     23      1.1  pooka  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     24      1.1  pooka  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     25      1.1  pooka  * SUCH DAMAGE.
     26      1.1  pooka  */
     27      1.1  pooka 
     28      1.1  pooka #include <sys/cdefs.h>
     29  1.2.2.1    tls __KERNEL_RCSID(0, "$NetBSD: hyperentropy.c,v 1.2.2.1 2014/04/07 03:37:33 tls Exp $");
     30      1.1  pooka 
     31      1.1  pooka #include <sys/param.h>
     32      1.1  pooka #include <sys/kmem.h>
     33      1.1  pooka #include <sys/rnd.h>
     34      1.1  pooka 
     35      1.1  pooka #include <rump/rumpuser.h>
     36      1.1  pooka 
     37      1.1  pooka #include "rump_private.h"
     38      1.1  pooka 
     39      1.1  pooka static krndsource_t rndsrc;
     40      1.1  pooka 
     41      1.2  pooka #define MAXGET (RND_POOLBITS/NBBY)
     42      1.1  pooka static void
     43      1.1  pooka feedrandom(size_t bytes, void *arg)
     44      1.1  pooka {
     45      1.2  pooka 	uint8_t *rnddata;
     46      1.1  pooka 	size_t dsize;
     47      1.1  pooka 
     48      1.2  pooka 	rnddata = kmem_intr_alloc(MAXGET, KM_SLEEP);
     49      1.2  pooka 	if (rumpuser_getrandom(rnddata, MIN(MAXGET, bytes),
     50      1.1  pooka 	    RUMPUSER_RANDOM_HARD|RUMPUSER_RANDOM_NOWAIT, &dsize) == 0)
     51      1.2  pooka 		rnd_add_data(&rndsrc, rnddata, dsize, NBBY*dsize);
     52      1.2  pooka 	kmem_intr_free(rnddata, MAXGET);
     53      1.1  pooka }
     54      1.1  pooka 
     55      1.1  pooka void
     56      1.1  pooka rump_hyperentropy_init(void)
     57      1.1  pooka {
     58      1.1  pooka 
     59      1.1  pooka 	if (rump_threads) {
     60      1.1  pooka 		rndsource_setcb(&rndsrc, feedrandom, &rndsrc);
     61      1.1  pooka 		rnd_attach_source(&rndsrc, "rump_hyperent", RND_TYPE_VM,
     62  1.2.2.1    tls 		    RND_FLAG_COLLECT_VALUE|RND_FLAG_HASCB);
     63      1.1  pooka 	} else {
     64      1.2  pooka 		/* without threads, just fill the pool */
     65      1.1  pooka 		rnd_attach_source(&rndsrc, "rump_hyperent", RND_TYPE_VM,
     66  1.2.2.1    tls 		    RND_FLAG_COLLECT_VALUE);
     67      1.2  pooka 		feedrandom(RND_POOLBITS/NBBY, NULL);
     68      1.1  pooka 	}
     69      1.1  pooka }
     70