You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
1.8 KiB
70 lines
1.8 KiB
#!/bin/sh |
|
# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*- |
|
# ex: ts=8 sw=4 sts=4 et filetype=sh |
|
do_fips() |
|
{ |
|
FIPSMODULES=$(cat /etc/fipsmodules) |
|
BOOT=$(getarg boot=) |
|
KERNEL=$(uname -r) |
|
udevadm trigger --action=add >/dev/null 2>&1 |
|
case "$boot" in |
|
block:LABEL=*|LABEL=*) |
|
boot="${boot#block:}" |
|
boot="$(echo $boot | sed 's,/,\\x2f,g')" |
|
boot="/dev/disk/by-label/${boot#LABEL=}" |
|
bootok=1 ;; |
|
block:UUID=*|UUID=*) |
|
boot="${boot#block:}" |
|
boot="/dev/disk/by-uuid/${root#UUID=}" |
|
bootok=1 ;; |
|
/dev/*) |
|
bootok=1 ;; |
|
esac |
|
|
|
[ -z "$UDEVVERSION" ] && UDEVVERSION=$(udevadm --version) |
|
|
|
if [ $UDEVVERSION -ge 143 ]; then |
|
udevadm settle --exit-if-exists=$boot |
|
else |
|
udevadm settle --timeout=30 |
|
fi |
|
|
|
[ -e "$boot" ] |
|
|
|
mkdir /boot |
|
info "Mounting $boot as /boot" |
|
mount -oro "$boot" /boot |
|
|
|
info "Checking integrity of kernel" |
|
|
|
if ! [ -e "/boot/.vmlinuz-${KERNEL}.hmac" ]; then |
|
warn "/boot/.vmlinuz-${KERNEL}.hmac does not exist" |
|
return 1 |
|
fi |
|
|
|
sha512hmac -c "/boot/.vmlinuz-${KERNEL}.hmac" || return 1 |
|
|
|
info "Umounting /boot" |
|
umount /boot |
|
|
|
info "Loading and integrity checking all crypto modules" |
|
for module in $FIPSMODULES; do |
|
if [ "$module" != "tcrypt" ]; then |
|
modprobe ${module} || return 1 |
|
fi |
|
done |
|
info "Self testing crypto algorithms" |
|
modprobe tcrypt noexit=1 || return 1 |
|
rmmod tcrypt |
|
info "All initrd crypto checks done" |
|
|
|
return 0 |
|
} |
|
|
|
if ! fipsmode=$(getarg fips) || [ $fipsmode = "0" ]; then |
|
rm -f /etc/modprobe.d/fips.conf >/dev/null 2>&1 |
|
else |
|
set -e |
|
do_fips || die "FIPS integrity test failed" |
|
set +e |
|
fi
|
|
|