79 lines
1.6 KiB
Plaintext
79 lines
1.6 KiB
Plaintext
|
#!/bin/sh
|
||
|
|
||
|
my_name="$0"
|
||
|
|
||
|
check_required_files() {
|
||
|
[ -x "$1" ] || {
|
||
|
echo "$my_name: $1 is missing"
|
||
|
exit 1
|
||
|
}
|
||
|
[ -z "$2" ] || [ -f "$2" ] || {
|
||
|
echo "$my_name: $2 is missing"
|
||
|
exit 1
|
||
|
}
|
||
|
}
|
||
|
|
||
|
check_device() {
|
||
|
ls -1 /dev/tpm[0-9]* > /dev/null 2>&1 || {
|
||
|
echo "device driver not loaded, skipping."
|
||
|
exit 0
|
||
|
}
|
||
|
chown tss:tss /dev/tpm[0-9]* && chmod 600 /dev/tpm*
|
||
|
}
|
||
|
|
||
|
rm_stale_pidfile() {
|
||
|
if [ -e "$1" ]; then
|
||
|
exe="/proc/$(cat "$1")/exe"
|
||
|
{ [ -s "$exe" ] && [ "$(readlink -f "$exe")" = "$2" ]; } || rm -f "$1"
|
||
|
fi
|
||
|
}
|
||
|
|
||
|
start() {
|
||
|
printf "Starting tpm2-abrmd: "
|
||
|
check_device
|
||
|
rm_stale_pidfile /var/run/tpm2-abrmd.pid /usr/sbin/tpm2-abrmd
|
||
|
start-stop-daemon -S -q -o -b -p /var/run/tpm2-abrmd.pid -c tss:tss -x /usr/sbin/tpm2-abrmd -- ${DAEMON_OPTS} || {
|
||
|
echo "FAIL"
|
||
|
exit 1
|
||
|
}
|
||
|
pidof /usr/sbin/tpm2-abrmd > /var/run/tpm2-abrmd.pid
|
||
|
echo "OK"
|
||
|
}
|
||
|
|
||
|
stop() {
|
||
|
printf "Stopping tpm2-abrmd: "
|
||
|
start-stop-daemon -K -q -o -p /var/run/tpm2-abrmd.pid -u tss -x /usr/sbin/tpm2-abrmd || {
|
||
|
echo "FAIL"
|
||
|
exit 1
|
||
|
}
|
||
|
rm_stale_pidfile /var/run/tpm2-abrmd.pid /usr/sbin/tpm2-abrmd
|
||
|
echo "OK"
|
||
|
}
|
||
|
|
||
|
check_required_files /usr/sbin/tpm2-abrmd /etc/dbus-1/system.d/tpm2-abrmd.conf
|
||
|
|
||
|
# defaults
|
||
|
DAEMON_OPTS="--tcti=device --logger=syslog --max-connections=20 --max-transient-objects=20 --fail-on-loaded-trans"
|
||
|
|
||
|
# Read configuration variable file if it is present
|
||
|
[ -r /etc/default/tpm2-abrmd ] && . /etc/default/tpm2-abrmd
|
||
|
|
||
|
case "$1" in
|
||
|
start)
|
||
|
start
|
||
|
;;
|
||
|
stop)
|
||
|
stop
|
||
|
;;
|
||
|
restart|reload)
|
||
|
stop
|
||
|
sleep 1
|
||
|
start
|
||
|
;;
|
||
|
*)
|
||
|
echo "Usage: tpm2-abrmd {start|stop|restart|reload}" >&2
|
||
|
exit 1
|
||
|
esac
|
||
|
|
||
|
exit 0
|