Chinaunix首页 | 论坛 | 博客
  • 博客访问: 174634
  • 博文数量: 67
  • 博客积分: 26
  • 博客等级: 民兵
  • 技术积分: 1189
  • 用 户 组: 普通用户
  • 注册时间: 2012-07-23 14:46
个人简介

linux --- 一切皆文件

文章分类

全部博文(67)

文章存档

2018年(3)

2017年(7)

2016年(11)

2015年(1)

2014年(2)

2013年(33)

2012年(10)

分类: C/C++

2017-11-06 14:23:52

Linux 2.6系统调用注册及调用流程:


init/main.c --->start_kernel()--->arch/x86/kernel/traps.c.trap_init()
在此文件中,执行如下函数进行system_call与int 0x80绑定:
# define SYSCALL_VECTOR 0x80
set_system_trap_gate(SYSCALL_VECTOR, &system_call);
arch/x86/kernel/entry_64.S.system_call():
cmpq $__NR_syscall_max,%rax #比较传入的系统调用号是否异常
call *sys_call_table(,%rax,8) #根据系统调用号,执行相应的系统调用函数
arch/x86/kernel/syscall_64.c.sys_call_table数组初始化如下:
const sys_call_ptr_t sys_call_table[__NR_syscall_max+1] = {
/*
*Smells like a like a compiler bug -- it doesn't work
*when the & below is removed.
*/
[0 ... __NR_syscall_max] = &sys_ni_syscall, //将所有下标设置成sys_ni_syscall函数
#include //定义下标和函数对应关系
};
#### sys_ni_syscall,中ni 表示 “not implemented”没有实现的意思
arch/x86/include/asm/unistd_64.h
#define __SYSCALL(nr, call) [nr] = (call),
#define __NR_read 0
__SYSCALL(__NR_read, sys_read)
#define __NR_write 1
__SYSCALL(__NR_write, sys_write)
......
推演如下:
const sys_call_ptr_t sys_call_table[__NR_syscall_max+1] = {
[__NR_read] = sys_read,
[__NR_write]=sys_write,
......
}

阅读(103) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~
评论热议
请登录后评论。

登录 注册