
我們知道,當我們啟動系統(在 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 }