summaryrefslogtreecommitdiffstats
path: root/etc/rc.d/initrandom
blob: 8802396ecb66a255b9ed4f7019888816dcce23ab (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#!/bin/sh
#
# $FreeBSD$
#

# PROVIDE: initrandom
# BEFORE: disks
# KEYWORD: nojail

. /etc/rc.subr

name="initrandom"
start_cmd="initrandom_start"
stop_cmd=":"

feed_dev_random()
{
	if [ -f "${1}" -a -r "${1}" -a -s "${1}" ]; then
		cat "${1}" | dd of=/dev/random bs=8k 2>/dev/null
	fi
}

initrandom_start()
{
	soft_random_generator=`sysctl kern.random 2>/dev/null`

	echo -n 'Entropy harvesting:'

	if [ \! -z "${soft_random_generator}" ] ; then

		if [ -w /dev/random ]; then
			if checkyesno harvest_interrupt; then
				${SYSCTL_W} kern.random.sys.harvest.interrupt=1 >/dev/null
				echo -n ' interrupts'
			else
				${SYSCTL_W} kern.random.sys.harvest.interrupt=0 >/dev/null
			fi

			if checkyesno harvest_ethernet; then
				${SYSCTL_W} kern.random.sys.harvest.ethernet=1 >/dev/null
				echo -n ' ethernet'
			else
				${SYSCTL_W} kern.random.sys.harvest.ethernet=0 >/dev/null
			fi

			if checkyesno harvest_p_to_p; then
				${SYSCTL_W} kern.random.sys.harvest.point_to_point=1 >/dev/null
				echo -n ' point_to_point'
			else
				${SYSCTL_W} kern.random.sys.harvest.point_to_point=0 >/dev/null
			fi
		fi

		# XXX temporary until we can improve the entropy
		# harvesting rate.
		# Entropy below is not great, but better than nothing.
		# This unblocks the generator at startup
		( ps -fauxww; sysctl -a; date; df -ib; dmesg; ps -fauxww ) \
		    | dd of=/dev/random bs=8k 2>/dev/null
		cat /bin/ls | dd of=/dev/random bs=8k 2>/dev/null

		# First pass at reseeding /dev/random.
		#
		case ${entropy_file} in
		[Nn][Oo] | '')
			;;
		*)
			if [ -w /dev/random ]; then
				feed_dev_random "${entropy_file}"
			fi
			;;
		esac

		echo -n ' kickstart'
	fi

	echo '.'
}

load_rc_config random
run_rc_command "$1"
OpenPOWER on IntegriCloud