一、概述
Linux内存管理有三大块——物理内存、虚拟内存和内存映射。
内存分配的流程是这样的:
- 一开始申请内存,分配的是虚拟地址空间内存:malloc、mmap等分配虚拟内存;
- 等到寻址发生映射的时候才会由缺页异常来分配物理内存:缺页异常;
- 如果内存不够,分配失败,那就要走回收内存流程:kswapd+LRU/active/inactive/watermark+swap(anno page)/swap cache/swap entry+cache(file-backed page和slab objects);
- 如果回收流程回收不到足够的内存,那么就走OOM流程:oom-killer;
所以,一开始的申请内存,是在虚拟地址空间的哪里?
二、划分
Linux mm_struct中有个属性task_size,他是用户地址空间的size,所以task_size的值就是地址空间中内核态地址空间和用户态地址空间的分界线。
地址:https://elixir.bootlin.com/linux/v5.8.12/source/include/linux/mm_types.h

内核里面是这样定义TASK_SIZE的:

本文介绍了Linux内存管理中的虚拟地址空间划分,包括用户态和内核态的边界,以及在32位和64位系统上的差异。在32位系统中,由于内核空间和用户空间的限制,存在ZONE_HIGHMEM来处理高端内存,而在64位系统中则无需此机制。malloc和mmap分配的内存分别对应堆和内存映射区,内核通过不同方式访问不同区域的物理内存。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



