Chinaunix首页 | 论坛 | 博客
  • 博客访问: 31973
  • 博文数量: 9
  • 博客积分: 265
  • 博客等级: 二等列兵
  • 技术积分: 100
  • 用 户 组: 普通用户
  • 注册时间: 2010-05-26 16:20
文章分类
文章存档

2020年(1)

2017年(2)

2016年(1)

2010年(5)

我的朋友

分类: LINUX

2010-06-04 17:00:43


在应用层,系统调用在C库中有相应的函数,在那里会期通过中断指令INT 0x80,
使cpu由用户态转变成内核态,会执行到system_call()(arch/i386/kernel/entry.S),每个系统调用都有自 己的系统调用号,在内核中有一个系统调用表sys_call_table[],以系统调用号为下标的相应元素是一个函数指针,即系统调用在内核中对应函数 的入中地址.system_call()中,会通过call指令调用到该函数.这样就完成了从shell中输入mkdir 调用到内核的sys_mkdir了.
首先把系统调用号装入EAX,然后把调用参数放在ebx、ecx、edx、esi、edi,然后触发0x80中断。这是x86上的做法,其他体系结构类似(Robert Love《LKD》)。
阅读(1002) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~