2023-02-17 22:29:10 +00:00
|
|
|
#!/bin/sh
|
|
|
|
# shellcheck disable=SC1091
|
|
|
|
|
2023-09-25 14:39:50 +00:00
|
|
|
IN_CI="false"
|
2024-04-04 14:04:50 +00:00
|
|
|
LOG_PREFIX="[pmOS-rd]"
|
2023-09-25 14:39:50 +00:00
|
|
|
|
2023-02-17 22:29:10 +00:00
|
|
|
[ -e /hooks/10-verbose-initfs.sh ] && set -x
|
|
|
|
|
2023-09-25 14:39:50 +00:00
|
|
|
[ -e /hooks/05-ci.sh ] && IN_CI="true"
|
|
|
|
|
2023-01-24 17:46:58 +00:00
|
|
|
[ -e /etc/unudhcpd.conf ] && . /etc/unudhcpd.conf
|
2023-02-17 22:29:10 +00:00
|
|
|
. ./init_functions.sh
|
2023-05-29 12:51:47 +00:00
|
|
|
. /usr/share/misc/source_deviceinfo
|
2023-10-11 23:57:00 +00:00
|
|
|
[ -e /etc/os-release ] && . /etc/os-release
|
|
|
|
# provide a default for os-release's VERSION in case the file doesn't exist
|
|
|
|
VERSION="${VERSION:-unknown}"
|
2023-02-17 22:29:10 +00:00
|
|
|
|
2023-12-18 22:48:14 +00:00
|
|
|
# This is set during packaging and is used when triaging bug reports
|
|
|
|
INITRAMFS_PKG_VERSION="<<INITRAMFS_PKG_VERSION>>"
|
|
|
|
|
2023-02-17 22:29:10 +00:00
|
|
|
export PATH=/usr/bin:/bin:/usr/sbin:/sbin
|
|
|
|
/bin/busybox --install -s
|
|
|
|
/bin/busybox-extras --install -s
|
|
|
|
|
|
|
|
# Mount everything, set up logging, modules, mdev
|
|
|
|
mount_proc_sys_dev
|
|
|
|
setup_log
|
|
|
|
setup_firmware_path
|
2024-04-28 14:20:14 +00:00
|
|
|
# Run udev early, before splash, to make sure any relevant display drivers are
|
|
|
|
# loaded in time
|
|
|
|
setup_udev
|
2023-09-25 14:39:50 +00:00
|
|
|
|
|
|
|
if [ "$IN_CI" = "false" ]; then
|
|
|
|
setup_framebuffer
|
|
|
|
show_splash "Loading..."
|
|
|
|
fi
|
2024-04-28 14:20:14 +00:00
|
|
|
|
|
|
|
setup_dynamic_partitions "${deviceinfo_super_partitions:=}"
|
|
|
|
|
2023-02-17 22:29:10 +00:00
|
|
|
run_hooks /hooks
|
|
|
|
|
2023-09-25 14:39:50 +00:00
|
|
|
if [ "$IN_CI" = "true" ]; then
|
|
|
|
echo "PMOS: CI tests done, disabling console and looping forever"
|
|
|
|
dmesg -n 1
|
2023-12-18 22:48:14 +00:00
|
|
|
fail_halt_boot
|
2023-09-25 14:39:50 +00:00
|
|
|
fi
|
|
|
|
|
2023-02-17 22:29:10 +00:00
|
|
|
setup_usb_network
|
|
|
|
start_unudhcpd
|
|
|
|
|
2024-04-10 01:28:08 +00:00
|
|
|
if grep -q "pmos.debug-shell" /proc/cmdline; then
|
|
|
|
debug_shell
|
|
|
|
fi
|
|
|
|
|
|
|
|
check_keys
|
|
|
|
|
2024-04-10 00:08:02 +00:00
|
|
|
mount_subpartitions
|
|
|
|
|
2024-01-30 18:00:35 +00:00
|
|
|
wait_boot_partition
|
2023-02-17 22:29:10 +00:00
|
|
|
mount_boot_partition /boot
|
|
|
|
extract_initramfs_extra /boot/initramfs-extra
|
|
|
|
run_hooks /hooks-extra
|
|
|
|
|
2023-12-18 22:48:14 +00:00
|
|
|
# For testing the mass storage gadget log export function. We use a flag
|
|
|
|
# file on /boot so that we can test it on all devices as modifying the
|
|
|
|
# kernel cmdline is not always possible.
|
|
|
|
if [ -e /boot/.pmos_export_logs ]; then
|
|
|
|
echo "PMOS: Exporting logs via mass storage gadget"
|
|
|
|
show_splash "Exporting boot logs..."
|
|
|
|
# Delete the flag so we don't soft-brick the device by always booting
|
|
|
|
# to the log export mode.
|
|
|
|
mount -o remount,rw /boot
|
|
|
|
rm -f /boot/.pmos_export_logs
|
|
|
|
fail_halt_boot
|
|
|
|
fi
|
|
|
|
|
2023-02-17 22:29:10 +00:00
|
|
|
wait_root_partition
|
|
|
|
delete_old_install_partition
|
|
|
|
resize_root_partition
|
|
|
|
unlock_root_partition
|
|
|
|
resize_root_filesystem
|
|
|
|
mount_root_partition
|
|
|
|
|
2024-05-01 15:55:40 +00:00
|
|
|
# Mount boot partition into sysroot, so we do not depend on /etc/fstab, as
|
|
|
|
# not all old installations have a proper /etc/fstab file. See #2800
|
2023-02-17 22:29:10 +00:00
|
|
|
umount /boot
|
|
|
|
mount_boot_partition /sysroot/boot "rw"
|
|
|
|
|
|
|
|
init="/sbin/init"
|
|
|
|
setup_bootchart2
|
|
|
|
|
|
|
|
# Switch root
|
2024-06-02 10:37:46 +00:00
|
|
|
run_hooks /hooks-cleanup
|
2024-04-04 14:04:50 +00:00
|
|
|
|
2024-04-10 01:28:08 +00:00
|
|
|
echo "Switching root"
|
|
|
|
|
|
|
|
# Restore stdout and stderr to their original values if they
|
|
|
|
# were stashed
|
|
|
|
if [ -e "/proc/1/fd/3" ]; then
|
|
|
|
exec 1>&3 2>&4
|
|
|
|
elif ! grep -q "pmos.debug-shell" /proc/cmdline; then
|
|
|
|
echo "$LOG_PREFIX Disabling console output again (use 'pmos.debug-shell' to keep it enabled)"
|
|
|
|
exec >/dev/null 2>&1
|
|
|
|
fi
|
2024-04-04 14:04:50 +00:00
|
|
|
|
|
|
|
# Re-enable kmsg ratelimiting (might have been disabled for logging)
|
|
|
|
echo ratelimit > /proc/sys/kernel/printk_devkmsg
|
|
|
|
|
|
|
|
killall mdev udevd syslogd 2>/dev/null
|
2023-02-17 22:29:10 +00:00
|
|
|
|
2024-04-10 01:28:08 +00:00
|
|
|
# Kill any getty shells that might be running
|
|
|
|
for pid in $(pidof sh); do
|
|
|
|
if ! [ "$pid" = "1" ]; then
|
|
|
|
kill -9 "$pid"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2023-02-17 22:29:10 +00:00
|
|
|
# shellcheck disable=SC2093
|
|
|
|
exec switch_root /sysroot "$init"
|
|
|
|
|
2024-04-04 14:04:50 +00:00
|
|
|
echo "$LOG_PREFIX ERROR: switch_root failed!" > /dev/kmsg
|
|
|
|
echo "$LOG_PREFIX Looping forever. Install and use the debug-shell hook to debug this." > /dev/kmsg
|
|
|
|
echo "$LOG_PREFIX For more information, see <https://postmarketos.org/debug-shell>" > /dev/kmsg
|
2023-12-18 22:48:14 +00:00
|
|
|
fail_halt_boot
|