2022-2023-1 20222801《Linux内核原理与分析》第八周作业

Linux系统内核第七周作业


实验七 Linux内核如何装载和启动一个可执行程序

理解编译链接的过程和ELF可执行文件格式

更新内核

cd ~/LinuxKernel
rm menu -rf
//git clone https://github.com/mengning/menu.git
unzip menu-master.zip//由于尝试多次连接不到GitHub,故在Windows系统下载到本地,再上传到实验楼使用
cd menu-master 
mv test_exec.c test.c//  将test.c替换为test_exec.c,仍命名为test.c,为menu增加exec功能
make rootfs  

在这里插入图片描述

make rootfs

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在menuOS中输入exec,则会相应地执行上述函数

在这里插入图片描述

gdb设置断点

在sys_execve、load_elf_binary和b start_thread处设置断点
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
使用readelf -h hello查看ELF文件的头部信息
在这里插入图片描述

总结:内核处理这个可执行程序的装载过程,实际上是执行程序装载的一个系统调用,和前面分析的 fork及其他的系统调用的主要过程是一样的。但是 execve这个系统调用的内核处理过程和 fork一样也是比较特殊的。因为正常的一个系统调用都是陷入内核态,再返回到用户态,然后继续执行系统调用后的下一条指令。fork和其他系统调用不同之处是它在陷入内核态之后有两次返回,第一次返回到原来的父进程的位置继续向下执行,这和其他的系统调用是一样的。在子进程中fork 也返回了一次,会返回到一个特定的点——ret_from_fork,通过内核构造的堆栈环境,它可以正常返回到用户态,所以它稍微特殊一点。同样,execve也比较特殊。当前的可执行程序在执行,执行到execve时陷入内核态,在内核里面用execve加载的可执行文件把当前进程的可执行程序给覆盖掉了。当 execve的系统调用返回时,返回的已经不是原来的那个可执行程序了,而是新的可执行程序。

20222801 余酋龙

2022 年 11月 6日

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值