7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync/* $Id$ */
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync/** @file
83de81b6f22c80532a478e79afaee21a0887302avboxsync * IPRT - Memory Allocation, Extended Alloc Workers, posix.
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync */
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync/*
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * Copyright (C) 2006-2013 Oracle Corporation
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync *
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * available from http://www.virtualbox.org. This file is free software;
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * you can redistribute it and/or modify it under the terms of the GNU
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * General Public License (GPL) as published by the Free Software
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync *
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * The contents of this file may alternatively be used under the terms
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * of the Common Development and Distribution License Version 1.0
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * VirtualBox OSE distribution, in which case the provisions of the
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * CDDL are applicable instead of those of the GPL.
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync *
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * You may elect to license modified versions of this file under the
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync * terms and conditions of either the GPL or the CDDL or both.
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync */
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync/*******************************************************************************
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync* Header Files *
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync*******************************************************************************/
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync#define RTMEM_NO_WRAP_TO_EF_APIS
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync#include <iprt/mem.h>
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync#include "internal/iprt.h"
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync#include <iprt/assert.h>
b56cf43aec514d501dec71d305d2043e00f3be53vboxsync#include <iprt/err.h>
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync#include <iprt/string.h>
83de81b6f22c80532a478e79afaee21a0887302avboxsync#include "../allocex.h"
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync#include <sys/mman.h>
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
83de81b6f22c80532a478e79afaee21a0887302avboxsyncDECLHIDDEN(int) rtMemAllocEx16BitReach(size_t cbAlloc, uint32_t fFlags, void **ppv)
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync{
a967bab752442538b3cb33cbac7c9ffa90b9c953vboxsync AssertReturn(cbAlloc < _64K, VERR_NO_MEMORY);
83de81b6f22c80532a478e79afaee21a0887302avboxsync
83de81b6f22c80532a478e79afaee21a0887302avboxsync /*
83de81b6f22c80532a478e79afaee21a0887302avboxsync * Try with every possible address hint since the possible range is very limited.
83de81b6f22c80532a478e79afaee21a0887302avboxsync */
83de81b6f22c80532a478e79afaee21a0887302avboxsync int fProt = PROT_READ | PROT_WRITE | (fFlags & RTMEMALLOCEX_FLAGS_EXEC ? PROT_EXEC : 0);
83de81b6f22c80532a478e79afaee21a0887302avboxsync uintptr_t uAddr = 0x1000;
83de81b6f22c80532a478e79afaee21a0887302avboxsync uintptr_t uAddrLast = _64K - uAddr - cbAlloc;
83de81b6f22c80532a478e79afaee21a0887302avboxsync while (uAddr <= uAddrLast)
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync {
83de81b6f22c80532a478e79afaee21a0887302avboxsync void *pv = mmap((void *)uAddr, cbAlloc, fProt, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
83de81b6f22c80532a478e79afaee21a0887302avboxsync if (pv && (uintptr_t)pv <= uAddrLast)
b15e144e6fb41bcfa068a6fb10b8cfb642b5613evboxsync {
83de81b6f22c80532a478e79afaee21a0887302avboxsync *ppv = pv;
83de81b6f22c80532a478e79afaee21a0887302avboxsync return VINF_SUCCESS;
b15e144e6fb41bcfa068a6fb10b8cfb642b5613evboxsync }
8c4cf52c3387cd9b37bbe910eb1c689965795ed8vboxsync
8c4cf52c3387cd9b37bbe910eb1c689965795ed8vboxsync if (pv)
83de81b6f22c80532a478e79afaee21a0887302avboxsync {
83de81b6f22c80532a478e79afaee21a0887302avboxsync munmap(pv, cbAlloc);
83de81b6f22c80532a478e79afaee21a0887302avboxsync pv = NULL;
83de81b6f22c80532a478e79afaee21a0887302avboxsync }
83de81b6f22c80532a478e79afaee21a0887302avboxsync uAddr += _4K;
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync }
83de81b6f22c80532a478e79afaee21a0887302avboxsync
83de81b6f22c80532a478e79afaee21a0887302avboxsync return VERR_NO_MEMORY;
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync}
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
83de81b6f22c80532a478e79afaee21a0887302avboxsyncDECLHIDDEN(int) rtMemAllocEx32BitReach(size_t cbAlloc, uint32_t fFlags, void **ppv)
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync{
83de81b6f22c80532a478e79afaee21a0887302avboxsync int fProt = PROT_READ | PROT_WRITE | (fFlags & RTMEMALLOCEX_FLAGS_EXEC ? PROT_EXEC : 0);
83de81b6f22c80532a478e79afaee21a0887302avboxsync#if ARCH_BITS == 32
83de81b6f22c80532a478e79afaee21a0887302avboxsync void *pv = mmap(NULL, cbAlloc, fProt, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
83de81b6f22c80532a478e79afaee21a0887302avboxsync if (pv)
83de81b6f22c80532a478e79afaee21a0887302avboxsync {
83de81b6f22c80532a478e79afaee21a0887302avboxsync *ppv = pv;
83de81b6f22c80532a478e79afaee21a0887302avboxsync return VINF_SUCCESS;
83de81b6f22c80532a478e79afaee21a0887302avboxsync }
83de81b6f22c80532a478e79afaee21a0887302avboxsync return VERR_NO_MEMORY;
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
83de81b6f22c80532a478e79afaee21a0887302avboxsync#elif defined(RT_OS_LINUX)
83de81b6f22c80532a478e79afaee21a0887302avboxsync# ifdef MAP_32BIT
83de81b6f22c80532a478e79afaee21a0887302avboxsync void *pv = mmap(NULL, cbAlloc, fProt, MAP_PRIVATE | MAP_ANONYMOUS | MAP_32BIT, -1, 0);
83de81b6f22c80532a478e79afaee21a0887302avboxsync if (pv)
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync {
83de81b6f22c80532a478e79afaee21a0887302avboxsync *ppv = pv;
83de81b6f22c80532a478e79afaee21a0887302avboxsync return VINF_SUCCESS;
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync }
83de81b6f22c80532a478e79afaee21a0887302avboxsync# endif
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
83de81b6f22c80532a478e79afaee21a0887302avboxsync /** @todo On linux, we need an accurate hint. Since I don't need this branch of
83de81b6f22c80532a478e79afaee21a0887302avboxsync * the code right now, I won't bother starting to parse
83de81b6f22c80532a478e79afaee21a0887302avboxsync * /proc/curproc/mmap right now... */
83de81b6f22c80532a478e79afaee21a0887302avboxsync#else
83de81b6f22c80532a478e79afaee21a0887302avboxsync#endif
83de81b6f22c80532a478e79afaee21a0887302avboxsync return VERR_NOT_SUPPORTED;
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync}
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync
83de81b6f22c80532a478e79afaee21a0887302avboxsyncDECLHIDDEN(void) rtMemFreeExYyBitReach(void *pv, size_t cb, uint32_t fFlags)
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync{
83de81b6f22c80532a478e79afaee21a0887302avboxsync munmap(pv, cb);
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync}
7d6d800ca6312fd789275abd4beeff2739c63f57vboxsync