提交 692b5581 编写于 作者: M Mike Kravetz 提交者: Linus Torvalds

userfaultfd/selftests: clean up hugetlb allocation code

The message for commit f5c73297 ("userfaultfd/selftests: fix hugetlb
area allocations") says there is no need to create a hugetlb file in the
non-shared testing case.  However, the commit did not actually change
the code to prevent creation of the file.

While it is technically true that there is no need to create and use a
hugetlb file in the case of non-shared-testing, it is useful.  This is
because 'hole punching' of a hugetlb file has the potentially incorrect
side effect of also removing pages from private mappings.  The
userfaultfd test relies on this side effect for removing pages from the
destination buffer during rounds of stress testing.

Remove the incomplete code that was added to deal with no hugetlb file.
Just keep the code that prevents reserves from being created for the
destination area.

Link: https://lkml.kernel.org/r/20220104021729.111006-1-mike.kravetz@oracle.comSigned-off-by: NMike Kravetz <mike.kravetz@oracle.com>
Reviewed-by: NAxel Rasmussen <axelrasmussen@google.com>
Cc: Peter Xu <peterx@redhat.com>
Cc: Andrea Arcangeli <aarcange@redhat.com>
Cc: Mina Almasry <almasrymina@google.com>
Cc: Shuah Khan <shuah@kernel.org>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 fab51505
...@@ -87,7 +87,7 @@ static bool test_uffdio_minor = false; ...@@ -87,7 +87,7 @@ static bool test_uffdio_minor = false;
static bool map_shared; static bool map_shared;
static int shm_fd; static int shm_fd;
static int huge_fd = -1; /* only used for hugetlb_shared test */ static int huge_fd;
static char *huge_fd_off0; static char *huge_fd_off0;
static unsigned long long *count_verify; static unsigned long long *count_verify;
static int uffd = -1; static int uffd = -1;
...@@ -223,9 +223,6 @@ static void noop_alias_mapping(__u64 *start, size_t len, unsigned long offset) ...@@ -223,9 +223,6 @@ static void noop_alias_mapping(__u64 *start, size_t len, unsigned long offset)
static void hugetlb_release_pages(char *rel_area) static void hugetlb_release_pages(char *rel_area)
{ {
if (huge_fd == -1)
return;
if (fallocate(huge_fd, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE, if (fallocate(huge_fd, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE,
rel_area == huge_fd_off0 ? 0 : nr_pages * page_size, rel_area == huge_fd_off0 ? 0 : nr_pages * page_size,
nr_pages * page_size)) nr_pages * page_size))
...@@ -238,17 +235,17 @@ static void hugetlb_allocate_area(void **alloc_area) ...@@ -238,17 +235,17 @@ static void hugetlb_allocate_area(void **alloc_area)
char **alloc_area_alias; char **alloc_area_alias;
*alloc_area = mmap(NULL, nr_pages * page_size, PROT_READ | PROT_WRITE, *alloc_area = mmap(NULL, nr_pages * page_size, PROT_READ | PROT_WRITE,
map_shared ? MAP_SHARED : (map_shared ? MAP_SHARED : MAP_PRIVATE) |
MAP_PRIVATE | MAP_HUGETLB | MAP_HUGETLB |
(*alloc_area == area_src ? 0 : MAP_NORESERVE), (*alloc_area == area_src ? 0 : MAP_NORESERVE),
huge_fd, huge_fd, *alloc_area == area_src ? 0 :
*alloc_area == area_src ? 0 : nr_pages * page_size); nr_pages * page_size);
if (*alloc_area == MAP_FAILED) if (*alloc_area == MAP_FAILED)
err("mmap of hugetlbfs file failed"); err("mmap of hugetlbfs file failed");
if (map_shared) { if (map_shared) {
area_alias = mmap(NULL, nr_pages * page_size, PROT_READ | PROT_WRITE, area_alias = mmap(NULL, nr_pages * page_size, PROT_READ | PROT_WRITE,
MAP_SHARED, MAP_SHARED | MAP_HUGETLB,
huge_fd, *alloc_area == area_src ? 0 : huge_fd, *alloc_area == area_src ? 0 :
nr_pages * page_size); nr_pages * page_size);
if (area_alias == MAP_FAILED) if (area_alias == MAP_FAILED)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册