VirtualBox

source: vbox/trunk/src/libs/kStuff/iprt/kHlpPage-iprt.cpp@ 7740

Last change on this file since 7740 was 5999, checked in by vboxsync, 17 years ago

The Giant CDDL Dual-License Header Change.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 2.3 KB
Line 
1/* $Id: kHlpPage-iprt.cpp 5999 2007-12-07 15:05:06Z vboxsync $ */
2/** @file
3 * kHlpPage - Page Memory Allocation, IPRT based implementation.
4 */
5
6/*
7 * Copyright (C) 2007 innotek GmbH
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18/*******************************************************************************
19* Header Files *
20*******************************************************************************/
21#include <k/kHlpAlloc.h>
22#include <k/kErrors.h>
23#include <iprt/mem.h>
24#include <iprt/assert.h>
25#include <iprt/err.h>
26
27
28
29static unsigned kHlpPageProtToNative(KPROT enmProt)
30{
31 switch (enmProt)
32 {
33 case KPROT_NOACCESS: return RTMEM_PROT_NONE;
34 case KPROT_READONLY: return RTMEM_PROT_READ;
35 case KPROT_READWRITE: return RTMEM_PROT_READ | RTMEM_PROT_WRITE;
36 case KPROT_EXECUTE: return RTMEM_PROT_EXEC;
37 case KPROT_EXECUTE_READ: return RTMEM_PROT_EXEC | RTMEM_PROT_READ;
38 case KPROT_EXECUTE_READWRITE: return RTMEM_PROT_EXEC | RTMEM_PROT_READ | RTMEM_PROT_WRITE;
39 default:
40 AssertFailed();
41 return ~0U;
42 }
43}
44
45
46KHLP_DECL(int) kHlpPageAlloc(void **ppv, KSIZE cb, KPROT enmProt, KBOOL fFixed)
47{
48 AssertReturn(fFixed, KERR_NOT_IMPLEMENTED);
49
50 int rc = VINF_SUCCESS;
51 void *pv = RTMemPageAlloc(cb);
52 if (pv)
53 {
54 rc = RTMemProtect(pv, cb, kHlpPageProtToNative(enmProt));
55 if (RT_SUCCESS(rc))
56 *ppv = pv;
57 else
58 RTMemPageFree(pv);
59 }
60 return rc;
61}
62
63
64KHLP_DECL(int) kHlpPageProtect(void *pv, KSIZE cb, KPROT enmProt)
65{
66 int rc = RTMemProtect(pv, cb, kHlpPageProtToNative(enmProt));
67 if (!rc)
68 return 0;
69 /** @todo convert iprt status code -> kErrors */
70 return rc;
71}
72
73
74KHLP_DECL(int) kHlpPageFree(void *pv, KSIZE cb)
75{
76 RTMemPageFree(pv);
77 return 0;
78}
79
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette