Chameleon

Chameleon Svn Source Tree

Root/trunk/i386/libsaio/bootargs.h

1/*
2 * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5 *
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.
14 *
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
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
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.
25 *
26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27 */
28#ifndef _PEXPERT_I386_BOOT_H
29#define _PEXPERT_I386_BOOT_H
30
31#include <stdint.h>
32
33/*
34 * What the booter leaves behind for the kernel.
35 */
36
37/*
38 * Types of boot driver that may be loaded by the booter.
39 */
40enum {
41 kBootDriverTypeInvalid = 0,
42 kBootDriverTypeKEXT = 1,
43 kBootDriverTypeMKEXT = 2
44};
45
46enum {
47 kEfiReservedMemoryType= 0,
48 kEfiLoaderCode= 1,
49 kEfiLoaderData= 2,
50 kEfiBootServicesCode= 3,
51 kEfiBootServicesData= 4,
52 kEfiRuntimeServicesCode= 5,
53 kEfiRuntimeServicesData= 6,
54 kEfiConventionalMemory= 7,
55 kEfiUnusableMemory= 8,
56 kEfiACPIReclaimMemory= 9,
57 kEfiACPIMemoryNVS= 10,
58 kEfiMemoryMappedIO= 11,
59 kEfiMemoryMappedIOPortSpace = 12,
60 kEfiPalCode= 13,
61 kEfiMaxMemoryType= 14
62};
63
64/*
65 * Memory range descriptor.
66 */
67typedef struct EfiMemoryRange {
68 uint32_t Type;
69 uint32_t Pad;
70 uint64_t PhysicalStart;
71 uint64_t VirtualStart;
72 uint64_t NumberOfPages;
73 uint64_t Attribute;
74} EfiMemoryRange;
75
76#define BOOT_LINE_LENGTH 1024
77#define BOOT_STRING_LEN BOOT_LINE_LENGTH
78
79/*
80 * Video information..
81 */
82
83struct Boot_Video {
84uint32_tv_baseAddr;/* Base address of video memory */
85uint32_tv_display;/* Display Code (if Applicable */
86uint32_tv_rowBytes;/* Number of bytes per pixel row */
87uint32_tv_width;/* Width */
88uint32_tv_height;/* Height */
89uint32_tv_depth;/* Pixel Depth */
90};
91typedef struct Boot_VideoBoot_Video;
92
93/* Values for v_display */
94
95#define GRAPHICS_MODE1
96#define FB_TEXT_MODE2
97
98
99/* Struct describing an image passed in by the booter */
100struct boot_icon_element {
101 unsigned int width;
102 unsigned int height;
103 int y_offset_from_center;
104 unsigned int data_size;
105 unsigned int __reserved1[4];
106 unsigned char data[0];
107};
108typedef struct boot_icon_element boot_icon_element;
109
110/* Boot argument structure - passed into Mach kernel at boot time.
111 * "Revision" can be incremented for compatible changes
112 */
113// Lion
114#define kBootArgsRevision0
115#define kBootArgsVersion2
116
117// Snow Leopard and older
118#define kBootArgsLegacyVersion1
119#define kBootArgsLegacyRevision6
120
121/* Snapshot constants of previous revisions that are supported */
122#define kBootArgsVersion11
123#define kBootArgsVersion22
124#define kBootArgsRevision2_00
125
126#define kBootArgsEfiMode32 32
127#define kBootArgsEfiMode64 64
128
129/* Bitfields for boot_args->flags */
130#define kBootArgsFlagRebootOnPanic(1 << 0)
131#define kBootArgsFlagHiDPI(1 << 1)
132#define kBootArgsFlagBlack(1 << 2)
133#define kBootArgsFlagCSRActiveConfig(1 << 3)
134#define kBootArgsFlagCSRConfigMode(1 << 4)
135#define kBootArgsFlagCSRBoot(1 << 5)
136#define kBootArgsFlagBlackBg(1 << 6)
137#define kBootArgsFlagLoginUI(1 << 7)
138#define kBootArgsFlagInstallUI(1 << 8)
139#define kBootArgsFlagUnknownHS(1 << 9)// 512 (High Sierra only)
140
141/* Rootless configuration flags */
142// http://www.idelta.info/archives/kext-to-check-sip-rootless-status-on-el-capitan/
143#define CSR_ALLOW_UNTRUSTED_KEXTS(1 << 0) /* Allow untrusted kexts */
144#define CSR_ALLOW_UNRESTRICTED_FS(1 << 1) /* Allow unrestricted file system. */
145#define CSR_ALLOW_TASK_FOR_PID(1 << 2) /* Allow test_for_pid() */
146#define CSR_ALLOW_KERNEL_DEBUGGER(1 << 3)
147#define CSR_ALLOW_APPLE_INTERNAL(1 << 4)
148#define CSR_ALLOW_UNRESTRICTED_DTRACE(1 << 5) /* Allow unrestricted dtrace */
149#define CSR_ALLOW_UNRESTRICTED_NVRAM(1 << 6) /* Allow unrestricted NVRAM */
150#define CSR_ALLOW_DEVICE_CONFIGURATION(1 << 7) /* Allow device configuration */
151#define CSR_ALLOW_ANY_RECOVERY_OS(1 << 8)
152#define CSR_ALLOW_UNAPPROVED_KEXTS(1 << 9)
153
154#define CSR_VALID_FLAGS (CSR_ALLOW_UNTRUSTED_KEXTS | \
155CSR_ALLOW_UNRESTRICTED_FS | \
156CSR_ALLOW_TASK_FOR_PID | \
157CSR_ALLOW_KERNEL_DEBUGGER | \
158CSR_ALLOW_APPLE_INTERNAL | \
159CSR_ALLOW_UNRESTRICTED_DTRACE | \
160CSR_ALLOW_UNRESTRICTED_NVRAM | \
161CSR_ALLOW_DEVICE_CONFIGURATION | \
162CSR_ALLOW_ANY_RECOVERY_OS | \
163CSR_ALLOW_UNAPPROVED_KEXTS)
164
165
166typedef struct boot_args
167{
168 uint16_t Revision;/* Revision of boot_args structure */
169 uint16_t Version;/* Version of boot_args structure */
170
171 uint8_t efiMode; /* 32 means 32-bit mode, 64 means 64-bit mode */
172 uint8_t debugMode; /* Bit field with behavior changes */
173 uint16_t flags;
174
175 char CommandLine[BOOT_LINE_LENGTH];/* Passed in command line */
176
177 uint32_t MemoryMap; /* Physical address of memory map */
178 uint32_t MemoryMapSize;
179 uint32_t MemoryMapDescriptorSize;
180 uint32_t MemoryMapDescriptorVersion;
181
182 Boot_VideoVideo;/* Video Information */
183
184 uint32_t deviceTreeP; /* Physical address of flattened device tree */
185 uint32_t deviceTreeLength; /* Length of flattened tree */
186
187 uint32_t kaddr; /* Physical address of beginning of kernel text */
188 uint32_t ksize; /* Size of combined kernel text+data+efi */
189
190 uint32_t efiRuntimeServicesPageStart; /* physical address of defragmented runtime pages */
191 uint32_t efiRuntimeServicesPageCount;
192 uint64_t efiRuntimeServicesVirtualPageStart; /* virtual address of defragmented runtime pages */
193
194 uint32_t efiSystemTable; /* physical address of system table in runtime area */
195 uint32_t kslide;
196
197 uint32_t performanceDataStart; /* physical address of log */
198 uint32_t performanceDataSize;
199
200 uint32_t keyStoreDataStart; /* physical address of key store data */
201 uint32_t keyStoreDataSize;
202 uint64_tbootMemStart;
203 uint64_tbootMemSize;
204 uint64_t PhysicalMemorySize;
205 uint64_t FSBFrequency;
206
207 uint64_t pciConfigSpaceBaseAddress;
208 uint32_t pciConfigSpaceStartBusNumber;
209 uint32_t pciConfigSpaceEndBusNumber;
210
211 uint32_t csrActiveConfig;
212 uint32_t csrCapabilities;
213 uint32_t boot_SMC_plimit;
214 uint16_tbootProgressMeterStart;
215 uint16_tbootProgressMeterEnd;
216 uint32_t __reserved4[726];
217
218} boot_args;
219
220typedef struct boot_args_legacy
221{
222 uint16_t Revision;/* Revision of boot_args structure */
223 uint16_t Version;/* Version of boot_args structure */
224
225 char CommandLine[BOOT_LINE_LENGTH];/* Passed in command line */
226
227 uint32_t MemoryMap; /* Physical address of memory map */
228 uint32_t MemoryMapSize;
229 uint32_t MemoryMapDescriptorSize;
230 uint32_t MemoryMapDescriptorVersion;
231
232 Boot_VideoVideo;/* Video Information */
233
234 uint32_t deviceTreeP; /* Physical address of flattened device tree */
235 uint32_t deviceTreeLength; /* Length of flattened tree */
236
237 uint32_t kaddr; /* Physical address of beginning of kernel text */
238 uint32_t ksize; /* Size of combined kernel text+data+efi */
239
240 uint32_t efiRuntimeServicesPageStart; /* physical address of defragmented runtime pages */
241 uint32_t efiRuntimeServicesPageCount;
242
243 uint32_t efiSystemTable; /* physical address of system table in runtime area */
244
245 uint8_t efiMode; /* 32 means 32-bit mode, 64 means 64-bit mode */
246 uint8_t __reserved1[3];
247 uint32_t __reserved2[1];
248 uint32_t performanceDataStart; /* physical address of log */
249 uint32_t performanceDataSize;
250 uint64_t efiRuntimeServicesVirtualPageStart; /* virtual address of defragmented runtime pages */
251 uint32_t __reserved3[2];
252
253} boot_args_legacy;
254
255#endif /* _PEXPERT_I386_BOOT_H */
256

Archive Download this file

Revision: HEAD