文章说明:
-
Linux内核版本:5.0
-
架构:ARM64
-
参考资料及图片来源:《奔跑吧Linux内核》
-
Linux 5.0内核源码注释仓库地址:
1. KSM定义
KSM指Kemel SamePage Merging,即内核同页合并,用于合并内容相同的页面。KSM的出现是为了优化虚拟化中产生的冗余页面,因为虚拟化的实际应用中在同一台主机上会有许多相同的操作系统和应用程序,许多内存页面的内容可能是相同的,所以它们可以合并,从而释放内存供其他应用程序使用。
KSM允许合并同—个进程或不同进程之间内容相同的匿名页面,这对应用程序来说是不可见的。把这些相同的页面合并成一个只读的页面,从而释放出多余的物理页面,当应用程序需要改变页面内容时,会发生写时复制。
2. 使能KSM
KSM只会处理通过madvise系统调用显式指定的用户进程地址空间,因此用户程序想使用这个功能就必须在分配地址空间时显式地调用madvise(addr,length,MADV_MERGEABLE)。如果用户想在KSM中取消某一个用户进程地址空间的合并功能,也需要显式地调用madvise(addr,length,MADV_UNMERGEABLE)。
KSM的sysfs节点在/sys/kernel/mm/ksm/目录下,如下图所示:
其中主要节点的描述如表所示:
KSM在初始化时会创建—个名为ksmd的内核线程
static int __init ksm_init(void)
{
...
ksm_thread = kthread_run(ksm_scan_thread, NULL, "ksmd");
...
}
程序可以显式地调用madvise系统调用把用户进程地址空间添加到KSM系统中
<madvise()->ksm_madvise()->__ksm_enter()>
int __ksm_enter(struct mm_struct *mm)
{