“casualet + 原创作品转载请注明出处 + 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000 ”,
Linux系统中提供了很多的系统调用, 这是用户程序进入0特权级和硬件交互的接口. 我们用c语言进行编程的时候, 使用的很多库函数就是对系统调用的一种封装. 所有的系统调用都是通过int 0x80以一种软中断的方式来实现的, 为了区别不同的系统调用, 有一个系统调用的号, 可以通过这个网址进行查询:http://codelab.shiyanlou.com/xref/linux-3.18.6/arch/x86/syscalls/syscall_32.tbl 这个系统调用号可以通过eax 寄存器进行传递. 也就是说, 我们先向寄存器eax中传入系统调用号, 然后使用int 0x80指令, 就可以调用相应的系统调用(中断处理函数). 系统调用执行完成以后, 会有一个函数的返回值, 这个返回值通过eax寄存器返回. 所以, 我们在系统调用执行完成以后, 通过eax 可以获得该系统调用的返回值, 我们通过一个例子程序来展示这个过程:
#include<stdio.h> #include<time.h> #include<unistd.h> int main(){ pid_t my_id; asm volatile( "mov $20,%%eax\n\t"//20传如eax,表示使用20号系统调用 "int $0x80\n\t" //产生中断,系统调用入口 "mov %%eax,%0\n\t"//eax是返回至, 写到内存变量my_id中. :"=m"(my_id) ); printf("asm_result=%d, api_result=%d\n",my_id, getpid()); return 0; }
我们把上面的程序保存为sys_asm.c 然后通过 gcc sys_asm.c -o sys_asm -m32 来编译, 然后使用./sys_asm运行.
上面的程序的执行结果是:
分别表示汇编代码运行的结果, 以及API运行的结果. 我们可以看到结果是一样的.
时间: 2024-10-06 12:35:49