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

作品转载请注明出处《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000 ”

首先我们从http://codelab.shiyanlou.com/xref/linux-3.18.6/arch/x86/syscalls/syscall_32.tbl这个网站中找一个我们想用来做实验的一个系统调用,我们本次使用execve来当这个实验的系统调用,从文中我们可以看到他的系统调用是11号(0xb)

c语言的实现:

函数如下:


#include <unistd.h>

void main()
{
    char *sh="/bin/ls";
    char *argv[]={"ls", "-al", "/home", (char*)0};
    char *envp[]={"PATH=/bin", 0};
    execve(sh, argv, envp);

}

编译执行:

ubuntu@ubuntu-virtual-machine:~/test/t4$ gcc -o syscall syscall.c -m32
ubuntu@ubuntu-virtual-machine:~/test/t4$ ./syscall 
total 12
drwxr-xr-x  3 root   root   4096 Mar  7 21:27 .
drwxr-xr-x 25 root   root   4096 Mar 20 10:29 ..
drwxr-xr-x 20 ubuntu ubuntu 4096 Mar 16 07:00 ubuntu

可以看出这个函数执行了ls命令,并显示了ls  /home下的内容;

汇编实现:

#include <unistd.h>
int main()
{
    char *sh="/bin/ls";
    char *argv[]={"ls", "-al", "/home", (char*)0};
    char *envp[]={"PATH=/bin", 0};
        __asm__ __volatile__("movl %0, %%ebx\n\t"
        "movl %1, %%ecx\n\t"
        "movl %2, %%edx\n\t"
        "mov $0x0b, %%eax\n\t"
        "int $0x80\n\t"
        :
        :"m"(sh),"r"(argv),"r"(envp)
        :"%eax","%ecx","%edx","%ebx"
    );
return 0;
}

编译执行:

ubuntu@ubuntu-virtual-machine:~/test/t4$ gcc -o syscall-asm syscall-asm.c -m32
ubuntu@ubuntu-virtual-machine:~/test/t4$ ./syscall-asm 
total 12
drwxr-xr-x  3 root   root   4096 Mar  7 21:27 .
drwxr-xr-x 25 root   root   4096 Mar 20 10:29 ..
drwxr-xr-x 20 ubuntu ubuntu 4096 Mar 16 07:00 ubuntu


通过实验我们可以看出,通过系统调用实现了,一个ls的执行;

另外我们要记住:

在32位Linux系统中是通过激活0x80中断来触发系统调用的,需要调用的系统调用号实现赋值给eax存储器,如果有传入参数可赋值给ebx寄存器,如果多于1个则按顺序赋值给ebx、ecx、edx、esi、edi、ebp,如果超过6个则通过指针变量指向另一片堆栈区,如果无参数传入则赋值为0




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值