1*699cd480SApple OSS Distributions /*
2*699cd480SApple OSS Distributions * Copyright (c) 2021 Apple Inc. All rights reserved.
3*699cd480SApple OSS Distributions *
4*699cd480SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*699cd480SApple OSS Distributions *
6*699cd480SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code
7*699cd480SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License
8*699cd480SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in
9*699cd480SApple OSS Distributions * compliance with the License. The rights granted to you under the License
10*699cd480SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of,
11*699cd480SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to
12*699cd480SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any
13*699cd480SApple OSS Distributions * terms of an Apple operating system software license agreement.
14*699cd480SApple OSS Distributions *
15*699cd480SApple OSS Distributions * Please obtain a copy of the License at
16*699cd480SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*699cd480SApple OSS Distributions *
18*699cd480SApple OSS Distributions * The Original Code and all software distributed under the License are
19*699cd480SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*699cd480SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*699cd480SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*699cd480SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*699cd480SApple OSS Distributions * Please see the License for the specific language governing rights and
24*699cd480SApple OSS Distributions * limitations under the License.
25*699cd480SApple OSS Distributions *
26*699cd480SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*699cd480SApple OSS Distributions */
28*699cd480SApple OSS Distributions /*
29*699cd480SApple OSS Distributions * @OSF_COPYRIGHT@
30*699cd480SApple OSS Distributions */
31*699cd480SApple OSS Distributions /*
32*699cd480SApple OSS Distributions * Mach Operating System
33*699cd480SApple OSS Distributions * Copyright (c) 1991,1990,1989,1988,1987 Carnegie Mellon University
34*699cd480SApple OSS Distributions * All Rights Reserved.
35*699cd480SApple OSS Distributions *
36*699cd480SApple OSS Distributions * Permission to use, copy, modify and distribute this software and its
37*699cd480SApple OSS Distributions * documentation is hereby granted, provided that both the copyright
38*699cd480SApple OSS Distributions * notice and this permission notice appear in all copies of the
39*699cd480SApple OSS Distributions * software, derivative works or modified versions, and any portions
40*699cd480SApple OSS Distributions * thereof, and that both notices appear in supporting documentation.
41*699cd480SApple OSS Distributions *
42*699cd480SApple OSS Distributions * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
43*699cd480SApple OSS Distributions * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
44*699cd480SApple OSS Distributions * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
45*699cd480SApple OSS Distributions *
46*699cd480SApple OSS Distributions * Carnegie Mellon requests users of this software to return to
47*699cd480SApple OSS Distributions *
48*699cd480SApple OSS Distributions * Software Distribution Coordinator or [email protected]
49*699cd480SApple OSS Distributions * School of Computer Science
50*699cd480SApple OSS Distributions * Carnegie Mellon University
51*699cd480SApple OSS Distributions * Pittsburgh PA 15213-3890
52*699cd480SApple OSS Distributions *
53*699cd480SApple OSS Distributions * any improvements or extensions that they make and grant Carnegie Mellon
54*699cd480SApple OSS Distributions * the rights to redistribute these changes.
55*699cd480SApple OSS Distributions */
56*699cd480SApple OSS Distributions
57*699cd480SApple OSS Distributions #ifndef _VM_VM_MAP_INTERNAL_H_
58*699cd480SApple OSS Distributions #define _VM_VM_MAP_INTERNAL_H_
59*699cd480SApple OSS Distributions
60*699cd480SApple OSS Distributions #include <vm/vm_map.h>
61*699cd480SApple OSS Distributions #include <vm/vm_kern.h>
62*699cd480SApple OSS Distributions
63*699cd480SApple OSS Distributions __BEGIN_DECLS
64*699cd480SApple OSS Distributions #pragma GCC visibility push(hidden)
65*699cd480SApple OSS Distributions
66*699cd480SApple OSS Distributions /*
67*699cd480SApple OSS Distributions * This file contains interfaces that are private to the VM
68*699cd480SApple OSS Distributions */
69*699cd480SApple OSS Distributions
70*699cd480SApple OSS Distributions #define KiB(x) (1024 * (x))
71*699cd480SApple OSS Distributions #define MeB(x) (1024 * 1024 * (x))
72*699cd480SApple OSS Distributions
73*699cd480SApple OSS Distributions #if __LP64__
74*699cd480SApple OSS Distributions #define KMEM_SMALLMAP_THRESHOLD (MeB(1))
75*699cd480SApple OSS Distributions #else
76*699cd480SApple OSS Distributions #define KMEM_SMALLMAP_THRESHOLD (KiB(256))
77*699cd480SApple OSS Distributions #endif
78*699cd480SApple OSS Distributions
79*699cd480SApple OSS Distributions struct kmem_page_meta;
80*699cd480SApple OSS Distributions
81*699cd480SApple OSS Distributions /* Initialize the module */
82*699cd480SApple OSS Distributions extern void vm_map_init(void);
83*699cd480SApple OSS Distributions
84*699cd480SApple OSS Distributions extern kern_return_t vm_map_locate_space(
85*699cd480SApple OSS Distributions vm_map_t map,
86*699cd480SApple OSS Distributions vm_map_size_t size,
87*699cd480SApple OSS Distributions vm_map_offset_t mask,
88*699cd480SApple OSS Distributions vm_map_kernel_flags_t vmk_flags,
89*699cd480SApple OSS Distributions vm_map_offset_t *start_inout,
90*699cd480SApple OSS Distributions vm_map_entry_t *entry_out);
91*699cd480SApple OSS Distributions
92*699cd480SApple OSS Distributions /* Allocate a range in the specified virtual address map and
93*699cd480SApple OSS Distributions * return the entry allocated for that range. */
94*699cd480SApple OSS Distributions extern kern_return_t vm_map_find_space(
95*699cd480SApple OSS Distributions vm_map_t map,
96*699cd480SApple OSS Distributions vm_map_address_t hint_addr,
97*699cd480SApple OSS Distributions vm_map_size_t size,
98*699cd480SApple OSS Distributions vm_map_offset_t mask,
99*699cd480SApple OSS Distributions vm_map_kernel_flags_t vmk_flags,
100*699cd480SApple OSS Distributions vm_map_entry_t *o_entry); /* OUT */
101*699cd480SApple OSS Distributions
102*699cd480SApple OSS Distributions extern void vm_map_clip_start(
103*699cd480SApple OSS Distributions vm_map_t map,
104*699cd480SApple OSS Distributions vm_map_entry_t entry,
105*699cd480SApple OSS Distributions vm_map_offset_t endaddr);
106*699cd480SApple OSS Distributions
107*699cd480SApple OSS Distributions extern void vm_map_clip_end(
108*699cd480SApple OSS Distributions vm_map_t map,
109*699cd480SApple OSS Distributions vm_map_entry_t entry,
110*699cd480SApple OSS Distributions vm_map_offset_t endaddr);
111*699cd480SApple OSS Distributions
112*699cd480SApple OSS Distributions extern boolean_t vm_map_entry_should_cow_for_true_share(
113*699cd480SApple OSS Distributions vm_map_entry_t entry);
114*699cd480SApple OSS Distributions
115*699cd480SApple OSS Distributions /*!
116*699cd480SApple OSS Distributions * @typedef vmr_flags_t
117*699cd480SApple OSS Distributions *
118*699cd480SApple OSS Distributions * @brief
119*699cd480SApple OSS Distributions * Flags for vm_map_remove() and vm_map_delete()
120*699cd480SApple OSS Distributions *
121*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_NO_FLAGS
122*699cd480SApple OSS Distributions * When no special flags is to be passed.
123*699cd480SApple OSS Distributions *
124*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_KUNWIRE
125*699cd480SApple OSS Distributions * Unwire memory as a side effect.
126*699cd480SApple OSS Distributions *
127*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_INTERRUPTIBLE
128*699cd480SApple OSS Distributions * Whether the call is interruptible if it needs to wait for a vm map
129*699cd480SApple OSS Distributions * entry to quiesce (interruption leads to KERN_ABORTED).
130*699cd480SApple OSS Distributions *
131*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_NOKUNWIRE_LAST
132*699cd480SApple OSS Distributions * Do not unwire the last page of this entry during remove.
133*699cd480SApple OSS Distributions * (Used by kmem_realloc()).
134*699cd480SApple OSS Distributions *
135*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_IMMUTABLE
136*699cd480SApple OSS Distributions * Allow permanent entries to be removed.
137*699cd480SApple OSS Distributions *
138*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_GAPS_FAIL
139*699cd480SApple OSS Distributions * Return KERN_INVALID_VALUE when a gap is being removed instead of panicking.
140*699cd480SApple OSS Distributions *
141*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_NO_YIELD.
142*699cd480SApple OSS Distributions * Try to avoid yielding during this call.
143*699cd480SApple OSS Distributions *
144*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_GUESS_SIZE
145*699cd480SApple OSS Distributions * The caller doesn't know the precise size of the entry,
146*699cd480SApple OSS Distributions * but the address must match an atomic entry.
147*699cd480SApple OSS Distributions *
148*699cd480SApple OSS Distributions * @const VM_MAP_REMOVE_IMMUTABLE_CODE
149*699cd480SApple OSS Distributions * Allow executables entries to be removed (for VM_PROT_COPY),
150*699cd480SApple OSS Distributions * which is used by debuggers.
151*699cd480SApple OSS Distributions */
152*699cd480SApple OSS Distributions __options_decl(vmr_flags_t, uint32_t, {
153*699cd480SApple OSS Distributions VM_MAP_REMOVE_NO_FLAGS = 0x000,
154*699cd480SApple OSS Distributions VM_MAP_REMOVE_KUNWIRE = 0x001,
155*699cd480SApple OSS Distributions VM_MAP_REMOVE_INTERRUPTIBLE = 0x002,
156*699cd480SApple OSS Distributions VM_MAP_REMOVE_NOKUNWIRE_LAST = 0x004,
157*699cd480SApple OSS Distributions VM_MAP_REMOVE_NO_MAP_ALIGN = 0x008,
158*699cd480SApple OSS Distributions VM_MAP_REMOVE_IMMUTABLE = 0x010,
159*699cd480SApple OSS Distributions VM_MAP_REMOVE_GAPS_FAIL = 0x020,
160*699cd480SApple OSS Distributions VM_MAP_REMOVE_NO_YIELD = 0x040,
161*699cd480SApple OSS Distributions VM_MAP_REMOVE_GUESS_SIZE = 0x080,
162*699cd480SApple OSS Distributions VM_MAP_REMOVE_IMMUTABLE_CODE = 0x100,
163*699cd480SApple OSS Distributions VM_MAP_REMOVE_TO_OVERWRITE = 0x200,
164*699cd480SApple OSS Distributions });
165*699cd480SApple OSS Distributions
166*699cd480SApple OSS Distributions /* Deallocate a region */
167*699cd480SApple OSS Distributions extern kmem_return_t vm_map_remove_guard(
168*699cd480SApple OSS Distributions vm_map_t map,
169*699cd480SApple OSS Distributions vm_map_offset_t start,
170*699cd480SApple OSS Distributions vm_map_offset_t end,
171*699cd480SApple OSS Distributions vmr_flags_t flags,
172*699cd480SApple OSS Distributions kmem_guard_t guard) __result_use_check;
173*699cd480SApple OSS Distributions
174*699cd480SApple OSS Distributions extern kmem_return_t vm_map_remove_and_unlock(
175*699cd480SApple OSS Distributions vm_map_t map,
176*699cd480SApple OSS Distributions vm_map_offset_t start,
177*699cd480SApple OSS Distributions vm_map_offset_t end,
178*699cd480SApple OSS Distributions vmr_flags_t flags,
179*699cd480SApple OSS Distributions kmem_guard_t guard) __result_use_check;
180*699cd480SApple OSS Distributions
181*699cd480SApple OSS Distributions /* Deallocate a region */
182*699cd480SApple OSS Distributions static inline void
vm_map_remove(vm_map_t map,vm_map_offset_t start,vm_map_offset_t end)183*699cd480SApple OSS Distributions vm_map_remove(
184*699cd480SApple OSS Distributions vm_map_t map,
185*699cd480SApple OSS Distributions vm_map_offset_t start,
186*699cd480SApple OSS Distributions vm_map_offset_t end)
187*699cd480SApple OSS Distributions {
188*699cd480SApple OSS Distributions vmr_flags_t flags = VM_MAP_REMOVE_NO_FLAGS;
189*699cd480SApple OSS Distributions kmem_guard_t guard = KMEM_GUARD_NONE;
190*699cd480SApple OSS Distributions
191*699cd480SApple OSS Distributions (void)vm_map_remove_guard(map, start, end, flags, guard);
192*699cd480SApple OSS Distributions }
193*699cd480SApple OSS Distributions
194*699cd480SApple OSS Distributions extern bool kmem_is_ptr_range(vm_map_range_id_t range_id);
195*699cd480SApple OSS Distributions
196*699cd480SApple OSS Distributions extern mach_vm_range_t kmem_validate_range_for_overwrite(
197*699cd480SApple OSS Distributions vm_map_offset_t addr,
198*699cd480SApple OSS Distributions vm_map_size_t size);
199*699cd480SApple OSS Distributions
200*699cd480SApple OSS Distributions extern uint32_t kmem_addr_get_slot_idx(
201*699cd480SApple OSS Distributions vm_map_offset_t start,
202*699cd480SApple OSS Distributions vm_map_offset_t end,
203*699cd480SApple OSS Distributions vm_map_range_id_t range_id,
204*699cd480SApple OSS Distributions struct kmem_page_meta **meta,
205*699cd480SApple OSS Distributions uint32_t *size_idx,
206*699cd480SApple OSS Distributions mach_vm_range_t slot);
207*699cd480SApple OSS Distributions
208*699cd480SApple OSS Distributions extern void kmem_validate_slot(
209*699cd480SApple OSS Distributions vm_map_offset_t addr,
210*699cd480SApple OSS Distributions struct kmem_page_meta *meta,
211*699cd480SApple OSS Distributions uint32_t size_idx,
212*699cd480SApple OSS Distributions uint32_t slot_idx);
213*699cd480SApple OSS Distributions
214*699cd480SApple OSS Distributions /*
215*699cd480SApple OSS Distributions * Function used to allocate VA from kmem pointer ranges
216*699cd480SApple OSS Distributions */
217*699cd480SApple OSS Distributions extern kern_return_t kmem_locate_space(
218*699cd480SApple OSS Distributions vm_map_size_t size,
219*699cd480SApple OSS Distributions vm_map_range_id_t range_id,
220*699cd480SApple OSS Distributions bool direction,
221*699cd480SApple OSS Distributions vm_map_offset_t *start_inout,
222*699cd480SApple OSS Distributions vm_map_entry_t *entry_out);
223*699cd480SApple OSS Distributions
224*699cd480SApple OSS Distributions /*
225*699cd480SApple OSS Distributions * Function used to free VA to kmem pointer ranges
226*699cd480SApple OSS Distributions */
227*699cd480SApple OSS Distributions extern void kmem_free_space(
228*699cd480SApple OSS Distributions vm_map_offset_t start,
229*699cd480SApple OSS Distributions vm_map_offset_t end,
230*699cd480SApple OSS Distributions vm_map_range_id_t range_id,
231*699cd480SApple OSS Distributions mach_vm_range_t slot);
232*699cd480SApple OSS Distributions
233*699cd480SApple OSS Distributions #pragma GCC visibility pop
234*699cd480SApple OSS Distributions __END_DECLS
235*699cd480SApple OSS Distributions
236*699cd480SApple OSS Distributions #endif /* _VM_VM_MAP_INTERNAL_H_ */
237