深入理解系统调用

本文详述了一次深入理解系统调用的实验过程,包括选择学号后2位对应的系统调用(80号),通过汇编触发系统调用,使用gdb进行内核调试,分析系统调用的保存、恢复现场和返回过程,以及内核堆栈状态变化。实验涉及安装开发工具、下载编译内核、创建根文件系统、编写汇编代码,并通过静态编译、gdb调试来跟踪系统调用处理流程。
摘要由CSDN通过智能技术生成

深入理解系统调用

实验目的


1.找一个系统调用,系统调用号为学号最后2位相同的系统调用,本人学号最后两位为80,即要测试的系统调用号为80
2.通过汇编指令触发该系统调用
3.通过gdb跟踪该系统调用的内核处理过程
4.重点阅读分析系统调用入口的保存现场、恢复现场和系统调用返回,以及重点关注系统调用过程中内核堆栈状态的变化


环境准备


1.安装开发工具

sudo apt install build-essential
sudo apt install qemu # install QEMU
sudo apt install libncurses5-dev bison flex libssl-dev libelf-dev

2.下载内核源码

sudo apt install axel
axel -n 20 https://mirrors.edge.kernel.org/pub/linux/kernel/v5.x/ linux-5.4.34.tar.xz
xz -d linux-5.4.34.tar.xz
tar -xvf linux-5.4.34.tar
cd linux-5.4.34

ps:出毛病,下载不了的,可以直接主机下载,拖过去。个人尝试多次后,逐渐难受,因此直接下载了

3.配置内核编译选项

make defconfig # Default configuration is based on ‘x86_64_defconfig’
make menuconfig

打开debug相关选项

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

关闭KASLR,否则会导致打断点失败

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值