- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第六章 系统调用 系统调用,顾名思义,说的是操作系统提供给用户程序调用的一组“特殊”接口。 从逻辑上来说,系统调用可被看成是一个内核与用户空间程序交互的接口——它好比一个中间人,把用户进程的请求传达给内核,待内核把请求处理完毕后再将处理结果送回给用户空间。 Linux的应用编程接口(API)遵循 POSIX标准 应用编程接口(API)其实是一组函数定义,这些函数说明了如何获得一个给定的服务;而系统调用是通过软中断向内核发出一个明确的请求 API有可能和系统调用的调用形式一致 API和系统调用关注的都是函数名、参数类型及返回代码的含义 系统调用的实现是在内核完成的,而用户态的函数是在函数库中实现的 系统命令相对应用编程接口更高一层,每个系统命令都是一个可执行程序,比如ls、hostname等, 系统命令的实现调用了系统调用 通过strace ls或strace hostname 命令可以查看系统命令所调用的系统调用 内核函数在形式上与普通函数一样,但它是在内核实现的,需要满足一些内核编程的要求 系统调用是用户进程进入内核的接口层,它本身并非内核函数,但它是由内核函数实现的 进入内核后,不同的系统调用会找到各自对应的内核函数,这些内核函数被称为系统调用的“服务例程” 当用户态的进程调用一个系统调用时,CPU切换到内核态并开始执行一个内核函数 系统调用处理程序执行下列操作: 在内核栈保存大多数寄存器的内容 调用所谓系统调用服务例程的相应的C函数来处理系统调用 通过ret_from_sys_call( )函数从系统调用返回 内核初始化期间调用trap_init( )函数建立IDT表中128号向量对应的表项: set_system_gate(0x80, system_call); 该调用把下列值装入该门描述符的相应域 : 段选择子: 偏移量:指向system_call( )异常处理程序 类型:置为15,表示该异常是一个陷阱 DPL(描述符特权级):置为3,这就允许用户态进程调用这个异常处理程序 system_call( )函数实现了系统调用处理程序 : 它首先把系统调用号和该异常处理程序用到的所有CPU寄存器保存到相应的栈中 把当前进程PCB的地址存放在ebx中 对用户态进程传递来的系统调用号进行有效性检查。若调用号大于或等于NR_syscalls,系统调用处理程序终止 若系统调用号无效,函数就把-ENOSYS值存放在栈中eax寄存器所在的单元,再跳到ret_from_sys_call( ) 根据eax中所包含的系统调用号调用对应的特定服务例程 每个系统调用至少有一个参数,即通过eax寄存器传递来的系统调用号 用寄存器传递参数必须满足两个条件: 每个参数的长度不能超过寄存器的长度 参数的个数不能超过6个(包括eax中传递的系统调用号),否则,用一个单独的寄存器指向进程地址空间中这些参数值所在的一个内存区即可 在少数情况下,系统调用不使用任何参数 服务例程的返回值必须写到eax寄存器中 分析系统调用有两种方法: 查看entry.s中的代码细节,阅读相关的源码来分析其运行过程; 借助一些内核调试工具,动态跟踪执行路径。 结合用户空间的执行路径,该程序的执行大致可归结为以下几个步骤: libc库中如何对不同的服务例程进行封装 ? Linux定义了从_syscall0到_syscall5的六个宏 每个宏名字的数字0到5对应着系统调用所用的参数个数(系统调用号除外) 每个宏严格地需要2+2?n个参数,n是系统调用的参数个数。另外两个参数指明系统调用的返回值类型和名字;每一对参数指明相应的系统调用参数的类型和名字 例:fork( )的封装例程:_syscall0(int,fork) 在用户态进行系统调用时,要进行用户态堆栈到内核态堆栈的切换,但在内核中进行系统调用时,不用进行堆栈切换 添加系统调用的步骤: 添加系统调用号。系统调用号在unistd.h 文件中定义,以“__NR_”开头 在系统调用表(在entry.S中)中添加自己的服务例程sys_mysyscall 实现系统调用服务例程:把sys_mysyscall加在kernel目录下的系统调用文件sys.c中 重新编译内核 编写用户态程序 利用系统调用实现一个调用日志收集系统,实时获取系统调用日志 本实例需要完成以下几个基本功能: 记录系统调用日志,将其写入缓冲区(内核中),以便用户读取(由syscall_audit()实现); 建立新的系统调用,将内核缓冲中的系统调用日志返回到用户空间(由Sys_audit()实现) 循环利用系统调用,以便能动态实时返回系统调用的日志(由 auditd
您可能关注的文档
- 第九课 管道设计及布置.ppt
- COM原理及应用----COM对象与接口.doc
- 常见语病类型(标准整理版).doc
- 一个完整的面向对象分析及设计例子.doc
- 用递归下降分析法编写一个用于判断数学表达式是否正确语法分析.doc
- tomcat安装目录各文件夹意义.doc
- 谈谈现行继承制度的缺陷及完善问题研究及分析.doc
- 零基础学按键精灵(第三篇).doc
- 消息的概念和实例.doc
- 第五章 循环结构 习题及答案.doc
- 小学科学:ESP8266智能插座电路原理与动手实践研究教学研究课题报告.docx
- 《金融开放浪潮下我国多层次监管体系构建与创新研究》教学研究课题报告.docx
- 区域教育质量监测中人工智能应用的数据质量分析与优化策略教学研究课题报告.docx
- 《金融科技监管中的数据治理与合规性要求》教学研究课题报告.docx
- 《3D打印技术在航空航天领域中的多材料制造与复合材料应用》教学研究课题报告.docx
- 《绿色金融发展中的政府职能与市场机制研究》教学研究课题报告.docx
- 《植物工厂多层立体栽培光环境调控技术对植物生长发育节律的调控机制探讨》教学研究课题报告.docx
- 销售团队年度业绩总结.docx
- 银行风险管理与金融危机防范.docx
- 银行网络攻击预警与快速响应机制.docx
最近下载
- 建设项目环境影响评价现状评价报告-中化云龙有限公司.PDF VIP
- 智能家居门窗控制系统设计.doc VIP
- cpl随钻测井介绍资料.ppt VIP
- 关于医药行业上市公司财务分析--以恒瑞医药为例.docx VIP
- 乡村非遗文化传承与乡村振兴战略中的文化传承与产业融合报告.docx VIP
- 小学生课前准备课件.pptx VIP
- 大隐静脉曲张患者的术后护理研究进展.docx VIP
- cpl随钻测井介绍.pptx VIP
- 乡村非遗文化传承与乡村振兴战略中的文化传承与乡村振兴报告.docx VIP
- 2025年山东烟台莱阳市结合事业单位招聘征集本科及以上学历毕业生入伍笔试备考题库及答案详解一套.docx VIP
文档评论(0)