20169211《Linux内核原理与分析》第四周作业
20169211《Linux内核原理与分析》第四周作业内容列表
1、《linux内核设计与实现》教材第3、5章节知识阅读学习总结
教材第3章节主要讲述了进程管理相关的知识,包括什么是进程、进程描述符及任务结构、如何创建进程、linux中线程的实现方法以及如何终结进程等。
首先,印象最深的是如何创建新的进程。在听孟老师的《linux内核分析》的课程时,曾谈到过计算机的“三大法宝”:存储程序计算机、函数调用堆栈和中断机制。针对于存储程序计算机这个特性,说一下我的理解:程序是存放在外边磁盘中的文件,为使其运行于计算机内存中,通过CPU一系列的计算而最终得到我们想要的结果的话,需要为其创建进程。那么,创建进程可以通过调研exec()这组函数为其创建新的地址空间,并把新的程序载入其中。在现代linux内核中,通常使用fork()来创建进程,而fork()实际上是clone()系统调用的实现。最终程序通过exit()系统调用退出程序的执行,也就是终结进程的生命周期。为了通过程序设计语言来描述我们提出的进程理论,需要为其创建进程描述符和相应的数据结构,下边是实验楼代码中一个PCB结构的代码:
typedef struct PCB{
int pid;//进程描述符,唯一标识一个进程
volatile long state ;
char stack[KERNEL_STACK_SIZE] ;
struct Thread thread ;
unsigned long task_entry ;
struct PCB *next ;
} tPCB ;
其中,进程描述符中的状态域描述了进程的状态,系统中每个进程都必然处于五中状态中的一种:运行态、可中断、不可中断、跟踪态、停止。
另外,就是线程机制在现代linux内核中的实现。从内核的角度来说,linux把所有的线程都当做进程来实现。它仅被视为一个与其他进程共享某些资源的进程,可以通过clone()系统调用来创建线程。
教材第5章节主要讲述了系统调用的相关知识。为了与操作系统内核通信,应用最终需要通过系统调用来进行,而通常情况下是使用C库中定义的函数调用来进行。用户程序通过包含标准头文件并和C库连接,就可以使用系统调用。另外,linux本身提供了一些宏,用于直接对系统调用进行访问。它会设置好寄存器并调用陷入指令。例如书中给出的例子,open()系统调用的定义是:
long open(const char *filename, int flags, int mode)
不靠C库的支持,而是直接通过系统调用的宏的形式:
#define NR_open 5
_syscall3(long, open, const char*, filename, int, flags, int, mode)
这样,应用程序就可以直接使用open()了。
2、实验楼《linux内核分析》实验二实验操作过程报告
这个实验主要涉及到两个c源程序,分别是mymain.c和myinterrupt.c。通过编写这两个源程序来实现一个简单的时间片轮转多道程序内核代码。下边,分别给出这两个源程序的代码:
mymain.c
... //硬件初始化操作所引入的头文件
void _init my_start_kernel(void){
int i=0 ;
while(1){
i++ ;
if(i%100000 == 0)
printk(KERN_NOTICE "my_start_kernel here %d \n", i) ;
}
}
myinterrupt.c
#define CREATE_TRACE_POINTS
#include <trace/events/timer.h>
/*
*Called by timer interrupt.
*/
void my_timer_handler(void){
printk(KERN_NOTICE "\n>>>>>>>>>>>>>>>>>>>");
}
编写完成之后,执行mystart_kernel中的代码,执行结果如下:

