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 xvz…
一.Unix历史 二.Linux足迹 类Linux系统.非商业化产品.用途广泛 三.操作系统和Linux内核简介 1.操作系统 (1)是指在整个最基本功能系统中负责完成最基本功能和系统管理的部分. (2)包括:内核.设备驱动程序.启动引导程序.命令行.用户界面.基本文件管理工具和系统工具. 2.内核--管理者/操作系统核心 (1)操作系统的内在核心. (2)组成:中断服务程序.调度程序.内存管理程序.系统服务程序. 3.linux由用户空间和内核空间组成 (1)通常内核空间和用户空间是程序执行的…
摘要: [20135337朱荟潼]原创作品转载请注明出处 第五章 系统调用 5.1 与内核通信 中间层 作用三个:1.为用户空间提供一种硬件的抽象接口:2.保证系统稳定和安全:3.除异常和陷入,是内核唯一的合法入口. 5.2 API.POSIX和C库 API定义了应用程序使用的编程接口(可实现系统调用). API.POSIX.C库与系统调用之间关系. 5.3 系统调用--syscall 5.3.1 系统调用号 当用户空间的进程执行一个系统调用,就用系统调用号指明到底执行哪个系统调用. sys_n…
第二章-从内核出发 获取内核代码 使用git 获取最新提交到版本树的一个副本 $ git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git 安装内核源代码 压缩形式为bzip2运行:$ tar xvjf linux-x.y.z.tar.bz2压缩形式为zip运行:$ tar xvzf linux-x.y.z.tar.gz 使用补丁 从内部源码树开始运行$ patch -p1 < ../patch-…
第三章 进程管理 总结 fork创造的子进程复制了父进程资源,包括内存及进程描述符的内容,资源的复制而不是指针的复制. vfork的行为更像一个线程(指没有自已独立的内存空间),更明显的是vfork的调用将挂起当前进程(即父进程). clone根据flag的不同可以实现不同的功能. 只要退出,最终都调用了do_exit. 3.1 进程 进程:是处于执行期的程序以及它所包含的资源的总称. 线程:是在进程中活动的对象. 每个线程都拥有一个独立的程序计数器.进程栈和一组进程寄存器. 内核调度的对象是线…
第4章 进程调度 0. 总结 调度:调度是一个平衡的过程.一方面,它要保证各个运行的进程能够最大限度的使用CP:另一方面,保证各个进程能公平的使用CPU. 调度功能:决定哪个进程运行以及进程运行多长时间. 调度实现原理:与进程的优先级有关 Linux上调度实现的方法:O(1)的调度算法 调度相关的系统调用 4.1 多任务 能同时并发地交互执行多个进程. 非抢占式多任务:主动停止运行. 抢占式多任务:进程时间片. 4.2 Linux的进程调度 O(1)拥有数以十计的多处理器的环境,但缺少交互进程.…
第七章--链接 0.总结 链接编译时可以采用静态链接或动态链接. 连接器主要任务:符号解析和重定位. 多个目标文件可定义相同的符号,可以被连接到一个单独的静态库. 链接器可以生成部分链接的可执行文件 动态链接器通过加载共享库和重定位程序中的引用来完成链接任务. 1.编译器驱动程序 编译系统提供的调用预处理器.编译器.汇编器和链接器来构造目标文件的程序. 2.静态链接 3.目标文件 三种形式: 1.可重定位目标文件: 2.可执行目标文件: 3.共享目标文件: 4.可重定位目标文件 ELF格式 5.…
第十八章 调试 0.总结 oops 内核的调试配置 用Git进行二分搜索 bug总会有,简洁描述发给LKML 1. 准备开始 在用户级的程序里,bug表现比较直接:在内核中却不清晰. 2. 内核中的bug 多种多样.变化多端. 引用空指针会产生一个oops:垃圾数据会导致系统崩溃. 定时限制和竞争条件都允许多个线程在内核中同时运行产生的结果. 3. 通过打印来调试 3.1 健壮性 printk()函数任何时候地方都可以调用它. 3.2 日志等级 printk()可以指定一个日志级别[与print…
一.计算机是如何工作的--总结 三个法宝 存储程序计算机.函数调用堆栈.中断机制 二.堆栈 1.是c语言程序运行时必须的一个记录调用路径和参数的空间. 函数调用框架.传递参数.保存返回地址.提供局部变量空间 2.相关寄存器 esp 堆栈指针 ebp 基址指针(记录当前函数调用基址) 3.操作 push 栈顶地址减少4个字节 pop 栈顶地址增加4个字节 4.其他寄存器 cs:eip 总是指向下一条的指令地址 -顺序:总是指向地址连续的下一条的指令地址: -跳转/分支:根据程序需要被修改: cal…
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 xvz…