如何在關機和啟動期間在螢幕上寫入日誌(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 }

相關內容