Linux内核之系统调用
2012-09-29 09:59
211 查看
Linux内核之系统调用
1. 应用程序通过API而不是直接调用系统调用来编程;
2. getpid()系统调用示例:
asmlinkage long sys_getpid(void)
{
return current->tgid;
}
asmlinkage 编译器仅从栈中提取参数
系统调用的命名规则:sys_syscallname()
3. 每个系统调用都对应一个唯一的系统调用号,如果系统调用被删除,但它占用的系统调用号不回收。
4. 系统调用通过软中断实现(int $0x80),通过引发一个异常陷入懂啊内核态去执行异常处理程序system_call。最近的x86处理器已经支持了sysenter指令。
5. 参数和返回值通过寄存器来传递。
6. 指针参数的合法性验证:
(1)指针指向的内存区属于用户空间;
(2)指针指向的内存区在进程的地址空间里;
(3)指针指向的内存区必须被标记为可读(读)/可写(写)。
系统提供了两个方法来完成内核空间与用户空间的数据拷贝:copy_to_user()和copy_from_user()。
7. 内核执行系统调用的时候处于内核上下文,此时内核可以休眠并可以被抢占。
8. 系统调用必须编译进内核映像,不能编译成模块。
9. 通常通过C库来使用系统调用(包含头文件并链接相应的库),但也可以通过宏来直接访问系统调用,如open()的调用:
先通过下面的宏将系统调用扩展为内嵌汇编的C函数:
#define_NR_open 5
_syscall3(long, open, const char*, filename, int, flags, int, mode)
这样,应用程序就可以直接使用open()了。
1. 应用程序通过API而不是直接调用系统调用来编程;
2. getpid()系统调用示例:
asmlinkage long sys_getpid(void)
{
return current->tgid;
}
asmlinkage 编译器仅从栈中提取参数
系统调用的命名规则:sys_syscallname()
3. 每个系统调用都对应一个唯一的系统调用号,如果系统调用被删除,但它占用的系统调用号不回收。
4. 系统调用通过软中断实现(int $0x80),通过引发一个异常陷入懂啊内核态去执行异常处理程序system_call。最近的x86处理器已经支持了sysenter指令。
5. 参数和返回值通过寄存器来传递。
6. 指针参数的合法性验证:
(1)指针指向的内存区属于用户空间;
(2)指针指向的内存区在进程的地址空间里;
(3)指针指向的内存区必须被标记为可读(读)/可写(写)。
系统提供了两个方法来完成内核空间与用户空间的数据拷贝:copy_to_user()和copy_from_user()。
7. 内核执行系统调用的时候处于内核上下文,此时内核可以休眠并可以被抢占。
8. 系统调用必须编译进内核映像,不能编译成模块。
9. 通常通过C库来使用系统调用(包含头文件并链接相应的库),但也可以通过宏来直接访问系统调用,如open()的调用:
先通过下面的宏将系统调用扩展为内嵌汇编的C函数:
#define_NR_open 5
_syscall3(long, open, const char*, filename, int, flags, int, mode)
这样,应用程序就可以直接使用open()了。
相关文章推荐
- linux内核分析之系统调用
- Linux内核添加系统调用总结
- Linux:内核模块实现替换系统调用的简单例子
- linux内核添加系统调用
- Linux系统调用怎么和内核或底层驱动交互的
- Linux 内核0.11 系统调用详解(上)
- linux修改内核、添加系统调用过程
- Linux:内核模块实现替换系统调用的简单例子
- 对linux 0.11版本内核的kill系统调用的理解
- Linux0.11内核--系统调用机制分析
- linux 内核修炼之道——系统调用
- akira之修改linux 4.6.2内核并添加系统调用
- 动静结合学内核之 linux 系统调用浅析
- 树莓派1代·添加一个linux系统调用·编译内核
- 修改Linux内核增加系统调用(转载)
- linux内核4.2.x实现自定义系统调用
- 在 Linux 下用户空间与内核空间数据交换的方式,第 1 部分: 内核启动参数、模块参数与sysfs、sysctl、系统调用和netlink
- mips处理器linux内核添加系统调用
- 内核驱动开发第五天linux系统调用
- linux 3.12内核里系统调用常见的问题