From 4599c1f37e1b43841083cc0e21b3417c4232f90e Mon Sep 17 00:00:00 2001 From: Szabolcs Nagy Date: Sat, 17 Sep 2016 23:20:09 +0000 Subject: [PATCH] use anonymous maps in vmfill needed on s390 where /dev/zero maps cannot fill all memory. --- src/common/vmfill.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/common/vmfill.c b/src/common/vmfill.c index 32b6cce..d44ad50 100644 --- a/src/common/vmfill.c +++ b/src/common/vmfill.c @@ -7,6 +7,9 @@ #ifndef PAGE_SIZE #define PAGE_SIZE sysconf(_SC_PAGE_SIZE) #endif +#ifndef MAP_ANONYMOUS + #define MAP_ANONYMOUS 0 +#endif /* max mmap size, *start is the largest power-of-2 size considered */ static size_t mmax(int fd, size_t *start) @@ -15,7 +18,7 @@ static size_t mmax(int fd, size_t *start) void *p; for (i=n=*start; i>=PAGE_SIZE; i/=2) { - if ((p=mmap(0, n, PROT_NONE, MAP_PRIVATE, fd, 0)) == MAP_FAILED) { + if ((p=mmap(0, n, PROT_NONE, MAP_PRIVATE|MAP_ANONYMOUS, fd, 0)) == MAP_FAILED) { n -= i/2; } else { munmap(p, n); @@ -34,7 +37,7 @@ the return value is the number of mappings or -1 on failure. */ int t_vmfill(void **p, size_t *n, int len) { - int fd = open("/dev/zero", O_RDWR); + int fd = MAP_ANONYMOUS ? -1 : open("/dev/zero", O_RDWR); size_t start = SIZE_MAX/2 + 1; size_t m; void *q; @@ -44,7 +47,7 @@ int t_vmfill(void **p, size_t *n, int len) m = mmax(fd, &start); if (!m) break; - q = mmap(0, m, PROT_NONE, MAP_PRIVATE, fd, 0); + q = mmap(0, m, PROT_NONE, MAP_PRIVATE|MAP_ANONYMOUS, fd, 0); if (q == MAP_FAILED) return -1; if (i < len) { -- 2.11.4.GIT