2 * Copyright (c) 2007 Apple Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
25 * File: vm/vm_shared_region.h
27 * protos and struct definitions for shared region
30 #ifndef _VM_SHARED_REGION_H_
31 #define _VM_SHARED_REGION_H_
35 #include <mach/vm_prot.h>
36 #include <mach/mach_types.h>
37 #include <mach/shared_region.h>
39 #include <kern/kern_types.h>
40 #include <kern/macro_help.h>
42 #include <vm/vm_map.h>
44 extern int shared_region_version
;
45 extern int shared_region_persistence
;
46 extern boolean_t shared_region_completed_slide
;
49 extern int shared_region_debug
;
50 #define SHARED_REGION_DEBUG(args) \
52 if (shared_region_debug) { \
57 #define SHARED_REGION_DEBUG(args)
60 extern int shared_region_trace_level
;
61 #define SHARED_REGION_TRACE_NONE_LVL 0 /* no trace */
62 #define SHARED_REGION_TRACE_ERROR_LVL 1 /* trace abnormal events */
63 #define SHARED_REGION_TRACE_INFO_LVL 2 /* trace all events */
64 #define SHARED_REGION_TRACE_DEBUG_LVL 3 /* extra traces for debug */
65 #define SHARED_REGION_TRACE(level, args) \
67 if (shared_region_trace_level >= level) { \
71 #define SHARED_REGION_TRACE_NONE(args)
72 #define SHARED_REGION_TRACE_ERROR(args) \
74 SHARED_REGION_TRACE(SHARED_REGION_TRACE_ERROR_LVL, \
77 #define SHARED_REGION_TRACE_INFO(args) \
79 SHARED_REGION_TRACE(SHARED_REGION_TRACE_INFO_LVL, \
82 #define SHARED_REGION_TRACE_DEBUG(args) \
84 SHARED_REGION_TRACE(SHARED_REGION_TRACE_DEBUG_LVL, \
88 typedef struct vm_shared_region
*vm_shared_region_t
;
90 #ifdef MACH_KERNEL_PRIVATE
92 #include <kern/queue.h>
93 #include <vm/vm_object.h>
94 #include <vm/memory_object.h>
96 /* address space shared region descriptor */
97 struct vm_shared_region
{
98 uint32_t sr_ref_count
;
101 cpu_type_t sr_cpu_type
;
103 boolean_t sr_mapping_in_progress
;
104 boolean_t sr_persists
;
105 ipc_port_t sr_mem_entry
;
106 mach_vm_offset_t sr_first_mapping
;
107 mach_vm_offset_t sr_base_address
;
108 mach_vm_size_t sr_size
;
109 mach_vm_offset_t sr_pmap_nesting_start
;
110 mach_vm_size_t sr_pmap_nesting_size
;
111 thread_call_t sr_timer_call
;
114 typedef struct vm_shared_region_slide_info_entry
*vm_shared_region_slide_info_entry_t
;
115 struct vm_shared_region_slide_info_entry
{
117 uint32_t toc_offset
; // offset from start of header to table-of-contents
118 uint32_t toc_count
; // number of entries in toc (same as number of pages in r/w mapping)
119 uint32_t entry_offset
;
120 uint32_t entry_count
;
124 #define NUM_SLIDING_BITMAPS_PER_PAGE (PAGE_SIZE/sizeof(int)/NBBY) /*128*/
125 typedef struct slide_info_entry_toc
*slide_info_entry_toc_t
;
126 struct slide_info_entry_toc
{
127 uint8_t entry
[NUM_SLIDING_BITMAPS_PER_PAGE
];
130 typedef struct vm_shared_region_slide_info vm_shared_region_slide_info_t
;
131 struct vm_shared_region_slide_info
{
132 mach_vm_offset_t start
;
133 mach_vm_offset_t end
;
135 vm_object_t slide_object
;
136 mach_vm_size_t slide_info_size
;
137 vm_shared_region_slide_info_entry_t slide_info_entry
;
138 vm_shared_region_t sr
;
141 extern struct vm_shared_region_slide_info slide_info
;
143 #else /* !MACH_KERNEL_PRIVATE */
145 struct vm_shared_region
;
146 struct vm_shared_region_slide_info
;
147 struct vm_shared_region_slide_info_entry
;
148 struct slide_info_entry_toc
;
150 #endif /* MACH_KERNEL_PRIVATE */
152 extern void vm_shared_region_init(void);
153 extern kern_return_t
vm_shared_region_enter(
158 extern kern_return_t
vm_shared_region_remove(
161 extern vm_shared_region_t
vm_shared_region_get(
163 extern void vm_shared_region_deallocate(
164 struct vm_shared_region
*shared_region
);
165 extern mach_vm_offset_t
vm_shared_region_base_address(
166 struct vm_shared_region
*shared_region
);
167 extern mach_vm_size_t
vm_shared_region_size(
168 struct vm_shared_region
*shared_region
);
169 extern ipc_port_t
vm_shared_region_mem_entry(
170 struct vm_shared_region
*shared_region
);
171 extern void vm_shared_region_set(
173 struct vm_shared_region
*new_shared_region
);
174 extern vm_shared_region_t
vm_shared_region_lookup(
178 extern kern_return_t
vm_shared_region_start_address(
179 struct vm_shared_region
*shared_region
,
180 mach_vm_offset_t
*start_address
);
181 extern void vm_shared_region_undo_mappings(
183 mach_vm_offset_t sr_base_address
,
184 struct shared_file_mapping_np
*mappings
,
185 unsigned int mappings_count
);
186 extern kern_return_t
vm_shared_region_map_file(
187 struct vm_shared_region
*shared_region
,
188 unsigned int mappings_count
,
189 struct shared_file_mapping_np
*mappings
,
190 memory_object_control_t file_control
,
191 memory_object_size_t file_size
,
193 struct shared_file_mapping_np
*mapping_to_slide
);
194 extern kern_return_t
vm_shared_region_sliding_valid(uint32_t slide
);
195 extern kern_return_t
vm_shared_region_slide_sanity_check(void);
196 extern kern_return_t
vm_shared_region_slide_init(mach_vm_size_t slide_info_size
,
197 mach_vm_offset_t start
,
200 memory_object_control_t
);
201 extern void* vm_shared_region_get_slide_info(void);
202 extern void* vm_shared_region_get_slide_info_entry(void);
203 extern kern_return_t
vm_shared_region_slide(
206 extern void vm_commpage_init(void);
207 extern void vm_commpage_text_init(void);
208 extern kern_return_t
vm_commpage_enter(
211 extern kern_return_t
vm_commpage_remove(
215 #endif /* KERNEL_PRIVATE */
217 #endif /* _VM_SHARED_REGION_H_ */