首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Linux 内核 内存管理】物理内存组织结构 ⑥ ( 物理页 page 简介 | 物理页 page 与 MMU 内存管理单元 | 内存节点 pglist_data 与 物理页 page 联系 )

文章目录 一、物理页 page 简介 1、物理页 page 引入 2、物理页 page 与 MMU 内存管理单元 3、物理页 page 结构体 4、Linux 内核源码中的 page 结构体 二、内存节点...pglist_data 与 物理页 page 联系 内存管理系统 3 级结构 : ① 内存节点 Node , ② 内存区域 Zone , ③ 物理页 Page , Linux 内核中 , 使用 上述...3 级结构 描述 和 管理 " 物理内存 " ; 一、物理页 page 简介 ---- 1、物理页 page 引入 " 内存节点 " node 是内存管理的 最顶层结构 , " 内存节点 " 再向下划分..., 就是 " 内存区域 " zone , " 内存区域 " 再向下划分 , 就是 " 物理页 " page ; 2、物理页 page 与 MMU 内存管理单元 在 Linux 内核中 , MMU 内存管理单元...进行描述 ; 为了节省 " 内存管理 " 的内存开销 , 物理页的描述符 page 中都是 union 联合体 , 如 : struct page { union { struct address_space

6.7K10

Linux内存描述之内存页面page--Linux内存管理(四)

页面(Page) 内存被细分为多个页面帧, 页面是最基本的页面分配的单位 首先内存被划分为结点....是系统中预留的可用内存空间, 不能被内核直接映射. 最后页帧(page frame)代表了系统内存的最小单位, 堆内存中的每个页都会创建一个struct page的一个实例....此时,内存变成了连续的页,即内存为页数组,每一页物理内存叫页帧,以页为单位对内存进行编号,该编号可作为页数组的索引,又称为页帧号. 2 页帧struct page 分页单元可以实现把线性地址转换为物理地址...页帧代表了系统内存的最小单位, 对内存中的每个页都会创建struct page的一个实例. 内核必须要保证page结构体足够的小,否则仅struct page就要占用大量的内存....在典型的系统中, 由于页的数目巨大, 因此对page结构的小改动, 也可能导致保存所有page实例所需的物理内存暴涨.

8.1K11
您找到你想要的搜索结果了吗?
是的
没有找到

alloc_page分配内存空间--Linux内存管理(十七)

v=4.7, line 483 get_zeroed_page(mask) 分配一页并返回一个page实例,页对应的内存填充0(所有其他函数,分配之后页的内容是未定义的) mm/page_alloc.c...v=4.7, line 503 在空闲内存无法满足请求以至于分配失败的情况下,所有上述函数都返回空指针(比如alloc_pages和alloc_page)或者0(比如get_zeroed_page、_...); 在这种情况下, 使用了一个普通函数而不是宏, 因为alloc_pages返回的page实例需要使用辅助 函数page_address转换为内存地址....在这里,只要知道该函数可根据page实例计算相关页的线性内存地址即可...., 则不进行内存分配. 3.3 get_page_from_freelist函数 get_page_from_freelist是伙伴系统使用的另一个重要的辅助函数.

3K11

Page Cache与Page回写

综述 Page cache是通过将磁盘中的数据缓存到内存中,从而减少磁盘I/O操作,从而提高性能。...Page Cache Page cache由内存中的物理page组成,其内容对应磁盘上的block。page cache的大小是动态变化的,可以扩大,也可以在内存不足时缩小。...Cache回收 Page cache的另一个重要工作是释放page,从而释放内存空间。cache回收的任务是选择合适的page释放,并且如果page是dirty的,需要将page写回到磁盘中再释放。...page_tree保存了该page cache中所有的page,使用基数树(radix Tree)来存储。i_mmap是保存了所有映射到当前page cache(物理的)的虚拟内存区域(VMA)。...内核在下面三种情况下会进行会将dirty page写回磁盘: 用户进程调用sync() 和 fsync()系统调用 空闲内存低于特定的阈值(threshold) Dirty数据在内存中驻留的时间超过一个特定的阈值

1.4K20

【Linux 内核 内存管理】物理内存组织结构 ② ( 内存模型 | 平坦内存 | 稀疏内存 | 非连续内存 | 内存管理系统三级结构 | 节点 Node | 区域 Zone | 页 Page )

文章目录 一、内存模型 二、内存管理系统三级结构 一、内存模型 ---- 从 CPU 处理器 的角度出发 , 观察 内存的 " 物理分布 " , 有如下 3 种内存模型 , Linux 内核针对这...3 种内存模型进行不同的处理 ; ① 平坦内存 : Flat Memory , 物理地址空间 是 连续的 , 没有 " 内存空洞 " ; ② 稀疏内存 : Space Memory , 物理地址空间...是 非连续 的 , 有 " 内存空洞 " , 该内存模型 支持 内存条的 " 热插拔 " 操作 ; ③ 非连续内存 : Discontiguous Memory , 物理地址空间 是 非连续 的 , 有..." 内存空洞 " ; 内存热插拔支持 : 只有 " 稀疏内存模型 " 支持 内存条 的 热插拔 操作 ; 内存空洞 : 系统的 2 个物理内存 之间 , 存在 内存空洞 ; 1 个物理内存 内部也可能存在...内存空洞 ; 二、内存管理系统三级结构 ---- 内存管理系统 3 级结构 : ① 节点 Node , ② 区域 Zone , ③ 页 Page , Linux 内核中 , 使用 上述 3 级结构

2.7K30

对atbus的小数据包的优化

/s Linux+跨机器转发+ipv4 2(仅一个连接压力测试) 128字节 50%/100% 280MB 65.75MB/s 526K/s Linux+共享内存 3(仅一个连接压力测试) 32KB 100%.../100% 280MB 3.06GB/s 98K/s Linux+共享内存 3(仅一个连接压力测试) 16KB 61%/71% 280MB 1.59GB/s 102K/s Linux+共享内存 3(仅一个连接压力测试...) 8KB 36%/70% 280MB 1.27GB/s 163K/s Linux+共享内存 3(仅一个连接压力测试) 4KB 40%/73% 280MB 1.30MB/s 333K/s Linux+共享内存.../s Linux+共享内存 3(仅一个连接压力测试) 512字节 44%/100% 280MB 610MB/s 1250K/s Linux+共享内存 3(仅一个连接压力测试) 256字节 42%/100%...165MB/s 2857K/s Linux+共享内存 1 8-16384字节 98%/98% 74MB/74MB 1.56GB/s 199K/s Linux+共享内存 1 8-128字节(模拟ping包

6.8K20

page compaction原理

这就导致了一个问题: 当我们需要申请一大块连续的物理内存的时候,就会出现无法找到一个连续的大块内存,剩下的大多数都是一页一页零散的内存了。这种问题就是内存碎片问题了。...为了解决内存碎片问题,linux内核引入了page compaction技术,俗称页块整理。...整理的原理如下: 假设现在有一个zone的内存布局内部如下:其中red 区域代表的是已经使用的,white是空闲的 ? 可以清晰的看见,所属的空闲区域连续的最大是2个page。...如果从该zone中分配四个连续的内存区域,就会出现必然失败的。有可能分配两个连续的页面也有可能失败,如果考虑对齐的话。...当然page compation有两种触发方式: 当分配page的时候,在LOW水位出现分配失败的时候,会尝试slowth分配的,在当中就会出现page compaction的流程 工程师可以通过echo

1.6K20
领券