fix bug in freeing huge OS page allocation spanning multiple huge OS pages
This commit is contained in:
parent
89090510bd
commit
f16435447c
5
src/os.c
5
src/os.c
@ -1254,8 +1254,8 @@ void* _mi_os_alloc_huge_os_pages(size_t pages, int numa_node, mi_msecs_t max_mse
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
mi_assert_internal(page*MI_HUGE_OS_PAGE_SIZE <= size);
|
mi_assert_internal(page*MI_HUGE_OS_PAGE_SIZE <= size);
|
||||||
if (pages_reserved != NULL) *pages_reserved = page;
|
if (pages_reserved != NULL) { *pages_reserved = page; }
|
||||||
if (psize != NULL) *psize = page * MI_HUGE_OS_PAGE_SIZE;
|
if (psize != NULL) { *psize = page * MI_HUGE_OS_PAGE_SIZE; }
|
||||||
return (page == 0 ? NULL : start);
|
return (page == 0 ? NULL : start);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1267,6 +1267,7 @@ void _mi_os_free_huge_pages(void* p, size_t size, mi_stats_t* stats) {
|
|||||||
while (size >= MI_HUGE_OS_PAGE_SIZE) {
|
while (size >= MI_HUGE_OS_PAGE_SIZE) {
|
||||||
_mi_os_free(base, MI_HUGE_OS_PAGE_SIZE, stats);
|
_mi_os_free(base, MI_HUGE_OS_PAGE_SIZE, stats);
|
||||||
size -= MI_HUGE_OS_PAGE_SIZE;
|
size -= MI_HUGE_OS_PAGE_SIZE;
|
||||||
|
base += MI_HUGE_OS_PAGE_SIZE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -163,7 +163,7 @@ int main(void) {
|
|||||||
for (size_t align = 1; align <= MI_ALIGNMENT_MAX && ok; align *= 2) {
|
for (size_t align = 1; align <= MI_ALIGNMENT_MAX && ok; align *= 2) {
|
||||||
void* ps[8];
|
void* ps[8];
|
||||||
for (int i = 0; i < 8 && ok; i++) {
|
for (int i = 0; i < 8 && ok; i++) {
|
||||||
ps[i] = mi_malloc_aligned(align/2 /*size*/, align);
|
ps[i] = mi_malloc_aligned(align*13 /*size*/, align);
|
||||||
if (ps[i] == NULL || (uintptr_t)(ps[i]) % align != 0) {
|
if (ps[i] == NULL || (uintptr_t)(ps[i]) % align != 0) {
|
||||||
ok = false;
|
ok = false;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user