*nix Documentation Project
·  Home
 +   man pages
·  Linux HOWTOs
·  FreeBSD Tips
·  *niX Forums

  man pages->FreeBSD man pages -> random_harvest (9)              
Title
Content
Arch
Section
 

RANDOM_HARVEST(9)

Contents


NAME    [Toc]    [Back]

     random_harvest -- gather entropy from the kernel for the entropy device

SYNOPSIS    [Toc]    [Back]

     #include <sys/types.h>
     #include <sys/random.h>

     void
     random_harvest(void *entropy, u_int size, u_int bits, u_int frac,
	 enum esource source);

DESCRIPTION    [Toc]    [Back]

     The random_harvest() function is used by device drivers and other kernel
     processes to pass data that is considered (at least partially) stochastic
     to the entropy device.

     The caller should pass a pointer (to no more than 16 bytes) of the
     ``random'' data in entropy.  The argument size contains the number of
     bytes pointed to.	The caller should very conservatively estimate the
     number of random bits in the sample, and pass this in bits or frac.  If
     the estimated number of bits per sample is an integer, then bits is used,
     and frac is 0.  Otherwise, for low-entropy samples, ``fractional''
     entropy can be supplied in frac.  (This is considered to be frac / 1024
     bits of entropy.)	The source is chosen from RANDOM_WRITE,
     RANDOM_KEYBOARD, RANDOM_MOUSE, RANDOM_NET and RANDOM_INTERRUPT, and is
     used to indicate the source of the entropy.

     Interrupt harvesting has been simplified for the kernel programmer.  If a
     device driver registers an interrupt handler with BUS_SETUP_INTR(9) or
     bus_setup_intr(9), then it is only necessary to include the INTR_ENTROPY
     bit in the flags argument to have that interrupt source be used for
     entropy harvesting.

SEE ALSO    [Toc]    [Back]

      
      
     random(4), BUS_SETUP_INTR(9)

AUTHORS    [Toc]    [Back]

     The FreeBSD random(4) entropy device and supporting documentation was
     written by Mark R V Murray.


FreeBSD 5.2.1		       February 6, 2002 		 FreeBSD 5.2.1
[ Back ]
 Similar pages
Name OS Title
random FreeBSD the entropy device
rnd_add_data NetBSD functions to make a device available for entropy collection
rnd_add_uint32 NetBSD functions to make a device available for entropy collection
rnd_detach_source NetBSD functions to make a device available for entropy collection
rnd_attach_source NetBSD functions to make a device available for entropy collection
rnd NetBSD functions to make a device available for entropy collection
RAND_status Tru64 Add entropy to the PRNG
RAND_add Tru64 Add entropy to the PRNG
RAND_screen Tru64 Add entropy to the PRNG
RAND_status OpenBSD add entropy to the PRNG
Copyright © 2004-2005 DeniX Solutions SRL
newsletter delivery service