Linux 0.11源码阅读笔记-总览

阅读源码的目的

加深对Linux操作系统的了解,了解Linux操作系统基本架构,熟悉进程管理、内存管理等主要模块知识。

通过阅读教复杂的代码,锻炼自己复杂项目代码的阅读能力。对于一般简短的程序,可以从main函数逐行阅读理解;对于复杂的项目,只能在了解源码主要结构的情况下,抓住某个具体的功能进行阅读。

选择较早版本的理由

Linux较新版本代码在百万行以上,而0.11版本内核不超过2万行代码。比较新版本的Linux内核源码太多且内容庞杂,自身能力不足,没有能力阅读。早期版本的代码虽然功能简陋,但基本功能都有,属于麻雀虽小五脏俱全,对于新手来说最适合不过。

不足在于0.11版本的代码中不包含专门的进程等待队列、TCP/IP网络等方面非常重要的代码,对内存的分配和使用与先进的内核也有所区别。可以在学习0.11版本代码之后,通过较新版本源码学习。

内核结构框图

内核位于用户层与硬件层之间,向下管理底层CPU、内存、磁盘等硬件,并向上通过系统调用的方式提供服务。0.11内核主要部分包括文件子系统和进程管理子系统,进程管理子系统进一步可分为内存管理、进程调度、进程通信三个主要模块。

内核代码主要部分

代码文件从功能上可分为三类:

  • 硬件(异常)中断处理程序文件
  • 系统调用服务处理程序文件
  • 进程调度等通用功能文件

  1. 中断处理程序

主要包括两个代码文件:

  • asm.s:实现了大部分硬件中断处理程序汇编代码
  • traps.c:实现了asm.s的中断处理过程中调用的c函数,这些c函数会在中断门中注册函数地址
  1. 系统调用处理相关程序

Linux中应用程序调用内核的功能是通过中断调用int 0x80进行的,寄存器eax中放调用号,每个调用号对应一个系统调用函数。实现系统调用的相关文件包括system_call.s、fork.c、signal.c和exit.c文件。

  • system_call.s:int 80中断调用处理程序,根据系统调用号调用相应的系统调用函数
  • fork.c、signal.c、exit.c:分别包含进程fork、信号、进程exit等相关的系统调用函数代码实现
  1. 其它通用类程序

包括schedule.c、mktime.c、panic.c、printk.c和vsprintf.c。

  • schedule.c:进程调度代码
  • mktime.c:内核使用的时间函数mktime(),仅在init/main.c中被调用一次
  • panic.c:包含panic()函数,用于内核运行出现错误时显示出错信息并停机
  • printk.c、vsprintf.c:内核显示信息的支持程序。实现了内核专用显示函数printk()和字符串格式化输出函数vsprintf()

内核函数调用关系图(Linux 2.6.26)

参考

  • Linux 内核完全注释 内核版本0.11 - 赵炯

