巨页的实现,涉及到两个模块:hugetlb和hugetlbfs。
hugetlb相当于是huge page页面管理者,页面的分配及释放,都由此模块负责。
hugetlbfs则用于向用户提供一套基于文件系统的巨页使用界面,其下层功能的实现,则依赖于hugetlb。
1. hugetlb模块
struct hstate hstates[HUGE_MAX_HSTATE];
上面定义了一个hstate数组,每个元素是一个巨页池。
不同的巨页池,其巨页尺寸是不一样的,例如2M的,4M的,1G的等等。
系统中可能会有多个巨页池,每一个池的巨页尺寸都是不一样的。
max_hstate标识当前有多少个hstate,即数组的前多少个元素是有效的。
默认的话,hugetlb_init中会创建一个hstate,其page size是默认大小,此hstate也就成了默认的hstate。
如果hugetlb.c被编译进内核,并且内核启动的时候,命令行参数中有hugepagesz=选项。
那么就会调用setup_hugepagesz进行处理,setup_hugepagesz应该会在hugetlb_init之前执行。
setup_hugepagesz中会调用hugetlb_add_hstate添加一个hstate,其pagesize大小为命令行参数中指定的大小。
每一个hstate,在/sys/kernel/mm/hugepages下面会有一个目录与之对应。通过读写此目录下的文件,即可实现对此hstate的各种属性的查看与修改。例如,可以查看或修改此hstate的页面数量。 <
hugetlb相当于是huge page页面管理者,页面的分配及释放,都由此模块负责。
hugetlbfs则用于向用户提供一套基于文件系统的巨页使用界面,其下层功能的实现,则依赖于hugetlb。
1. hugetlb模块
struct hstate hstates[HUGE_MAX_HSTATE];
上面定义了一个hstate数组,每个元素是一个巨页池。
不同的巨页池,其巨页尺寸是不一样的,例如2M的,4M的,1G的等等。
系统中可能会有多个巨页池,每一个池的巨页尺寸都是不一样的。
max_hstate标识当前有多少个hstate,即数组的前多少个元素是有效的。
默认的话,hugetlb_init中会创建一个hstate,其page size是默认大小,此hstate也就成了默认的hstate。
如果hugetlb.c被编译进内核,并且内核启动的时候,命令行参数中有hugepagesz=选项。
那么就会调用setup_hugepagesz进行处理,setup_hugepagesz应该会在hugetlb_init之前执行。
setup_hugepagesz中会调用hugetlb_add_hstate添加一个hstate,其pagesize大小为命令行参数中指定的大小。
每一个hstate,在/sys/kernel/mm/hugepages下面会有一个目录与之对应。通过读写此目录下的文件,即可实现对此hstate的各种属性的查看与修改。例如,可以查看或修改此hstate的页面数量。 <