2023-2024-1 20232829《Linux内核原理与分析》第六周作业

标题1.分析 system_call 中断处理过程

删除menu后重新clone该菜单,将上周的代码添加到test.c中,同时添加新的main函数,结果如下:
在这里插入图片描述
在这里插入图片描述
经过重新编译后得到如下结果:
在这里插入图片描述
使用qumu命令重新启动内核并使用-s和-S参数“冻结”系统执行。

qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S

打开gdb调试,代码如下:

$ gdb
(gdb) file linux-3.18.6/vmlinux
Reading symbols from linux-3.18.6/vmlinux...done.
(gdb) target remote:1234
Remote debugging using :1234
0x0000fff0 in ?? ()

同时在sys_creat处设置断点,然后按c执行,在系统界面中输入新增的Create命令,中断被执行,结果如下:

在这里插入图片描述

标题2.结果分析和总结

系统调用命令的具体格式因系统而异,但由用户程序进入系统调用的步骤及执行过程大体相同。其执行过程如下:
1 .保护用户程序的现场信息,同时把系统调用命令的编号等参数放入指定的存储单元;
2 .根据系统调用命令的编号查找系统调用入口表,找到相应系统功能调用子程序的入口地址;
3 .转到该子程序执行,当系统调用命令执行完毕,相应的结果通常返回给参数,这些参数放在指定的存储单元里;
4 .系统调用命令执行完毕后恢复用户程序执行的现场信息,同时把系统调用命令的返回参数或参数区首址放入指定的寄存器中,供用户程序使用。
nt 0x80——>system call:通过中断向量匹配;
system call——>sys_xyz():通过系统调用号匹配;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值