众所周知,当在adb shell中执行reboot命令时,系统会重启,但是你知道其具体执行流程吗?最近在分析bug时,研究了一下reboot流程,现总结如下:
https://blog.csdn.net/yxw0609131056/article/details/79926276,从这篇文章可以看出,adb shell所用的shell为/system/bin/sh,而/system/bin目录下有一个可执行程序的名字就是reboot,其源码如下:
LINUX/android/system/core/reboot/reboot.c
LINUX/android/system/core/libcutils/include/cutils/android_reboot.h
其实就是设置sys.powerctl属性值,那如何和kernel交互呢?别急,往下看
LINUX/android/system/core/init/init.cpp
这里会判断是否设置sys.powerctl属性,if yes,设置do_shutdown = true,shutdown_command = value
LINUX/android/system/core/init/init.cpp
这里会调用HandlePowerctlMessage(shutdown_command),这个是什么东东?
LINUX/android/system/core/init/reboot.cpp
这里会设置cmd = ANDROID_RB_RESTART2,然后调用DoReboot()函数,DoReboot()函数又会调用RebootSystem()函数,
这里看到终于要和kernel打交道了,而且通过系统调用:syscall(__NR_reboot
LINUX/android/kernel/kernel/reboot.c
这里会调用kernel_restart(buffer)
这样机器就会重启了,呵呵