VirtualBox

source: vbox/trunk/src/VBox/Devices/PC/vbox.dsl@ 17425

Last change on this file since 17425 was 16746, checked in by vboxsync, 16 years ago

SMP guests: implement support for multiple CPU ACPI objects (#ifdef'ed VBOX_WITH_SMP_GUESTS)

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
File size: 40.0 KB
Line 
1// $Id: vbox.dsl 16746 2009-02-13 16:06:37Z vboxsync $
2/// @file
3//
4// VirtualBox ACPI
5//
6// Copyright (C) 2006-2007 Sun Microsystems, Inc.
7//
8// This file is part of VirtualBox Open Source Edition (OSE), as
9// available from http://www.virtualbox.org. This file is free software;
10// you can redistribute it and/or modify it under the terms of the GNU
11// General Public License as published by the Free Software Foundation,
12// in version 2 as it comes in the "COPYING" file of the VirtualBox OSE
13// distribution. VirtualBox OSE is distributed in the hope that it will
14// be useful, but WITHOUT ANY WARRANTY of any kind.
15//
16
17DefinitionBlock ("DSDT.aml", "DSDT", 1, "VBOX ", "VBOXBIOS", 2)
18{
19 // Declare debugging ports withing SystemIO
20 OperationRegion(DBG0, SystemIO, 0x3000, 4)
21
22 // Writes to this field Will dump hex char
23 Field (DBG0, ByteAcc, NoLock, Preserve)
24 {
25 DHE1, 8,
26 }
27
28 // Writes to this field Will dump hex word
29 Field (DBG0, WordAcc, NoLock, Preserve)
30 {
31 DHE2, 16,
32 }
33
34 // Writes to this field Will dump hex double word
35 Field (DBG0, DWordAcc, NoLock, Preserve)
36 {
37 DHE4, 32,
38 }
39
40 // Writes to this field will dump ascii char
41 Field (DBG0, ByteAcc, NoLock, Preserve)
42 {
43 Offset (1),
44 DCHR, 8
45 }
46
47 // Shortcuts
48 Method(HEX, 1)
49 {
50 Store (Arg0, DHE1)
51 }
52
53 Method(HEX2, 1)
54 {
55 Store (Arg0, DHE2)
56 }
57
58 Method(HEX4, 1)
59 {
60 Store (Arg0, DHE4)
61 }
62
63 // Code from Microsoft sample
64 // http://www.microsoft.com/whdc/system/pnppwr/powermgmt/_OSI-method.mspx
65
66 //
67 // SLEN(Str) - Returns the length of Str (excluding NULL).
68 //
69 Method(SLEN, 1)
70 {
71 //
72 // Note: The caller must make sure that the argument is a string object.
73 //
74 Store(Arg0, Local0)
75 Return(Sizeof(Local0))
76 }
77
78 Method(S2BF, 1)
79 {
80 //
81 // Note: The caller must make sure that the argument is a string object.
82 //
83 // Local0 contains length of string + NULL.
84 //
85 Store(Arg0, Local0)
86 Add(SLEN(Local0), One, Local0)
87 //
88 // Convert the string object into a buffer object.
89 //
90 Name(BUFF, Buffer(Local0) {})
91 Store(Arg0, BUFF)
92 Return(BUFF)
93 }
94
95 // Convert ASCII string to buffer and store it's contents (char by
96 // char) into DCHR (thus possibly writing the string to console)
97 Method (\DBG, 1, NotSerialized)
98 {
99 Store(Arg0, Local0)
100 Store(S2BF (Local0), Local1)
101 Store(SizeOf (Local1), Local0)
102 Decrement (Local0)
103 Store(Zero, Local2)
104 While (Local0)
105 {
106 Decrement (Local0)
107 Store (DerefOf (Index (Local1, Local2)), DCHR)
108 Increment (Local2)
109 }
110 }
111
112 Name(PICM, 0)
113 Method(_PIC, 1)
114 {
115 DBG ("Pic mode: ")
116 HEX4 (Arg0)
117 Store (Arg0, PICM)
118 }
119
120 // Processor object
121 // #1463: Showing the CPU can make the guest do bad things on it like SpeedStep.
122 // In this case, XP SP2 contains this buggy Intelppm.sys driver which wants to mess
123 // with SpeedStep if it finds a CPU object and when it finds out that it can't, it
124 // tries to unload and crashes (MS probably never tested this code path).
125 // So we enable this ACPI object only for certain guests, which do need it,
126 // if by accident Windows guest seen enabled CPU object, just boot from latest
127 // known good configuration, as it remembers state, even if ACPI object gets disabled.
128 Scope (\_PR)
129 {
130 Processor (CPU0, /* Name */
131 0x00, /* Id */
132 0x0, /* Processor IO ports range start */
133 0x0 /* Processor IO ports range length */
134 )
135 {
136 Method (_STA) { Return(\_SB.UCP0) }
137 }
138 Processor (CPU1, /* Name */
139 0x01, /* Id */
140 0x0, /* Processor IO ports range start */
141 0x0 /* Processor IO ports range length */
142 )
143 {
144 Method (_STA) { Return(\_SB.UCP1) }
145 }
146 Processor (CPU2, /* Name */
147 0x02, /* Id */
148 0x0, /* Processor IO ports range start */
149 0x0 /* Processor IO ports range length */
150 )
151 {
152 Method (_STA) { Return(\_SB.UCP2) }
153 }
154 Processor (CPU3, /* Name */
155 0x03, /* Id */
156 0x0, /* Processor IO ports range start */
157 0x0 /* Processor IO ports range length */
158 )
159 {
160 Method (_STA) { Return(\_SB.UCP3) }
161 }
162 }
163
164 Scope (\_SB)
165 {
166 OperationRegion (SYSI, SystemIO, 0x4048, 0x08)
167 Field (SYSI, DwordAcc, NoLock, Preserve)
168 {
169 IDX0, 32,
170 DAT0, 32,
171 }
172
173 IndexField (IDX0, DAT0, DwordAcc, NoLock, Preserve)
174 {
175 MEML, 32,
176 UIOA, 32,
177 UHPT, 32,
178 USMC, 32,
179 UFDC, 32,
180 // @todo: maybe make it bitmask instead?
181 UCP0, 32,
182 UCP1, 32,
183 UCP2, 32,
184 UCP3, 32,
185 Offset (0x80),
186 ININ, 32,
187 Offset (0x200),
188 VAIN, 32,
189 }
190
191 Method (_INI, 0, NotSerialized)
192 {
193 Store (0xbadc0de, VAIN)
194 DBG ("MEML: ")
195 HEX4 (MEML)
196 DBG ("UIOA: ")
197 HEX4 (UIOA)
198 DBG ("UHPT: ")
199 HEX4 (UHPT)
200 DBG ("USMC: ")
201 HEX4 (USMC)
202 DBG ("UFDC: ")
203 HEX4 (UFDC)
204 DBG ("UCP0: ")
205 HEX4 (UCP0)
206 }
207
208 // PCI PIC IRQ Routing table
209 // Must match pci.c:pci_slot_get_pirq
210 Name (PR00, Package ()
211 {
212 Package (0x04) {0x0002FFFF, 0x00, LNKB, 0x00,},
213 Package (0x04) {0x0002FFFF, 0x01, LNKC, 0x00,},
214 Package (0x04) {0x0002FFFF, 0x02, LNKD, 0x00,},
215 Package (0x04) {0x0002FFFF, 0x03, LNKA, 0x00,},
216
217 Package (0x04) {0x0003FFFF, 0x00, LNKC, 0x00,},
218 Package (0x04) {0x0003FFFF, 0x01, LNKD, 0x00,},
219 Package (0x04) {0x0003FFFF, 0x02, LNKA, 0x00,},
220 Package (0x04) {0x0003FFFF, 0x03, LNKB, 0x00,},
221
222 Package (0x04) {0x0004FFFF, 0x00, LNKD, 0x00,},
223 Package (0x04) {0x0004FFFF, 0x01, LNKA, 0x00,},
224 Package (0x04) {0x0004FFFF, 0x02, LNKB, 0x00,},
225 Package (0x04) {0x0004FFFF, 0x03, LNKC, 0x00,},
226
227 Package (0x04) {0x0005FFFF, 0x00, LNKA, 0x00,},
228 Package (0x04) {0x0005FFFF, 0x01, LNKB, 0x00,},
229 Package (0x04) {0x0005FFFF, 0x02, LNKC, 0x00,},
230 Package (0x04) {0x0005FFFF, 0x03, LNKD, 0x00,},
231
232 Package (0x04) {0x0006FFFF, 0x00, LNKB, 0x00,},
233 Package (0x04) {0x0006FFFF, 0x01, LNKC, 0x00,},
234 Package (0x04) {0x0006FFFF, 0x02, LNKD, 0x00,},
235 Package (0x04) {0x0006FFFF, 0x03, LNKA, 0x00,},
236
237 Package (0x04) {0x0007FFFF, 0x00, LNKC, 0x00,},
238 Package (0x04) {0x0007FFFF, 0x01, LNKD, 0x00,},
239 Package (0x04) {0x0007FFFF, 0x02, LNKA, 0x00,},
240 Package (0x04) {0x0007FFFF, 0x03, LNKB, 0x00,},
241
242 Package (0x04) {0x0008FFFF, 0x00, LNKD, 0x00,},
243 Package (0x04) {0x0008FFFF, 0x01, LNKA, 0x00,},
244 Package (0x04) {0x0008FFFF, 0x02, LNKB, 0x00,},
245 Package (0x04) {0x0008FFFF, 0x03, LNKC, 0x00,},
246
247 Package (0x04) {0x0009FFFF, 0x00, LNKA, 0x00,},
248 Package (0x04) {0x0009FFFF, 0x01, LNKB, 0x00,},
249 Package (0x04) {0x0009FFFF, 0x02, LNKC, 0x00,},
250 Package (0x04) {0x0009FFFF, 0x03, LNKD, 0x00,},
251
252 Package (0x04) {0x000AFFFF, 0x00, LNKB, 0x00,},
253 Package (0x04) {0x000AFFFF, 0x01, LNKC, 0x00,},
254 Package (0x04) {0x000AFFFF, 0x02, LNKD, 0x00,},
255 Package (0x04) {0x000AFFFF, 0x03, LNKA, 0x00,},
256
257 Package (0x04) {0x000BFFFF, 0x00, LNKC, 0x00,},
258 Package (0x04) {0x000BFFFF, 0x01, LNKD, 0x00,},
259 Package (0x04) {0x000BFFFF, 0x02, LNKA, 0x00,},
260 Package (0x04) {0x000BFFFF, 0x03, LNKB, 0x00,},
261
262 Package (0x04) {0x000CFFFF, 0x00, LNKD, 0x00,},
263 Package (0x04) {0x000CFFFF, 0x01, LNKA, 0x00,},
264 Package (0x04) {0x000CFFFF, 0x02, LNKB, 0x00,},
265 Package (0x04) {0x000CFFFF, 0x03, LNKC, 0x00,},
266
267 Package (0x04) {0x000DFFFF, 0x00, LNKA, 0x00,},
268 Package (0x04) {0x000DFFFF, 0x01, LNKB, 0x00,},
269 Package (0x04) {0x000DFFFF, 0x02, LNKC, 0x00,},
270 Package (0x04) {0x000DFFFF, 0x03, LNKD, 0x00,},
271
272 Package (0x04) {0x000EFFFF, 0x00, LNKB, 0x00,},
273 Package (0x04) {0x000EFFFF, 0x01, LNKC, 0x00,},
274 Package (0x04) {0x000EFFFF, 0x02, LNKD, 0x00,},
275 Package (0x04) {0x000EFFFF, 0x03, LNKA, 0x00,},
276
277 Package (0x04) {0x000FFFFF, 0x00, LNKC, 0x00,},
278 Package (0x04) {0x000FFFFF, 0x01, LNKD, 0x00,},
279 Package (0x04) {0x000FFFFF, 0x02, LNKA, 0x00,},
280 Package (0x04) {0x000FFFFF, 0x03, LNKB, 0x00,},
281
282 Package (0x04) {0x0010FFFF, 0x00, LNKD, 0x00,},
283 Package (0x04) {0x0010FFFF, 0x01, LNKA, 0x00,},
284 Package (0x04) {0x0010FFFF, 0x02, LNKB, 0x00,},
285 Package (0x04) {0x0010FFFF, 0x03, LNKC, 0x00,},
286
287 Package (0x04) {0x0011FFFF, 0x00, LNKA, 0x00,},
288 Package (0x04) {0x0011FFFF, 0x01, LNKB, 0x00,},
289 Package (0x04) {0x0011FFFF, 0x02, LNKC, 0x00,},
290 Package (0x04) {0x0011FFFF, 0x03, LNKD, 0x00,},
291
292 Package (0x04) {0x0012FFFF, 0x00, LNKB, 0x00,},
293 Package (0x04) {0x0012FFFF, 0x01, LNKC, 0x00,},
294 Package (0x04) {0x0012FFFF, 0x02, LNKD, 0x00,},
295 Package (0x04) {0x0012FFFF, 0x03, LNKA, 0x00,},
296
297 Package (0x04) {0x0013FFFF, 0x00, LNKC, 0x00,},
298 Package (0x04) {0x0013FFFF, 0x01, LNKD, 0x00,},
299 Package (0x04) {0x0013FFFF, 0x02, LNKA, 0x00,},
300 Package (0x04) {0x0013FFFF, 0x03, LNKB, 0x00,},
301
302 Package (0x04) {0x0014FFFF, 0x00, LNKD, 0x00,},
303 Package (0x04) {0x0014FFFF, 0x01, LNKA, 0x00,},
304 Package (0x04) {0x0014FFFF, 0x02, LNKB, 0x00,},
305 Package (0x04) {0x0014FFFF, 0x03, LNKC, 0x00,},
306
307 Package (0x04) {0x0015FFFF, 0x00, LNKA, 0x00,},
308 Package (0x04) {0x0015FFFF, 0x01, LNKB, 0x00,},
309 Package (0x04) {0x0015FFFF, 0x02, LNKC, 0x00,},
310 Package (0x04) {0x0015FFFF, 0x03, LNKD, 0x00,},
311
312 Package (0x04) {0x0016FFFF, 0x00, LNKB, 0x00,},
313 Package (0x04) {0x0016FFFF, 0x01, LNKC, 0x00,},
314 Package (0x04) {0x0016FFFF, 0x02, LNKD, 0x00,},
315 Package (0x04) {0x0016FFFF, 0x03, LNKA, 0x00,},
316
317 Package (0x04) {0x0017FFFF, 0x00, LNKC, 0x00,},
318 Package (0x04) {0x0017FFFF, 0x01, LNKD, 0x00,},
319 Package (0x04) {0x0017FFFF, 0x02, LNKA, 0x00,},
320 Package (0x04) {0x0017FFFF, 0x03, LNKB, 0x00,},
321
322 Package (0x04) {0x0018FFFF, 0x00, LNKD, 0x00,},
323 Package (0x04) {0x0018FFFF, 0x01, LNKA, 0x00,},
324 Package (0x04) {0x0018FFFF, 0x02, LNKB, 0x00,},
325 Package (0x04) {0x0018FFFF, 0x03, LNKC, 0x00,},
326
327 Package (0x04) {0x0019FFFF, 0x00, LNKA, 0x00,},
328 Package (0x04) {0x0019FFFF, 0x01, LNKB, 0x00,},
329 Package (0x04) {0x0019FFFF, 0x02, LNKC, 0x00,},
330 Package (0x04) {0x0019FFFF, 0x03, LNKD, 0x00,},
331
332 Package (0x04) {0x001AFFFF, 0x00, LNKB, 0x00,},
333 Package (0x04) {0x001AFFFF, 0x01, LNKC, 0x00,},
334 Package (0x04) {0x001AFFFF, 0x02, LNKD, 0x00,},
335 Package (0x04) {0x001AFFFF, 0x03, LNKA, 0x00,},
336
337 Package (0x04) {0x001BFFFF, 0x00, LNKC, 0x00,},
338 Package (0x04) {0x001BFFFF, 0x01, LNKD, 0x00,},
339 Package (0x04) {0x001BFFFF, 0x02, LNKA, 0x00,},
340 Package (0x04) {0x001BFFFF, 0x03, LNKB, 0x00,},
341
342 Package (0x04) {0x001CFFFF, 0x00, LNKD, 0x00,},
343 Package (0x04) {0x001CFFFF, 0x01, LNKA, 0x00,},
344 Package (0x04) {0x001CFFFF, 0x02, LNKB, 0x00,},
345 Package (0x04) {0x001CFFFF, 0x03, LNKC, 0x00,},
346
347 Package (0x04) {0x001DFFFF, 0x00, LNKA, 0x00,},
348 Package (0x04) {0x001DFFFF, 0x01, LNKB, 0x00,},
349 Package (0x04) {0x001DFFFF, 0x02, LNKC, 0x00,},
350 Package (0x04) {0x001DFFFF, 0x03, LNKD, 0x00,},
351
352 Package (0x04) {0x001EFFFF, 0x00, LNKB, 0x00,},
353 Package (0x04) {0x001EFFFF, 0x01, LNKC, 0x00,},
354 Package (0x04) {0x001EFFFF, 0x02, LNKD, 0x00,},
355 Package (0x04) {0x001EFFFF, 0x03, LNKA, 0x00,},
356
357 Package (0x04) {0x001FFFFF, 0x00, LNKC, 0x00,},
358 Package (0x04) {0x001FFFFF, 0x01, LNKD, 0x00,},
359 Package (0x04) {0x001FFFFF, 0x02, LNKA, 0x00,},
360 Package (0x04) {0x001FFFFF, 0x03, LNKB, 0x00,}
361 })
362
363 // PCI I/O APIC IRQ Routing table
364 // Must match pci.c:pci_slot_get_acpi_pirq
365 Name (PR01, Package ()
366 {
367 Package (0x04) {0x0002FFFF, 0x00, 0x00, 0x12,},
368 Package (0x04) {0x0002FFFF, 0x01, 0x00, 0x13,},
369 Package (0x04) {0x0002FFFF, 0x02, 0x00, 0x14,},
370 Package (0x04) {0x0002FFFF, 0x03, 0x00, 0x15,},
371
372 Package (0x04) {0x0003FFFF, 0x00, 0x00, 0x13,},
373 Package (0x04) {0x0003FFFF, 0x01, 0x00, 0x14,},
374 Package (0x04) {0x0003FFFF, 0x02, 0x00, 0x15,},
375 Package (0x04) {0x0003FFFF, 0x03, 0x00, 0x16,},
376
377 Package (0x04) {0x0004FFFF, 0x00, 0x00, 0x14,},
378 Package (0x04) {0x0004FFFF, 0x01, 0x00, 0x15,},
379 Package (0x04) {0x0004FFFF, 0x02, 0x00, 0x16,},
380 Package (0x04) {0x0004FFFF, 0x03, 0x00, 0x17,},
381
382 Package (0x04) {0x0005FFFF, 0x00, 0x00, 0x15,},
383 Package (0x04) {0x0005FFFF, 0x01, 0x00, 0x16,},
384 Package (0x04) {0x0005FFFF, 0x02, 0x00, 0x17,},
385 Package (0x04) {0x0005FFFF, 0x03, 0x00, 0x10,},
386
387 Package (0x04) {0x0006FFFF, 0x00, 0x00, 0x16,},
388 Package (0x04) {0x0006FFFF, 0x01, 0x00, 0x17,},
389 Package (0x04) {0x0006FFFF, 0x02, 0x00, 0x10,},
390 Package (0x04) {0x0006FFFF, 0x03, 0x00, 0x11,},
391
392 Package (0x04) {0x0007FFFF, 0x00, 0x00, 0x17,},
393 Package (0x04) {0x0007FFFF, 0x01, 0x00, 0x10,},
394 Package (0x04) {0x0007FFFF, 0x02, 0x00, 0x11,},
395 Package (0x04) {0x0007FFFF, 0x03, 0x00, 0x12,},
396
397 Package (0x04) {0x0008FFFF, 0x00, 0x00, 0x10,},
398 Package (0x04) {0x0008FFFF, 0x01, 0x00, 0x11,},
399 Package (0x04) {0x0008FFFF, 0x02, 0x00, 0x12,},
400 Package (0x04) {0x0008FFFF, 0x03, 0x00, 0x13,},
401
402 Package (0x04) {0x0009FFFF, 0x00, 0x00, 0x11,},
403 Package (0x04) {0x0009FFFF, 0x01, 0x00, 0x12,},
404 Package (0x04) {0x0009FFFF, 0x02, 0x00, 0x13,},
405 Package (0x04) {0x0009FFFF, 0x03, 0x00, 0x14,},
406
407 Package (0x04) {0x000AFFFF, 0x00, 0x00, 0x12,},
408 Package (0x04) {0x000AFFFF, 0x01, 0x00, 0x13,},
409 Package (0x04) {0x000AFFFF, 0x02, 0x00, 0x14,},
410 Package (0x04) {0x000AFFFF, 0x03, 0x00, 0x15,},
411
412 Package (0x04) {0x000BFFFF, 0x00, 0x00, 0x13,},
413 Package (0x04) {0x000BFFFF, 0x01, 0x00, 0x14,},
414 Package (0x04) {0x000BFFFF, 0x02, 0x00, 0x15,},
415 Package (0x04) {0x000BFFFF, 0x03, 0x00, 0x16,},
416
417 Package (0x04) {0x000CFFFF, 0x00, 0x00, 0x14,},
418 Package (0x04) {0x000CFFFF, 0x01, 0x00, 0x15,},
419 Package (0x04) {0x000CFFFF, 0x02, 0x00, 0x16,},
420 Package (0x04) {0x000CFFFF, 0x03, 0x00, 0x17,},
421
422 Package (0x04) {0x000DFFFF, 0x00, 0x00, 0x15,},
423 Package (0x04) {0x000DFFFF, 0x01, 0x00, 0x16,},
424 Package (0x04) {0x000DFFFF, 0x02, 0x00, 0x17,},
425 Package (0x04) {0x000DFFFF, 0x03, 0x00, 0x10,},
426
427 Package (0x04) {0x000EFFFF, 0x00, 0x00, 0x16,},
428 Package (0x04) {0x000EFFFF, 0x01, 0x00, 0x17,},
429 Package (0x04) {0x000EFFFF, 0x02, 0x00, 0x10,},
430 Package (0x04) {0x000EFFFF, 0x03, 0x00, 0x11,},
431
432 Package (0x04) {0x000FFFFF, 0x00, 0x00, 0x17,},
433 Package (0x04) {0x000FFFFF, 0x01, 0x00, 0x10,},
434 Package (0x04) {0x000FFFFF, 0x02, 0x00, 0x11,},
435 Package (0x04) {0x000FFFFF, 0x03, 0x00, 0x12,},
436
437 Package (0x04) {0x0010FFFF, 0x00, 0x00, 0x10,},
438 Package (0x04) {0x0010FFFF, 0x01, 0x00, 0x11,},
439 Package (0x04) {0x0010FFFF, 0x02, 0x00, 0x12,},
440 Package (0x04) {0x0010FFFF, 0x03, 0x00, 0x13,},
441
442 Package (0x04) {0x0011FFFF, 0x00, 0x00, 0x11,},
443 Package (0x04) {0x0011FFFF, 0x01, 0x00, 0x12,},
444 Package (0x04) {0x0011FFFF, 0x02, 0x00, 0x13,},
445 Package (0x04) {0x0011FFFF, 0x03, 0x00, 0x14,},
446
447 Package (0x04) {0x0012FFFF, 0x00, 0x00, 0x12,},
448 Package (0x04) {0x0012FFFF, 0x01, 0x00, 0x13,},
449 Package (0x04) {0x0012FFFF, 0x02, 0x00, 0x14,},
450 Package (0x04) {0x0012FFFF, 0x03, 0x00, 0x15,},
451
452 Package (0x04) {0x0013FFFF, 0x00, 0x00, 0x13,},
453 Package (0x04) {0x0013FFFF, 0x01, 0x00, 0x14,},
454 Package (0x04) {0x0013FFFF, 0x02, 0x00, 0x15,},
455 Package (0x04) {0x0013FFFF, 0x03, 0x00, 0x16,},
456
457 Package (0x04) {0x0014FFFF, 0x00, 0x00, 0x14,},
458 Package (0x04) {0x0014FFFF, 0x01, 0x00, 0x15,},
459 Package (0x04) {0x0014FFFF, 0x02, 0x00, 0x16,},
460 Package (0x04) {0x0014FFFF, 0x03, 0x00, 0x17,},
461
462 Package (0x04) {0x0015FFFF, 0x00, 0x00, 0x15,},
463 Package (0x04) {0x0015FFFF, 0x01, 0x00, 0x16,},
464 Package (0x04) {0x0015FFFF, 0x02, 0x00, 0x17,},
465 Package (0x04) {0x0015FFFF, 0x03, 0x00, 0x10,},
466
467 Package (0x04) {0x0016FFFF, 0x00, 0x00, 0x16,},
468 Package (0x04) {0x0016FFFF, 0x01, 0x00, 0x17,},
469 Package (0x04) {0x0016FFFF, 0x02, 0x00, 0x10,},
470 Package (0x04) {0x0016FFFF, 0x03, 0x00, 0x11,},
471
472 Package (0x04) {0x0017FFFF, 0x00, 0x00, 0x17,},
473 Package (0x04) {0x0017FFFF, 0x01, 0x00, 0x10,},
474 Package (0x04) {0x0017FFFF, 0x02, 0x00, 0x11,},
475 Package (0x04) {0x0017FFFF, 0x03, 0x00, 0x12,},
476
477 Package (0x04) {0x0018FFFF, 0x00, 0x00, 0x10,},
478 Package (0x04) {0x0018FFFF, 0x01, 0x00, 0x11,},
479 Package (0x04) {0x0018FFFF, 0x02, 0x00, 0x12,},
480 Package (0x04) {0x0018FFFF, 0x03, 0x00, 0x13,},
481
482 Package (0x04) {0x0019FFFF, 0x00, 0x00, 0x11,},
483 Package (0x04) {0x0019FFFF, 0x01, 0x00, 0x12,},
484 Package (0x04) {0x0019FFFF, 0x02, 0x00, 0x13,},
485 Package (0x04) {0x0019FFFF, 0x03, 0x00, 0x14,},
486
487 Package (0x04) {0x001AFFFF, 0x00, 0x00, 0x12,},
488 Package (0x04) {0x001AFFFF, 0x01, 0x00, 0x13,},
489 Package (0x04) {0x001AFFFF, 0x02, 0x00, 0x14,},
490 Package (0x04) {0x001AFFFF, 0x03, 0x00, 0x15,},
491
492 Package (0x04) {0x001BFFFF, 0x00, 0x00, 0x13,},
493 Package (0x04) {0x001BFFFF, 0x01, 0x00, 0x14,},
494 Package (0x04) {0x001BFFFF, 0x02, 0x00, 0x15,},
495 Package (0x04) {0x001BFFFF, 0x03, 0x00, 0x16,},
496
497 Package (0x04) {0x001CFFFF, 0x00, 0x00, 0x14,},
498 Package (0x04) {0x001CFFFF, 0x01, 0x00, 0x15,},
499 Package (0x04) {0x001CFFFF, 0x02, 0x00, 0x16,},
500 Package (0x04) {0x001CFFFF, 0x03, 0x00, 0x17,},
501
502 Package (0x04) {0x001DFFFF, 0x00, 0x00, 0x15,},
503 Package (0x04) {0x001DFFFF, 0x01, 0x00, 0x16,},
504 Package (0x04) {0x001DFFFF, 0x02, 0x00, 0x17,},
505 Package (0x04) {0x001DFFFF, 0x03, 0x00, 0x10,},
506
507 Package (0x04) {0x001EFFFF, 0x00, 0x00, 0x16,},
508 Package (0x04) {0x001EFFFF, 0x01, 0x00, 0x17,},
509 Package (0x04) {0x001EFFFF, 0x02, 0x00, 0x10,},
510 Package (0x04) {0x001EFFFF, 0x03, 0x00, 0x11,},
511
512 Package (0x04) {0x001FFFFF, 0x00, 0x00, 0x17,},
513 Package (0x04) {0x001FFFFF, 0x01, 0x00, 0x10,},
514 Package (0x04) {0x001FFFFF, 0x02, 0x00, 0x11,},
515 Package (0x04) {0x001FFFFF, 0x03, 0x00, 0x12,}
516 })
517
518 // Possible resource settings for PCI link A
519 Name (PRSA, ResourceTemplate ()
520 {
521 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
522 })
523
524 // Possible resource settings for PCI link B
525 Name (PRSB, ResourceTemplate ()
526 {
527 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
528 })
529
530 // Possible resource settings for PCI link C
531 Name (PRSC, ResourceTemplate ()
532 {
533 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
534 })
535
536 // Possible resource settings for PCI link D
537 Name (PRSD, ResourceTemplate ()
538 {
539 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
540 })
541
542 // PCI bus 0
543 Device (PCI0)
544 {
545 Name (_HID, EisaId ("PNP0A03"))
546 Name (_ADR, 0x00) // address
547 Name (_BBN, 0x00) // base bus adddress
548 Name (_UID, 0x00)
549
550 // Method that returns routing table
551 Method (_PRT, 0, NotSerialized)
552 {
553 if (LEqual (LAnd (PICM, UIOA), Zero)) {
554 DBG ("RETURNING PIC\n")
555 Store (0x00, \_SB.PCI0.SBRG.APDE)
556 Store (0x00, \_SB.PCI0.SBRG.APAD)
557 Return (PR00)
558 }
559 else {
560 DBG ("RETURNING APIC\n")
561 Store (0xbe, \_SB.PCI0.SBRG.APDE)
562 Store (0xef, \_SB.PCI0.SBRG.APAD)
563 Return (PR01)
564 }
565 }
566
567 Device (SBRG)
568 {
569 // Address of the PIIX3 (device 1 function 0)
570 Name (_ADR, 0x00010000)
571 OperationRegion (PCIC, PCI_Config, 0x00, 0xff)
572
573 Field (PCIC, ByteAcc, NoLock, Preserve)
574 {
575 Offset (0xad),
576 APAD, 8,
577 Offset (0xde),
578 APDE, 8,
579 }
580
581 // Keyboard device
582 Device (PS2K)
583 {
584 Name (_HID, EisaId ("PNP0303"))
585 Method (_STA, 0, NotSerialized)
586 {
587 Return (0x0F)
588 }
589
590 Name (_CRS, ResourceTemplate ()
591 {
592 IO (Decode16, 0x0060, 0x0060, 0x00, 0x01)
593 IO (Decode16, 0x0064, 0x0064, 0x00, 0x01)
594 IRQNoFlags () {1}
595 })
596 }
597
598 // DMA Controller
599 Device (DMAC)
600 {
601 Name (_HID, EisaId ("PNP0200"))
602 Name (_CRS, ResourceTemplate ()
603 {
604 IO (Decode16, 0x0000, 0x0000, 0x01, 0x10)
605 IO (Decode16, 0x0080, 0x0080, 0x01, 0x10)
606 IO (Decode16, 0x00C0, 0x00C0, 0x01, 0x20)
607 DMA (Compatibility, BusMaster, Transfer8_16) {4}
608 })
609 }
610
611 // Floppy disk controller
612 Device (FDC0)
613 {
614 Name (_HID, EisaId ("PNP0700"))
615
616 Method (_STA, 0, NotSerialized)
617 {
618 Return (UFDC)
619 }
620
621 // Current resource settings
622 Name (_CRS, ResourceTemplate ()
623 {
624 IO (Decode16, 0x03F0, 0x03F0, 0x01, 0x06)
625 IO (Decode16, 0x03F7, 0x03F7, 0x01, 0x01)
626 IRQNoFlags () {6}
627 DMA (Compatibility, NotBusMaster, Transfer8) {2}
628 })
629
630 // Possible resource settings
631 Name (_PRS, ResourceTemplate ()
632 {
633 IO (Decode16, 0x03F0, 0x03F0, 0x01, 0x06)
634 IO (Decode16, 0x03F7, 0x03F7, 0x01, 0x01)
635 IRQNoFlags () {6}
636 DMA (Compatibility, NotBusMaster, Transfer8) {2}
637 })
638
639 }
640
641 // Mouse device
642 Device (PS2M)
643 {
644 Name (_HID, EisaId ("PNP0F03"))
645 Method (_STA, 0, NotSerialized)
646 {
647 Return (0x0F)
648 }
649
650 Name (_CRS, ResourceTemplate ()
651 {
652 IO (Decode16, 0x0060, 0x0060, 0x00, 0x01)
653 IO (Decode16, 0x0064, 0x0064, 0x00, 0x01)
654 IRQNoFlags () {12}
655 })
656 }
657
658 // Parallel port
659 Device (LPT)
660 {
661 Name (_HID, EisaId ("PNP0400"))
662 Method (_STA, 0, NotSerialized)
663 {
664 Return (0x0F)
665 }
666 Name (_CRS, ResourceTemplate ()
667 {
668 IO (Decode16, 0x0378, 0x0378, 0x08, 0x08)
669 IO (Decode16, 0x0778, 0x0778, 0x08, 0x08)
670 IRQNoFlags () {7}
671 })
672 }
673 }
674
675 // Control method battery
676 Device (BAT0)
677 {
678 Name (_HID, EisaId ("PNP0C0A"))
679 Name (_UID, 0x00)
680
681 Scope (\_GPE)
682 {
683 // GPE bit 0 handler
684 // GPE.0 must be set and SCI raised when
685 // battery info changed and _BIF must be
686 // re-evaluated
687 Method (_L00, 0, NotSerialized)
688 {
689 Notify (\_SB.PCI0.BAT0, 0x81)
690 }
691 }
692
693 OperationRegion (CBAT, SystemIO, 0x4040, 0x08)
694 Field (CBAT, DwordAcc, NoLock, Preserve)
695 {
696 IDX0, 32,
697 DAT0, 32,
698 }
699
700 IndexField (IDX0, DAT0, DwordAcc, NoLock, Preserve)
701 {
702 STAT, 32,
703 PRAT, 32,
704 RCAP, 32,
705 PVOL, 32,
706
707 UNIT, 32,
708 DCAP, 32,
709 LFCP, 32,
710 BTEC, 32,
711 DVOL, 32,
712 DWRN, 32,
713 DLOW, 32,
714 GRN1, 32,
715 GRN2, 32,
716
717 BSTA, 32,
718 APSR, 32,
719 }
720
721 Method (_STA, 0, NotSerialized)
722 {
723 return (BSTA)
724 }
725
726 Name (PBIF, Package ()
727 {
728 0x01, // Power unit, 1 - mA
729 0x7fffffff, // Design capacity
730 0x7fffffff, // Last full charge capacity
731 0x00, // Battery technology
732 0xffffffff, // Design voltage
733 0x00, // Design capacity of Warning
734 0x00, // Design capacity of Low
735 0x04, // Battery capacity granularity 1
736 0x04, // Battery capacity granularity 2
737 "1", // Model number
738 "0", // Serial number
739 "VBOX", // Battery type
740 "innotek" // OEM Information
741 })
742
743 Name (PBST, Package () {
744 0, // Battery state
745 0x7fffffff, // Battery present rate
746 0x7fffffff, // Battery remaining capacity
747 0x7fffffff // Battery present voltage
748 })
749
750 // Battery information
751 Method (_BIF, 0, NotSerialized)
752 {
753 Store (UNIT, Index (PBIF, 0,))
754 Store (DCAP, Index (PBIF, 1,))
755 Store (LFCP, Index (PBIF, 2,))
756 Store (BTEC, Index (PBIF, 3,))
757 Store (DVOL, Index (PBIF, 4,))
758 Store (DWRN, Index (PBIF, 5,))
759 Store (DLOW, Index (PBIF, 6,))
760 Store (GRN1, Index (PBIF, 7,))
761 Store (GRN2, Index (PBIF, 8,))
762
763 DBG ("_BIF:\n")
764 HEX4 (DerefOf (Index (PBIF, 0,)))
765 HEX4 (DerefOf (Index (PBIF, 1,)))
766 HEX4 (DerefOf (Index (PBIF, 2,)))
767 HEX4 (DerefOf (Index (PBIF, 3,)))
768 HEX4 (DerefOf (Index (PBIF, 4,)))
769 HEX4 (DerefOf (Index (PBIF, 5,)))
770 HEX4 (DerefOf (Index (PBIF, 6,)))
771 HEX4 (DerefOf (Index (PBIF, 7,)))
772 HEX4 (DerefOf (Index (PBIF, 8,)))
773
774 return (PBIF)
775 }
776
777 // Battery status
778 Method (_BST, 0, NotSerialized)
779 {
780 Store (STAT, Index (PBST, 0,))
781 Store (PRAT, Index (PBST, 1,))
782 Store (RCAP, Index (PBST, 2,))
783 Store (PVOL, Index (PBST, 3,))
784/*
785 DBG ("_BST:\n")
786 HEX4 (DerefOf (Index (PBST, 0,)))
787 HEX4 (DerefOf (Index (PBST, 1,)))
788 HEX4 (DerefOf (Index (PBST, 2,)))
789 HEX4 (DerefOf (Index (PBST, 3,)))
790*/
791 return (PBST)
792 }
793 }
794
795 Device (AC)
796 {
797 Name (_HID, "ACPI0003")
798 Name (_UID, 0x00)
799 Name (_PCL, Package (0x01)
800 {
801 \_SB
802 })
803
804 Method (_PSR, 0, NotSerialized)
805 {
806 // DBG ("_PSR:\n")
807 // HEX4 (\_SB.PCI0.BAT0.APSR)
808 return (\_SB.PCI0.BAT0.APSR)
809 }
810
811 Method (_STA, 0, NotSerialized)
812 {
813 return (0x0f)
814 }
815 }
816 }
817 }
818
819 Scope (\_SB)
820 {
821 Scope (PCI0)
822 {
823 // PCI0 current resource settings
824 Name (CRS, ResourceTemplate ()
825 {
826 WordBusNumber (ResourceProducer, MinFixed, MaxFixed, PosDecode,
827 0x0000,
828 0x0000,
829 0x00FF,
830 0x0000,
831 0x0100)
832 IO (Decode16, 0x0CF8, 0x0CF8, 0x01, 0x08)
833 WordIO (ResourceProducer, MinFixed, MaxFixed,
834 PosDecode, EntireRange,
835 0x0000,
836 0x0000,
837 0x0CF7,
838 0x0000,
839 0x0CF8)
840 WordIO (ResourceProducer, MinFixed, MaxFixed,
841 PosDecode, EntireRange,
842 0x0000,
843 0x0D00,
844 0xFFFF,
845 0x0000,
846 0xF300)
847
848 /* Taken from ACPI faq (with some modifications) */
849 DwordMemory( // descriptor for video RAM behind ISA bus
850 ResourceProducer, // bit 0 of general flags is 0
851 PosDecode,
852 MinFixed, // Range is fixed
853 MaxFixed, // Range is Fixed
854 Cacheable,
855 ReadWrite,
856 0x00000000, // Granularity
857 0x000a0000, // Min
858 0x000bffff, // Max
859 0x00000000, // Translation
860 0x00020000 // Range Length
861 )
862
863 DwordMemory( // Consumed-and-produced resource
864 // (all of memory space)
865 ResourceProducer, // bit 0 of general flags is 0
866 PosDecode, // positive Decode
867 MinFixed, // Range is fixed
868 MaxFixed, // Range is fixed
869 Cacheable,
870 ReadWrite,
871 0x00000000, // Granularity
872 0x00000000, // Min (calculated dynamically)
873
874 0xffdfffff, // Max = 4GB - 2MB
875 0x00000000, // Translation
876 0xdfdfffff, // Range Length (calculated
877 // dynamically)
878 , // Optional field left blank
879 , // Optional field left blank
880 MEM3 // Name declaration for this
881 // descriptor
882 )
883 })
884
885 Method (_CRS, 0, NotSerialized)
886 {
887 CreateDwordField (CRS, \_SB.PCI0.MEM3._MIN, RAMT)
888 CreateDwordField (CRS, \_SB.PCI0.MEM3._LEN, RAMR)
889 Store (MEML, RAMT)
890 Subtract (0xffe00000, RAMT, RAMR)
891 Return (CRS)
892 }
893 }
894 }
895
896 Scope (\_SB)
897 {
898 // High Precision Event Timer
899 Device(HPET) {
900 Name(_HID, EISAID("PNP0103"))
901 Name(_UID, 0)
902 Method (_STA, 0, NotSerialized) {
903 Return(UHPT)
904 }
905 Name(_CRS, ResourceTemplate() {
906 DWordMemory(
907 ResourceConsumer, PosDecode, MinFixed, MaxFixed,
908 NonCacheable, ReadWrite,
909 0x00000000,
910 0xFED00000,
911 0xFED003FF,
912 0x00000000,
913 0x00000400 /* 1K memory: FED00000 - FED003FF */
914 )
915 })
916 }
917
918 // System Management Controller
919 Device (SMC)
920 {
921 Name (_HID, EisaId ("APP0001"))
922 Name (_CID, "smc-napa")
923
924 Method (_STA, 0, NotSerialized)
925 {
926 Return (USMC)
927 }
928 Name (_CRS, ResourceTemplate ()
929 {
930 IO (Decode16,
931 0x0300, // Range Minimum
932 0x0300, // Range Maximum
933 0x01, // Alignment
934 0x20, // Length
935 )
936 // This line seriously confuses Windows ACPI driver, so not even try to
937 // enable SMC for Windows guests
938 IRQNoFlags () {8}
939 })
940 }
941
942 // Fields within PIIX3 configuration[0x60..0x63] with
943 // IRQ mappings
944 Field (\_SB.PCI0.SBRG.PCIC, ByteAcc, NoLock, Preserve)
945 {
946 Offset (0x60),
947 PIRA, 8,
948 PIRB, 8,
949 PIRC, 8,
950 PIRD, 8
951 }
952
953 Name (BUFA, ResourceTemplate ()
954 {
955 IRQ (Level, ActiveLow, Shared) {15}
956 })
957 CreateWordField (BUFA, 0x01, ICRS)
958
959 // Generic status of IRQ routing entry
960 Method (LSTA, 1, NotSerialized)
961 {
962 And (Arg0, 0x80, Local0)
963// DBG ("LSTA: ")
964// HEX (Arg0)
965 If (Local0)
966 {
967 Return (0x09)
968 }
969 Else
970 {
971 Return (0x0B)
972 }
973 }
974
975 // Generic "current resource settings" for routing entry
976 Method (LCRS, 1, NotSerialized)
977 {
978 And (Arg0, 0x0F, Local0)
979 ShiftLeft (0x01, Local0, ICRS)
980// DBG ("LCRS: ")
981// HEX (ICRS)
982 Return (BUFA)
983 }
984
985 // Generic "set resource settings" for routing entry
986 Method (LSRS, 1, NotSerialized)
987 {
988 CreateWordField (Arg0, 0x01, ISRS)
989 FindSetRightBit (ISRS, Local0)
990 Return (Decrement (Local0))
991 }
992
993 // Generic "disable" for routing entry
994 Method (LDIS, 1, NotSerialized)
995 {
996 Return (Or (Arg0, 0x80))
997 }
998
999 // Link A
1000 Device (LNKA)
1001 {
1002 Name (_HID, EisaId ("PNP0C0F"))
1003 Name (_UID, 0x01)
1004
1005 // Status
1006 Method (_STA, 0, NotSerialized)
1007 {
1008 DBG ("LNKA._STA\n")
1009 Return (LSTA (PIRA))
1010 }
1011
1012 // Possible resource settings
1013 Method (_PRS, 0, NotSerialized)
1014 {
1015 DBG ("LNKA._PRS\n")
1016 Return (PRSA)
1017 }
1018
1019 // Disable
1020 Method (_DIS, 0, NotSerialized)
1021 {
1022 DBG ("LNKA._DIS\n")
1023 Store (LDIS (PIRA), PIRA)
1024 }
1025
1026 // Current resource settings
1027 Method (_CRS, 0, NotSerialized)
1028 {
1029 DBG ("LNKA._CRS\n")
1030 Return (LCRS (PIRA))
1031 }
1032
1033 // Set resource settings
1034 Method (_SRS, 1, NotSerialized)
1035 {
1036 DBG ("LNKA._SRS: ")
1037 HEX (LSRS (Arg0))
1038 Store (LSRS (Arg0), PIRA)
1039 }
1040 }
1041
1042 // Link B
1043 Device (LNKB)
1044 {
1045 Name (_HID, EisaId ("PNP0C0F"))
1046 Name (_UID, 0x02)
1047 Method (_STA, 0, NotSerialized)
1048 {
1049 // DBG ("LNKB._STA\n")
1050 Return (LSTA (PIRB))
1051 }
1052
1053 Method (_PRS, 0, NotSerialized)
1054 {
1055 // DBG ("LNKB._PRS\n")
1056 Return (PRSB)
1057 }
1058
1059 Method (_DIS, 0, NotSerialized)
1060 {
1061 // DBG ("LNKB._DIS\n")
1062 Store (LDIS (PIRB), PIRB)
1063 }
1064
1065 Method (_CRS, 0, NotSerialized)
1066 {
1067 // DBG ("LNKB._CRS\n")
1068 Return (LCRS (PIRB))
1069 }
1070
1071 Method (_SRS, 1, NotSerialized)
1072 {
1073 DBG ("LNKB._SRS: ")
1074 HEX (LSRS (Arg0))
1075 Store (LSRS (Arg0), PIRB)
1076 }
1077 }
1078
1079 // Link C
1080 Device (LNKC)
1081 {
1082 Name (_HID, EisaId ("PNP0C0F"))
1083 Name (_UID, 0x03)
1084 Method (_STA, 0, NotSerialized)
1085 {
1086 // DBG ("LNKC._STA\n")
1087 Return (LSTA (PIRC))
1088 }
1089
1090 Method (_PRS, 0, NotSerialized)
1091 {
1092 // DBG ("LNKC._PRS\n")
1093 Return (PRSC)
1094 }
1095
1096 Method (_DIS, 0, NotSerialized)
1097 {
1098 // DBG ("LNKC._DIS\n")
1099 Store (LDIS (PIRC), PIRC)
1100 }
1101
1102 Method (_CRS, 0, NotSerialized)
1103 {
1104 // DBG ("LNKC._CRS\n")
1105 Return (LCRS (PIRC))
1106 }
1107
1108 Method (_SRS, 1, NotSerialized)
1109 {
1110 DBG ("LNKC._SRS: ")
1111 HEX (LSRS (Arg0))
1112 Store (LSRS (Arg0), PIRC)
1113 }
1114 }
1115
1116 // Link D
1117 Device (LNKD)
1118 {
1119 Name (_HID, EisaId ("PNP0C0F"))
1120 Name (_UID, 0x04)
1121 Method (_STA, 0, NotSerialized)
1122 {
1123 // DBG ("LNKD._STA\n")
1124 Return (LSTA (PIRD))
1125 }
1126
1127 Method (_PRS, 0, NotSerialized)
1128 {
1129 // DBG ("LNKD._PRS\n")
1130 Return (PRSD)
1131 }
1132
1133 Method (_DIS, 0, NotSerialized)
1134 {
1135 // DBG ("LNKD._DIS\n")
1136 Store (LDIS (PIRA), PIRD)
1137 }
1138
1139 Method (_CRS, 0, NotSerialized)
1140 {
1141 // DBG ("LNKD._CRS\n")
1142 Return (LCRS (PIRD))
1143 }
1144
1145 Method (_SRS, 1, NotSerialized)
1146 {
1147 DBG ("LNKD._SRS: ")
1148 HEX (LSRS (Arg0))
1149 Store (LSRS (Arg0), PIRD)
1150 }
1151 }
1152 }
1153
1154 // Sx states
1155 Name (_S0, Package (2) {
1156 0x00,
1157 0x00,
1158 })
1159
1160 Name (_S5, Package (2) {
1161 0x05,
1162 0x05,
1163 })
1164
1165 Method (_PTS, 1, NotSerialized)
1166 {
1167 DBG ("Prepare to sleep: ")
1168 HEX (Arg0)
1169 }
1170}
1171
1172/*
1173 * Local Variables:
1174 * comment-start: "//"
1175 * End:
1176 */
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette