1.获取内核源码

1.1Git

分布式的;下载和管理Linux内核源代码;

- 获取最新提交到版本树的一个副本

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

- 下载代码后,更新自己的分支到最新分支

$ git pull

1.2安装内核源代码

- 压缩形式为bzip2

运行:$ tar xvjf linux-x.y.z.tar.bz2

- 压缩形式为zip

运行:$ tar xvzf linux-x.y.z.tar.gz

- 注释(xvjf、xvzf):

-x 解开;

-v 显示详细信息;

-j 使用bzip2程序;

-z 使用gzip程序;

-f 使用归档文件;

1.3使用补丁

- 从内部源码树开始

运行$ patch -p1 < ../patch-x,y,z

2.内核源码树

……这个……还是看书吧

3.编译内核

3.1配置内核

- 配置选项(指定内核源码可以访问的值,一般以预处理宏的形式表示)

1.决定哪些文件编译进内核;通过预处理命令处理代码。

2.二选一:yes/no

3.三选一:yes(把代码编译进主内核映像中)/no/module(该配置项被选定了)【驱动程序一般是三选一】

4.可以是字符串或整数

- 配置工具:

$ make config 配置命令解释器,最简单的一个字符界面下的命令行工具;

$ make menuconfig 配置用户界面,基于ncurse库的图形界面工具;

$ make gconfig 基于gtk+的图形工具;

$ make defconfig 基于默认的配置为个人的体系结构创建一个配置;

$ make oldconfig 验证和更新配置;

- .config文件:配置项会被存放在内核代码树根目录下。

$ zcat /proc/config.gz > .config 目前的内核已经启用了CONFIG_IKCONFIG_PROC选项,可以从/proc下复制文件;

$ make oldconfig 便以一个新内核;

$ make 编译该配置好的内核;

3.2减少编译的垃圾信息

- 不看错误报告和警告信息,对输出重定向

$ make > ../detritus

- 把无用的输出信息重定向到永无返回值的黑洞/dev/null中

$ make > /dev/null

3.3衍生多个编译作业

- 以多个作业编译内核

$ make -jn (j:指定同时执行多任务;n:要衍生出的作业数)

- 16核处理器

$ make -j32 > /dev/null

3.4安装新内核

- 以root身份,运行,把所有已编译的模块安装到正确的主目录/lib/modules下。

% make modules_install

- System.map文件:编译时在内核代码树的根目录下创建的文件;是一个符号对照表;用来将内核符号与它们的起始地址对应起来;调试时,把内存地址转化为函数名和变量名。

4.内核开发的特点

4.1无libc库抑或标准头文件

主要原因:速度与大小。

头文件

- 基本头文件位于内核源代码顶级目录下的include中。

-体系结构相关头文件:内核源代码树的arch/<architecture>/include/asm目录下

4.2GNU C

GCC是多种GNU编译器的集合。

内联函数

- 定义一个内联函数,用static作关键字,用inline限定它。

static inline void wolf(unsigned long tail_size);

内联汇编

- 用asm()指令嵌入汇编代码

unsigned int low, high;

asm volatile("rdtsc" : "=a" (low), "=d" (high)); //low 和 high 分别包含64位时间戳的低32位和高32位

分支声明

- /* error在绝大多数情况下为0 */

if (unlikely(error)) {

/* ... */

}

- /* success在通常不为0 */

if (likely(success)) {

/* ... */

}

- 如果判断正确,性能会提升;如果搞错,性能反而下降。

4.3没有内存保护机制

在内核中,不该访问非法的内存地址,引用空指针,否则内核会over;

内核中的内存不分页:每用掉一个字节,物理内存都减少一个;

4.4不用轻易在内核中使用浮点数

与用户空间进程不同,内核不完美支持浮点操作,因为他本身不能陷入;

4.5容积小而固定的栈

用户空间的栈本身比较大,而且可以动态增长;

对于不用的体系结构,内核栈的大小不一样并都是固定的;

4.6同步和并发

- 内核易产生竞争条件,许多特性都要求能过并发地访问共享数据,就要求同步机制以保证不出现竞争条件,特别是:

Linux是抢占多任务操作系统;Linux内核支持对称多处理器系统(SMP); 中断异步到来; Linux内核可以抢占

- 常用解决方法:自旋锁和信号量

4.7可移植性的重要性

Linux是可移植的操作系统。

