Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3038139
  • 博文数量: 674
  • 博客积分: 17881
  • 博客等级: 上将
  • 技术积分: 4849
  • 用 户 组: 普通用户
  • 注册时间: 2010-03-17 10:15
文章分类

全部博文(674)

文章存档

2013年(34)

2012年(146)

2011年(197)

2010年(297)

分类: LINUX

2010-08-19 19:21:36

    1、系统调用的声明前都有asmlinkage限定词,用于通知编译器仅从栈中提取该函数的参数。系统调用的命名上都有sys_前缀。

    2、每个系统调用被赋予一个系统调用号。进程不会提及系统调用的名称,所以通过这个独一无二的号就可以关联系统调用。如果一个系统调用被删除,它所占用的系统调用号也不允许被回收利用,其一旦分配就不能再有任何变更。

    3、内核记录了系统调用表中的所有已注册过的系统调用的列表,存储在sys_call_table中。它与体系结构有关,一般在entry.s中定义。

    4、系统调用必须仔细检查它们所有的参数是否合法有效。在接收一个用户空间的指针之前,内核必须保证:

    •  指针指向的内存区域属于用户空间。

    •  指针指向的内存区域在进程的地址空间里。

    •  如果是读,该内存应被标记为可读。如果是写,该内存应被标记为可写。

    若大家想知道Linux有哪些系统调用,请参考下面网址的内容。

    http://www.ibm.com/developerworks/cn/linux/kernel/syscall/part1/appendix.html

阅读(866) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~