如何在关机和启动期间在屏幕上写入日志(grub之后)

如何在关机和启动期间在屏幕上写入日志(grub之后)

我们知道,当我们启动系统(在 grub 之后)和关闭系统时,屏幕上会打印许多日志。

我知道内核会写一些内核的日志。但其他人呢?谁写的?

据我所知,Ubuntu 使用systemd并且有一些来自systemd.我想知道是否可以创建一个 的服务systemd,它可以在启动和关闭时在屏幕上写入一些日志?

答案1

可以分析一下reboot系统调用源码,也许答案就在那里。路径:linux-4.4.1/kernel/reboot.c

280 SYSCALL_DEFINE4(reboot, int, magic1, int, magic2, unsigned int, cmd,
281                 void __user *, arg)
282 {
        ....
315         switch (cmd) {
316         case LINUX_REBOOT_CMD_RESTART:
        ....
333         case LINUX_REBOOT_CMD_POWER_OFF:
334                 kernel_power_off();
335                 do_exit(0);
336                 break;
        ....


257 void kernel_power_off(void)
258 {
259         kernel_shutdown_prepare(SYSTEM_POWER_OFF);
260         if (pm_power_off_prepare)
261                 pm_power_off_prepare();
262         migrate_to_reboot_cpu();
263         syscore_shutdown();
264         pr_emerg("Power down\n");
265         kmsg_dump(KMSG_DUMP_POWEROFF);
266         machine_power_off();
267 }

相关内容