- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
西安电子科技大学
计算机学院
实
验
报
告
题目:班级:
姓名:学号:
一、理论分析(分值:20%)
【从操作系统原理(理论)的角度阐述系统功能调用的过程】
函数声明中都有asmlinkage限定词,用于通知编译器仅从栈中提取该函数的参数。
系统调用getXXX()在内核中被定义为sys系统调用号:在linux中,每个系统调用都赋予一个系统调用号,通过这个独一无二的号就可以关联系统调用。当用户空间的进程执行一个系统调用的时候,这个系统?内核记录了系统调用表中所有已注册过的系统调用的列表,存储在sys_call_table中。它与体系结构有关,一般在entry.s中定义。这个表中为每一个有效的系统调用指定了唯一的系统调用号。
Makefile控制着整个内核的编译,在每个子目录下调用编译.c 文件,生成.o文件,生成新的内核。会把新编译的sys_hello内核加入到系统调用中。系统调用表gedit syscall_32.tbl中加入354 i386 hello sys_hello,当系统调用时可以在调用表中找到系统调用的号。
在syscalls.h中添加定义的内容的引用函数。
编译执行结果。
二、设计与实现(分值:30%)
【阐述在Linux中添加系统功能调用的方法】
在内核目录下创建hello文件夹 mkdir hello
进入hello文件夹 cd hello
创建hello.c的文件 vim hello.c
加入代码
#include linux/kernel.h
asmlinkage long sys_hello(void)
{
printk(“Hello world\n”);
return 0;
}
在hello文件夹下添加Makefile文件 vim Makefile
在文件里添加 obj-y := hello.o
返回内核的根目录中,打开Makefile文件,在842行添加代码 vim Makefile
将core-y += kernel/ mm/ fs/ ipc/ security/ crypto/ block/
改为core-y += kernel/ mm/ fs/ ipc/ security/ crypto/ block/ hello/
打开系统调用表 cd arch/x86/syscalls
Vim syscall_32.tbl
在文件最后一行添加354 i386 hello sys_hello
在调用函数名的文件中加入添加的函数
cd include/linux/
Vim syscalls.h
asmlinkage long sys_hello(void);
进行编译
cd /usr/src/linux-3.16/
sudo make menuconfig
sudo make oldconfig
make -j4
安装编译好的内核
sudo make modules_install install
shutdown -r now
重启后选择新的内核载入测试
uname -r
编写测试文件hello.c
#include stdio.h
#include linux/kernel.h
#include sys/syscall.h
#include unistd.h
int main(){
printf(%ld\n, syscall(354));
return 0;
}
编译测试
gcc -o hello.c hello
./hello.out
dmesg
三、实验结果(分值:10%)
【对实验结果进行简要分析和说明】
测试文件调用系统调用号354,并且将返回结果0输出,dmesg可以将开机显示结果输出查看。
四、心得与收获(分值:40%)
【本部分内容应至少包括如下部分:(1)从代码层面阐述Linux系统调用的整个过程;(2)应用程序调用Linux系统功能的方式以及你采用的方式。以及任何你想表达的内容】
1、在系统启动的时候start_kernel会调用trap_init来初始化异常向量表。设置0x80号软中断的服务程序为system_call, system_call是所有系统调用的总入口。
当进程执行到用户程序的系统调用命令时,实际上执行了由宏命令_syscallN()展开的函数。系统调用的参数由各通用寄存器传递,比如通过eax寄存器传递系统调用号和系统调用返回值,通过ebx/ecx/edx/esi/edi传递系统调用参数,然后执行INT 0x80,以内核态进入入口地址system_call。
start_kernel
trap_init
set_system_trap_gate(SYSC
文档评论(0)