Chinaunix首页 | 论坛 | 博客
  • 博客访问: 15884
  • 博文数量: 4
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 10
  • 用 户 组: 普通用户
  • 注册时间: 2015-09-01 20:22
文章分类
文章存档

2015年(4)

我的朋友

分类: LINUX

2015-12-10 19:40:12

linux内核编程4部曲之一:linux内核编译(2.6.12版本)图文解说

linux内核编程4部曲之二:增加linux内核系统调用

linux内核编程4部曲之三:修改O(1)调度算法

linux内核编程4部曲之四:模块编程

 

 

本文,承接上面一篇linux内核编译,增加系统调用后,需要重新编译内核。

一、实验目的
    增加加减乘除系统调用,并测试系统调用和用户调用的性能差异。
二、增加系统调用
    增加系统调用主要分为3步:
    1)、增加系统调用函数。修改/usr/src/linux-2.6.12/kernel/sys.c文件,在文件末尾增加4个系统响应函数(+、-、*、/)。函数实现如下:
    
    2)、在系统调用表中注册。
         在/usr/src/linux-2.6.12/arch/i386/kernel/syscall_table_32.S中添加我们的系统调用。
    
    3)、添加系统调用入口参数
    在/usr/src/linux-2.6.12/include/asm-i386/unistd.h中添加系统调用入口参数(注意:其中会顺序定义入口参数的序号,添加的序号是在原有最大值的基础上+1)。
    
三、编译内核,引导新内核启动
四、测试
    测试需要在添加了系统调用的新系统中进行。
    1)功能测试
   首先测试,系统调用是否能正常执行,测试程序为testsyscall.c

  1. #include<asm/unistd.h>
  2. #include<errno.h>
  3. #include<stdio.h>

  4. #define __NR_add 289
  5. #define __NR_sub 290
  6. _syscall2(int ,add,int ,x,int,y)
  7. _syscall2(int ,sub,int ,x,int ,y)
  8. int main()
  9. {
  10.    printf("%d\n",add(10,10));
  11.    printf("%d\n",sub(15,10));
  12.    return 0;
  13. }
     编译运行,查看结果,成功调用。这里要注意的是,在testsyscall.c中声明__NR_add 289.
    
    2)、性能测试
    要对比系统调用和用户调用的性能差异,我们先编写用户调用的测试程序testusercall.c

  1. #include<stdio.h>
  2. int add(int x,int y)
  3. {
  4.    return x+y;
  5. }
  6. int main()
  7. {
  8.    int i=0;
  9.    for(i=0;i<100000000;i++)
  10.    {
  11.       add(10,20);
  12.    }
  13.    return 0;
  14. }
     再编写系统调用的测试程序testsyscall.c
  1. #include<asm/unistd.h>
  2. #include<stdio.h>

  3. #define __NR_add 289
  4. _syscall2(int ,add,int ,x,int,y)
  5. int main()
  6. {
  7.    int i=0;
  8.    for(i=0;i<100000000;i++)
  9.    {
  10.       add(10,20);
  11.    }
  12.    return 0;
  13. }
  两个程序均是运行10000000次,然后分别统计他们的时间。
  
   
   可以发现,两个测试程序在系统sys运行时间差别很大,testusercall仅在sys运行了0m0.003s,而testsyscall却在sys运行了0m4.028s,说明,系统调用的sys时间远远大于用户层调用的时间。
    
阅读(1659) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~