]> git.saurik.com Git - apple/xnu.git/blame - osfmk/ppc/machine_routines.h
xnu-1504.7.4.tar.gz
[apple/xnu.git] / osfmk / ppc / machine_routines.h
CommitLineData
1c79356b 1/*
2d21ac55 2 * Copyright (c) 2000-2006 Apple Computer, Inc. All rights reserved.
1c79356b 3 *
2d21ac55 4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
1c79356b 5 *
2d21ac55
A
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. The rights granted to you under the License
10 * may not be used to create, or enable the creation or redistribution of,
11 * unlawful or unlicensed copies of an Apple operating system, or to
12 * circumvent, violate, or enable the circumvention or violation of, any
13 * terms of an Apple operating system software license agreement.
8f6c56a5 14 *
2d21ac55
A
15 * Please obtain a copy of the License at
16 * http://www.opensource.apple.com/apsl/ and read it before using this file.
17 *
18 * The Original Code and all software distributed under the License are
19 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
8f6c56a5
A
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
2d21ac55
A
22 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23 * Please see the License for the specific language governing rights and
24 * limitations under the License.
8f6c56a5 25 *
2d21ac55 26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
1c79356b
A
27 */
28/*
29 * @OSF_COPYRIGHT@
30 */
31
32#ifndef _PPC_MACHINE_ROUTINES_H_
33#define _PPC_MACHINE_ROUTINES_H_
34
35#include <mach/mach_types.h>
36#include <mach/boolean.h>
37#include <kern/kern_types.h>
38#include <pexpert/pexpert.h>
39
b0d623f7
A
40#include <sys/cdefs.h>
41#include <sys/appleapiopts.h>
42
43__BEGIN_DECLS
44
9bccf70c 45/* Get Interrupts Enabled */
91447636
A
46extern boolean_t ml_get_interrupts_enabled(
47 void);
1c79356b 48
9bccf70c 49/* Set Interrupts Enabled */
91447636
A
50extern boolean_t ml_set_interrupts_enabled(
51 boolean_t enable);
1c79356b 52
9bccf70c 53/* Check if running at interrupt context */
91447636
A
54extern boolean_t ml_at_interrupt_context(
55 void);
56
57#ifdef KERNEL_PRIVATE
1c79356b 58
9bccf70c 59/* Generate a fake interrupt */
91447636
A
60extern void ml_cause_interrupt(
61 void);
9bccf70c
A
62
63/* Type for the IPI Hander */
64typedef void (*ipi_handler_t)(void);
65
66/* Type for the Time Base Enable function */
67typedef void (*time_base_enable_t)(cpu_id_t cpu_id, boolean_t enable);
68
69/* enables (or disables) the processor nap mode the function returns the previous value*/
91447636
A
70extern boolean_t ml_enable_nap(
71 int target_cpu,
72 boolean_t nap_enabled);
9bccf70c
A
73
74/* Put the processor to sleep */
91447636
A
75extern void ml_ppc_sleep(
76 void);
77
78extern void ml_get_timebase(
79 unsigned long long *timstamp);
9bccf70c 80
91447636
A
81extern int ml_enable_cache_level(
82 int cache_level,
83 int enable);
1c79356b 84
91447636
A
85extern void ml_static_mfree(
86 vm_offset_t vaddr,
87 vm_size_t size);
1c79356b 88
1c79356b 89/* Init Interrupts */
91447636
A
90extern void ml_install_interrupt_handler(
91 void *nub,
92 int source,
93 void *target,
94 IOInterruptHandler handler,
95 void *refCon);
1c79356b 96
91447636
A
97extern vm_offset_t ml_static_ptovirt(
98 vm_offset_t paddr);
1c79356b 99
9bccf70c 100/* virtual to physical on wired pages */
91447636
A
101extern vm_offset_t ml_vtophys(
102 vm_offset_t vaddr);
1c79356b 103
2d21ac55
A
104vm_size_t ml_nofault_copy(
105 vm_offset_t virtsrc, vm_offset_t virtdst, vm_size_t size);
106
1c79356b 107/* PCI config cycle probing */
91447636
A
108extern boolean_t ml_probe_read(
109 vm_offset_t paddr,
110 unsigned int *val);
111
112extern boolean_t ml_probe_read_64(
113 addr64_t paddr,
114 unsigned int *val);
1c79356b
A
115
116/* Read physical address byte */
91447636
A
117extern unsigned int ml_phys_read_byte(
118 vm_offset_t paddr);
119
120extern unsigned int ml_phys_read_byte_64(
121 addr64_t paddr);
55e303ae
A
122
123/* Read physical address half word */
91447636
A
124extern unsigned int ml_phys_read_half(
125 vm_offset_t paddr);
126
127extern unsigned int ml_phys_read_half_64(
128 addr64_t paddr);
1c79356b 129
55e303ae 130/* Read physical address word*/
91447636
A
131extern unsigned int ml_phys_read(
132 vm_offset_t paddr);
133
134extern unsigned int ml_phys_read_64(
135 addr64_t paddr);
136
137extern unsigned int ml_phys_read_word(
138 vm_offset_t paddr);
139
140extern unsigned int ml_phys_read_word_64(
141 addr64_t paddr);
55e303ae
A
142
143/* Read physical address double word */
91447636
A
144extern unsigned long long ml_phys_read_double(
145 vm_offset_t paddr);
146
147extern unsigned long long ml_phys_read_double_64(
148 addr64_t paddr);
1c79356b
A
149
150/* Write physical address byte */
91447636
A
151extern void ml_phys_write_byte(
152 vm_offset_t paddr,
153 unsigned int data);
154
155extern void ml_phys_write_byte_64(
156 addr64_t paddr,
157 unsigned int data);
1c79356b 158
55e303ae 159/* Write physical address half word */
91447636
A
160extern void ml_phys_write_half(
161 vm_offset_t paddr,
162 unsigned int data);
163
164extern void ml_phys_write_half_64(
165 addr64_t paddr,
166 unsigned int data);
55e303ae
A
167
168/* Write physical address word */
91447636
A
169extern void ml_phys_write(
170 vm_offset_t paddr,
171 unsigned int data);
172
173extern void ml_phys_write_64(
174 addr64_t paddr,
175 unsigned int data);
176
177extern void ml_phys_write_word(
178 vm_offset_t paddr,
179 unsigned int data);
180
181extern void ml_phys_write_word_64(
182 addr64_t paddr,
183 unsigned int data);
55e303ae
A
184
185/* Write physical address double word */
91447636
A
186extern void ml_phys_write_double(
187 vm_offset_t paddr,
188 unsigned long long data);
189
190extern void ml_phys_write_double_64(
191 addr64_t paddr,
192 unsigned long long data);
1c79356b 193
1c79356b 194/* Struct for ml_processor_register */
55e303ae 195struct ml_processor_info {
1c79356b
A
196 cpu_id_t cpu_id;
197 boolean_t boot_cpu;
198 vm_offset_t start_paddr;
199 boolean_t supports_nap;
91447636
A
200 unsigned long l2cr_value;
201 time_base_enable_t time_base_enable;
483a1d10
A
202 uint32_t power_mode_0;
203 uint32_t power_mode_1;
1c79356b
A
204};
205
55e303ae 206typedef struct ml_processor_info ml_processor_info_t;
1c79356b
A
207
208/* Register a processor */
91447636
A
209extern kern_return_t ml_processor_register(
210 ml_processor_info_t *ml_processor_info,
211 processor_t *processor,
212 ipi_handler_t *ipi_handler);
1c79356b 213
55e303ae 214/* Zero bytes starting at a physical address */
91447636
A
215extern void bzero_phys(
216 addr64_t phys_address,
217 uint32_t length);
55e303ae 218
2d21ac55
A
219/* Zero bytes starting at a physical address that's uncacheable */
220extern void bzero_phys_nc(
221 addr64_t phys_address,
222 uint32_t length);
223
b0d623f7
A
224/* Bytes available on current stack */
225vm_offset_t ml_stack_remaining(void);
226
91447636 227#endif /* KERNEL_PRIVATE */
1c79356b 228
91447636 229#ifdef XNU_KERNEL_PRIVATE
9bccf70c 230#if defined(PEXPERT_KERNEL_PRIVATE) || defined(MACH_KERNEL_PRIVATE)
1c79356b 231
9bccf70c 232/* Map memory map IO space */
91447636
A
233extern vm_offset_t ml_io_map(
234 vm_offset_t phys_addr,
235 vm_size_t size);
1c79356b 236
0c530ab8
A
237void ml_get_bouncepool_info(
238 vm_offset_t *phys_addr,
239 vm_size_t *size);
240
241
9bccf70c 242/* boot memory allocation */
91447636
A
243extern vm_offset_t ml_static_malloc(
244 vm_size_t size);
1c79356b 245
9bccf70c 246#endif /* PEXPERT_KERNEL_PRIVATE || MACH_KERNEL_PRIVATE */
1c79356b 247
1c79356b 248
91447636
A
249#ifdef MACH_KERNEL_PRIVATE
250extern void ml_init_interrupt(
251 void);
1c79356b 252
91447636
A
253extern void cacheInit(
254 void);
1c79356b 255
91447636
A
256extern void cacheDisable(
257 void);
1c79356b 258
91447636
A
259extern void ml_init_lock_timeout(
260 void);
1c79356b 261
91447636 262void ml_ppc_do_sleep(void);
ab86ba33 263
9bccf70c 264#endif /* MACH_KERNEL_PRIVATE */
91447636 265#endif /* XNU_KERNEL_PRIVATE */
9bccf70c 266
91447636
A
267#ifdef KERNEL_PRIVATE
268extern void ml_thread_policy(
269 thread_t thread,
270 unsigned policy_id,
271 unsigned policy_info);
9bccf70c
A
272
273#define MACHINE_GROUP 0x00000001
274#define MACHINE_NETWORK_GROUP 0x10000000
275#define MACHINE_NETWORK_WORKLOOP 0x00000001
276#define MACHINE_NETWORK_NETISR 0x00000002
277
43866e37 278/* Initialize the maximum number of CPUs */
91447636
A
279extern void ml_init_max_cpus(
280 unsigned int max_cpus);
43866e37
A
281
282/* Return the maximum number of CPUs set by ml_init_max_cpus() */
91447636
A
283extern unsigned int ml_get_max_cpus(
284 void);
43866e37 285
91447636
A
286extern void ml_cpu_up(void);
287extern void ml_cpu_down(void);
43866e37
A
288
289/* Struct for ml_cpu_get_info */
290struct ml_cpu_info {
9bccf70c
A
291 unsigned long vector_unit;
292 unsigned long cache_line_size;
293 unsigned long l1_icache_size;
294 unsigned long l1_dcache_size;
295 unsigned long l2_settings;
296 unsigned long l2_cache_size;
297 unsigned long l3_settings;
298 unsigned long l3_cache_size;
299};
300
43866e37 301typedef struct ml_cpu_info ml_cpu_info_t;
9bccf70c
A
302
303/* Get processor info */
91447636
A
304extern void ml_cpu_get_info(
305 ml_cpu_info_t *ml_cpu_info);
306
307extern void ml_set_processor_speed(
308 unsigned long speed);
309extern void ml_set_processor_speed_slave(
310 unsigned long speed);
311extern void ml_set_processor_speed_dpll(
312 unsigned long speed);
313extern void ml_set_processor_speed_dfs(
314 unsigned long speed);
315extern void ml_set_processor_speed_powertune(
316 unsigned long speed);
317
318extern void ml_set_processor_voltage(
319 unsigned long voltage);
320
321extern unsigned int ml_scom_write(
322 uint32_t reg,
323 uint64_t data);
324
325extern unsigned int ml_scom_read(
326 uint32_t reg,
327 uint64_t *data);
328
329extern uint32_t ml_hdec_ratio(void);
330
2d21ac55
A
331extern int boffSettingsInit;
332
91447636 333#endif /* KERNEL_PRIVATE */
9bccf70c 334
b0d623f7
A
335__END_DECLS
336
1c79356b 337#endif /* _PPC_MACHINE_ROUTINES_H_ */