实验报告 一、理论分析(分值:20%)【从操作系统原理(理论)的角度阐述系统功能调用的过程】1、函数声明中都有asmlinkage限定词,用于通知编译器仅从栈中提取该函数的参数
2、系统调用getXXX()在内核中被定义为sys_getXXX()
系统调用号:在linux中,每个系统调用都给予一个系统调用号,通过这个独一无二的号就可以关联系统调用
当用户空间的进程执行一个系统调用的时候,这个系统调用号就被用来指明到底要执行哪个系统调用;进程不会提及系统调用的名称
系统调用号一旦分配就不能再有任何变更(否则编译好的应用程序就会崩溃),假如一个系统调用被删除,它所占用的系统调用号也不允许被回收利用
Linux有一个"未使用"系统调用sys_ni_syscall(),它除了返回-ENOSYS外不做任何其他工作,这个错误号就是专门针对无效的系统调用而设的
内核记录了系统调用表中所有已注册过的系统调用的列表,存储在sys_call_table中
它与体系结构有关,一般在entry
这个表中为每一个有效的系统调用指定了唯一的系统调用号
3、Makefile控制着整个内核的编译,在每个子目录下调用编译
c 文件,生成
o文件,生成新的内核
会把新编译的sys_hello内核加入到系统调用中
系统调用表gedit syscall_32
tbl中加入354 i386 hello sys_hello,当系统调用时可以在调用表中找到系统调用的号
4、在syscalls
h中添加定义的内容的引用函数
5、编译执行结果
二、设计与实现(分值:30%)【阐述在Linux中添加系统功能调用的方法】1、在内核目录下创建hello文件夹 mkdir hello2、进入hello文件夹 cd hello3、创建hello
c的文件 vim hello
c4、加入代码#include asmlink