aboutsummaryrefslogtreecommitdiffstats
path: root/vespamalloc/src/vespamalloc/util/osmem.cpp
diff options
context:
space:
mode:
authorHenning Baldersheim <balder@yahoo-inc.com>2022-05-11 07:44:24 +0000
committerHenning Baldersheim <balder@yahoo-inc.com>2022-05-11 07:44:24 +0000
commite7a5599c2fda0ed779d5c9a11dd8d1f2f2e47567 (patch)
treeeb5b2b1aa044fd3455ccadd8c65978e3bef96a75 /vespamalloc/src/vespamalloc/util/osmem.cpp
parent631c539a74a1500b7956071e1ccf375e45ceca7b (diff)
Add madvise(buf, len, MADV_HUGEPAGE) call to signal that you strongly prefer huge pages.
This will make a difference if /sys/kernel/mm/transparent_hugepage/enabled has been set to [madvise], and not [always].
Diffstat (limited to 'vespamalloc/src/vespamalloc/util/osmem.cpp')
-rw-r--r--vespamalloc/src/vespamalloc/util/osmem.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/vespamalloc/src/vespamalloc/util/osmem.cpp b/vespamalloc/src/vespamalloc/util/osmem.cpp
index e0cfbc36938..2cb0eb78ad2 100644
--- a/vespamalloc/src/vespamalloc/util/osmem.cpp
+++ b/vespamalloc/src/vespamalloc/util/osmem.cpp
@@ -214,6 +214,9 @@ MmapMemory::getBasePages(size_t len, int mmapOpt, int fd, size_t offset)
ok = (mem == wanted);
}
if (mem != MAP_FAILED) {
+ if (madvise(mem, len, MADV_HUGEPAGE) != 0) {
+ // Just an advise, not everyone will listen...
+ }
if (getStart() == nullptr) {
setStart(mem);
// assumes len parameter is always multiple of the current block size.