VirtualBox

source: vbox/trunk/include/iprt/param.h@ 107288

Last change on this file since 107288 was 106061, checked in by vboxsync, 4 months ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.7 KB
Line 
1/** @file
2 * IPRT - Parameter Definitions.
3 */
4
5/*
6 * Copyright (C) 2006-2024 Oracle and/or its affiliates.
7 *
8 * This file is part of VirtualBox base platform packages, as
9 * available from https://www.virtualbox.org.
10 *
11 * This program is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU General Public License
13 * as published by the Free Software Foundation, in version 3 of the
14 * License.
15 *
16 * This program is distributed in the hope that it will be useful, but
17 * WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 * General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with this program; if not, see <https://www.gnu.org/licenses>.
23 *
24 * The contents of this file may alternatively be used under the terms
25 * of the Common Development and Distribution License Version 1.0
26 * (CDDL), a copy of it is provided in the "COPYING.CDDL" file included
27 * in the VirtualBox distribution, in which case the provisions of the
28 * CDDL are applicable instead of those of the GPL.
29 *
30 * You may elect to license modified versions of this file under the
31 * terms and conditions of either the GPL or the CDDL or both.
32 *
33 * SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
34 */
35
36#ifndef IPRT_INCLUDED_param_h
37#define IPRT_INCLUDED_param_h
38#ifndef RT_WITHOUT_PRAGMA_ONCE
39# pragma once
40#endif
41
42#include <iprt/cdefs.h>
43
44/** @todo Much of the PAGE_* stuff here is obsolete and highly risky to have around.
45 * As for component configs (MM_*), either we gather all in here or we move those bits away! */
46
47/** @defgroup grp_rt_param System Parameter Definitions
48 * @ingroup grp_rt_cdefs
49 * @{
50 */
51
52/* Undefine PAGE_SIZE and PAGE_SHIFT to avoid unnecessary noice when clashing
53 * with system headers. Include system headers before / after iprt depending
54 * on which you wish to take precedence. */
55#undef PAGE_SIZE
56#undef PAGE_SHIFT
57
58/* Undefine PAGE_OFFSET_MASK to avoid the conflict with the-linux-kernel.h */
59#undef PAGE_OFFSET_MASK
60
61/**
62 * i386 Page size.
63 */
64#if defined(RT_ARCH_SPARC64)
65# define PAGE_SIZE 8192
66#elif defined(RT_ARCH_ARM64)
67# if defined(RT_OS_DARWIN)
68# define PAGE_SIZE 16384
69# elif defined(RT_OS_LINUX)
70# ifdef IN_RING0
71# if RTLNX_VER_MIN(6,9,0)
72# define PAGE_SIZE (1 << CONFIG_PAGE_SHIFT)
73# else
74# define PAGE_SIZE (1 << CONFIG_ARM64_PAGE_SHIFT)
75# endif
76# elif defined(IPRT_STATIC_ARM64_PAGE_SHIFT)
77# define PAGE_SIZE (1 << IPRT_STATIC_ARM64_PAGE_SHIFT)
78# else
79# define PAGE_SIZE RT_DONT_USE_PAGE_SIZE_ON_LINUX_ARM64_IN_USERSPACE_DUE_TO_VARIABLE_PAGE_SIZE
80# endif
81# elif defined(RT_OS_WINDOWS)
82# define PAGE_SIZE 4096
83# else
84# error "This needs porting"
85# endif
86#else
87# define PAGE_SIZE 4096
88#endif
89
90/**
91 * i386 Page shift.
92 * This is used to convert between size (in bytes) and page count.
93 */
94#if defined(RT_ARCH_SPARC64)
95# define PAGE_SHIFT 13
96#elif defined(RT_ARCH_ARM64)
97# if defined(RT_OS_DARWIN)
98# define PAGE_SHIFT 14
99# elif defined(RT_OS_LINUX)
100# ifdef IN_RING0
101# if RTLNX_VER_MIN(6,9,0)
102# define PAGE_SHIFT CONFIG_PAGE_SHIFT
103# else
104# define PAGE_SHIFT CONFIG_ARM64_PAGE_SHIFT
105# endif
106# elif defined(IPRT_STATIC_ARM64_PAGE_SHIFT)
107# define PAGE_SHIFT IPRT_STATIC_ARM64_PAGE_SHIFT
108# else
109# define PAGE_SHIFT RT_DONT_USE_PAGE_SHIFT_ON_LINUX_ARM64_IN_USERSPACE_DUE_TO_VARIABLE_PAGE_SIZE
110# endif
111# elif defined(RT_OS_WINDOWS)
112# define PAGE_SHIFT 12
113# else
114# error "This needs porting"
115# endif
116#else
117# define PAGE_SHIFT 12
118#endif
119
120/**
121 * i386 Page offset mask.
122 *
123 * @note If you do one-complement this, always insert a target type case after
124 * the operator! Otherwise you may end up with weird results.
125 */
126#if defined(RT_ARCH_SPARC64)
127# define PAGE_OFFSET_MASK 0x1fff
128#elif defined(RT_ARCH_ARM64)
129# if defined(RT_OS_DARWIN)
130# define PAGE_OFFSET_MASK 0x3fff
131# elif defined(RT_OS_LINUX)
132# ifdef IN_RING0
133# define PAGE_OFFSET_MASK (PAGE_SIZE - 1)
134# elif defined(IPRT_STATIC_ARM64_PAGE_SHIFT)
135# define PAGE_OFFSET_MASK ((1 << IPRT_STATIC_ARM64_PAGE_SHIFT) - 1)
136# else
137# define PAGE_OFFSET_MASK RT_DONT_USE_PAGE_OFFSET_MASK_ON_LINUX_ARM64_IN_USERSPACE_DUE_TO_VARIABLE_PAGE_SIZE
138# endif
139# elif defined(RT_OS_WINDOWS)
140# define PAGE_OFFSET_MASK 0xfff
141# else
142# error "This needs porting"
143# endif
144#else
145# define PAGE_OFFSET_MASK 0xfff
146#endif
147
148/**
149 * Page address mask for the uintptr_t sized pointers.
150 *
151 * Be careful when using this since it may be a size too big!
152 * @remark Physical addresses are always masked using X86_PTE_PAE_PG_MASK!
153 */
154#define PAGE_BASE_MASK (~(uintptr_t)PAGE_OFFSET_MASK)
155
156/**
157 * Get the page aligned address of a POINTER in the CURRENT context.
158 *
159 * @returns Page aligned address (it's an uintptr_t).
160 * @param pv The virtual address to align.
161 *
162 * @remarks Physical addresses are always masked using X86_PTE_PAE_PG_MASK!
163 * @remarks This only works with POINTERS in the current context.
164 * Do NOT use on guest address or physical address!
165 */
166#define PAGE_ADDRESS(pv) ((uintptr_t)(pv) & ~(uintptr_t)PAGE_OFFSET_MASK)
167
168/**
169 * Get the page aligned address of a physical address
170 *
171 * @returns Page aligned address (it's an RTHCPHYS or RTGCPHYS).
172 * @param Phys The physical address to align.
173 */
174#define PHYS_PAGE_ADDRESS(Phys) ((Phys) & X86_PTE_PAE_PG_MASK)
175
176/**
177 * Host max path (the reasonable value).
178 * @remarks defined both by iprt/param.h and iprt/path.h.
179 */
180#if !defined(IPRT_INCLUDED_path_h) || defined(DOXYGEN_RUNNING)
181# define RTPATH_MAX (4096 + 4) /* (PATH_MAX + 1) on linux w/ some alignment */
182#endif
183
184/** @} */
185
186#endif /* !IPRT_INCLUDED_param_h */
187
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