作者:王鹤楼 原创作品转载请注明出处 《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
选择alrm定时器系统调用:
C语言代码为:
1 #include <stdio.h>
2 #include <stdlib.h>
3 #include <signal.h>
4
5 void alarm_handler(int signo)
6 {
7 printf(" come into alarm handler!!!\n");
8 }
9
10 int main()
11 {
12 signal(SIGALRM, alarm_handler);
13 alarm(5);//5秒后进入alarm_handler信号处理函数
14 pause();
15 return 0;
16 }
内嵌汇编代码格式为:
1 #include <stdio.h>
2 #include <stdlib.h>
3 #include <signal.h>
4
5 void alarm_handler(int signo)
6 {
7 printf(" come into alarm handler!!!\n");
8 }
9
10 int main()
11 {
12 int ret;
13 signal(SIGALRM, alarm_handler);
14 //alarm(5);
15 asm volatile(
16 "mov $5,%%ebx\n\t" //系统调用参数为5
17 "mov $0x1b,%%eax\n\t"//系统调用号为27
18 "int $0x80\n\t" //触发系统调用
19 "mov %%eax,%0\n\t"
20 : "=m" (ret)
21 );
22 pause();
23 return 0;
24 }
程序的输出结果是一样的:
总结:
系统调用是linux中所有系统调用的入口点,每个系统调用至少有一个参数,即系统调用号,由eax传递。在系统调用号eax之外,参数个数不能超过6个,要系统调用时先把参数放到ebc,ecx,edx,esi,edi,ebp。如果参数超过6个的话要借助堆栈来实参。
当所有参数设置好之后,调用int $0x80,触发系统调用。
本实验用到的系统调用alarm的调用号为27。