基于Linux-3.9.4的mykernel实验环境的极简内核分析
382 + 原创作品转载请注明出处 + https://github.com/mengning/linuxkernel/
一、实验环境
win10 -> VMware -> Ubuntu16.04 -> QEMU -> linux-3.9.4
二、实验目的
1、了解在一个极简内核中,为了实现多进程的切换,需要哪些必要的数据结构;
2、了解对于一个OS来说,进程是如何启动以及如何基于时间片轮转对进程进行切换。
三、实验结果

图 1 实验结果
四、代码分析
(1) 对应的PCB(进程控制块)
为了能够实现进程的切换和正常运行,对于每一个进程,都需要有一些必要的资源、参数。比如,对应进程的唯一标识(pid)、进程的状态(state)、每一个进程对应的堆栈(stack)、进程的入口地址(entry)、指向进程队列中位于当前进程的下一进程指针(pnext)等等。

图 2 PCB结构体定义

图 3 进程切换的大致流程图
(2)进程切换的逻辑分析
具体来讲,对于进程的上下文切换,需要在平常的C代码之间嵌入一些必要的汇编代码,以保存将要被替换的进程的相关信息(现场)以及执行下一的进程,对于新的进程,也并非是从头开始执行(第一次执行除外),而是从上一次被中断的地方继续开始执行。

图 4 进程切换中实现进程间上下文切换的汇编代码
(3)极简内核的整体流程分析

图 5 极简内核整体运行流程图
在个人看来,该极简内核的运行在本质上是一个死循环,在这个死循环中,基于固定时间片轮转思想,修改进程切换标志,在该死循环中查询进程切换标志,如果符合要求,则进行进程的切换,否则继续执行当前进程,不进行进程切换。当然,这个死循环,是由内核中的0号进程触发。0号进程是内核启动起来,经过相应的初始化之后,执行的第一个进程。

图 6 my_start_kernel中对0号进程的初始化
· 
图 7 my_start_kernel中对进程链表的初始化(包括PCB初始化)

图 8 my_start_kernel中执行的第一个进程(0号进程)

图 9 时间片的实现(系统时钟中断

图 10 0号进程死循环查询是否执行进程切换
四、总结
通过分析实验代码,比较清楚地了解一个简单的时间片轮转多道操作系统内核,了解了操作系统的中断上下文和进程上下文切换。对于当前执行的进程来说,如果被分配到的时间片执行完,CPU 则会进行相应的进程切换。其中的调度程序,就是在维护一个就绪进程队列,当进程用完属于它的时间片后,在队列中就会按照优先级重新排序。这种调度方式,应该是属于一种比较简单、公平同时也是比较高效的方式。
基于Linux-3.9.4的mykernel实验环境的极简内核分析的更多相关文章
- 基于七牛云对象存储,搭建一个自己专属的极简Web图床应用(手摸手的注释讲解核心部分的实现原理)
一个极简的Web图床应用,支持复制粘贴与拖拽上传图片 1.开发缘由 日常使用Vs Code编写markdown笔记与博客文章时,在文章中插入图片时发现非常不便 使用本地文件编写相对路径---没法直接复 ...
- [Android] 基于 Linux 命令行构建 Android 应用(七):自动化构建
本章将演示如何基于 Linux 命令行构建 Android 应用,在开始本章之前,希望你已经阅读之前几章内容. 本文环境为 RHEL Sandiego 32-bits,要基于 Linux CLI 构建 ...
- Linux内核分析——第八周学习笔记20135308
第八周 进程的切换和系统的一般执行过程 一.进程切换的关键代码switch_to分析 1.进程调度与进程调度的时机分析 (1)进程分类 第一种分类 I/O-bound:等待I/O CPU-bound: ...
- 《Linux内核分析》第八周学习总结
<Linux内核分析>第八周学习总结 ——进程的切换和系统的一般执行过程 姓名:王玮怡 学号:20135116 ...
- Linux内核分析 笔记八 进程的切换和系统的一般执行过程 ——by王玥
一.进程切换的关键代码switch_to的分析 (一)进程调度与进程调度的时机分析 1.不同类型的进程有不同的调度需求 第一种分类: I/O-bound:频繁地进行I/O,花费很多的时间等待I/O操作 ...
- Nginx配置多个基于域名的虚拟主机+实验环境搭建+测试
标签:Linux 域名 Nginx 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://xpleaf.blog.51cto.com/9 ...
- 【MOOC EXP】Linux内核分析实验八报告
程涵 原创博客 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 进程的切换和系统的一般执行过程 知识点 ...
- “Linux内核分析”实验二报告
张文俊 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.第二周学习内 ...
- 【MOOC EXP】Linux内核分析实验二报告
程涵 原创博客 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 [操作系统是如何工作的] 教学内 ...
随机推荐
- JAVAEE 第六周
JSF 生命周期: FacesServlet 充当用户和 JSF 应用程序之间的纽带.它在明确限定的 JSF 生命周期(规定了用户请求之间的整个事件流)的范围内工作. 1. 当JSF页面上的一个事 ...
- CDN原理介绍(转)
内容分发网络(Content delivery network或Content distribution network,缩写:CDN)是指一种通过互联网互相连接的电脑网络系统,利用最靠近每位用户的服 ...
- 本地pip 源搭建起来
pip install pip2pi pip2tgz target_dir -r requirement.txt 下载想要的本地的py包 /usr/local/python3/bin/dir2pi ...
- Leet Code 3. Longest Substring Without Repeating Characters
Given a string, find the length of the longest substring without repeating characters. Examples: Giv ...
- 转载:入门Webpack,看这篇就够了
写在前面的话 阅读本文之前,先看下面这个webpack的配置文件,如果每一项你都懂,那本文能带给你的收获也许就比较有限,你可以快速浏览或直接跳过:如果你和十天前的我一样,对很多选项存在着疑惑,那花一段 ...
- 贝塞尔(Bezier) 曲线 研究
贝塞尔曲线最近经常接触到,今天研究了一下. 原理 关于它的原理,网上有很多. 1.一阶 2.二阶 3.多阶 可以看到,多阶可以慢慢降阶为一阶贝塞尔曲线. //一阶 private Vector3 Ba ...
- Swing学习1——总体概述
以下来自于JDK1.6 一.Swing学习我划分为两个方面: 一方面Swing的界面设计部分,包括相关组件类的继承关系,组件的功能用途,布局管理: 1.首先继承关系上自上而下为 java.lang.O ...
- [RESTful] 设计要素
如何设计RESTful API 资源路径(入何规划资源路径) HTTP动词(请求方式 GET/POST...) 过滤信息(分页,查询操作的时候进行信息过滤) 状态码(服务器端响应什么样的状态码) 错误 ...
- 转自CSDN-详述 Java 中的别名现象
在任何编程语言中,赋值操作都是最常见的操作之一,Java 自然也不例外.赋值时,使用赋值操作符=,它的意思是:“将等号右边的值(右值),复制给左边的值(左值)”.右值可以是任何常数.变量或者表达式(只 ...
- 运动控制之一_PID控制理论
PID算法是早期发展起来的控制算法,该算法因其简单.鲁棒性强且可靠性高而被广泛地应用于过程控制和运动控制中. 常规的PID控制系统原理框图如下所示: PID控制系统原理图 误差信号Err(t)输入到控 ...