1
1
mirror of https://github.com/NixOS/mobile-nixos.git synced 2025-01-05 19:03:21 +03:00
mobile-nixos/modules/initrd-fail.nix
Samuel Dionne-Riel 4467f28daf initrd: Adds failure reporting
Uses the sad-phone artwork to convey that something's wrong.

A color has to be given to help convey the issue in constrained
situations where no proper logging happens.
2019-12-03 15:36:13 -05:00

64 lines
1.8 KiB
Nix

{ config, lib, pkgs, ... }:
let
inherit (lib) mkIf mkOption mkOrder optionalString types;
inherit (import ./initrd-order.nix) BEFORE_DEVICE_INIT;
withSplash = config.mobile.boot.stage-1.splash.enable;
cfg = config.mobile.boot.stage-1.fail;
delay = toString cfg.delay;
in
{
options.mobile = {
boot.stage-1.fail = {
reboot = mkOption {
type = types.bool;
default = true;
description = ''
Reboots the device after a delay on failure.
'';
};
delay = mkOption {
type = types.int;
default = 10;
description = ''
Duration (in seconds) before a reboot on failure.
'';
};
};
};
config = mkIf cfg.reboot {
mobile.boot.stage-1.init = mkOrder BEFORE_DEVICE_INIT ''
# color: An hexadecimal color FF0000 being red.
# The display will be cleared with that color.
# code: A user-friendly short and unique code, only logged as a prefix for now.
# The code will be displayed on the screen in the future.
# message: A longer user-friendly message. It will be logged to the console.
# It might be shown, smaller, on the display in the future.
init_fail() {
color="$1"; shift
code="$1"; shift
message="$1"; shift
${optionalString withSplash ''
ply-image --clear=0x"$color" /sad-phone.png
>&2 echo "$code: $message"
''}
>&2 echo "[Rebooting in ${delay} seconds]"
sleep ${delay}
>&2 echo "$code: $message"
echo b > /proc/sysrq-trigger
exit 1
}
'';
mobile.boot.stage-1.contents = mkIf withSplash [
{
object = (builtins.path { path = ../artwork/sad-phone.png; });
symlink = "/sad-phone.png";
}
];
};
}