分析如上程序,通过
qemu -kernel arch/x86/boot/bzImage
从qemu窗口中可以看到my_start_kernel正在执行,同时my_timer_handle时钟中断处理程序在周期性的执行。
20169211《Linux内核原理与分析》第四周作业的更多相关文章
- 2019-2020-1 20199303<Linux内核原理与分析>第二周作业
2019-2020-1 20199303第二周作业 1.汇编与寄存器的学习 寄存器是中央处理器内的组成部份.寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令.数据和位址.在中央处理器的控制部件中 ...
- 20169219 linux内核原理与分析第二周作业
"linux内核分析"的第一讲主要讲了计算机的体系结构,和各寄存器之间对数据的处理过程. 通用寄存器 AX:累加器 BX:基地址寄存器 CX:计数寄存器 DX:数据寄存器 BP:堆 ...
- 2019-2020-1 20199314 <Linux内核原理与分析>第二周作业
1.基础学习内容 1.1 冯诺依曼体系结构 计算机由控制器.运算器.存储器.输入设备.输出设备五部分组成. 1.1.1 冯诺依曼计算机特点 (1)采用存储程序方式,指令和数据不加区别混合存储在同一个存 ...
- 20169219linux 内核原理与分析第四周作业
系统调用 系统调用是用户空间访问内核的唯一手段:除异常和陷入外,它们是内核唯一的合法入口. 一般情况下,应用程序通过在用户空间实现的应用编程接口(API)而不是直接通过系统调用来编程. 要访问系统调用 ...
- Linux内核原理与分析-第一周作业
本科期间,学校开设过linux相关的课程,当时的学习方式主要以课堂听授为主.虽然老师也提供了相关的学习教材跟参考材料,但是整体学下来感觉收获并不是太大,现在回想起来,主要还是由于自己课下没有及时动手实 ...
- 2019-2020-1 20199314 <Linux内核原理与分析>第一周作业
前言 本周对实验楼的Linux基础入门进行了学习,目前学习到实验九完成到挑战二. 学习和实验内容 快速学习了Linux系统的发展历程及其简介,学习了下的变量.用户权限管理.文件打包及压缩.常用命令的和 ...
- Linux内核原理与分析-第二周作业
写之前回看了一遍秒速五厘米:如果
- 2018-2019-1 20189221《Linux内核原理与分析》第一周作业
Linux内核原理与分析 - 第一周作业 实验1 Linux系统简介 Linux历史 1991 年 10 月,Linus Torvalds想在自己的电脑上运行UNIX,可是 UNIX 的商业版本非常昂 ...
- 2018-2019-1 20189221《Linux内核原理与分析》第四周作业
2018-2019-1 20189221<Linux内核原理与分析>第四周作业 教材学习:<庖丁解牛Linux内核分析> 第 3 章 MenuOS的构造 计算机三大法宝:存储程 ...
随机推荐
- Splay 区间操作(二)
首先基本操作如下: 删除第rank个点 void Remove(int id){//删除第rank个点 rank++; int x = find(root, rank - 1); splay(x, 0 ...
- struts标签错误:Can not find the tag library descriptor for "http://java.sun.com/jsp/jstl/core"
今天使用eclipse开发ssh,出现Can not find the tag library descriptor for "http://java.sun.com/jsp/jstl/co ...
- Google Map API使用详解(一)——Google Map开发背景知识
一.谷歌地图主页 谷歌地图对应不同的地区都会有一些专门的主页,首次登陆时会显示这些地区.比如,香港的:http://maps.google.com.hk,台湾的:http://maps.google. ...
- 维护后面的position sg函数概念,离线+线段 bzoj 3339
3339: Rmq Problem Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 1160 Solved: 596[Submit][Status][ ...
- 【BZOJ】4033: [HAOI2015]树上染色 树上背包
[题目]#2124. 「HAOI2015」树上染色 [题意]给定n个点的带边权树,要求将k个点染成黑色,使得 [ 黑点的两两距离和+白点的两两距离和 ] 最大.n<=2000. [算法]树上背包 ...
- 【CodeForces】704 C. Black Widow 动态规划+模拟
[题目]C. Black Widow [题意]给定一个表达式,形式为(...)^(...)^......^(...)=1(n个括号),括号中为1~2个值取或.有m个变量,给出表达式的值为xi或 !xi ...
- 2017ACM暑期多校联合训练 - Team 6 1008 HDU 6103 Kirinriki (模拟 尺取法)
题目链接 Problem Description We define the distance of two strings A and B with same length n is disA,B= ...
- 组合数+逆元 A - Chat Group Gym - 101775A
题目链接:https://cn.vjudge.net/contest/274151#problem/A 具体思路:我们可以先把所有的情况算出来,为2^n.然后不合法的情况减去就可以了.注意除法的时候要 ...
- OGG相关操作
参数文件详解: 1)truncate ogg 进程: Manager进程:manager进程是配置在源端和目标端 Extract(抽取)进程:部署在源端,用于捕获数据表或者日志中的数据文件: Pump ...
- easyui datagrid 去掉 全选checkbox
在加载 表格的时候添加事件:onLoadSuccess 在事件中写入下面句,用空代替原有HTML 达到取消效果. $(".datagrid-header-check").html( ...