《Linux内核设计与实现》第五章读书笔记
第五章 系统调用
5.1与内核通信
1. 系统调用
让应用程序受限的访问硬件设备
提供创建新进程并与已有进程通信的机制
提供申请操作系统其他资源能力
是用户空间进程和硬件设备之间的中间层
2. 系统调用的功能
1)硬件的抽象接口:用户程序通过系统调用来使用硬件,而不用关心具体的硬件设备,简化了用户程序的开发
2)保证系统的稳定与安全:基于某些规则的访问控制
3)增强系统的稳定性
在Linux中,系统调用是用户空间访问内核的唯一手段除异常和陷入外,他们是内核唯一的合法入口
5.2 API、POSIX和C库
1.API可以在各种不同的操作系统实现,给应用程序提供完全相同的接口,而它们本身在这些系统上的实现却可能迥异。
2.在Unix世界中,最流行的应用编程接口是基于POSIX标准的。
3. C库包括:标准C库函数、系统调用接口
4. 注意:
程序员<--->API
内核<--->系统调用
5.关系图:
5.3系统调用
1. 介绍:在linux中常称作syscall,通常通过C库中定义的函数调用来进行。
- 注意:返回值是long型变量,如果出错,C库会将错误代码写入errno全局变量。
- 系统调用再出现错误的时候C库会把错误码写入errno全局变量。通过调用perror()库函数,可以把该变量翻译成用户可以理解的错误字符串。
- SYSCALL_DEFINE0只是一个宏,它定义一个无参数的系统调用。
2. 定义系统调用:
asmlinkage long sys_getpid(void)
- 限定词:asmlinkage
- 函数返回值类型:long
- 符合命名规则的命名:sys_getpid
3. 系统调用在用户空间和内核空间有不同的返回值类型,在用户空间为int在内核空间为long。
4. 系统调用号一旦分配就不能再有任何变更。
- 如果一个系统调用被删除,它所占用的系统调用号也不允许被回收利用
- Linux有一个“未实现”系统调用sysnisyscall(),它除了返回―ENOSYS外不做任何其他工作,这个错误号就是专门针对无效的系统调用而设的
5.4 系统调用处理程序
1. 内核记录了系统调用表中的所有已注册过的系统调用的列表,存储在syscalltable中。在×86-64中,它定义于arch/i386/kernel/syscall_64.c文件中。
2.注意:
x86系统,ebx,ecx,edx,esi,edi按顺序存放前五个参数。
需要6个及以上参数,应用一个单独的寄存器存放指向这些参数在用户空间地址的指针。
返回值存放在eax。
3. Linux系统执行快的原因:
- 很短的上下文切换时间
- 系统调用处理程序和每个系统调用本身也十分简洁
5.5 系统调用的实现
1.参数验证
- 参数合法有效并正确:不应让内核访问无权访问的资源
最重要的检查:用户提供的指针是否有效。内核必须保证指针:
指向的内存区域属于用户空间;
指向的内存区在进程的地址空间里;
指向的内存区在内存的访问权限范围中。- 两个方法检查在两空间之间数据的来回拷贝:
copy_to_user():向用户空间写入数据
copy_from_user():从用户空间读取数据 - 针对是否有合法权限的检查
capable():是否有权对指定的资源进行操作
返回0:无权操作
2.关系图:

5.6 系统调用上下文
1. 进程上下文:内核在执行系统调用的时候处于进程上下文
current指针指向当前任务。
在进程上下文中,内核可以休眠、被抢占。
当系统调用返回时,控制权仍然在system_call()中,负责切换到用户空间,并让用户进程继续执行下去
2. 绑定一个系统调用的最后步骤:编写完系统调用之后,将其注册成一个正式的系统调用
在系统调用表中加入表项;
系统调用号定义于<asm/unistd.h>中;
编译进内核映像,放入kernel/下的相关文件。
3. 从用户空间访问系统调用
_syscalln():Linux提供的一组宏,用于直接对系统调用进行访问。会设置好寄存器并调用陷入指令。- n的范围:0~6,代表传递给系统调用的参数个数。
- 对每个宏来说,都有
2+2*n个参数。
第一个参数:对应系统调用返回值类型
第二个参数:系统调用的名称
按系统调用参数顺序排列的每个参数的类型和名称
eg.
long open(const char *filename, int flags, int mode)
#define NR_open 5
_syscall3(long, open, const char*, filename, int, flags, int, mode)
4. 为什么不通过系统调用的方式实现?
(1)建立一个系统调用的好处
创建容易、使用方便
Linux系统调用的高性能
(2)问题是:
系统调用号需要在内核处于开发版本时官方分配
系统调用加入稳定内核后被固化,接口不允许做改动
需要将系统调用分别注册到每个需要支持的体系结构中去
脚本中不容易调用,不能从文件系统直接访问
主内核树之外难以维护和使用
(3)替代方法
某些接口可以用文件描述符表示
把增加的信息作为文件放在sysfs的合适位置
=======================================================
总结
我觉得在这一章中,最应该重点理解的还是系统调用的内涵,以及它和API的区别。也提及补充了系统调用的优势之处。这也让我们从底层能够比较系统地去理解内核运行机制,它是如何提供基本功能的,其中包含的那些层层包装递进的过程。
《Linux内核设计与实现》第五章读书笔记的更多相关文章
- Linux内核设计与实现第五周读书笔记
第十八章 调试 18.1准备开始 需要的只是: 一个确定的bug.大部分bug通常都不是行为可靠而且定义明确的. 一个藏匿bug的内核版本. 相关的内核代码的知识和运气. 18.2内核中的bug 内核 ...
- 《Linux内核设计与实现》第四周读书笔记——第五章
<Linux内核设计与实现>第四周读书笔记--第五章 20135301张忻 估算学习时间:共1.5小时 读书:1.0 代码:0 作业:0 博客:0.5 实际学习时间:共2.0小时 读书:1 ...
- 《Linux内核设计与实现》Chapter 3 读书笔记
<Linux内核设计与实现>Chapter 3 读书笔记 进程管理是所有操作系统的心脏所在. 一.进程 1.进程就是处于执行期的程序以及它所包含的资源的总称. 2.线程是在进程中活动的对象 ...
- 《Linux内核设计与实现》Chapter 1 读书笔记
<Linux内核设计与实现>Chapter 1 读书笔记 一.Unix的特点 Unix从Multics中产生,是一个强大.健壮和稳定的操作系统. 特点 1.很简洁 2.在Unix系统中,所 ...
- 《Linux内核设计与实现》Chapter 5 读书笔记
<Linux内核设计与实现>Chapter 5 读书笔记 在现代操作系统中,内核提供了用户进程与内核进行交互的一组接口,这些接口的作用是: 使应用程序受限地访问硬件设备 提供创建新进程与已 ...
- 《Linux内核设计与实现》Chapter 18 读书笔记
<Linux内核设计与实现>Chapter 18 读书笔记 一.准备开始 一个bug 一个藏匿bug的内核版本 知道这个bug最早出现在哪个内核版本中. 相关内核代码的知识和运气 想要成功 ...
- LINUX内核设计与实现第三周读书笔记
LINUX内核设计与实现第三周读书笔记 第一章 LINUX内核简介 1.1 Unix的历史 1969年的夏天,贝尔实验室的程序员们在一台PDR-7型机上实现了Unix这个全新的操作系统. 1973年, ...
- 《Linux内核设计与实现》Chapter 2 读书笔记
<Linux内核设计与实现>Chapter 2 读书笔记 一.获取内核源码 1.使用Git 我们曾经在以前的学习中使用过Git方法 $ git clone git://git.kernel ...
- Linux内核设计与实现 第五章
1. 什么是系统调用 系统调用就是用户程序和硬件设备之间的桥梁. 用户程序在需要的时候,通过系统调用来使用硬件设备. 系统调用的存在意义: 1)用户程序通过系统调用来使用硬件,而不用关心具体的硬件设备 ...
- Linux内核设计与实现第十周读书笔记
第十七章 设备与模块 关于设备驱动与设备管理,我们讨论四种内核成分. 设备类型 模块 内核对象 sysfs 17.1设备类型 在Linux以及所有Unix系统中,设备被分为以下三种类型: 块设备,块设 ...
随机推荐
- Beta阶段总结博客
Beta阶段的规划 1.完善并做完阿尔法版本 2.美化界面 3.规格化GIt的使用 4.新增登录注册功能 5.与服务器端有了交互,实现了前后端的对接 6.增加了一些特效 7.每个人分了模块并且最后对于 ...
- Alpha冲刺报告(5/12)(麻瓜制造者)
今日已完成 明日计划 部分api示意图 燃尽图 scrum会议照片 今日已完成 邓弘立: 完成部分首页逻辑功能 符天愉: 写代码写着写着想起来昨天的登录接口有个非常zz的逻辑错误,今天修改完后应该没有 ...
- vue-devtoools 调试工具安装
最近在研究vue单页面应用,一步一步用上全家桶,开发避免不了的就是调试工具,因为vue是进行数据驱动的,单从chrome里面进行element查看,查不到什么鸟东西,必须要进行对数据动向进行关查,那我 ...
- python第二十七课——os模块
演示os模块中常用的属性和函数: 1.os模块: 作用:管理文件和目录 属性: os.name:返回系统类型 常用的windows系统 --> nt os.environ:返回当前系统所有的环境 ...
- 使用react-navigation时报错:undefined is not an object (evaluating rngesturehandlermodule.direction)
问题: 使用react-navigation时报错:undefined is not an object (evaluating rngesturehandlermodule.direction). ...
- PRML5-神经网络(2)
本节来自<pattern recognition and machine learning>第5章. 接(PRML5-神经网络(1)) 5.5NN中的正则化 NN的输入层和输出层的单元个数 ...
- jqgrid 滚动分页
有时,我们不想在底部显示分页信息,而是通过用户滚动鼠标,当鼠标滚到到底自动加载下一页数据,再滚动再加载直至数据全部加载完毕.如何配置? 设置 scroll:true emptyrecords用于在 ...
- Hadoop、Yarn和vcpu资源的配置
转载自:https://www.cnblogs.com/S-tec-songjian/p/5740691.html Hadoop YARN同时支持内存和CPU两种资源的调度(默认只支持内存,如果想进 ...
- Exp2 MAL_后门原理与实践 20155214
目录 Exp2 MAL_后门原理与实践 实验内容 通过nc反向连接创建后门 meterpreter应用 主要思路 知识点 启发 Exp2 MAL_后门原理与实践 本次实验操使用nc实现win,mac, ...
- C# event线程安全
突然想到有关C#中使用event特性时关于线程安全的问题,以前虽然有遵从“复制引用+null判断”的模式(盲目地),但没有深入了解和思考. 为之查询了资料和实验,对此有了进一步的理解. 一般event ...