《Linux内核设计与实现》课本学习笔记

By20135203齐岳

一、Linux内核简介

Unix内核的特点

  • Unix很简洁,所提供的系统调用都有很明确的设计目的。
  • Unix中一切皆文件,对数据和设备的操作都是通过一套相同的系统调用接口进行的。
  • Unix内核和相关的系统工具都是用C语言编写成的。
  • Unix进程创建非常迅速。
  • Unix提供了一套简单而稳定的进程间通信原语。

Unix现在已经发展为一个支持抢占式多任务、多线程、虚拟内存、换页、动态链接和TCP/IP网络的现代化操作系统。

操作系统与内核

操作系统是计算机完成基本功能和系统管理的核心,内核是操作系统的核心。在系统中运行的应用程序通过系统调用来与内核通信。

内核提供的服务主要有:

  • 中断服务程序,负责响应响应中断
  • 调度程序,负责管理多个进程从而分配处理器轮转时间
  • 内存管理程序,管理进程地址空间
  • 网络、进程间通信等系统服务

Linux与Unix的联系

  • Linux是类Unix系统,但不是Unix,也没有直接使用Unix的源代码。
  • Linux内核是自由公开的软件,开源。
  • Linux是单内核,但汲取了微内核的精华:模块化设计、抢占式内核、支持内核线程以及动态装载内核模块的能力。

单内核与微内核

  • 单内核:内核通常以单个静态二进制文件的形式存放于磁盘中所有内核服务都运行在内核态并身处同一地址空间,内核可以直接调用函数。特点是简单,性能高。

  • 微内核:不同的功能被划分为独立的过程,每个过程叫做一个服务器,通过消息传递处理微内核通信,采用了进程间通信(IPC)机制。

二、内核源代码

获取内核源代码

使用Git来获取最新版本源代码:

$ git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git

更新到Linux的最新分支:

$ git pull

解压并安装内核源代码:

$ tar xvjf linux-x.y.z.tar.bz2/gz

使用补丁:

$ patch -p1 < ../patch-x.y.z

注意:内核源码一般都安装在/usr/src/linux目录下,但不能把这个源码树用于内核开发,或者以root身份对内核进行修改。

内核源码树

三、编译内核

配置内核

Linux中可以配置的选项其前缀均为CONFIG。

配置项二选一:yes 或 no

配置项三选一:yes 、no 或 module(以模块形式生成,为独立代码段)

简化内核配置工具:

  • 字符界面下的Linux工具:逐一遍历所有的配置项,要求用户逐一选择,耗时长。

      $ make config
  • 基于ncurse库编制的图形界面工具:

      $ make menuconfig
  • 基于gtk+的图形工具:

      $ make gconfig
  • 基于默认配置为体系结构创建一个配置:

      $ make defconfig
  • 验证和更新配置:

      $ make oldconfig

一旦内核配置好,就可以利用一个简单的命令来编译它。

	$ make

减少编译的垃圾信息

尽量减少垃圾信息的方法:对输出进行重定向。

	$ make > .. /detritus  将输出信息重定向到这个文件目录
$ make > /dev/null 把无用的输出信息重定向到永无返回值的黑洞/dev/null

衍生多个编译作业

以多个作业编译内核:

$ make jn  n为要衍生出的作业数,每个处理器可以衍生出1或2个作业,16核时n可取32

安装新内核

$ make modules_install

编译时会在内核代码目录树的根目录下创建一个System.map文件,为符号对照表,用于将内核符号和他们的起始地址对应起来,方便调试。

四、内核开发特点

无libc库或标准头文件

大部分常用的C库函数在内核中都已经得到实现,只要包含<linux/string.h>文件就可以使用它们。

GUN C

内联函数

内联函数的工作模式:函数会在它所调用的位置上展开,可以消除函数调用和返回所带来的开销(寄存器存储和恢复)。但是代码会变长,占用更多的内存空间或者缓存指令。

定义一个内联函数的时候需要使用static作为关键字并用inline限定,并且必须在使用之间就定义好。

static inline void wolf(unsigned long tail_size)
内联汇编

gcc编译器支持在C函数中嵌入汇编指令。通常使用asm()指令嵌入汇编代码。

分支声明

对于条件选择语句,在一个条件经常出现或很少出现的时候,编译器可以根据这条指令对条件分支进行选择优化。并将其封装成宏,如likely()和unlikely()。

  • 将一个选择标记成绝少发生的分支:

      /*error绝大多数时间都会为0*/
    if(unlikely(error)){
    ...
    }
  • 将一个分支标记为通常为真的分支:

      /*success通常都不会为0*/
    if(likely(success)){
    ...
    }

没有内存保护机制

  • 内核中发生内存错误会导致oops。访问非法地址或引用空指针可能会造成死机。
  • 内核中所有的内存都不分页。每使用一个字节,物理内存就减少一个字节。

同步和并发

内核很容易产生竞争条件,许多性能要求并发地共享访问数据。通常解决竞争的办法是自旋锁和信号量

  • Linux是抢占式多任务操作系统。
  • Linux内核支持对称处理器系统(SMP)。
  • 中断是异步到来的,完全不考虑当前正在执行的代码。
  • Linux内核可以抢占。

