前面介绍的基于线性映射SLAB/SLUB内核内存对象管理,以及基于分页映射的持久内核映射、临时内核映射和非连续内存管理。它们都有一个共同点:这些内存管理方法的使用者都是内核本身。而本节所要描述的是面向用户态程序的内核管理,称为进程地址空间管理。
用户态的内存管理很大程度上是内核外面的runtime库完成的,如malloc/free的实现。然而malloc/free所需要的内存资源最终都是通过系统调用从内核申请的,因此,内核在一定程度上相当于runtime库的“后端服务器”,而malloc/free只是一个前端代理。并且,malloc/free面对的只是虚拟地址资源,也就是说,malloc仅仅申请到一块虚拟内存,并没有真正映射到物理内页。物理页是一种宝贵的资源,内核自身的物理内存分配可以即时完成,而用户态进程的物理内存分配时通过"缺页中断"延迟完成的。
一、mm_struct和vm_area_struct
进程地址空间里二个最重要的数据结构是mm_struct和vm_struct
1)进程内存描述符:mm_struct
每一个进程(包括普通进程和内核线性)用一个进程描述符task_struct来表示,每个进程描述符里有二个类型为内存描述符mm_struct的指针:mm和active_mm。一个内存描述符表征一个进程地址空间,普通的进程拥有独立的地址空间,而属于同一个进程的线程共享同一个地址空间。进程描述符中的mm字段是进程拥有的内存描述符,而active_mm是运行的实际使用的活动内存描述符。