2017-2018-1 20179205《Linux内核原理与设计》第三周作业
《Linux内核原理与分析》第三周作业
教材学习总结
第三章 进程管理
进程是Unix操作系统抽象概念中最基本的一种,是正在执行的程序代码的实时结果;线程,是在进程中活动的对象。而Linux实现线程的机制非常独特,从内核的角度来说,它并没有线程的概念。Linux把所有的线程都当作进程来实现。在进程的创建中,Unix分解到两个单独的函数中去执行:fork()和exec(),Linux的fork()使用写时拷贝(copy-on-write)页实现。最后,内核释放它所占有的资源,在进程调用exit(),进程终结。
第五章 系统调用
系统调用在用户空间进程和硬件设备之间添加了一个中间层,为用户空间提供了一种硬件的抽象借口,系统调用保证了系统的稳定和安全。应用程序通过在用户空间实现的应用编程接口(API)而不是直接通过系统调用来编程,因为应用程序使用的这种编程接口实际上并不需要和内核提供的系统调用对应。要访问系统调用(syscall),通常通过C库中定义的函数调用来进行。在Linux中,每个系统调用被赋予一个独一无二的系统调用号,来关联系统调用。在参数验证中,为了向用户空间读取数据,内核提供了copy_from_user();为了从用户空间读取数据,内核提供了copy_from_user(),同样都需要三个参数。最后一项检查针对是否有合法权限,调用者可以使用capable()函数来检查是否有权能对指定的资源进行操作,如果返回非0值,调用者就有权进行操作,返回0则无权操作。在系统调用上下文中,内核在执行系统调用的时候处于新城上下文,current指针指向当前任务。通常,系统调用靠C库支持。用户程序通过包含标准头文件并和C库链接,就可以使用系统调用。
视频学习总结
计算机工作的三大法宝:
存储结构计算机、函数调用堆栈和中断机制
堆栈相关的寄存器
-esp 堆栈指针,指向栈顶
-ebp 基址指针,指向指针
-push 栈顶地址减少4个字节(32位)
-pop 栈顶地址增加4个字节(由高地址向低地址增加)
其他关键寄存器
-cs:eip: 总是指向下一条的指令地址
call:将当前的cs:eip的值压入栈顶,cs:eip指向调用函数的入口地址
ret:从栈顶弹出来原来保存子啊这里的cs:eip的值,放入cs:eip中
深入理解函数调用堆栈的工作机制:
//建立被调用者函数的堆栈框架
push %ebp
movl %esp,%ebp
//被调用者函数体
//do sth
...
//拆除被调用者函数的堆栈框架
movl %ebp, %esp
popl %ebp
ret
C代码中嵌入汇编代码
内嵌汇编语法
asm(
汇编语句模板:
输出部分:
输入部分);
格式为:
asm("statements":output_regs:input_regs:clobbered_regs);
实验操作:
使用实验楼的虚拟机打开shell,通过cd LinuxKernel/linux-3.9.4
qemu -Kernel arch/x86/boot/bzImage 打开程序执行结果:

之后通过cd mykernel 可以看到qemu窗口输出的内容的myinterrupt.c

以及mymain.c

