Linux 内核开发 - 内存管理
1.1什么是内存管理
内存管理是对计算机内存进行分配和使用的技术。内存管理主要存在于多任务的操作系统中,因为内存资源极其有限。须要在不同的任务之间共享内存,内存管理的存在就是要高效、高速的非配内存,并在适当的时候回收和释放内存。以保各个任务正常的运行。最常见的内存管理机制有:段式内存管理和页式内存管理。
1.2内存中的地址
早期的16位计算中。寄存器的位宽仅仅有16位。为了能訪问到1M Bit的内存空间,CPU就採用了分段的方式来管理内存,将1M的内存分为若干个逻辑段,每一个逻辑段的起始地址必须是16的整数倍,每一个逻辑段最大的訪问空间为64K。
1) 段基地址
将物理地址分为64K Bit 为单位的多个段,因为最后4位总是0,所以段的起始地址被右移4位后保存,须要计算实际的物理地址时再左移四位。
2) 逻辑地址(段内偏移地址)
逻辑地址地分段后段内偏移量。
3) 线性地址
线性地址代表了计算机的地址訪问能力。代表了一个非物理的实体地址。是逻辑地址到物理地址变换之间的中间层。
在段式管理中。线性地址 = 段内基地址 + 逻辑地址。
4) 虚拟地址
虚拟地址的概念主要出如今虚拟内存技术中。它使得应用程序觉得它拥有连续的可用的内存(一个连续完整的地址空间)。所以在某种情况下被称为线性地址。
5) 物理地址
实际物理存储器的地址,是地址转换的终于结果。
PS: 对于16位机来说,他的实际物理地址是20位,线性地址和物理地址是同样的所以线性地址到物理地址之间是一一相应的。
1.3 段式管理(32位CPU)
x86的32位机型有“实模式”与“保护模式”两种。在“实模式”下段的使用方式与16位机时一致的。可是在“保护模式”下,段寄存器被称为段选择器(segment selector)。它存储的是段描写叙述符(segment descriptor),段描写叙述符记录了该段的基地址、权限等信息,段基地址+逻辑地址 能够转换成线性地址。
段式管理的长处:可以依据实际的代码。从用户的角度(程序猿)的角度将代码分成多个逻辑段,比方数据段、代码段、堆栈段。段大小可变,利于保护数据、方便内存共享。
1.4 页式管理
页式管理是将线性地址划分为固定长度的管理单元,一般是4K大小,对32位计算机来说就划分了2^20个也,以二级的页式内存管理机制来说,线性地址被分为三部分
l 页文件夹地址:22~31 (共10位)
l 页表地址:12~21(共10位)
l 页内偏移量:0~11(共12位)
系统会为每一个进程的页文件夹位置,通过线性地址的最高10位找到页表的起始地址,再通过中间10位找到页的起始地址。最后通过低12位找到页内偏移量。终于计算出物理地址。
1.5 Linux 的内存管理模式
Linux 是一个跨平台的操作系统。为了能支持Intel 的段式管理方式,它採用了段式 + 页式管理机制。不过Linux 不过有限度的使用段式管理方式。由于Linux 系统中每一个段的基地址都是0,所以 逻辑地址= 线性地址,逻辑地址转换成线性地址时一一相应。Linux 的这样的处理方式不仅简化了内核。也为移植到不支持段式管理方式的平台上提供了方便。
更严格的说,Linux 採用了页式管理模式,只是由于不同的平台的页级数不一致,Linux 2.6.29使用了四级的页式管理结构来兼容不同页级数的CPU。
这四级分别为:
页全局文件夹(Page Global Directory) :pgd
页上级文件夹(Page Upper Directory):pud
页中间文件夹(Page Middle Directory):pmd
页表(Page Table Entry):pte
Linux 内核开发 - 内存管理的更多相关文章
- 24小时学通Linux内核之内存管理方式
昨天分析的进程的代码让自己还在头昏目眩,脑子中这几天都是关于Linux内核的,对于自己出现的一些问题我会继续改正,希望和大家好好分享,共同进步.今天将会讲诉Linux如何追踪和管理用户空间进程的可用内 ...
- Linux内核之内存管理
Linux内核之内存管理 Linux利用的是分段+分页单元把逻辑地址转换为物理地址; RAM的某些部分永久地分配给内核, 并用来存放内核代码以及静态内核数据结构; RAM的其余部分称动态内存(dyna ...
- Linux内核笔记--内存管理之用户态进程内存分配
内核版本:linux-2.6.11 Linux在加载一个可执行程序的时候做了种种复杂的工作,内存分配是其中非常重要的一环,作为一个linux程序员必然会想要知道这个过程到底是怎么样的,内核源码会告诉你 ...
- Linux内核之内存管理完全剖析
linux虚拟内存管理功能 ? 大地址空间:? 进程保护:? 内存映射:? 公平的物理内存分配:? 共享虚拟内存.实现结构剖析 (1)内存映射模块(mmap):负责把磁盘文件的逻辑地址映射到虚拟地 ...
- Linux内核笔记——内存管理之slab分配器
内核版本:linux-2.6.11 内存区和内存对象 伙伴系统是linux用于满足对不同大小块内存分配和释放请求的解决方案,它为slab分配器提供页框分配请求的实现. 如果我们需要请求具有连续物理地址 ...
- 深入理解Linux内核-内存管理
内核如果给自己分配动态内存 动态内存:RAM的某些部分被永久打分配给内核,用来存放内核代码以及静态内核数据结构:剩余的部分被称为动态内存 连续物理内存区管理: 页框管理:1.页大小的选择,通常情况下主 ...
- Linux内核之 内存管理
前面几篇介绍了进程的一些知识,从这篇开始介绍内存.文件.IO等知识,发现更不好写哈哈.但还是有必要记录下自己的所学所思.供后续翻阅,同时写作也是一个巩固的过程. 这些知识以前有文档涉及过,但是角度不同 ...
- Linux内核笔记——内存管理之块内存分配
内核版本:linux-2.6.11 伙伴系统 伙伴系统是linux用于满足对不同大小块物理内存分配和释放请求的解决方案. 内存管理区 linux将物理内存分成三个内存管理区,分别为ZONE_DMA Z ...
- Linux内核之内存管理(4)--缺页处理程序
本文主要解说缺页处理程序,凝视足够具体,不再解释. //以下函数将一页内存页面映射到指定线性地址处,它返回页面的物理地址 //把一物理内存页面映射到线性地址空间指定处或者说把线性地址空间指定地址add ...
随机推荐
- Lodash数组方法中文总结
LodashAPI总结 Lodash是一个特别特别好用的工具,感觉有了Lodash就没有解决不了的问题了~~~~ 使用初开始 官网 https://www.lodashjs.com/docs/4.17 ...
- asp 数据库 模块化 - 思路是没一个页面有一个自己的数据类 这里用nPath表示
<!--#include file="db_class.asp" --> <% '当前页面数据 nPath = "..\..\.." 't模块 ...
- CS2QS
inline QString MotorCS2QS(CString cs) { return QString::fromWCharArray((LPCTSTR)cs, cs.GetLength()); ...
- 题解 P1967 货车运输
题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的情况下,最多能 ...
- C++中const与constexpr区别
对于对象来说 const指的是编译期常量和运行时常量,两者并没有区分 constexpr特指编译期常量 对于函数来说 const可以修饰类的成员函数,被修饰的函数在执行期间不会改变对象的值. clas ...
- nginx网站标准配置
#nginx开启的进程数worker_processes 4; #4核CPU #定义全局错误日志定义类型,[debug|info|notice|warn|crit]error_log ...
- linux core dump 生成和调试
core dump 某些信号的产生会导致产生core dump,包含了进程终止时的内存镜像.在某些时候这个core文件就非常的有用处,配合gdb或者lldb调试起来非常方便. 更详细的文档参考 Lin ...
- CURL PHP模拟浏览器get和post
模拟浏览器get和post数据需要经常用到的类, 在这里收藏了几个不错的方法 方法一 <?php define ( 'IS_PROXY', true ); //是否启用代理 /* cookie文 ...
- 将一个list中的元素的某一属性取出来单独放到一个list里面
有很多时候我们会遇到这样的场景,就是要将一个list中的某一个元素中的某一属性单独拿出来放在一个新的list里面,这中时候,我们就可以用以下的方法来进行实现: List<DTO> item ...
- jquery源码——noConflict实现
实现方式很简单:在初始化的时候,记录当前全局中jQuery和$两个变量的的值,用_jQuery和_$分别存放,调用noConflict方法时,使用_jQuery和_$分别恢复对应的值,并且返回jQue ...