Chameleon

Chameleon Svn Source Tree

Root/branches/cparm/i386/libsaio/bootstruct.h

1/*
2 * Copyright (c) 2002-2003 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * Portions Copyright (c) 2002-2003 Apple Computer, Inc. All Rights
7 * Reserved. This file contains Original Code and/or Modifications of
8 * Original Code as defined in and that are subject to the Apple Public
9 * Source License Version 2.0 (the "License"). You may not use this file
10 * except in compliance with the License. Please obtain a copy of the
11 * License at http://www.apple.com/publicsource and read it before using
12 * this file.
13 *
14 * The Original Code and all software distributed under the License are
15 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
16 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
17 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE OR NON- INFRINGEMENT. Please see the
19 * License for the specific language governing rights and limitations
20 * under the License.
21 *
22 * @APPLE_LICENSE_HEADER_END@
23 */
24
25#ifndef __BOOTSTRUCT_H
26#define __BOOTSTRUCT_H
27
28#include "bootLion.h"
29#include "saio_types.h"
30#include "bios.h"
31#include "device_tree.h"
32/*!
33 Kernel boot args global also used by booter for its own data.
34 */
35extern boot_args_common *bootArgs;
36
37/*!
38 Boot args passed to the kernel.
39 */
40extern boot_args_Legacy *bootArgsLegacy;
41extern boot_args_107 *bootArgs107;
42
43extern Node *gMemoryMapNode;
44
45#define VGA_TEXT_MODE 0
46
47#if 0
48/*
49 * Maximum number of boot drivers that can be loaded.
50 */
51#define NDRIVERS 500
52
53#define CONFIG_SIZE (40 * 4096)
54#endif
55
56#define kMemoryMapCountMax 40
57
58#if UNUSED
59
60/*
61 * PCI bus information.
62 */
63typedef struct _PCI_bus_info_t {
64 union {
65 struct {
66 unsigned char configMethod1 :1;
67 unsigned char configMethod2 :1;
68 unsigned char :2;
69 unsigned char specialCycle1 :1;
70 unsigned char specialCycle2 :1;
71 } s;
72 unsigned char d;
73 } u_bus;
74 unsigned char maxBusNum;
75 unsigned char majorVersion;
76 unsigned char minorVersion;
77 unsigned char BIOSPresent;
78} PCI_bus_info_t;
79
80typedef struct {
81 unsigned long address; // address where driver was loaded
82 unsigned long size; // number of bytes
83 unsigned long type; // driver type
84} driver_config_t;
85#endif
86
87/*
88 * INT15, E820h - Query System Address Map.
89 *
90 * Documented in ACPI Specification Rev 2.0,
91 * Chapter 15 (System Address Map Interfaces).
92 */
93
94/*
95 * ACPI defined memory range types.
96 */
97enum {
98 kMemoryRangeUsable = 1, // RAM usable by the OS.
99 kMemoryRangeReserved = 2, // Reserved. (Do not use)
100 kMemoryRangeACPI = 3, // ACPI tables. Can be reclaimed.
101 kMemoryRangeNVS = 4, // ACPI NVS memory. (Do not use)
102
103 /* Undefined types should be treated as kMemoryRangeReserved */
104};
105
106/*!
107 PrivateBootInfo has fields used by the booter that used to be part of
108 KernelBootArgs_t *bootArgs. When the switch was made to EFI the structure
109 completely changed to boot_args *bootArgs. This (new to boot-132) structure
110 contains the fields the kernel no longer cares about but the booter still
111 uses internally. Some fields (e.g. the video information) remain interesting
112 to the kernel and are thus located in bootArgs although with different field names.
113 */
114typedef struct PrivateBootInfo {
115 int convmem; // conventional memory
116 int extmem; // extended memory
117#if 0
118 int numBootDrivers; // number of drivers loaded
119#endif
120 char bootFile[128]; // kernel file name
121
122 unsigned long memoryMapCount;
123 MemoryRange memoryMap[kMemoryMapCountMax];
124
125#if 0
126 PCI_bus_info_t pciInfo;
127 driver_config_t driverConfig[NDRIVERS];
128 char * configEnd; // pointer to end of config files
129 char config[CONFIG_SIZE];
130#endif
131
132 config_file_t bootConfig; // the booter boot.plist
133 config_file_t overrideConfig; // additional boot.plist which can override bootConfig keys
134
135config_file_t SystemConfig; // system confing found in /Library/Preferences/SystemConfiguration/com.apple.Boot.plist
136
137
138 config_file_t themeConfig; // theme.plist
139 config_file_t smbiosConfig; // smbios.plist
140 config_file_t helperConfig; // boot helper partition's boot.plist
141 config_file_t ramdiskConfig; // RAMDisk.plist
142
143unsigned long adler32;
144
145char uuidStr[64+1];//boot device uuid
146
147} PrivateBootInfo_t;
148
149extern PrivateBootInfo_t *bootInfo;
150
151#endif /* __BOOTSTRUCT_H */
152

Archive Download this file

Revision: 1804