码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2016-03-18 21:54:37      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:

 

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

 

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

标签:

原文地址:http://www.cnblogs.com/syw-casualet/p/5293597.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!