linux reset 分析
2013-11-27 22:02
453 查看
遇到个系统reset的问题,简单看了下kernel reset的代码,简单记录下:
简单看下log:
[ 25.900749] Restarting system with command 'recovery'.
[ 25.901449] arch_reset: cmd = recovery
[ 25.901981] wdt_arch_reset called@Kernel
//系统调用reboot
//参考:syscalls.h
asmlinkage long sys_reboot(int magic1, int magic2, unsigned int cmd,
void __user *arg);
//参考:kernel/kernel/sys.c
SYSCALL_DEFINE4(reboot, int, magic1, int, magic2, unsigned int, cmd,
void __user *, arg)
{
char buffer[256];
switch (cmd) {
case LINUX_REBOOT_CMD_RESTART:
kernel_restart(NULL);
break;
// 带参数的reboot ,如:recovery
case LINUX_REBOOT_CMD_RESTART2:
if (strncpy_from_user(&buffer[0], arg, sizeof(buffer) - 1) < 0) {
ret = -EFAULT;
break;
}
buffer[sizeof(buffer) - 1] = '\0';
kernel_restart(buffer);
break;
......
}
// 架构无关的restart
void kernel_restart(char *cmd)
{
kernel_restart_prepare(cmd);
if (!cmd)
printk(KERN_EMERG "Restarting system.\n");
else
printk(KERN_EMERG "Restarting system with command '%s'.\n", cmd);
kmsg_dump(KMSG_DUMP_RESTART);
// 架构相关代码,ARM架构
machine_restart(cmd);
}
参考: kernel/arch/arm/kernel/process.c
void machine_restart(char *cmd)
{
machine_shutdown();
printk("Reboot:machine restart...\n");
// 刷新log到控制台,如实际调试中的串口
// 保证调试人员能读到最后的有用信息
arm_machine_flush_console();
arm_pm_restart(reboot_mode, cmd);
// 1秒内没有重启成功,则提示,并进入死循环
mdelay(1000);
printk("Reboot failed -- System halted\n");
while (1);
}
// 主要是导出堆栈信息,函数调用
// 关于dump_stack的实现可以参考:
void machine_shutdown(void)
{
#ifdef CONFIG_SMP
printk("machine_shutdown: start, Proess(%s:%d)\n", current->comm, current->pid);
dump_stack();
preempt_disable();
smp_send_stop();
printk("machine_shutdown: done\n");
#endif
}
简单看下log:
[ 25.900749] Restarting system with command 'recovery'.
[ 25.901449] arch_reset: cmd = recovery
[ 25.901981] wdt_arch_reset called@Kernel
//系统调用reboot
//参考:syscalls.h
asmlinkage long sys_reboot(int magic1, int magic2, unsigned int cmd,
void __user *arg);
//参考:kernel/kernel/sys.c
SYSCALL_DEFINE4(reboot, int, magic1, int, magic2, unsigned int, cmd,
void __user *, arg)
{
char buffer[256];
switch (cmd) {
case LINUX_REBOOT_CMD_RESTART:
kernel_restart(NULL);
break;
// 带参数的reboot ,如:recovery
case LINUX_REBOOT_CMD_RESTART2:
if (strncpy_from_user(&buffer[0], arg, sizeof(buffer) - 1) < 0) {
ret = -EFAULT;
break;
}
buffer[sizeof(buffer) - 1] = '\0';
kernel_restart(buffer);
break;
......
}
// 架构无关的restart
void kernel_restart(char *cmd)
{
kernel_restart_prepare(cmd);
if (!cmd)
printk(KERN_EMERG "Restarting system.\n");
else
printk(KERN_EMERG "Restarting system with command '%s'.\n", cmd);
kmsg_dump(KMSG_DUMP_RESTART);
// 架构相关代码,ARM架构
machine_restart(cmd);
}
参考: kernel/arch/arm/kernel/process.c
void machine_restart(char *cmd)
{
machine_shutdown();
printk("Reboot:machine restart...\n");
// 刷新log到控制台,如实际调试中的串口
// 保证调试人员能读到最后的有用信息
arm_machine_flush_console();
arm_pm_restart(reboot_mode, cmd);
// 1秒内没有重启成功,则提示,并进入死循环
mdelay(1000);
printk("Reboot failed -- System halted\n");
while (1);
}
// 主要是导出堆栈信息,函数调用
// 关于dump_stack的实现可以参考:
void machine_shutdown(void)
{
#ifdef CONFIG_SMP
printk("machine_shutdown: start, Proess(%s:%d)\n", current->comm, current->pid);
dump_stack();
preempt_disable();
smp_send_stop();
printk("machine_shutdown: done\n");
#endif
}
相关文章推荐
- linux reset 分析
- 需求分析方法论(大纲)
- BT源代码学习心得(十):客户端源代码分析(相关对象一览)
- s3c2410的Bootloader(Vivi)源代码分析
- BT源代码学习心得(六):跟踪服务器(Tracker)的代码分析(初始化) -- 转贴自 wolfenstein (NeverSayNever)
- 需求分析阶段的工作(二):用例描述和逻辑模型
- 深入分析C++中char * 和char []的区别
- LINUX开源监控平台Nagios(性能分析图表)
- 系统运行级别 /etc/inittab 分析
- 最短路径算法—Dijkstra(迪杰斯特拉)算法分析与实现(C/C++)
- SQLite入门与分析(八)---存储模型(2)
- 《数据机构与算法分析》(Java语言描述)读书笔记(1)---表
- mini2440启动代码分析之第十一篇(完结)
- Hadoopz安装与配置-日志分析(4)
- linux内核网络协议栈学习笔记:关于GRO/GSO/LRO/TSO等patch的分析和测试
- U-Boot启动第一阶段代码分析
- Android 4.0 Launcher2源码分析——导入eclipse进行调试
- 主成分分析(PCA)
- H3C项目实例分析
- SmartWatch2开发-ControlSample分析