简单的操作系统内核源代码分析
在mykernel基础上构造一个简单的操作系统内核
struct Thread { //Thread 用来储存ip和sp
unsigned long ip;
unsigned long sp;
};
typedef struct PCB{
int pid; //进程的id号
volatile long state; //进程的状态
char stack[KERNEL_STACK_SIZE]; //内核堆栈
struct Thread thread; //Thread 结构体
unsigned long task_entry; //进程的起始入口
struct PCB *next; //指向下一个进程的指针
}tPCB;
void my_schedule(void); //函数执行的调度器
2017-2018-1 20179205《Linux内核原理与设计》第三周作业的更多相关文章
- 2017-2018-1 20179205《Linux内核原理与设计》第九周作业
<Linux内核原理与设计>第九周作业 视频学习及代码分析 一.进程调度时机与进程的切换 不同类型的进程有不同的调度需求,第一种分类:I/O-bound 会频繁的进程I/O,通常会花费很多 ...
- 2017-2018-1 20179205《Linux内核原理与设计》第二周作业
<Linux内核原理与分析>第二周作业 本周视频学习情况: 通过孟老师的视频教程,大致对风诺依曼体系结构有了一个初步的认识,视频从硬件角度和程序员角度对CPU和Main Memory(内存 ...
- 20169212《Linux内核原理与分析》第二周作业
<Linux内核原理与分析>第二周作业 这一周学习了MOOCLinux内核分析的第一讲,计算机是如何工作的?由于本科对相关知识的不熟悉,所以感觉有的知识理解起来了有一定的难度,不过多查查资 ...
- 20169210《Linux内核原理与分析》第二周作业
<Linux内核原理与分析>第二周作业 本周作业分为两部分:第一部分为观看学习视频并完成实验楼实验一:第二部分为看<Linux内核设计与实现>1.2.18章并安装配置内核. 第 ...
- 2018-2019-1 20189221 《Linux内核原理与分析》第九周作业
2018-2019-1 20189221 <Linux内核原理与分析>第九周作业 实验八 理理解进程调度时机跟踪分析进程调度与进程切换的过程 进程调度 进度调度时机: 1.中断处理过程(包 ...
- 2017-2018-1 20179215《Linux内核原理与分析》第二周作业
20179215<Linux内核原理与分析>第二周作业 这一周主要了解了计算机是如何工作的,包括现在存储程序计算机的工作模型.X86汇编指令包括几种内存地址的寻址方式和push.pop.c ...
- 2019-2020-1 20199329《Linux内核原理与分析》第九周作业
<Linux内核原理与分析>第九周作业 一.本周内容概述: 阐释linux操作系统的整体构架 理解linux系统的一般执行过程和进程调度的时机 理解linux系统的中断和进程上下文切换 二 ...
- 2019-2020-1 20199329《Linux内核原理与分析》第二周作业
<Linux内核原理与分析>第二周作业 一.上周问题总结: 未能及时整理笔记 Linux还需要多用 markdown格式不熟练 发布博客时间超过规定期限 二.本周学习内容: <庖丁解 ...
- 2019-2020-1 20209313《Linux内核原理与分析》第二周作业
2019-2020-1 20209313<Linux内核原理与分析>第二周作业 零.总结 阐明自己对"计算机是如何工作的"理解. 一.myod 步骤 复习c文件处理内容 ...
- 2017-2018-1 20179205《Linux内核原理与设计》第四周作业
<Linux内核原理与分析> 视频学习及实验操作 Linux内核源代码 视频中提到了三个我们要重点专注的目录下的代码,一个是arch目录下的x86,支持不同cpu体系架构的源代码:第二个是 ...
随机推荐
- java数组相等
java中数组相等判断: 1.最常规的是遍历 public static boolean arrayEquals(String[] a,String[] b){ boolean flag = fals ...
- MVC绕过登陆界面验证时HttpContext.Current.User.Identity.Name取值为空问题解决方法
Global.asax界面添加如下方法: void FormsAuthentication_Authenticate(object sender, FormsAuthenticationEventAr ...
- 升级到EFCore2.0
EF Core 2.0上周已经发布了 文章内容基于vs2017,请大家先安装好vs2017(15.3). 本篇文章主要讲下差异点,跟之前一样的就不再重复了. 文章目录(差异点): 一.新建项目, EF ...
- Access Denied for user root @localhost 解决方案
问题描述: C:\Users\bo.wang> mysql -u root -p Enter password: ERROR 1045 (28000): Access denied for us ...
- 【bzoj2763】[JLOI2011]飞行路线 分层图最短路
题目描述 Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为0到n-1,一共有m种航线,每种航线连接两个城市,并且航线有一定的 ...
- P1120 小木棍 [数据加强版](poj 1011)
题目描述 乔治有一些同样长的小木棍,他把这些木棍随意砍成几段,直到每段的长都不超过50. 现在,他想把小木棍拼接成原来的样子,但是却忘记了自己开始时有多少根木棍和它们的长度. 给出每段小木棍的长度,编 ...
- Dom-直接 /间接选择器
Dom:Document Object Model的缩写, 把html转换成了文本对象. 1. 直接选择器 1.直接查找 document.getElementById 根据ID获取一个标签 docu ...
- Elasticsearch cat Apis
1._cat列入所有有效命令 GET /_cat 返回:有个猫...所以不难想象为啥是cat api =^.^= /_cat/allocation /_cat/shards /_cat/shards/ ...
- [LOJ #2473] [九省联考2018] 秘密袭击coat
题目链接 洛谷. LOJ,LOJ机子是真的快 Solution 我直接上暴力了...\(O(n^2k)\)洛谷要\(O2\)才能过...loj平均单点一秒... 直接枚举每个点为第\(k\)大的点,然 ...
- ubuntu安装记录——安装作业部落cmd markdown
安装这个折腾了一个多小时,,,, 表示是因为印象笔记没有markdown才买的作业部落cmd markdown的会员,,,,然而刚刚随意一看发现印象笔记出markdown了,,,,, 还是记录一下安装 ...