使用汇编代码调用系统调用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用汇编代码调用系统调用相关的知识,希望对你有一定的参考价值。

 

“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运行的结果. 我们可以看到结果是一样的.

 

以上是关于使用汇编代码调用系统调用的主要内容,如果未能解决你的问题,请参考以下文章

汇编代码调用系统调用的工作过程

实验--使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用(杨光)

使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

实验--使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用(李鹏举)

系统调用的API以及汇编代码实现

实验四:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用