Linux 0.11源码阅读笔记-总览的更多相关文章

  1. Linux 0.11源码阅读笔记-文件管理

    Linux 0.11源码阅读笔记-文件管理 文件系统 生磁盘 未安装文件系统的磁盘称之为生磁盘,生磁盘也可以作为文件读写,linux中一切皆文件. 磁盘分区 生磁盘可以被分区,分区中可以安装文件系统, ...

  2. Linux 0.11源码阅读笔记-中断过程

    Linux 0.11源码阅读笔记-中断过程 是什么中断 中断发生时,计算机会停止当前运行的程序,转而执行中断处理程序,然后再返回原被中断的程序继续运行.中断包括硬件中断和软件中断,硬中断是由外设自动产 ...

  3. Linux 0.11源码阅读笔记-总结

    总结 Linux 0.11主要包含文件管理和进程管理两个部分.进程管理包括内存管理.进程管理.进程间通信模块.文件管理包含磁盘文件系统,打开文件内存数据.磁盘文件系统包括空闲磁盘块管理,文件数据块的管 ...

  4. Linux 0.11源码阅读笔记-块设备驱动程序

    块设备驱动程序 块设备驱动程序负责实现对块设备数据的读写功能.内核代码统一使用缓冲块间接和块设备(如磁盘)交换数据,缓冲区数据通过块设备驱动程序和块设备交换数据. 块设备的管理 块设备表 内核通过一张 ...

  5. Linux 0.11源码阅读笔记-内存管理

    内存管理 Linux内核使用段页式内存管理方式. 内存池 物理页:物理空闲内存被划分为固定大小(4k)的页 内存池:所有空闲物理页组成内存池,以页为单位进行分配回收.并通过位图记录了每个物理页是否空闲 ...

  6. Linux 0.11源码阅读笔记-文件IO流程

    文件IO流程 用户进程read.write在高速缓冲块上读写数据,高速缓冲块和块设备交换数据. 什么时机将磁盘块数据读到缓冲块? 什么时机将缓冲块数据刷到磁盘块? 函数调用关系 read/write( ...

  7. Linux 0.11源码阅读笔记-高速缓冲

    高速缓冲 概念 高速缓冲区是内存中的一块内存,在块设备与内核其它程序之间起着一个桥梁作用.内核程序如果需要访问块设备中的数据,都需要经过高速缓冲区来间接的操作. 高速缓冲区结构 高速缓冲区被划分为1k ...

  8. 【从头到脚品读 Linux 0.11 源码】第一回 最开始的两行代码

    从这一篇开始,您就将跟着我一起进入这操作系统的梦幻之旅! 别担心,每一章的内容会非常的少,而且你也不要抱着很大的负担去学习,只需要像读小说一样,跟着我一章一章读下去就好. 话不多说,直奔主题.当你按下 ...

  9. linux 0.11 源码学习+ IO模型

    http://www.cnblogs.com/Fredric-2013/category/696688.html

随机推荐

  1. Go基础知识梳理(二)

    Go基础知识梳理(二) 简单函数的定义 //有参数有返回值 func sum(a int, b int) int { return a + b } //无返回值 func sum(a int, b i ...

  2. JAVA——选择,循环,顺序控制结构

    目录 一.顺序控制 二.选择控制 2.1分支控制 2.1.1单分支 2.1.2双分支 2.1.3分支控制if-else 2.1.4嵌套分支 2.2switch分支结构 细节讨论 练习 题目1 题目2 ...

  3. JZ-012-数值的整数次方

    数值的整数次方 题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 保证base和exponent不同时为0. 题目链接: 数值的 ...

  4. ASP.NET Core 6框架揭秘实例演示[19]:数据加解密与哈希

    数据保护(Data Protection)框架旨在解决数据在传输与持久化存储过程中的一致性(Integrity)和机密性(confidentiality)问题,前者用于检验接收到的数据是否经过篡改,后 ...

  5. Python中的dotenv的详细用法

    最简单和最常见的用法是在应用程序启动时调用load_dotenv,从当前目录或其父目录中的.env文件或指定的路径加载环境变量,然后你可以调用os.getenv提供的与环境相关的方法. .env 文件 ...

  6. 【转载】深入浅出SQL Server中的死锁

    essay from:http://www.cnblogs.com/CareySon/archive/2012/09/19/2693555.html 简介 死锁的本质是一种僵持状态,是多个主体对于资源 ...

  7. Mysql 8.0 配置主从备份

    my.ini文件的位置 mysql 8.0安装完过后没有my.ini疑惑了我好久,最后发现,配置文件在,C盘的一个隐藏文件夹里面 具体路径如下图 主库配置 修改主库INI文件 在[mysqld]节点添 ...

  8. springboot Redistemplate的execute和 executePipelined

    springboot 的 RedisTemplate 的 execute 和 executePipelined 功能的区别 1.execute 以下是 springboot 官网原文: Redis p ...

  9. 《手把手教你》系列基础篇(七十八)-java+ selenium自动化测试-框架设计基础-TestNG依赖测试- 中篇(详解教程)

    1.简介 上一篇讲解了依赖测试的各种方法,今天继续讲解依赖测试的方法,这一篇主要是讲解和分享通过xml文件配置组名依赖方法( 主要是测试组的用法).废话不说,直接上干货. 2.实例 测试组:一个组可包 ...

  10. 硬吃一个P0故障,「在线业务」应该如何调优HBase参数?

    1.背景 由于种种原因,最近将核心业务生产使用的HBase迁移到了云上的弹性MapReduce(EMR)集群上,并使用了EMR的HBase组件默认参数配置. 结果在流量高峰期出现了宿主机故障,挂掉了两 ...