深入理解系统调用
实验目的
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,否则会导致打断点失败