Initial commit
This commit is contained in:
parent
23fd4beb0e
commit
460c475a8d
5 changed files with 165 additions and 0 deletions
12
src/usr/lib/kernel/install.d/50-mkinitcpio-fallback.install
Executable file
12
src/usr/lib/kernel/install.d/50-mkinitcpio-fallback.install
Executable file
|
@ -0,0 +1,12 @@
|
|||
#!/bin/sh
|
||||
|
||||
case $1 in
|
||||
add)
|
||||
mkinitcpio -S autodetect -k "$2" -g "$3"/initrd-fallback
|
||||
;;
|
||||
remove)
|
||||
rm -f -- "$3"/initrd-fallback
|
||||
;;
|
||||
esac
|
||||
|
||||
# vim: set ft=sh ts=4 sw=4 et:
|
124
src/usr/lib/kernel/install.d/90-loaderentry-fallback.install
Executable file
124
src/usr/lib/kernel/install.d/90-loaderentry-fallback.install
Executable file
|
@ -0,0 +1,124 @@
|
|||
#!/usr/bin/env bash
|
||||
# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
|
||||
# ex: ts=8 sw=4 sts=4 et filetype=sh
|
||||
|
||||
COMMAND="$1"
|
||||
KERNEL_VERSION="$2"
|
||||
ENTRY_DIR_ABS="$3"
|
||||
KERNEL_IMAGE="$4"
|
||||
INITRD_OPTIONS_START="5"
|
||||
|
||||
if ! [[ $KERNEL_INSTALL_MACHINE_ID ]]; then
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if ! [[ -d "$ENTRY_DIR_ABS" ]]; then
|
||||
exit 0
|
||||
fi
|
||||
|
||||
MACHINE_ID=$KERNEL_INSTALL_MACHINE_ID
|
||||
|
||||
BOOT_ROOT=${ENTRY_DIR_ABS%/$MACHINE_ID/$KERNEL_VERSION}
|
||||
BOOT_MNT=$(stat -c %m $BOOT_ROOT)
|
||||
ENTRY_DIR=${ENTRY_DIR_ABS#$BOOT_MNT}
|
||||
|
||||
if [[ $COMMAND == remove ]]; then
|
||||
rm -f "$BOOT_ROOT/loader/entries/$MACHINE_ID-$KERNEL_VERSION-fallback.conf"
|
||||
rm -f "$BOOT_ROOT/loader/entries/$MACHINE_ID-$KERNEL_VERSION-fallback+"*".conf"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if ! [[ $COMMAND == add ]]; then
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if ! [[ $KERNEL_IMAGE ]]; then
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [[ -f /etc/os-release ]]; then
|
||||
. /etc/os-release
|
||||
elif [[ -f /usr/lib/os-release ]]; then
|
||||
. /usr/lib/os-release
|
||||
fi
|
||||
|
||||
if ! [[ $PRETTY_NAME ]]; then
|
||||
PRETTY_NAME="Linux $KERNEL_VERSION"
|
||||
fi
|
||||
|
||||
if [[ -f /etc/kernel/cmdline ]]; then
|
||||
read -r -d '' -a BOOT_OPTIONS < /etc/kernel/cmdline
|
||||
elif [[ -f /usr/lib/kernel/cmdline ]]; then
|
||||
read -r -d '' -a BOOT_OPTIONS < /usr/lib/kernel/cmdline
|
||||
else
|
||||
declare -a BOOT_OPTIONS
|
||||
|
||||
read -r -d '' -a line < /proc/cmdline
|
||||
for i in "${line[@]}"; do
|
||||
[[ "${i#initrd=*}" != "$i" ]] && continue
|
||||
[[ "${i#BOOT_IMAGE=*}" != "$i" ]] && continue
|
||||
BOOT_OPTIONS+=("$i")
|
||||
done
|
||||
fi
|
||||
|
||||
if [[ -f /etc/kernel/tries ]]; then
|
||||
read -r TRIES </etc/kernel/tries
|
||||
if ! [[ "$TRIES" =~ ^[0-9]+$ ]] ; then
|
||||
echo "/etc/kernel/tries does not contain an integer." >&2
|
||||
exit 1
|
||||
fi
|
||||
LOADER_ENTRY="$BOOT_ROOT/loader/entries/$MACHINE_ID-$KERNEL_VERSION-fallback+$TRIES.conf"
|
||||
else
|
||||
LOADER_ENTRY="$BOOT_ROOT/loader/entries/$MACHINE_ID-$KERNEL_VERSION-fallback.conf"
|
||||
fi
|
||||
|
||||
cp "$KERNEL_IMAGE" "$ENTRY_DIR_ABS/linux" &&
|
||||
chown root:root "$ENTRY_DIR_ABS/linux" &&
|
||||
chmod 0644 "$ENTRY_DIR_ABS/linux" || {
|
||||
echo "Could not copy '$KERNEL_IMAGE to '$ENTRY_DIR_ABS/linux'." >&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
INITRD_OPTIONS=( "${@:${INITRD_OPTIONS_START}}" )
|
||||
|
||||
for initrd in "${INITRD_OPTIONS[@]}"; do
|
||||
if [[ -f "${initrd}" ]]; then
|
||||
initrd_basename="$(basename ${initrd})"
|
||||
[ "$KERNEL_INSTALL_VERBOSE" -gt 0 ] && \
|
||||
echo "Installing $ENTRY_DIR_ABS/${initrd_basename}"
|
||||
cp "${initrd}" "$ENTRY_DIR_ABS/${initrd_basename}" &&
|
||||
chown root:root "$ENTRY_DIR_ABS/${initrd_basename}" &&
|
||||
chmod 0644 "$ENTRY_DIR_ABS/${initrd_basename}" || {
|
||||
echo "Could not copy '${initrd}' to '$ENTRY_DIR_ABS/${initrd_basename}'." >&2
|
||||
exit 1
|
||||
}
|
||||
fi
|
||||
done
|
||||
|
||||
# If no initrd option is supplied, fall back to "initrd" which is
|
||||
# the name used by dracut when generating it in its kernel-install hook
|
||||
[[ ${#INITRD_OPTIONS[@]} == 0 ]] && INITRD_OPTIONS=( initrd-fallback )
|
||||
|
||||
mkdir -p "${LOADER_ENTRY%/*}" || {
|
||||
echo "Could not create loader entry directory '${LOADER_ENTRY%/*}'." >&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
[ "$KERNEL_INSTALL_VERBOSE" -gt 0 ] && \
|
||||
echo "Creating $LOADER_ENTRY"
|
||||
{
|
||||
echo "title $PRETTY_NAME"
|
||||
echo "version $KERNEL_VERSION-fallback"
|
||||
echo "machine-id $MACHINE_ID"
|
||||
echo "options ${BOOT_OPTIONS[*]}"
|
||||
echo "linux $ENTRY_DIR/linux"
|
||||
for initrd in "${INITRD_OPTIONS[@]}"; do
|
||||
[[ -f $ENTRY_DIR_ABS/$(basename ${initrd}) ]] && \
|
||||
echo "initrd $ENTRY_DIR/$(basename ${initrd})"
|
||||
done
|
||||
:
|
||||
} > "$LOADER_ENTRY" || {
|
||||
echo "Could not create loader entry '$LOADER_ENTRY'." >&2
|
||||
exit 1
|
||||
}
|
||||
exit 0
|
11
src/usr/share/libalpm/hooks/90-kernel-install.hook
Normal file
11
src/usr/share/libalpm/hooks/90-kernel-install.hook
Normal file
|
@ -0,0 +1,11 @@
|
|||
[Trigger]
|
||||
Type = Path
|
||||
Operation = Install
|
||||
Operation = Upgrade
|
||||
Target = usr/lib/modules/*/vmlinuz
|
||||
|
||||
[Action]
|
||||
Description = Installing kernel...
|
||||
When = PostTransaction
|
||||
Exec = /usr/share/libalpm/scripts/kernel-install add
|
||||
NeedsTargets
|
10
src/usr/share/libalpm/hooks/90-kernel-remove.hook
Normal file
10
src/usr/share/libalpm/hooks/90-kernel-remove.hook
Normal file
|
@ -0,0 +1,10 @@
|
|||
[Trigger]
|
||||
Type = Path
|
||||
Operation = Remove
|
||||
Target = usr/lib/modules/*/vmlinuz
|
||||
|
||||
[Action]
|
||||
Description = Removing kernel...
|
||||
When = PreTransaction
|
||||
Exec = /usr/share/libalpm/scripts/kernel-install remove
|
||||
NeedsTargets
|
8
src/usr/share/libalpm/scripts/kernel-install
Executable file
8
src/usr/share/libalpm/scripts/kernel-install
Executable file
|
@ -0,0 +1,8 @@
|
|||
#!/bin/bash -e
|
||||
|
||||
while read -r line; do
|
||||
version=$(basename "${line%/vmlinuz}")
|
||||
echo ":: Installing kernel $version"
|
||||
|
||||
kernel-install $1 "${version}" "${line}"
|
||||
done
|
Loading…
Add table
Reference in a new issue