20169211《Linux内核原理与分析》第四周作业内容列表

1、教材第3、5章节知识学习总结;

2、实验楼配套实验二实验报告;

1、《linux内核设计与实现》教材第3、5章节知识阅读学习总结

教材第3章节主要讲述了进程管理相关的知识,包括什么是进程、进程描述符及任务结构、如何创建进程、linux中线程的实现方法以及如何终结进程等。

首先,印象最深的是如何创建新的进程。在听孟老师的《linux内核分析》的课程时,曾谈到过计算机的“三大法宝”:存储程序计算机、函数调用堆栈和中断机制。针对于存储程序计算机这个特性,说一下我的理解:程序是存放在外边磁盘中的文件,为使其运行于计算机内存中,通过CPU一系列的计算而最终得到我们想要的结果的话,需要为其创建进程。那么,创建进程可以通过调研exec()这组函数为其创建新的地址空间,并把新的程序载入其中。在现代linux内核中,通常使用fork()来创建进程,而fork()实际上是clone()系统调用的实现。最终程序通过exit()系统调用退出程序的执行,也就是终结进程的生命周期。为了通过程序设计语言来描述我们提出的进程理论,需要为其创建进程描述符和相应的数据结构,下边是实验楼代码中一个PCB结构的代码:

  1. typedef struct PCB{
  2. int pid//进程描述符,唯一标识一个进程
  3. volatile long state ;
  4. char stack[KERNEL_STACK_SIZE]
  5. struct Thread thread ;
  6. unsigned long task_entry ;
  7. struct PCB *next ;
  8. } tPCB ;

其中,进程描述符中的状态域描述了进程的状态,系统中每个进程都必然处于五中状态中的一种:运行态、可中断、不可中断、跟踪态、停止。

另外,就是线程机制在现代linux内核中的实现。从内核的角度来说,linux把所有的线程都当做进程来实现。它仅被视为一个与其他进程共享某些资源的进程,可以通过clone()系统调用来创建线程。

教材第5章节主要讲述了系统调用的相关知识。为了与操作系统内核通信,应用最终需要通过系统调用来进行,而通常情况下是使用C库中定义的函数调用来进行。用户程序通过包含标准头文件并和C库连接,就可以使用系统调用。另外,linux本身提供了一些宏,用于直接对系统调用进行访问。它会设置好寄存器并调用陷入指令。例如书中给出的例子,open()系统调用的定义是:

  1. long open(const char *filename, int flags, int mode)

不靠C库的支持,而是直接通过系统调用的宏的形式:

  1. #define NR_open 5
  2. _syscall3(long, open, const char*, filename, int, flags, int, mode)

这样,应用程序就可以直接使用open()了。

2、实验楼《linux内核分析》实验二实验操作过程报告

这个实验主要涉及到两个c源程序,分别是mymain.c和myinterrupt.c。通过编写这两个源程序来实现一个简单的时间片轮转多道程序内核代码。下边,分别给出这两个源程序的代码:

mymain.c

  1. ... //硬件初始化操作所引入的头文件
  2. void _init my_start_kernel(void){
  3. int i=0 ;
  4. while(1){
  5. i++ ;
  6. if(i%100000 == 0)
  7. printk(KERN_NOTICE "my_start_kernel here %d \n", i) ;
  8. }
  9. }

myinterrupt.c

  1. #define CREATE_TRACE_POINTS
  2. #include <trace/events/timer.h>
  3. /*
  4. *Called by timer interrupt.
  5. */
  6. void my_timer_handler(void){
  7. printk(KERN_NOTICE "\n>>>>>>>>>>>>>>>>>>>");
  8. }

编写完成之后,执行mystart_kernel中的代码,执行结果如下:

分析如上程序,通过

  1. qemu -kernel arch/x86/boot/bzImage

从qemu窗口中可以看到my_start_kernel正在执行,同时my_timer_handle时钟中断处理程序在周期性的执行。

