mirror of
https://github.com/microsoft/mimalloc.git
synced 2025-05-05 06:59:32 +03:00
Merge branch 'dev' of https://github.com/microsoft/mimalloc into dev
This commit is contained in:
commit
4d8ba61a2d
2 changed files with 50 additions and 1 deletions
|
@ -173,7 +173,7 @@ extern "C" {
|
||||||
void cfree(void* p) MI_FORWARD0(mi_free, p)
|
void cfree(void* p) MI_FORWARD0(mi_free, p)
|
||||||
void* reallocf(void* p, size_t newsize) MI_FORWARD2(mi_reallocf,p,newsize)
|
void* reallocf(void* p, size_t newsize) MI_FORWARD2(mi_reallocf,p,newsize)
|
||||||
size_t malloc_size(const void* p) MI_FORWARD1(mi_usable_size,p)
|
size_t malloc_size(const void* p) MI_FORWARD1(mi_usable_size,p)
|
||||||
#if !defined(__ANDROID__)
|
#if !defined(__ANDROID__) && !defined(__FreeBSD__)
|
||||||
size_t malloc_usable_size(void *p) MI_FORWARD1(mi_usable_size,p)
|
size_t malloc_usable_size(void *p) MI_FORWARD1(mi_usable_size,p)
|
||||||
#else
|
#else
|
||||||
size_t malloc_usable_size(const void *p) MI_FORWARD1(mi_usable_size,p)
|
size_t malloc_usable_size(const void *p) MI_FORWARD1(mi_usable_size,p)
|
||||||
|
|
49
src/os.c
49
src/os.c
|
@ -51,6 +51,14 @@ terms of the MIT license. A copy of the license can be found in the file
|
||||||
#include <mach/vm_statistics.h>
|
#include <mach/vm_statistics.h>
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(__FreeBSD__) || defined(__DragonFly__)
|
||||||
|
#include <sys/param.h>
|
||||||
|
#if __FreeBSD_version >= 1200000
|
||||||
|
#include <sys/cpuset.h>
|
||||||
|
#include <sys/domainset.h>
|
||||||
|
#endif
|
||||||
|
#include <sys/sysctl.h>
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* -----------------------------------------------------------
|
/* -----------------------------------------------------------
|
||||||
|
@ -1236,6 +1244,47 @@ static size_t mi_os_numa_node_countx(void) {
|
||||||
}
|
}
|
||||||
return (node+1);
|
return (node+1);
|
||||||
}
|
}
|
||||||
|
#elif defined(__FreeBSD__) && __FreeBSD_version >= 1200000
|
||||||
|
static size_t mi_os_numa_nodex(void) {
|
||||||
|
domainset_t dom;
|
||||||
|
size_t node;
|
||||||
|
int policy;
|
||||||
|
|
||||||
|
if (cpuset_getdomain(CPU_LEVEL_CPUSET, CPU_WHICH_PID, -1, sizeof(dom), &dom, &policy) == -1) return 0ul;
|
||||||
|
|
||||||
|
for (node = 0; node < MAXMEMDOM; node++) {
|
||||||
|
if (DOMAINSET_ISSET(node, &dom)) return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0ul;
|
||||||
|
}
|
||||||
|
|
||||||
|
static size_t mi_os_numa_node_countx(void) {
|
||||||
|
size_t ndomains = 0;
|
||||||
|
size_t len = sizeof(ndomains);
|
||||||
|
|
||||||
|
if (sysctlbyname("vm.ndomains", &ndomains, &len, NULL, 0) == -1) return 0ul;
|
||||||
|
|
||||||
|
return ndomains;
|
||||||
|
}
|
||||||
|
#elif defined(__DragonFly__)
|
||||||
|
static size_t mi_os_numa_nodex(void) {
|
||||||
|
// TODO DragonFlyBSD does not seem to provide any userland mean to
|
||||||
|
// check this information, even less the possibility to control
|
||||||
|
// the allocation to a logical core level's granularity, only the kernel
|
||||||
|
// is fully NUMA aware at the moment.
|
||||||
|
return 0ul;
|
||||||
|
}
|
||||||
|
|
||||||
|
static size_t mi_os_numa_node_countx(void) {
|
||||||
|
size_t ncpus = 0, nvirtcoresperphys = 0;
|
||||||
|
size_t len = sizeof(size_t);
|
||||||
|
|
||||||
|
if (sysctlbyname("hw.ncpu", &ncpus, &len, NULL, 0) == -1) return 0ul;
|
||||||
|
if (sysctlbyname("hw.cpu_topology_ht_ids", &nvirtcoresperphys, &len, NULL, 0) == -1) return 0ul;
|
||||||
|
|
||||||
|
return nvirtcoresperphys * ncpus;
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
static size_t mi_os_numa_nodex(void) {
|
static size_t mi_os_numa_nodex(void) {
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Add table
Reference in a new issue