#!/bin/sh # # $FreeBSD: src/etc/rc.d/random,v 1.3 2003/04/18 17:55:05 mtm Exp $ # $DragonFly: src/etc/rc.d/random,v 1.4 2006/07/10 22:19:14 dillon Exp $ # # PROVIDE: random # REQUIRE: diskless mountcritlocal initrandom # BEFORE: netif # KEYWORD: shutdown . /etc/rc.subr name="random" start_cmd="random_start" stop_cmd="random_stop" feed_dev_random() { if [ -f "${1}" -a -r "${1}" -a -s "${1}" ]; then sysctl kern.seedenable=1 cat "${1}" | dd of=/dev/random bs=8k 2>/dev/null sysctl kern.seedenable=1 fi } random_start() { # Reseed /dev/random with previously stored entropy. case ${entropy_dir} in [Nn][Oo]) ;; *) entropy_dir=${entropy_dir:-/var/db/entropy} if [ -d "${entropy_dir}" ]; then if [ -w /dev/random ]; then for seedfile in ${entropy_dir}/*; do feed_dev_random "${seedfile}" done fi fi ;; esac case ${entropy_file} in [Nn][Oo] | '') ;; *) if [ -w /dev/random ]; then feed_dev_random "${entropy_file}" fi ;; esac } random_stop() { # Write some entropy so when the machine reebots /dev/random # can be reseeded # case ${entropy_file} in [Nn][Oo] | '') ;; *) echo -n 'Writing entropy file:' rm -f ${entropy_file} oumask=`umask` umask 077 if touch ${entropy_file}; then entropy_file_confirmed="${entropy_file}" else # Try this as a reasonable alternative for read-only # roots, diskless workstations, etc. rm -f /var/db/entropy if touch /var/db/entropy; then entropy_file_confirmed=/var/db/entropy fi fi case ${entropy_file_confirmed} in '') err 1 '${entropy_file_confirmed}:' \ ' entropy file write failed.' ;; *) dd if=/dev/random of=${entropy_file_confirmed} \ bs=4096 count=1 2> /dev/null echo '.' ;; esac umask ${oumask} ;; esac } load_rc_config $name run_rc_command "$1"