《Linux内核设计与实现》课本第一章&第二章学习笔记的更多相关文章

  1. 《Linux内核设计与实现》第一、二章学习笔记

    <Linux内核设计与实现>第一.二章学习笔记 姓名:王玮怡  学号:20135116 第一章 Linux内核简介 一.关于Unix ——一个支持抢占式多任务.多线程.虚拟内存.换页.动态 ...

  2. 《LINUX内核设计与实现》第一、二章学习总结

    第一章 Linux内核简介 (一)Unix是一个强大.健壮和稳定的操作系统,特点是: Unix很简洁,仅仅提供几个几百个系统调用并且有一个非常明确的设计目的 在Unix中,所有的东西都被当作文件对待, ...

  3. 《Linux内核设计与实现》 第一、二章学习笔记

    第一章 Linux内核简介 一.Unix 1.Unix的特点 简洁 绝大部分东西都被当做文件对待.这种抽象使对数据和对设备的操作都是通过一套相同的系统调用借口来进行的:open(),read(),wr ...

  4. 《Linux内核设计与实现》 第一二章学习笔记

    <Linux内核设计与实现> 第一二章学习笔记 第一章 Linux内核简介 1.1 Unix的历史 Unix的特点 Unix很简洁,所提供的系统调用都有很明确的设计目的. Unix中一切皆 ...

  5. linux及安全《Linux内核设计与实现》第一章——20135227黄晓妍

    <linux内核设计与实现>第一章 第一章Linux内核简介: 1.3操作系统和内核简介 操作系统:系统包含了操作系统和所有运行在它之上的应用程序.操作系统是指整个在系统中负责完成最基本功 ...

  6. 《Linux内核设计与实现》第一二章笔记

    第一章 linux内核简介 每个处理器在任何时间点上的活动必然概括为下列三者: 运行于用户空间,执行用户进程 运行于内核空间,处于进程上下文,代表某个特定的进程执行 运行于内核空间,处于中断上下文,与 ...

  7. linux内核设计的艺术--系统启动第一步

    计算机究竟是如何执行起来的呢,在我学习计算机的时候一直不是非常明确,可是近期借了本<linux内核设计的艺术>算是知道了计算机从按开机到启动操作系统之间究竟做了些什么. 这本书刚開始介绍的 ...

  8. 《linux内核设计与实现》第一章

    第一章Linux内核简介 一.unix 1.Unix的历史 Unix是现存操作系统中最强大和最优秀的系统. ——1969年由Ken Thompson和Dernis Ritchie的灵感点亮的产物. — ...

  9. 《Linux内核设计与实现》第一二章读书笔记

    第一章 Linux内核简介 1.Unix简介 (一)概念:支持抢占式多任务.多进程.虚拟内存.换页.动态链接和TCP/IP网络的现代化操作系统. (二)Unix特点(层次化结构): Unix很简洁,仅 ...

  10. 【读书笔记】Linux内核设计与实现(第一章&第二章)

    http://pan.baidu.com/s/1hqYAZNQ OneNote做的笔记没法儿带着格式一起导进来.所以上传到百度云,麻烦老师下载一下了. 下次不再用OneNote.

随机推荐

  1. wampserver-----------如何设置wampserver在windows下开机自动启动。

    虽然很简单,但是还是做个记录.我的习惯,还是看图: 到你电脑的服务里面找到这两项然后点击右键属性,设置为自动.

  2. mongo的安装

    windows: 1 安装scons (1): 下载python2.7, 使用x86_32位,因为scons只有32位安装包可用, http://www.python.org/download/rel ...

  3. python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息,抓取政府网新闻内容

    python3.4学习笔记(十三) 网络爬虫实例代码,使用pyspider抓取多牛投资吧里面的文章信息PySpider:一个国人编写的强大的网络爬虫系统并带有强大的WebUI,采用Python语言编写 ...

  4. wex5 教程 之 图文讲解 bind-css和bind-sytle的异同

    wex5作为网页开发利器,在前台UI数据交互设计中大量使用了绑定技术,即官方视频教学中也提到了KO,实质是数据绑定与追踪.在前台组件的属性中,为我们提供了两个重要的样式绑定属性,bind-css和bi ...

  5. Java学习第三天160818 表单 框架 下拉列表等

    rect 矩形  src 引用 width宽  height  高  iframe  网页内嵌式小窗口(成对出现) auto  自动的  frameborder  边线  scrolling  滚动条 ...

  6. 两个img之间出现间隙的解决方法

    今天写了个小页面,发现了一个问题,两个包在a标签里的img之间总是有间隙,不能挨在一起,最后在同事的帮助下,找到解决的办法是,设置img的基线,css代码如下: img{vertical-align: ...

  7. 右值引用、move与move constructor

    http://blog.chinaunix.net/uid-20726254-id-3486721.htm 这个绝对是新增的top特性,篇幅非常多.看着就有点费劲,总结更费劲. 原来的标准当中,参数与 ...

  8. JAVA基础知识之JDBC——使用ResultSetMetaData分析结果集

    通过ResultSetMetaData可以对ResultSet进行分析,获取ResultSet里包含了哪些数据列,以及每个列的数据类型. ResultSet中包含了一个getMetaData()方法, ...

  9. C++提前delete

    ////////////////////////////////////// ///类析构以后,成员变量内存空间释放, ///函数 和 变量 还是可以引用的 ///////////////////// ...

  10. 使用Python一步一步地来进行数据分析总结

    原文链接:Step by step approach to perform data analysis using Python译文链接:使用Python一步一步地来进行数据分析--By Michae ...