20169211《Linux内核原理与分析》第四周作业的更多相关文章

  1. 2019-2020-1 20199303<Linux内核原理与分析>第二周作业

    2019-2020-1 20199303第二周作业 1.汇编与寄存器的学习 寄存器是中央处理器内的组成部份.寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令.数据和位址.在中央处理器的控制部件中 ...

  2. 20169219 linux内核原理与分析第二周作业

    "linux内核分析"的第一讲主要讲了计算机的体系结构,和各寄存器之间对数据的处理过程. 通用寄存器 AX:累加器 BX:基地址寄存器 CX:计数寄存器 DX:数据寄存器 BP:堆 ...

  3. 2019-2020-1 20199314 <Linux内核原理与分析>第二周作业

    1.基础学习内容 1.1 冯诺依曼体系结构 计算机由控制器.运算器.存储器.输入设备.输出设备五部分组成. 1.1.1 冯诺依曼计算机特点 (1)采用存储程序方式,指令和数据不加区别混合存储在同一个存 ...

  4. 20169219linux 内核原理与分析第四周作业

    系统调用 系统调用是用户空间访问内核的唯一手段:除异常和陷入外,它们是内核唯一的合法入口. 一般情况下,应用程序通过在用户空间实现的应用编程接口(API)而不是直接通过系统调用来编程. 要访问系统调用 ...

  5. Linux内核原理与分析-第一周作业

    本科期间,学校开设过linux相关的课程,当时的学习方式主要以课堂听授为主.虽然老师也提供了相关的学习教材跟参考材料,但是整体学下来感觉收获并不是太大,现在回想起来,主要还是由于自己课下没有及时动手实 ...

  6. 2019-2020-1 20199314 <Linux内核原理与分析>第一周作业

    前言 本周对实验楼的Linux基础入门进行了学习,目前学习到实验九完成到挑战二. 学习和实验内容 快速学习了Linux系统的发展历程及其简介,学习了下的变量.用户权限管理.文件打包及压缩.常用命令的和 ...

  7. Linux内核原理与分析-第二周作业

    写之前回看了一遍秒速五厘米:如果

  8. 2018-2019-1 20189221《Linux内核原理与分析》第一周作业

    Linux内核原理与分析 - 第一周作业 实验1 Linux系统简介 Linux历史 1991 年 10 月,Linus Torvalds想在自己的电脑上运行UNIX,可是 UNIX 的商业版本非常昂 ...

  9. 2018-2019-1 20189221《Linux内核原理与分析》第四周作业

    2018-2019-1 20189221<Linux内核原理与分析>第四周作业 教材学习:<庖丁解牛Linux内核分析> 第 3 章 MenuOS的构造 计算机三大法宝:存储程 ...

随机推荐

  1. 网站访问日志User Agent对照表

    percent useragent system user_agent_string_md5 8.9% Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleW ...

  2. poi复杂excel的实现

    一:前言 最近帮一个朋友做excel的导出功能,对于我来说还是挺头疼,我看了下表格样式,对于我来说还是挺头疼的,想当年耗子刚刚出社会的时候做的第一份工作,第一份任务就是把把word转换为html,在这 ...

  3. C11工具类:字符转换

    1.数值类型和字符串转换 1.1 数值转换为字符 std::string to_string(int value); std::string to_string(long value); std::s ...

  4. 免密码登录服务器python脚本

    在自动化运维平台没有做完之前,常需要登录服务器做很多维护操作,每次找好长好长的密码,那么多服务器,你会疯掉的,所以瞎搞了以下脚本.先解一下燃眉之急,哈哈 cat login_root.exp #!/u ...

  5. 【Atcoer】ARC088 E - Papple Sort

    [题目]E - Papple Sort [题意]给定长度为n的小写字母串,只能交换相邻字母,求形成回文串的最小步数.n<=2*10^5. [算法]数学 [题解]官方题解 本题题解中有以下重要的思 ...

  6. session_write_close()的作用

    简单地说,当开启session_start以后,这个session会一直开启,并且被一个用户使用.其他用户开启session的话要等待第一个session用户关闭以后才可以开启sessio,这样就造成 ...

  7. 【leetcode 简单】第五题 最长公共前缀

    编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower","flow" ...

  8. 【文件上传】jquery之ajaxfileupload异步上传插件

    来自:http://www.blogjava.net/sxyx2008/archive/2010/11/02/336826.html 由于项目需求,在处理文件上传时需要使用到文件的异步上传.这里使用J ...

  9. Web安全的三个攻防姿势

    原文地址:https://segmentfault.com/a/1190000011601837 作者: zwwill_木羽 关于Web安全的问题,是一个老生常谈的问题,作为离用户最近的一层,我们大前 ...

  10. linux的防火墙管理

    换oricle-linux7系统后,发现iptables的管理方法有不小的改动,记录一下遇到的问题. iptables linux系统已经默认安装了iptables和firewalld两款防火墙管理工 ...