西电计算机操作系统实验Linux系统调用.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 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)

xingyuxiaxiang + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档