`
M_ittrue
  • 浏览: 76979 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Linux自定义系统调用

 
阅读更多

 

Linux自定义系统调用

 

如果用户在Linux中添加新的系统调用,应该遵循几个步骤才能添加成功,下面几个步骤详细说明了添加系统调用的相关内容。

2.1添加源代码

第一个任务是编写加到内核中的源程序,即将要加到一个内核文件中去的一个函数,该函数的名称应该是新的系统调用名称前面加上sys_标志。假设新加的系统调用为mycall(int number),在/usr/src/linux/kernel/sys.c文件中添加源代码,如下所示:

asmlinkage int sys_mycall(int number)

{

 return number;

}

作为一个最简单的例子,我们新加的系统调用仅仅返回一个整型值。

2.2 连接新的系统调用

添加新的系统调用后,下一个任务是使Linux内核的其余部分知道该程序的存在。为了从已有的内核程序中增加到新的函数的连接,需要编辑两个文件。

在我们所用的Linux内核版本(RedHat 6.0,内核为2.2.5-15)中,第一个要修改的文件是:

/usr/src/linux/include/asm-i386/unistd.h

该文件中包含了系统调用清单,用来给每个系统调用分配一个唯一的号码。文件中每一行的格式如下:

#define __NR_name NNN

其中,name用系统调用名称代替,而NNN则是该系统调用对应的号码。应该将新的系统调用名称加到清单的最后,并给它分配号码序列中下一个可用的系统调用号。我们的系统调用如下:

#define __NR_mycall 191

系统调用号为191,之所以系统调用号是191,是因为Linux-2.2内核自身的系统调用号码已经用到190。

第二个要修改的文件是:

/usr/src/linux/arch/i386/kernel/entry.S

该文件中有类似如下的清单:

.long SYMBOL_NAME()

该清单用来对sys_call_table[]数组进行初始化。该数组包含指向内核中每个系统调用的指针。这样就在数组中增加了新的内核函数的指针。我们在清单最后添加一行:

.long SYMBOL_NAME(sys_mycall)

 

2.3 重建新的Linux内核

为使新的系统调用生效,需要重建Linux的内核。这需要以超级用户身份登录。

#pwd

/usr/src/linux

#

超级用户在当前工作目录(/usr/src/linux)下,才可以重建内核。

#make config

#make dep

#make clearn

#make bzImage

编译完毕后,系统生成一可用于安装的、压缩的内核映象文件:

/usr/src/linux/arch/i386/boot/bzImage 

2.4用新的内核启动系统

要使用新的系统调用,需要用重建的新内核重新引导系统。为此,需要修改/etc/lilo.conf文件,在我们的系统中,该文件内容如下:

  boot=/dev/hda

  map=/boot/map

  install=/boot/boot.b

  prompt

  timeout=50

  image=/boot/vmlinuz-2.2.5-15

  label=linux

  root=/dev/hdb1

  read-only

  other=/dev/hda1

  label=dos

  table=/dev/had

  首先编辑该文件,添加新的引导内核:

  image=/boot/bzImage-new

  label=linux-new

  root=/dev/hdb1

  read-only

  添加完毕,该文件内容如下所示:

  boot=/dev/hda

  map=/boot/map

  install=/boot/boot.b

  prompt

  timeout=50

  image=/boot/bzImage-new

  label=linux-new

  root=/dev/hdb1

  read-only

  image=/boot/vmlinuz-2.2.5-15

  label=linux

  root=/dev/hdb1

  read-only

  other=/dev/hda1

  label=dos

  table=/dev/hda

  这样,新的内核映象bzImage-new成为缺省的引导内核。

  为了使用新的lilo.conf配置文件,还应执行下面的命令:

  #cp /usr/src/linux/arch/i386/boot/zImage /boot/bzImage-new

  其次配置lilo:

  # /sbin/lilo

  现在,当重新引导系统时,在boot:提示符后面有三种选择:linux-new 、 linux、dos,新内核成为缺省的引导内核。

  至此,新的Linux内核已经建立,新添加的系统调用已成为操作系统的一部分,重新启动Linux,用户就可以在应用程序中使用该系统调用了。

2.5使用新的系统调用

在应用程序中使用新添加的系统调用mycall。同样为实验目的,我们写了一个简单的例子xtdy.c。

       /* xtdy.c */

  #include $#@60;linux/unistd.h$#@62;

  _syscall1(int,mycall,int,ret)

  main()

  {

  printf("%d \n",mycall(100));

  }

  编译该程序:

  # cc -o xtdy xtdy.c

  执行:

  # xtdy

  结果:

  # 100

注意,由于使用了系统调用,编译和执行程序时,用户都应该是超级用户身份。

转自:http://blog.csdn.net/orange_os/article/details/7485069

分享到:
评论

相关推荐

    Linux下添加简单自定义系统调用.pdf

    在Linux内核编译法添加自定义系统调用的过程中,首先需要熟悉Linux操作系统的基本命令和操作,包括查看系统版本信息、更新软件源、下载和编译内核等步骤。 在实验环境的搭建中,推荐使用Ubuntu**.**.*.* LTS版本的...

    实验(五)Linux系统调用的编程技术 - 副本.doc

    实验的目的在于让学生深入理解Linux系统调用的工作原理,包括如何通过API调用系统服务,以及如何直接使用汇编代码触发系统调用。例如,`time()`函数是一个库函数API,它封装了获取系统时间的系统调用。当调用`time()...

    linux中添加系统调用

    本主题将深入探讨如何在Linux 2.6.30版本中添加自定义的系统调用,并理解其运行原理。 首先,我们需要了解系统调用的基本概念。系统调用是一种特殊的子程序,由操作系统内核提供,用户程序通过特定的接口(通常在...

    linux系统调用可视化 操作系统课程设计 实验报告

    【操作系统课程设计——Linux系统调用可视化实验报告】 在操作系统的学习过程中,系统调用是连接用户空间和内核空间的重要桥梁。本实验旨在通过可视化Linux系统调用的过程,加深对系统调用的理解,同时锻炼动手实践...

    linux 通过模块实现自己的系统调用

    总的来说,通过Linux内核模块实现自定义系统调用涉及多个步骤,包括模块编写、系统调用号分配、函数实现、注册、用户空间接口以及加载和卸载。这个过程需要对Linux内核有深入的理解,同时也是一项挑战性的任务,但也...

    linux2.6系统调用18内核升级

    1. **添加系统调用函数**:在内核源码的 `kernel/sys.c` 文件中添加自定义系统调用函数。 2. **更新用户空间系统调用表**:在 `include/asm-i386/unistd.h` 文件中添加相应的系统调用编号。 3. **更新系统调用表**:...

    实验五Linux系统调用的编程技术

    在实验五“Linux系统调用的编程技术”中,主要目标是理解和掌握系统调用的工作原理,包括如何通过API调用系统服务以及参数传递的方式。 系统调用通常通过库函数的形式对外提供,例如libc库,它提供了众多的API,如...

    Linux2.6系统调用钩子的原理分析和实现应用.pdf

    总结起来,Linux 2.6系统调用钩子的原理是利用系统调用表的动态修改,将原本的系统调用函数替换为自定义的监控函数,以此来监控和控制系统的特定行为。实现这一技术需要对Linux内核有深入的理解,并且需要遵循最佳...

    ARM64 架构增加一个系统调用.pdf

    在Linux操作系统中,系统调用是用户空间与内核空间交互的重要途径,它们提供了安全的接口,使得应用程序能够执行只有内核权限才能完成的任务。在ARM64(也称为AArch64)架构中,系统调用的实现相对复杂,因为它们...

    操作系统课程实践之Linux系统调用.doc

    在这个实验中,学生主要学习了如何在Linux内核中添加自定义的系统调用,并通过两种不同的方法进行实现。 首先,第一种方法是直接修改内核源码来添加系统调用。这涉及到以下几个关键步骤: 1. 获取root权限,因为对...

    基于ARM-Linux的可扩展系统调用模块的实现.pdf

    总结来说,这篇论文详细阐述了在ARM-Linux环境下,如何通过设计一个可扩展的系统调用模块来解决用户自定义系统调用的问题。这种方法既保证了系统的安全性和稳定性,又提供了灵活的系统调用扩展能力,对于ARM-Linux...

    Linux系统调用劫持:技术原理、应用及检测.pdf

    修改系统调用表意味着改变某个系统调用编号所对应的函数指针,将其指向攻击者自定义的函数,从而在调用原始功能之前或之后执行恶意代码。而篡改中断描述符表则是改变中断处理程序,使得int 0x80指令触发时会调用攻击...

    浅析Linux的系统调用方法 (1).pdf

    此外,文档还可能涉及如何实现自定义的系统调用,包括编写响应函数,注册系统调用号,以及更新系统调用表等步骤。这通常需要对汇编语言和内核编程有深入的理解。 总的来说,理解和掌握Linux的系统调用方法对于进行...

    基于C语言的Linux内核编译及添加系统调用.zip

    为了在内核态下运行,本实验针对Linux的内核进行修改,增加自定义系统调用函数实现用户态程序对任意进程的nice值进行修改或者读取来进行测试。详细介绍参考:...

    Linux系统调用的实现.ppt

    Linux系统调用是操作系统提供给用户空间程序访问内核服务的一种接口,它是操作系统与应用程序之间的桥梁。在Linux中,系统调用的实现...通过上述步骤,开发者可以自定义新的系统调用来扩展内核的功能,满足特定需求。

    向Linux内核增加一个系统调用【CentOS和Ubuntu版本】

    这通常涉及到使用`syscall()`函数或者`#define`宏来调用系统调用号。 实验环境建议使用CentOS或Ubuntu这样的Linux发行版,因为它们提供了稳定的开发环境和丰富的开源工具。学生应该熟悉基本的Linux命令行操作,如`...

    实验二 Linux 系统调用.zip

    这个实验的目标是理解和实践如何在Linux环境下创建和使用自定义的系统调用。 首先,我们需要了解Linux系统调用的工作原理。在Linux中,系统调用通常通过一个特定的汇编指令`int 0x80`或`sysenter`触发,这会将控制...

Global site tag (gtag.js) - Google Analytics