• xu xin's avatar
    ksm: support unsharing KSM-placed zero pages · 79271476
    xu xin authored
    Patch series "ksm: support tracking KSM-placed zero-pages", v10.
    
    The core idea of this patch set is to enable users to perceive the number
    of any pages merged by KSM, regardless of whether use_zero_page switch has
    been turned on, so that users can know how much free memory increase is
    really due to their madvise(MERGEABLE) actions.  But the problem is, when
    enabling use_zero_pages, all empty pages will be merged with kernel zero
    pages instead of with each other as use_zero_pages is disabled, and then
    these zero-pages are no longer monitored by KSM.
    
    The motivations to do this is seen at:
    https://lore.kernel.org/lkml/202302100915227721315@zte.com.cn/
    
    In one word, we hope to implement the support for KSM-placed zero pages
    tracking without affecting the feature of use_zero_pages, so that app
    developer can also benefit from knowing the actual KSM profit by getting
    KSM-placed zero pages to optimize applications eventually when
    /sys/kernel/mm/ksm/use_zero_pages is enabled.
    
    
    This patch (of 5):
    
    When use_zero_pages of ksm is enabled, madvise(addr, len,
    MADV_UNMERGEABLE) and other ways (like write 2 to /sys/kernel/mm/ksm/run)
    to trigger unsharing will *not* actually unshare the shared zeropage as
    placed by KSM (which is against the MADV_UNMERGEABLE documentation).  As
    these KSM-placed zero pages are out of the control of KSM, the related
    counts of ksm pages don't expose how many zero pages are placed by KSM
    (these special zero pages are different from those initially mapped zero
    pages, because the zero pages mapped to MADV_UNMERGEABLE areas are
    expected to be a complete and unshared page).
    
    To not blindly unshare all shared zero_pages in applicable VMAs, the patch
    use pte_mkdirty (related with architecture) to mark KSM-placed zero pages.
    Thus, MADV_UNMERGEABLE will only unshare those KSM-placed zero pages.
    
    In addition, we'll reuse this mechanism to reliably identify KSM-placed
    ZeroPages to properly account for them (e.g., calculating the KSM profit
    that includes zeropages) in the latter patches.
    
    The patch will not degrade the performance of use_zero_pages as it doesn't
    change the way of merging empty pages in use_zero_pages's feature.
    
    Link: https://lkml.kernel.org/r/202306131104554703428@zte.com.cn
    Link: https://lkml.kernel.org/r/20230613030928.185882-1-yang.yang29@zte.com.cnSigned-off-by: default avatarxu xin <xu.xin16@zte.com.cn>
    Acked-by: default avatarDavid Hildenbrand <david@redhat.com>
    Cc: Claudio Imbrenda <imbrenda@linux.ibm.com>
    Cc: Xuexin Jiang <jiang.xuexin@zte.com.cn>
    Reviewed-by: default avatarXiaokai Ran <ran.xiaokai@zte.com.cn>
    Reviewed-by: default avatarYang Yang <yang.yang29@zte.com.cn>
    Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
    79271476
ksm.c 95.9 KB