Linux内存管理(三十五):内存规整简介
源码基于:Linux5.4
0. 前言
伙伴系统以页面为单位来管理内存,内存碎片也是基于页面的,即由大量离散且不连续的页面组成的。从内核角度来看,出现内存碎片不是好事情,有些情况下物理设备需要大段的连续的物理内存,如果内核无法满足,则会发生内核错误。内存规整就是为了解决内核碎片化而出现的一个功能。
内核中去碎片化的基本原理是按照页面的可移动性将页面分组。
迁移内核本身使用的物理内存的实现难度和复杂度都很大,因此目前的内存不迁移内核本身使用的物理页面。对于户进程使用的页面,实际上通过用户用页表的映射来访问,用户页表可以移动和修改映射关系,不会影响用户进程,因此内存规整是基于页面迁移实现的。
1. 内存规整的基本原理
系统长时间运行后,页面变得越来越分散,分配一大块连续的物理内存变得越来越难,但有时系统就是需要一大块连续的物理内存,这就是内存碎片化(memory fragmentation)。
Anti-frgmentation 核心思想是吧内存页面按照可移动、可回收、不可移动等特