免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1324 | 回复: 0
打印 上一主题 下一主题

[linux] 系统调用 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-01-01 13:30 |只看该作者 |倒序浏览
系统调用跳转表 sys_call_table[] 一个函数指针数组
       所有表中不支持的系统调用号,全部指向sys_ni_call()(仅返回出错代码-ENOSYS)
宏调用GET_CURRENT(%ebx)使%ebx指向当前进程的task_struct,然后检查%eax中的系统调用号是否超出范围。
task_struct结构中有字段flags,其中有一标志位PT_TRACESYS,一个进程可通过系统调用ptrace()将一个子进程的该标志位设置为1,从而跟中该子进程的系统调用(系统命令strace即如此)。
------------------------
系统调用返回时,会检查返回值(%eax),若处于-1~-4095之间,则表示出错,转向__syscall_error()(libc.a)
在__syscall_error()中
  
  
  1.  %eax  取负值 --->  堆栈
  2.  __errno_location() 全局errono地址 --->  %eax  
  3.  堆栈 : 出错代码 ---> %ecx
                    ---> 全局errono
  4.  -1 改写 ---> %eax
-----------------------------------------------------------
以sethostname调用做例子
asmlinkage long sys_sethostname(char* name, int len)
{
    ...
    /*
        sethostname是特权用户才可进行的操作,所以一开始就做权限检查
           capable(CAP_SYS_ADMIN)检查当前进程是否有CAP_SYS_ADMIN的授权
     */
    if( !capable(CAP_SYS_ADMIN) )
          return -EPERM;
    //检查字符串长度
    if( len  __NEW_UTS_LEN )
          return -EINVAL;
   
    //sethostname要操作的是临界区,这里在操作前,必须加信号量,防止race condition出现
    down_write(&uts_sem);
    ...
    up_write(&uts_sem);
   
    /*
       在以上的临界区操作中,使用了宏调用copy_from_user(to,from,n):
            copy_from_user(system_utsname.nodename, name, len)
         
    */
               
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u3/109164/showart_2137213.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP