2020-02-28 07:02:15 +03:00
|
|
|
begin
|
|
|
|
# TODO: Allow defining depending on stage-0/stage-1.
|
|
|
|
STAGE = 1
|
|
|
|
|
2020-05-29 23:35:59 +03:00
|
|
|
LOADER = "/loader"
|
|
|
|
|
2020-02-28 07:02:15 +03:00
|
|
|
log("************************")
|
|
|
|
log("* Mobile NixOS stage-#{STAGE} *")
|
|
|
|
log("************************")
|
|
|
|
log("")
|
2020-10-22 06:15:42 +03:00
|
|
|
# Since we would like to *somewhat* guesstimate how long it took to get to the
|
|
|
|
# actual init program, we can print the CLOCK_MONOTONIC at startup.
|
|
|
|
# It's not perfect, but that gets us halfway there I guess.
|
|
|
|
log("init started ~#{"%.6f" % (Process.clock_gettime(Process::CLOCK_MONOTONIC))}s after kernel boot time.")
|
2020-02-28 07:02:15 +03:00
|
|
|
log("Built for device #{Configuration["device"]["name"]}")
|
|
|
|
log("")
|
|
|
|
|
|
|
|
# This file is a hard-coded map of non-implicit tasks.
|
|
|
|
# To these tasks, add all Singleton tasks found under tasks/*
|
|
|
|
|
|
|
|
# Without any added dependency, show a first splash ASAP
|
2020-03-10 00:34:31 +03:00
|
|
|
Tasks::Splash.new("/etc/logo.svg")
|
2020-02-28 07:02:15 +03:00
|
|
|
|
|
|
|
# Some software (mainly extfs tools) bark angrily and fail when this is missing.
|
|
|
|
Tasks::Symlink.new("/proc/mounts", "/etc/mtab")
|
|
|
|
|
|
|
|
Mounting.create_special_mount_points()
|
|
|
|
Mounting.create_boot_mount_points()
|
|
|
|
|
|
|
|
[
|
|
|
|
"/etc/udev",
|
|
|
|
"/var/log",
|
|
|
|
].each do |dir|
|
|
|
|
Tasks::Directory.new(dir)
|
|
|
|
end
|
|
|
|
|
|
|
|
Tasks::Modules.new(*Configuration["kernel"]["modules"])
|
|
|
|
|
|
|
|
Tasks::go()
|
|
|
|
|
|
|
|
$logger.fatal("Tasks all ran, but we're still here...")
|
|
|
|
System.failure("did_not_switch", color: "ff0000")
|
|
|
|
|
|
|
|
rescue => e
|
2020-03-10 02:45:34 +03:00
|
|
|
System.sad_phone("765300", "Uncaught Exception", e.inspect)
|
2020-02-28 07:02:15 +03:00
|
|
|
3.times do
|
|
|
|
$logger.fatal("********************")
|
|
|
|
end
|
|
|
|
$logger.fatal("Handling exception")
|
|
|
|
$logger.fatal(e.inspect)
|
|
|
|
$logger.fatal("`init` will exit and the kernel will crash.")
|
|
|
|
$logger.fatal("********************")
|
|
|
|
# Leave some time for the $logger.fatals to flush before the kernel crashes.
|
|
|
|
sleep(1)
|
|
|
|
System.shell if System.respond_to?(:shell)
|
|
|
|
|
|
|
|
# Users with access to serial debug may prefer crashing to the bootloader.
|
|
|
|
# Though, crashing the kernel is *required* for console ramoops to be present.
|
|
|
|
if Configuration["boot"]["crashToBootloader"] then
|
|
|
|
System.run("reboot bootloader")
|
|
|
|
else
|
|
|
|
exit 99
|
|
|
|
end
|
|
|
|
end
|