分析Linux内核5.0系统调用处理过程
學號: 363
本實驗來源?https://github.com/mengning/linuxkernel/
?
一、實驗要求
1.編譯內核5.0
2.qemu -kernel linux-5.0.1/arch/x86/boot/bzImage -initrd rootfs.img
3.選擇系統調用號后兩位與您的學號后兩位相同的系統調用進行跟蹤分析https://github.com/mengning/menu
4.給出相關關鍵源代碼及實驗截圖,撰寫一篇博客(署真實姓名或學號最后3位編號),并在博客文章中注明“原創作品轉載請注明出處 + https://github.com/mengning/linuxkernel/ ”,博客內容的具體 如下:
題目自擬,內容圍繞系統調用進行;
博客中需要使用實驗截圖
博客內容中需要仔細分析系統調用、保護現場與恢復現場、系統調用號及參數傳遞過程
總結部分需要闡明自己對系統調用工作機制的理解。
編譯環境:?Ubuntu 18? ? ? ? ?gcc 4.8
?
二、編譯內核:
mkdir kernel wget https://mirrors.edge.kernel.org/pub/linux/kernel/v5.x/linux-5.0.1.tar.xz xz -d linux-5.0.1.tar.xz tar -xvf linux-5.0.1.tar cd linux-5.0.1 make menuconfig make?
?
三、制作根文件系統
cd .. mkdir rootfs git clone https://github.com/mengning/menu.git cd menu sudo apt install gcc-multilib gcc -pthread -o init linktable.c menu.c test.c -m32 -static cd ../rootfs cp ../menu/init ./ find . | cpio -o -Hnewc | gzip -9 > ../rootfs.img?
四、 啟動MenuOS
qemu-system-i386 -kernel bzImage -initrd rootfs.img?
五、 系統調用(學號后兩位:63)
在test.c中增加pipe函數,再重新編譯rootfs.img.
int Pipe(int argc, char *argv[]) {int result=-1;int fd[2];result = pipe(fd);if(-1 == result){printf("fail to create pipe\n");}else{printf("successfully create pipe\n");}return 0; }?
六、實驗總結
本實驗讓我了解了系統調用的工作機制,作為程序員的我們通常只跟用戶空間實現的API打交道,內核只跟系統調用打交道,內核不關心應用程序是如何系統調用的。內核中大多數系統函數調用名稱以sys_為前綴,每個系統調用有唯一的系統調用號。應用程序通過軟中斷來通知內核,進入系統調用入口system_call,從而執行對應的系統調用函數。
轉載于:https://www.cnblogs.com/xiguas/p/10562304.html
總結
以上是生活随笔為你收集整理的分析Linux内核5.0系统调用处理过程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 百度献礼高校开学季:AI Studio教
- 下一篇: Manjaro Linux执行某些命令缺