geli revision 149050
1149050Spjd#!/bin/sh
2149050Spjd#
3149050Spjd# Copyright (c) 2005 Pawel Jakub Dawidek <pjd@FreeBSD.org>
4149050Spjd# All rights reserved.
5149050Spjd#
6149050Spjd# Redistribution and use in source and binary forms, with or without
7149050Spjd# modification, are permitted provided that the following conditions
8149050Spjd# are met:
9149050Spjd# 1. Redistributions of source code must retain the above copyright
10149050Spjd#    notice, this list of conditions and the following disclaimer.
11149050Spjd# 2. Redistributions in binary form must reproduce the above copyright
12149050Spjd#    notice, this list of conditions and the following disclaimer in the
13149050Spjd#    documentation and/or other materials provided with the distribution.
14149050Spjd# 
15149050Spjd# THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
16149050Spjd# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17149050Spjd# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18149050Spjd# ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
19149050Spjd# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20149050Spjd# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21149050Spjd# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22149050Spjd# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23149050Spjd# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24149050Spjd# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25149050Spjd# SUCH DAMAGE.
26149050Spjd#
27149050Spjd# $FreeBSD: head/etc/rc.d/geli 149050 2005-08-14 18:02:22Z pjd $
28149050Spjd#
29149050Spjd
30149050Spjd# PROVIDE: disks
31149050Spjd# REQUIRE: initrandom
32149050Spjd# KEYWORD: nojail
33149050Spjd
34149050Spjd. /etc/rc.subr
35149050Spjd
36149050Spjdname="geli"
37149050Spjdstart_cmd="geli_start"
38149050Spjdstop_cmd="geli_stop"
39149050Spjd
40149050Spjdgeli_start()
41149050Spjd{
42149050Spjd	devices=`geli_make_list`
43149050Spjd
44149050Spjd	# If there are no devices return before loading geom_eli.ko.
45149050Spjd	if [ -z "${devices}" ]; then
46149050Spjd		return
47149050Spjd	fi
48149050Spjd
49149050Spjd	geli load >/dev/null 2>&1
50149050Spjd	if ! kldstat -v | grep -q g_eli\$; then
51149050Spjd		err 1 'geom_eli module failed to load.'
52149050Spjd	fi
53149050Spjd
54149050Spjd	if [ -z "${geli_tries}" ]; then
55149050Spjd		if [ -n "${geli_attach_attempts}" ]; then
56149050Spjd			# Compatibility with rc.d/gbde.
57149050Spjd			geli_tries=${geli_attach_attempts}
58149050Spjd		else
59149050Spjd			geli_tries=`${SYSCTL_N} kern.geom.eli.tries`
60149050Spjd		fi
61149050Spjd	fi
62149050Spjd
63149050Spjd	for provider in ${devices}; do
64149050Spjd		provider_=`ltr ${provider} '/' '_'`
65149050Spjd
66149050Spjd		eval "flags=\${geli_${provider_}_flags}"
67149050Spjd		if [ -z "${flags}" ]; then
68149050Spjd			flags=${geli_default_flags}
69149050Spjd		fi
70149050Spjd		if [ -e "/dev/${provider}" -a ! -e "/dev/${provider}.eli" ]; then
71149050Spjd			echo "Configuring Disk Encryption for ${provider}."
72149050Spjd			count=1
73149050Spjd			while [ ${count} -le ${geli_tries} ]; do
74149050Spjd				geli attach ${flags} ${provider}
75149050Spjd				if [ -e "/dev/${provider}.eli" ]; then
76149050Spjd					break
77149050Spjd				fi
78149050Spjd				echo "Attach failed; attempt ${count} of ${geli_tries}."
79149050Spjd				count=$((count+1))
80149050Spjd			done
81149050Spjd		fi
82149050Spjd	done
83149050Spjd}
84149050Spjd
85149050Spjdgeli_stop()
86149050Spjd{
87149050Spjd	devices=`geli_make_list`
88149050Spjd
89149050Spjd	for provider in ${devices}; do
90149050Spjd		if [ -e "/dev/${provider}.eli" ]; then
91149050Spjd			umount "/dev/${provider}.eli" 2>/dev/null
92149050Spjd			geli detach "${provider}"
93149050Spjd		fi
94149050Spjd	done
95149050Spjd}
96149050Spjd
97149050Spjdload_rc_config $name
98149050Spjdrun_rc_command "$1"
99