summaryrefslogtreecommitdiff
path: root/Zend/zend_alloc.c
diff options
context:
space:
mode:
authorNikita Popov <nikita.ppv@gmail.com>2019-02-18 14:04:30 +0100
committerNikita Popov <nikita.ppv@gmail.com>2019-02-18 14:04:30 +0100
commit709b8aaf9fa5fc81946aa9698abb1533bd38a439 (patch)
tree817f9b9d11db5c0c9fd5e5c7263a4642fb8da37d /Zend/zend_alloc.c
parentc9ffae1bec67d628d2859368be66175b5c693de5 (diff)
parent3b3fafa637914d59c5588d72ddd0f6016642be0a (diff)
downloadphp-git-709b8aaf9fa5fc81946aa9698abb1533bd38a439.tar.gz
Merge branch 'PHP-7.3' into PHP-7.4
Diffstat (limited to 'Zend/zend_alloc.c')
-rw-r--r--Zend/zend_alloc.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/Zend/zend_alloc.c b/Zend/zend_alloc.c
index 139fb694e7..f0ceb4dd35 100644
--- a/Zend/zend_alloc.c
+++ b/Zend/zend_alloc.c
@@ -190,9 +190,7 @@ typedef struct _zend_mm_free_slot zend_mm_free_slot;
typedef struct _zend_mm_chunk zend_mm_chunk;
typedef struct _zend_mm_huge_list zend_mm_huge_list;
-#ifdef MAP_HUGETLB
int zend_mm_use_huge_pages = 0;
-#endif
/*
* Memory is retrieved from OS by chunks of fixed size 2MB.
@@ -709,7 +707,9 @@ static void *zend_mm_chunk_alloc_int(size_t size, size_t alignment)
return NULL;
} else if (ZEND_MM_ALIGNED_OFFSET(ptr, alignment) == 0) {
#ifdef MADV_HUGEPAGE
- madvise(ptr, size, MADV_HUGEPAGE);
+ if (zend_mm_use_huge_pages) {
+ madvise(ptr, size, MADV_HUGEPAGE);
+ }
#endif
return ptr;
} else {
@@ -740,7 +740,9 @@ static void *zend_mm_chunk_alloc_int(size_t size, size_t alignment)
zend_mm_munmap((char*)ptr + size, alignment - REAL_PAGE_SIZE);
}
# ifdef MADV_HUGEPAGE
- madvise(ptr, size, MADV_HUGEPAGE);
+ if (zend_mm_use_huge_pages) {
+ madvise(ptr, size, MADV_HUGEPAGE);
+ }
# endif
#endif
return ptr;
@@ -2702,9 +2704,7 @@ ZEND_API void shutdown_memory_manager(int silent, int full_shutdown)
static void alloc_globals_ctor(zend_alloc_globals *alloc_globals)
{
-#if ZEND_MM_CUSTOM || MAP_HUGETLB
char *tmp;
-#endif
#if ZEND_MM_CUSTOM
tmp = getenv("USE_ZEND_ALLOC");
@@ -2718,12 +2718,11 @@ static void alloc_globals_ctor(zend_alloc_globals *alloc_globals)
return;
}
#endif
-#ifdef MAP_HUGETLB
+
tmp = getenv("USE_ZEND_ALLOC_HUGE_PAGES");
if (tmp && zend_atoi(tmp, 0)) {
zend_mm_use_huge_pages = 1;
}
-#endif
ZEND_TSRMLS_CACHE_UPDATE();
alloc_globals->mm_heap = zend_mm_init();
}