Support HW_PHYSMEM64

This commit is contained in:
Lasse Collin 2009-06-24 20:14:10 +03:00
parent ae82dde5d9
commit b317b218e2
1 changed files with 19 additions and 11 deletions

View File

@ -59,19 +59,27 @@ physmem(void)
ret = (uint64_t)(pagesize) * (uint64_t)(pages); ret = (uint64_t)(pagesize) * (uint64_t)(pages);
#elif defined(HAVE_PHYSMEM_SYSCTL) #elif defined(HAVE_PHYSMEM_SYSCTL)
int name[2] = { CTL_HW, HW_PHYSMEM }; int name[2] = {
CTL_HW,
#ifdef HW_PHYSMEM64
HW_PHYSMEM64
#else
HW_PHYSMEM
#endif
};
union { union {
unsigned long ul; uint32_t u32;
unsigned int ui; uint64_t u64;
} mem; } mem;
size_t mem_ptr_size = sizeof(mem.ul); size_t mem_ptr_size = sizeof(mem.u64);
if (!sysctl(name, 2, &mem.ul, &mem_ptr_size, NULL, NULL)) { if (!sysctl(name, 2, &mem.u64, &mem_ptr_size, NULL, NULL)) {
// Some systems use unsigned int as the "return value". // IIRC, 64-bit "return value" is possible on some 64-bit
// This makes a difference on 64-bit boxes. // BSD systems even with HW_PHYSMEM (instead of HW_PHYSMEM64),
if (mem_ptr_size == sizeof(mem.ul)) // so support both.
ret = mem.ul; if (mem_ptr_size == sizeof(mem.u64))
else if (mem_ptr_size == sizeof(mem.ui)) ret = mem.u64;
ret = mem.ui; else if (mem_ptr_size == sizeof(mem.u32))
ret = mem.u32;
} }
#elif defined(HAVE_PHYSMEM_SYSINFO) #elif defined(HAVE_PHYSMEM_SYSINFO)