> On Jul 23, 2019, at 4:59 PM, Huang, Kai <kai.huang@xxxxxxxxx> wrote: > > On Mon, 2019-06-24 at 17:12 -0700, Song Liu wrote: >> This patch is (hopefully) the first step to enable THP for non-shmem >> filesystems. >> >> This patch enables an application to put part of its text sections to THP >> via madvise, for example: >> >> madvise((void *)0x600000, 0x200000, MADV_HUGEPAGE); >> >> We tried to reuse the logic for THP on tmpfs. >> >> Currently, write is not supported for non-shmem THP. khugepaged will only >> process vma with VM_DENYWRITE. sys_mmap() ignores VM_DENYWRITE requests >> (see ksys_mmap_pgoff). The only way to create vma with VM_DENYWRITE is >> execve(). This requirement limits non-shmem THP to text sections. >> >> The next patch will handle writes, which would only happen when the all >> the vmas with VM_DENYWRITE are unmapped. >> >> An EXPERIMENTAL config, READ_ONLY_THP_FOR_FS, is added to gate this >> feature. >> >> Acked-by: Rik van Riel <riel@xxxxxxxxxxx> >> Signed-off-by: Song Liu <songliubraving@xxxxxx> >> --- >> mm/Kconfig | 11 ++++++ >> mm/filemap.c | 4 +-- >> mm/khugepaged.c | 94 +++++++++++++++++++++++++++++++++++++++++-------- >> mm/rmap.c | 12 ++++--- >> 4 files changed, 100 insertions(+), 21 deletions(-) >> >> diff --git a/mm/Kconfig b/mm/Kconfig >> index f0c76ba47695..0a8fd589406d 100644 >> --- a/mm/Kconfig >> +++ b/mm/Kconfig >> @@ -762,6 +762,17 @@ config GUP_BENCHMARK >> >> See tools/testing/selftests/vm/gup_benchmark.c >> >> +config READ_ONLY_THP_FOR_FS >> + bool "Read-only THP for filesystems (EXPERIMENTAL)" >> + depends on TRANSPARENT_HUGE_PAGECACHE && SHMEM > > Hi, > > Maybe a stupid question since I am new, but why does it depend on SHMEM? Not stupid at all. :) We reuse a lot of code for shmem thp, thus the dependency. Technically, we can remove the dependency. However, we will remove this config option when THP for FS is more mature. So it doesn't make sense to resolve the dependency at this stage. Thanks, Song