Linux第二章读书笔记的更多相关文章

  1. 20135320赵瀚青LINUX第二章读书笔记

    第二章-从内核出发 获取内核代码 使用git 获取最新提交到版本树的一个副本 $ git clone git://git.kernel.org/pub/scm/linux/kernel/git/tor ...

  2. 2013337朱荟潼 Linux第二章读书笔记——从内核出发

    1.获取内核源码 1.1Git 分布式的:下载和管理Linux内核源代码: - 获取最新提交到版本树的一个副本 $ git clone git://git.kernel.org/pub/scm/lin ...

  3. linux第二次读书笔记

    <Linux内核设计与实现>读书笔记 第五章 系统调用   第五章系统调用 系统调用是用户进程与内核进行交互的接口.为了保护系统稳定可靠,避免应用程序恣意忘形. 5.1与内核通信 系统调用 ...

  4. 20135320赵瀚青LINUX第一章读书笔记

    第一章-Linux内核简介 Unix的历史 依旧被认为是最强大和最优秀的系统 由一个失败的操作系统Multics中产生 被移植到PDP-11型机中 由其他组织进一步开发 重写了虚拟内存系统,最终官方版 ...

  5. 《Ansible自动化运维:技术与佳实践》第二章读书笔记

    Ansible 安装与配置 本章主要讲的是 Ansible 安装与基本配置,主要包含以下内容: Ansible 环境准备 安装 Ansible 配置运行环境 Ansible 环境准备 从 GitHub ...

  6. Android深度探索--HAL与驱动开发----第二章读书笔记

    1. 底层开发工具包括: JDk6或者以上版本:Eclipse3.4或以上版本:ADT(用于开发Android应用程序),CDT(用于开发AndroidNDK程序):Android SDK:Andro ...

  7. Linux第一章读书笔记

    一.Linux历史 Unix强大的根本原因: 1.简洁,仅仅提供几百个系统调用并且有一个非常明确的设计目的 2.文件对待所有东西,通过一套相同的系统调用接口来进行对数据和设备的操作 3.由于用C语言编 ...

  8. 2013337朱荟潼 Linux第一章读书笔记——Linux内核简介

    一.Unix历史 二.Linux足迹 类Linux系统.非商业化产品.用途广泛 三.操作系统和Linux内核简介 1.操作系统 (1)是指在整个最基本功能系统中负责完成最基本功能和系统管理的部分. ( ...

  9. 《深入理解JVM》第二章读书笔记

    Java内存区域与内存溢出异常 运行时数据区域 JVM执行java程序的时候有一个运行时数据区,每个区域有自己的作用,了解这些区域有助于我们理解JVM.JVM运行时数据区如图所示: 程序计数器 该区域 ...

随机推荐

  1. SQL SERVR 逻辑函数

    IIF: 根据布尔表达式计算为 true 还是 false,返回其中一个值. IIF 是一种用于编写 CASE 表达式的快速方法. 它将传递的布尔表达式计算为第一个参数,然后根据计算结果返回其他两个参 ...

  2. DevExpress12、DocumentManager

    DocumentManager控件 你用过Photoshop吗?里面每打开一个照片,就有一个小窗体承载这个照片,你可以在这些小窗体间切换,最小化.最大化.排列窗体, 这些操作都在Photoshop的大 ...

  3. 以太坊预言机与WEB API(原创,转载请说明原址)

    什么是预言机? 从链外获得数据,提供区块链与现实世界事件之间的连接,提供外部信息的平台 预言机自身也是一种智能合约,它允许区块链连接到任何现有的API 是这个预言机去调用各种 WEB API的接口 这 ...

  4. UltraISO制作使用(服务器装机u盘制作)

    1.准备工作: 1)U盘一个,需要格式化(大于4G,毕竟ISO文件就已经大于4G了) 2)CentOS7.1 iso文件一个(去这里下载:http://www.centoscn.com/) 3)Ult ...

  5. A “Type Erasure” Pattern that Works in Swift:类型域的转换

    新视角:通过函数式编程的范畴理论来看待这个问题会更容易理解: 在低层类型无法很好表达的类型,可以将其转化为高阶类型进行表示. 将协议的实现类型转化为monad类型: 解决将具有关联类型的协议当作类型的 ...

  6. Android Studio运行找不到Genymotion虚拟机

    如图: 在Genymotion->Settings下ADB选项卡下选择使用SDK工具: 完成后试试吧

  7. 【转】 最新版chrome谷歌浏览器Ajax跨域调试问题

    Ajax本身是不支持跨域的,而我们在开发工作中,可能会遇到本地开发环境未配置相关代码,需要到其他服务器上获取数据的情况,尤其在用HTML5开发app的过程中,前后台完全分离,使用Ajax进行数据交互, ...

  8. Scala学习之路 (四)Scala的数组、映射、元组、集合

    一.数组 1.定长数组和变长数组 import scala.collection.mutable.ArrayBuffer object TestScala { def main(args: Array ...

  9. SQL必知必会摘要

    数据检索 2.2 检索单个列 SELECT prod_name FROM Products; SQL语句不区分大小写   2.3 检索多个列 SELECT prod_name,prod_id,prod ...

  10. 剑指offer.从未到头打印链表

    输入一个链表的头结点,按照 从尾到头 的顺序返回节点的值.返回的结果用数组存储. 样例 输入:[2, 3, 5] 返回:[5, 3, 2] 1.使用栈. class Solution { public ...