我们知道,当我们启动系统(在 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 }