VirtualBox

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

Last change on this file since 57426 was 56292, checked in by vboxsync, 10 years ago

Devices: Updated (C) year.

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
File size: 54.9 KB
Line 
1// $Id: vbox.dsl 56292 2015-06-09 14:20:46Z vboxsync $
2/// @file
3//
4// VirtualBox ACPI
5//
6// Copyright (C) 2006-2015 Oracle Corporation
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 (GPL) as published by the Free Software
12// Foundation, in version 2 as it comes in the "COPYING" file of the
13// VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14// hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15
16DefinitionBlock ("DSDT.aml", "DSDT", 1, "VBOX ", "VBOXBIOS", 2)
17{
18 // Declare debugging ports withing SystemIO
19 OperationRegion(DBG0, SystemIO, 0x3000, 4)
20
21 // Writes to this field Will dump hex char
22 Field (DBG0, ByteAcc, NoLock, Preserve)
23 {
24 DHE1, 8,
25 }
26
27 // Writes to this field Will dump hex word
28 Field (DBG0, WordAcc, NoLock, Preserve)
29 {
30 DHE2, 16,
31 }
32
33 // Writes to this field Will dump hex double word
34 Field (DBG0, DWordAcc, NoLock, Preserve)
35 {
36 DHE4, 32,
37 }
38
39 // Writes to this field will dump ascii char
40 Field (DBG0, ByteAcc, NoLock, Preserve)
41 {
42 Offset (1),
43 DCHR, 8
44 }
45
46 // Shortcuts
47 Method(HEX, 1)
48 {
49 Store (Arg0, DHE1)
50 }
51
52 Method(HEX2, 1)
53 {
54 Store (Arg0, DHE2)
55 }
56
57 Method(HEX4, 1)
58 {
59 Store (Arg0, DHE4)
60 }
61
62 // Code from Microsoft sample
63 // http://www.microsoft.com/whdc/system/pnppwr/powermgmt/_OSI-method.mspx
64
65 //
66 // SLEN(Str) - Returns the length of Str (excluding NULL).
67 //
68 Method(SLEN, 1)
69 {
70 //
71 // Note: The caller must make sure that the argument is a string object.
72 //
73 Store(Arg0, Local0)
74 Return(Sizeof(Local0))
75 }
76
77 Method(S2BF, 1)
78 {
79 //
80 // Note: The caller must make sure that the argument is a string object.
81 //
82 // Local0 contains length of string + NULL.
83 //
84 Store(Arg0, Local0)
85 Add(SLEN(Local0), One, Local0)
86 //
87 // Convert the string object into a buffer object.
88 //
89 Name(BUFF, Buffer(Local0) {})
90 Store(Arg0, BUFF)
91 Return(BUFF)
92 }
93
94 // Convert ASCII string to buffer and store it's contents (char by
95 // char) into DCHR (thus possibly writing the string to console)
96 Method (\DBG, 1, NotSerialized)
97 {
98 Store(Arg0, Local0)
99 Store(S2BF (Local0), Local1)
100 Store(SizeOf (Local1), Local0)
101 Decrement (Local0)
102 Store(Zero, Local2)
103 While (Local0)
104 {
105 Decrement (Local0)
106 Store (DerefOf (Index (Local1, Local2)), DCHR)
107 Increment (Local2)
108 }
109 }
110
111 Name(PICM, 0)
112 Method(_PIC, 1)
113 {
114 DBG ("Pic mode: ")
115 HEX4 (Arg0)
116 Store (Arg0, PICM)
117 }
118
119 // Declare indexed registers used for reading configuration information
120 OperationRegion (SYSI, SystemIO, 0x4048, 0x08)
121 Field (SYSI, DwordAcc, NoLock, Preserve)
122 {
123 IDX0, 32,
124 DAT0, 32,
125 }
126
127 IndexField (IDX0, DAT0, DwordAcc, NoLock, Preserve)
128 {
129 MEML, 32,
130 UIOA, 32, // if IO APIC enabled
131 UHPT, 32, // if HPET enabled
132 USMC, 32, // if SMC enabled
133 UFDC, 32, // if floppy controller enabled
134 // UCP0-UCP3 no longer used and only kept here for saved state compatibility
135 UCP0, 32,
136 UCP1, 32,
137 UCP2, 32,
138 UCP3, 32,
139 MEMH, 32,
140 URTC, 32, // if RTC shown in tables
141 CPUL, 32, // flag of CPU lock state
142 CPUC, 32, // CPU to check lock status
143 CPET, 32, // type of CPU hotplug event
144 CPEV, 32, // id of CPU event targets
145 NICA, 32, // Primary NIC PCI address
146 HDAA, 32, // HDA PCI address
147 PWRS, 32, // power states
148 IOCA, 32, // southbridge IO controller PCI address
149 HBCA, 32, // host bus controller address
150 PCIB, 32, // PCI MCFG base start
151 PCIL, 32, // PCI MCFG length
152 SL0B, 32, // Serial0 base IO address
153 SL0I, 32, // Serial0 IRQ
154 SL1B, 32, // Serial1 base IO address
155 SL1I, 32, // Serial1 IRQ
156 Offset (0x80),
157 ININ, 32,
158 Offset (0x200),
159 VAIN, 32,
160 }
161
162 Scope (\_SB)
163 {
164 Method (_INI, 0, NotSerialized)
165 {
166 Store (0xbadc0de, VAIN)
167 DBG ("MEML: ")
168 HEX4 (MEML)
169 DBG ("UIOA: ")
170 HEX4 (UIOA)
171 DBG ("UHPT: ")
172 HEX4 (UHPT)
173 DBG ("USMC: ")
174 HEX4 (USMC)
175 DBG ("UFDC: ")
176 HEX4 (UFDC)
177 DBG ("MEMH: ")
178 HEX4 (MEMH)
179 }
180
181 // PCI PIC IRQ Routing table
182 // Must match pci.c:pci_slot_get_pirq
183 Name (PR00, Package ()
184 {
185 Package (0x04) {0x0002FFFF, 0x00, LNKB, 0x00,},
186 Package (0x04) {0x0002FFFF, 0x01, LNKC, 0x00,},
187 Package (0x04) {0x0002FFFF, 0x02, LNKD, 0x00,},
188 Package (0x04) {0x0002FFFF, 0x03, LNKA, 0x00,},
189
190 Package (0x04) {0x0003FFFF, 0x00, LNKC, 0x00,},
191 Package (0x04) {0x0003FFFF, 0x01, LNKD, 0x00,},
192 Package (0x04) {0x0003FFFF, 0x02, LNKA, 0x00,},
193 Package (0x04) {0x0003FFFF, 0x03, LNKB, 0x00,},
194
195 Package (0x04) {0x0004FFFF, 0x00, LNKD, 0x00,},
196 Package (0x04) {0x0004FFFF, 0x01, LNKA, 0x00,},
197 Package (0x04) {0x0004FFFF, 0x02, LNKB, 0x00,},
198 Package (0x04) {0x0004FFFF, 0x03, LNKC, 0x00,},
199
200 Package (0x04) {0x0005FFFF, 0x00, LNKA, 0x00,},
201 Package (0x04) {0x0005FFFF, 0x01, LNKB, 0x00,},
202 Package (0x04) {0x0005FFFF, 0x02, LNKC, 0x00,},
203 Package (0x04) {0x0005FFFF, 0x03, LNKD, 0x00,},
204
205 Package (0x04) {0x0006FFFF, 0x00, LNKB, 0x00,},
206 Package (0x04) {0x0006FFFF, 0x01, LNKC, 0x00,},
207 Package (0x04) {0x0006FFFF, 0x02, LNKD, 0x00,},
208 Package (0x04) {0x0006FFFF, 0x03, LNKA, 0x00,},
209
210 Package (0x04) {0x0007FFFF, 0x00, LNKC, 0x00,},
211 Package (0x04) {0x0007FFFF, 0x01, LNKD, 0x00,},
212 Package (0x04) {0x0007FFFF, 0x02, LNKA, 0x00,},
213 Package (0x04) {0x0007FFFF, 0x03, LNKB, 0x00,},
214
215 Package (0x04) {0x0008FFFF, 0x00, LNKD, 0x00,},
216 Package (0x04) {0x0008FFFF, 0x01, LNKA, 0x00,},
217 Package (0x04) {0x0008FFFF, 0x02, LNKB, 0x00,},
218 Package (0x04) {0x0008FFFF, 0x03, LNKC, 0x00,},
219
220 Package (0x04) {0x0009FFFF, 0x00, LNKA, 0x00,},
221 Package (0x04) {0x0009FFFF, 0x01, LNKB, 0x00,},
222 Package (0x04) {0x0009FFFF, 0x02, LNKC, 0x00,},
223 Package (0x04) {0x0009FFFF, 0x03, LNKD, 0x00,},
224
225 Package (0x04) {0x000AFFFF, 0x00, LNKB, 0x00,},
226 Package (0x04) {0x000AFFFF, 0x01, LNKC, 0x00,},
227 Package (0x04) {0x000AFFFF, 0x02, LNKD, 0x00,},
228 Package (0x04) {0x000AFFFF, 0x03, LNKA, 0x00,},
229
230 Package (0x04) {0x000BFFFF, 0x00, LNKC, 0x00,},
231 Package (0x04) {0x000BFFFF, 0x01, LNKD, 0x00,},
232 Package (0x04) {0x000BFFFF, 0x02, LNKA, 0x00,},
233 Package (0x04) {0x000BFFFF, 0x03, LNKB, 0x00,},
234
235 Package (0x04) {0x000CFFFF, 0x00, LNKD, 0x00,},
236 Package (0x04) {0x000CFFFF, 0x01, LNKA, 0x00,},
237 Package (0x04) {0x000CFFFF, 0x02, LNKB, 0x00,},
238 Package (0x04) {0x000CFFFF, 0x03, LNKC, 0x00,},
239
240 Package (0x04) {0x000DFFFF, 0x00, LNKA, 0x00,},
241 Package (0x04) {0x000DFFFF, 0x01, LNKB, 0x00,},
242 Package (0x04) {0x000DFFFF, 0x02, LNKC, 0x00,},
243 Package (0x04) {0x000DFFFF, 0x03, LNKD, 0x00,},
244
245 Package (0x04) {0x000EFFFF, 0x00, LNKB, 0x00,},
246 Package (0x04) {0x000EFFFF, 0x01, LNKC, 0x00,},
247 Package (0x04) {0x000EFFFF, 0x02, LNKD, 0x00,},
248 Package (0x04) {0x000EFFFF, 0x03, LNKA, 0x00,},
249
250 Package (0x04) {0x000FFFFF, 0x00, LNKC, 0x00,},
251 Package (0x04) {0x000FFFFF, 0x01, LNKD, 0x00,},
252 Package (0x04) {0x000FFFFF, 0x02, LNKA, 0x00,},
253 Package (0x04) {0x000FFFFF, 0x03, LNKB, 0x00,},
254
255 Package (0x04) {0x0010FFFF, 0x00, LNKD, 0x00,},
256 Package (0x04) {0x0010FFFF, 0x01, LNKA, 0x00,},
257 Package (0x04) {0x0010FFFF, 0x02, LNKB, 0x00,},
258 Package (0x04) {0x0010FFFF, 0x03, LNKC, 0x00,},
259
260 Package (0x04) {0x0011FFFF, 0x00, LNKA, 0x00,},
261 Package (0x04) {0x0011FFFF, 0x01, LNKB, 0x00,},
262 Package (0x04) {0x0011FFFF, 0x02, LNKC, 0x00,},
263 Package (0x04) {0x0011FFFF, 0x03, LNKD, 0x00,},
264
265 Package (0x04) {0x0012FFFF, 0x00, LNKB, 0x00,},
266 Package (0x04) {0x0012FFFF, 0x01, LNKC, 0x00,},
267 Package (0x04) {0x0012FFFF, 0x02, LNKD, 0x00,},
268 Package (0x04) {0x0012FFFF, 0x03, LNKA, 0x00,},
269
270 Package (0x04) {0x0013FFFF, 0x00, LNKC, 0x00,},
271 Package (0x04) {0x0013FFFF, 0x01, LNKD, 0x00,},
272 Package (0x04) {0x0013FFFF, 0x02, LNKA, 0x00,},
273 Package (0x04) {0x0013FFFF, 0x03, LNKB, 0x00,},
274
275 Package (0x04) {0x0014FFFF, 0x00, LNKD, 0x00,},
276 Package (0x04) {0x0014FFFF, 0x01, LNKA, 0x00,},
277 Package (0x04) {0x0014FFFF, 0x02, LNKB, 0x00,},
278 Package (0x04) {0x0014FFFF, 0x03, LNKC, 0x00,},
279
280 Package (0x04) {0x0015FFFF, 0x00, LNKA, 0x00,},
281 Package (0x04) {0x0015FFFF, 0x01, LNKB, 0x00,},
282 Package (0x04) {0x0015FFFF, 0x02, LNKC, 0x00,},
283 Package (0x04) {0x0015FFFF, 0x03, LNKD, 0x00,},
284
285 Package (0x04) {0x0016FFFF, 0x00, LNKB, 0x00,},
286 Package (0x04) {0x0016FFFF, 0x01, LNKC, 0x00,},
287 Package (0x04) {0x0016FFFF, 0x02, LNKD, 0x00,},
288 Package (0x04) {0x0016FFFF, 0x03, LNKA, 0x00,},
289
290 Package (0x04) {0x0017FFFF, 0x00, LNKC, 0x00,},
291 Package (0x04) {0x0017FFFF, 0x01, LNKD, 0x00,},
292 Package (0x04) {0x0017FFFF, 0x02, LNKA, 0x00,},
293 Package (0x04) {0x0017FFFF, 0x03, LNKB, 0x00,},
294
295 Package (0x04) {0x0018FFFF, 0x00, LNKD, 0x00,},
296 Package (0x04) {0x0018FFFF, 0x01, LNKA, 0x00,},
297 Package (0x04) {0x0018FFFF, 0x02, LNKB, 0x00,},
298 Package (0x04) {0x0018FFFF, 0x03, LNKC, 0x00,},
299
300 Package (0x04) {0x0019FFFF, 0x00, LNKA, 0x00,},
301 Package (0x04) {0x0019FFFF, 0x01, LNKB, 0x00,},
302 Package (0x04) {0x0019FFFF, 0x02, LNKC, 0x00,},
303 Package (0x04) {0x0019FFFF, 0x03, LNKD, 0x00,},
304
305 Package (0x04) {0x001AFFFF, 0x00, LNKB, 0x00,},
306 Package (0x04) {0x001AFFFF, 0x01, LNKC, 0x00,},
307 Package (0x04) {0x001AFFFF, 0x02, LNKD, 0x00,},
308 Package (0x04) {0x001AFFFF, 0x03, LNKA, 0x00,},
309
310 Package (0x04) {0x001BFFFF, 0x00, LNKC, 0x00,},
311 Package (0x04) {0x001BFFFF, 0x01, LNKD, 0x00,},
312 Package (0x04) {0x001BFFFF, 0x02, LNKA, 0x00,},
313 Package (0x04) {0x001BFFFF, 0x03, LNKB, 0x00,},
314
315 Package (0x04) {0x001CFFFF, 0x00, LNKD, 0x00,},
316 Package (0x04) {0x001CFFFF, 0x01, LNKA, 0x00,},
317 Package (0x04) {0x001CFFFF, 0x02, LNKB, 0x00,},
318 Package (0x04) {0x001CFFFF, 0x03, LNKC, 0x00,},
319
320 Package (0x04) {0x001DFFFF, 0x00, LNKA, 0x00,},
321 Package (0x04) {0x001DFFFF, 0x01, LNKB, 0x00,},
322 Package (0x04) {0x001DFFFF, 0x02, LNKC, 0x00,},
323 Package (0x04) {0x001DFFFF, 0x03, LNKD, 0x00,},
324
325 Package (0x04) {0x001EFFFF, 0x00, LNKB, 0x00,},
326 Package (0x04) {0x001EFFFF, 0x01, LNKC, 0x00,},
327 Package (0x04) {0x001EFFFF, 0x02, LNKD, 0x00,},
328 Package (0x04) {0x001EFFFF, 0x03, LNKA, 0x00,},
329
330 Package (0x04) {0x001FFFFF, 0x00, LNKC, 0x00,},
331 Package (0x04) {0x001FFFFF, 0x01, LNKD, 0x00,},
332 Package (0x04) {0x001FFFFF, 0x02, LNKA, 0x00,},
333 Package (0x04) {0x001FFFFF, 0x03, LNKB, 0x00,}
334 })
335
336 // PCI I/O APIC IRQ Routing table
337 // Must match pci.c:pci_slot_get_acpi_pirq
338 Name (PR01, Package ()
339 {
340 Package (0x04) {0x0002FFFF, 0x00, 0x00, 0x12,},
341 Package (0x04) {0x0002FFFF, 0x01, 0x00, 0x13,},
342 Package (0x04) {0x0002FFFF, 0x02, 0x00, 0x14,},
343 Package (0x04) {0x0002FFFF, 0x03, 0x00, 0x15,},
344
345 Package (0x04) {0x0003FFFF, 0x00, 0x00, 0x13,},
346 Package (0x04) {0x0003FFFF, 0x01, 0x00, 0x14,},
347 Package (0x04) {0x0003FFFF, 0x02, 0x00, 0x15,},
348 Package (0x04) {0x0003FFFF, 0x03, 0x00, 0x16,},
349
350 Package (0x04) {0x0004FFFF, 0x00, 0x00, 0x14,},
351 Package (0x04) {0x0004FFFF, 0x01, 0x00, 0x15,},
352 Package (0x04) {0x0004FFFF, 0x02, 0x00, 0x16,},
353 Package (0x04) {0x0004FFFF, 0x03, 0x00, 0x17,},
354
355 Package (0x04) {0x0005FFFF, 0x00, 0x00, 0x15,},
356 Package (0x04) {0x0005FFFF, 0x01, 0x00, 0x16,},
357 Package (0x04) {0x0005FFFF, 0x02, 0x00, 0x17,},
358 Package (0x04) {0x0005FFFF, 0x03, 0x00, 0x10,},
359
360 Package (0x04) {0x0006FFFF, 0x00, 0x00, 0x16,},
361 Package (0x04) {0x0006FFFF, 0x01, 0x00, 0x17,},
362 Package (0x04) {0x0006FFFF, 0x02, 0x00, 0x10,},
363 Package (0x04) {0x0006FFFF, 0x03, 0x00, 0x11,},
364
365 Package (0x04) {0x0007FFFF, 0x00, 0x00, 0x17,},
366 Package (0x04) {0x0007FFFF, 0x01, 0x00, 0x10,},
367 Package (0x04) {0x0007FFFF, 0x02, 0x00, 0x11,},
368 Package (0x04) {0x0007FFFF, 0x03, 0x00, 0x12,},
369
370 Package (0x04) {0x0008FFFF, 0x00, 0x00, 0x10,},
371 Package (0x04) {0x0008FFFF, 0x01, 0x00, 0x11,},
372 Package (0x04) {0x0008FFFF, 0x02, 0x00, 0x12,},
373 Package (0x04) {0x0008FFFF, 0x03, 0x00, 0x13,},
374
375 Package (0x04) {0x0009FFFF, 0x00, 0x00, 0x11,},
376 Package (0x04) {0x0009FFFF, 0x01, 0x00, 0x12,},
377 Package (0x04) {0x0009FFFF, 0x02, 0x00, 0x13,},
378 Package (0x04) {0x0009FFFF, 0x03, 0x00, 0x14,},
379
380 Package (0x04) {0x000AFFFF, 0x00, 0x00, 0x12,},
381 Package (0x04) {0x000AFFFF, 0x01, 0x00, 0x13,},
382 Package (0x04) {0x000AFFFF, 0x02, 0x00, 0x14,},
383 Package (0x04) {0x000AFFFF, 0x03, 0x00, 0x15,},
384
385 Package (0x04) {0x000BFFFF, 0x00, 0x00, 0x13,},
386 Package (0x04) {0x000BFFFF, 0x01, 0x00, 0x14,},
387 Package (0x04) {0x000BFFFF, 0x02, 0x00, 0x15,},
388 Package (0x04) {0x000BFFFF, 0x03, 0x00, 0x16,},
389
390 Package (0x04) {0x000CFFFF, 0x00, 0x00, 0x14,},
391 Package (0x04) {0x000CFFFF, 0x01, 0x00, 0x15,},
392 Package (0x04) {0x000CFFFF, 0x02, 0x00, 0x16,},
393 Package (0x04) {0x000CFFFF, 0x03, 0x00, 0x17,},
394
395 Package (0x04) {0x000DFFFF, 0x00, 0x00, 0x15,},
396 Package (0x04) {0x000DFFFF, 0x01, 0x00, 0x16,},
397 Package (0x04) {0x000DFFFF, 0x02, 0x00, 0x17,},
398 Package (0x04) {0x000DFFFF, 0x03, 0x00, 0x10,},
399
400 Package (0x04) {0x000EFFFF, 0x00, 0x00, 0x16,},
401 Package (0x04) {0x000EFFFF, 0x01, 0x00, 0x17,},
402 Package (0x04) {0x000EFFFF, 0x02, 0x00, 0x10,},
403 Package (0x04) {0x000EFFFF, 0x03, 0x00, 0x11,},
404
405 Package (0x04) {0x000FFFFF, 0x00, 0x00, 0x17,},
406 Package (0x04) {0x000FFFFF, 0x01, 0x00, 0x10,},
407 Package (0x04) {0x000FFFFF, 0x02, 0x00, 0x11,},
408 Package (0x04) {0x000FFFFF, 0x03, 0x00, 0x12,},
409
410 Package (0x04) {0x0010FFFF, 0x00, 0x00, 0x10,},
411 Package (0x04) {0x0010FFFF, 0x01, 0x00, 0x11,},
412 Package (0x04) {0x0010FFFF, 0x02, 0x00, 0x12,},
413 Package (0x04) {0x0010FFFF, 0x03, 0x00, 0x13,},
414
415 Package (0x04) {0x0011FFFF, 0x00, 0x00, 0x11,},
416 Package (0x04) {0x0011FFFF, 0x01, 0x00, 0x12,},
417 Package (0x04) {0x0011FFFF, 0x02, 0x00, 0x13,},
418 Package (0x04) {0x0011FFFF, 0x03, 0x00, 0x14,},
419
420 Package (0x04) {0x0012FFFF, 0x00, 0x00, 0x12,},
421 Package (0x04) {0x0012FFFF, 0x01, 0x00, 0x13,},
422 Package (0x04) {0x0012FFFF, 0x02, 0x00, 0x14,},
423 Package (0x04) {0x0012FFFF, 0x03, 0x00, 0x15,},
424
425 Package (0x04) {0x0013FFFF, 0x00, 0x00, 0x13,},
426 Package (0x04) {0x0013FFFF, 0x01, 0x00, 0x14,},
427 Package (0x04) {0x0013FFFF, 0x02, 0x00, 0x15,},
428 Package (0x04) {0x0013FFFF, 0x03, 0x00, 0x16,},
429
430 Package (0x04) {0x0014FFFF, 0x00, 0x00, 0x14,},
431 Package (0x04) {0x0014FFFF, 0x01, 0x00, 0x15,},
432 Package (0x04) {0x0014FFFF, 0x02, 0x00, 0x16,},
433 Package (0x04) {0x0014FFFF, 0x03, 0x00, 0x17,},
434
435 Package (0x04) {0x0015FFFF, 0x00, 0x00, 0x15,},
436 Package (0x04) {0x0015FFFF, 0x01, 0x00, 0x16,},
437 Package (0x04) {0x0015FFFF, 0x02, 0x00, 0x17,},
438 Package (0x04) {0x0015FFFF, 0x03, 0x00, 0x10,},
439
440 Package (0x04) {0x0016FFFF, 0x00, 0x00, 0x16,},
441 Package (0x04) {0x0016FFFF, 0x01, 0x00, 0x17,},
442 Package (0x04) {0x0016FFFF, 0x02, 0x00, 0x10,},
443 Package (0x04) {0x0016FFFF, 0x03, 0x00, 0x11,},
444
445 Package (0x04) {0x0017FFFF, 0x00, 0x00, 0x17,},
446 Package (0x04) {0x0017FFFF, 0x01, 0x00, 0x10,},
447 Package (0x04) {0x0017FFFF, 0x02, 0x00, 0x11,},
448 Package (0x04) {0x0017FFFF, 0x03, 0x00, 0x12,},
449
450 Package (0x04) {0x0018FFFF, 0x00, 0x00, 0x10,},
451 Package (0x04) {0x0018FFFF, 0x01, 0x00, 0x11,},
452 Package (0x04) {0x0018FFFF, 0x02, 0x00, 0x12,},
453 Package (0x04) {0x0018FFFF, 0x03, 0x00, 0x13,},
454
455 Package (0x04) {0x0019FFFF, 0x00, 0x00, 0x11,},
456 Package (0x04) {0x0019FFFF, 0x01, 0x00, 0x12,},
457 Package (0x04) {0x0019FFFF, 0x02, 0x00, 0x13,},
458 Package (0x04) {0x0019FFFF, 0x03, 0x00, 0x14,},
459
460 Package (0x04) {0x001AFFFF, 0x00, 0x00, 0x12,},
461 Package (0x04) {0x001AFFFF, 0x01, 0x00, 0x13,},
462 Package (0x04) {0x001AFFFF, 0x02, 0x00, 0x14,},
463 Package (0x04) {0x001AFFFF, 0x03, 0x00, 0x15,},
464
465 Package (0x04) {0x001BFFFF, 0x00, 0x00, 0x13,},
466 Package (0x04) {0x001BFFFF, 0x01, 0x00, 0x14,},
467 Package (0x04) {0x001BFFFF, 0x02, 0x00, 0x15,},
468 Package (0x04) {0x001BFFFF, 0x03, 0x00, 0x16,},
469
470 Package (0x04) {0x001CFFFF, 0x00, 0x00, 0x14,},
471 Package (0x04) {0x001CFFFF, 0x01, 0x00, 0x15,},
472 Package (0x04) {0x001CFFFF, 0x02, 0x00, 0x16,},
473 Package (0x04) {0x001CFFFF, 0x03, 0x00, 0x17,},
474
475 Package (0x04) {0x001DFFFF, 0x00, 0x00, 0x15,},
476 Package (0x04) {0x001DFFFF, 0x01, 0x00, 0x16,},
477 Package (0x04) {0x001DFFFF, 0x02, 0x00, 0x17,},
478 Package (0x04) {0x001DFFFF, 0x03, 0x00, 0x10,},
479
480 Package (0x04) {0x001EFFFF, 0x00, 0x00, 0x16,},
481 Package (0x04) {0x001EFFFF, 0x01, 0x00, 0x17,},
482 Package (0x04) {0x001EFFFF, 0x02, 0x00, 0x10,},
483 Package (0x04) {0x001EFFFF, 0x03, 0x00, 0x11,},
484
485 Package (0x04) {0x001FFFFF, 0x00, 0x00, 0x17,},
486 Package (0x04) {0x001FFFFF, 0x01, 0x00, 0x10,},
487 Package (0x04) {0x001FFFFF, 0x02, 0x00, 0x11,},
488 Package (0x04) {0x001FFFFF, 0x03, 0x00, 0x12,}
489 })
490
491 // Possible resource settings for PCI link A
492 Name (PRSA, ResourceTemplate ()
493 {
494 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
495 })
496
497 // Possible resource settings for PCI link B
498 Name (PRSB, ResourceTemplate ()
499 {
500 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
501 })
502
503 // Possible resource settings for PCI link C
504 Name (PRSC, ResourceTemplate ()
505 {
506 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
507 })
508
509 // Possible resource settings for PCI link D
510 Name (PRSD, ResourceTemplate ()
511 {
512 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
513 })
514
515 // PCI bus 0
516 Device (PCI0)
517 {
518
519 Name (_HID, EisaId ("PNP0A03")) // PCI bus PNP id
520 Method(_ADR, 0, NotSerialized) // PCI address
521 {
522 Return (HBCA)
523 }
524 Name (_BBN, 0x00) // base bus address (bus number)
525 Name (_UID, 0x00)
526
527 // Method that returns routing table; also opens PCI to I/O APIC
528 // interrupt routing backdoor by writing 0xdead 0xbeef signature
529 // to ISA bridge config space. See DevPCI.cpp/pciSetIrqInternal().
530 Method (_PRT, 0, NotSerialized)
531 {
532 if (LEqual (LAnd (PICM, UIOA), Zero)) {
533 DBG ("RETURNING PIC\n")
534 Store (0x00, \_SB.PCI0.SBRG.APDE)
535 Store (0x00, \_SB.PCI0.SBRG.APAD)
536 Return (PR00)
537 }
538 else {
539 DBG ("RETURNING APIC\n")
540 Store (0xbe, \_SB.PCI0.SBRG.APDE)
541 Store (0xef, \_SB.PCI0.SBRG.APAD)
542 Return (PR01)
543 }
544 }
545
546 Device (SBRG)
547 {
548 // Address of the southbridge device (PIIX or ICH9)
549 Method(_ADR, 0, NotSerialized)
550 {
551 Return (IOCA)
552 }
553 OperationRegion (PCIC, PCI_Config, 0x00, 0xff)
554
555 Field (PCIC, ByteAcc, NoLock, Preserve)
556 {
557 Offset (0xad),
558 APAD, 8,
559 Offset (0xde),
560 APDE, 8,
561 }
562
563 // PCI MCFG MMIO ranges
564 Device (^PCIE)
565 {
566 Name (_HID, EisaId ("PNP0C02"))
567 Name (_UID, 0x11)
568 Name (CRS, ResourceTemplate ()
569 {
570 Memory32Fixed (ReadOnly,
571 0xdc000000, // Address Base
572 0x4000000, // Address Length
573 _Y13)
574 })
575 Method (_CRS, 0, NotSerialized)
576 {
577 CreateDWordField (CRS, \_SB.PCI0.PCIE._Y13._BAS, BAS1)
578 CreateDWordField (CRS, \_SB.PCI0.PCIE._Y13._LEN, LEN1)
579 Store (PCIB, BAS1)
580 Store (PCIL, LEN1)
581 Return (CRS)
582 }
583 Method (_STA, 0, NotSerialized)
584 {
585 if (LEqual (PCIB, Zero)) {
586 Return (0x00)
587 }
588 else {
589 Return (0x0F)
590 }
591 }
592 }
593
594 // Keyboard device
595 Device (PS2K)
596 {
597 Name (_HID, EisaId ("PNP0303"))
598 Method (_STA, 0, NotSerialized)
599 {
600 Return (0x0F)
601 }
602
603 Name (_CRS, ResourceTemplate ()
604 {
605 IO (Decode16, 0x0060, 0x0060, 0x00, 0x01)
606 IO (Decode16, 0x0064, 0x0064, 0x00, 0x01)
607 IRQNoFlags () {1}
608 })
609 }
610
611 // DMA Controller
612 Device (DMAC)
613 {
614 Name (_HID, EisaId ("PNP0200"))
615 Name (_CRS, ResourceTemplate ()
616 {
617 IO (Decode16, 0x0000, 0x0000, 0x01, 0x10)
618 IO (Decode16, 0x0080, 0x0080, 0x01, 0x10)
619 IO (Decode16, 0x00C0, 0x00C0, 0x01, 0x20)
620 DMA (Compatibility, BusMaster, Transfer8_16) {4}
621 })
622 }
623
624 // Floppy disk controller
625 Device (FDC0)
626 {
627 Name (_HID, EisaId ("PNP0700"))
628
629 Method (_STA, 0, NotSerialized)
630 {
631 Return (UFDC)
632 }
633
634 // Current resource settings
635 Name (_CRS, ResourceTemplate ()
636 {
637 IO (Decode16, 0x03F0, 0x03F0, 0x01, 0x06)
638 IO (Decode16, 0x03F7, 0x03F7, 0x01, 0x01)
639 IRQNoFlags () {6}
640 DMA (Compatibility, NotBusMaster, Transfer8) {2}
641 })
642
643 // Possible resource settings
644 Name (_PRS, ResourceTemplate ()
645 {
646 IO (Decode16, 0x03F0, 0x03F0, 0x01, 0x06)
647 IO (Decode16, 0x03F7, 0x03F7, 0x01, 0x01)
648 IRQNoFlags () {6}
649 DMA (Compatibility, NotBusMaster, Transfer8) {2}
650 })
651
652 }
653
654 // Mouse device
655 Device (PS2M)
656 {
657 Name (_HID, EisaId ("PNP0F03"))
658 Method (_STA, 0, NotSerialized)
659 {
660 Return (0x0F)
661 }
662
663 Name (_CRS, ResourceTemplate ()
664 {
665 IRQNoFlags () {12}
666 })
667 }
668
669 // Parallel port
670 Device (LPT)
671 {
672 Name (_HID, EisaId ("PNP0400"))
673 Method (_STA, 0, NotSerialized)
674 {
675 Return (0x0F)
676 }
677 Name (_CRS, ResourceTemplate ()
678 {
679 IO (Decode16, 0x0378, 0x0378, 0x08, 0x08)
680 IO (Decode16, 0x0778, 0x0778, 0x08, 0x08)
681 IRQNoFlags () {7}
682 })
683 }
684
685 // Serial port 0
686 Device (^SRL0)
687 {
688 Name (_HID, EisaId ("PNP0501"))
689 Name (_UID, 0x01)
690 Method (_STA, 0, NotSerialized)
691 {
692 If (LEqual (SL0B, Zero))
693 {
694 Return (0x00)
695 }
696 Else
697 {
698 Return (0x0F)
699 }
700 }
701 Name (CRS, ResourceTemplate ()
702 {
703 IO (Decode16, 0x03F8, 0x03F8, 0x01, 0x08, _Y14)
704 IRQNoFlags (_Y15) {4}
705 })
706 Method (_CRS, 0, NotSerialized)
707 {
708 CreateWordField (CRS, \_SB.PCI0.SRL0._Y14._MIN, MIN0)
709 CreateWordField (CRS, \_SB.PCI0.SRL0._Y14._MAX, MAX0)
710 CreateWordField (CRS, \_SB.PCI0.SRL0._Y15._INT, IRQ0)
711 Store (SL0B, MIN0)
712 Store (SL0B, MAX0)
713 ShiftLeft (0x01, SL0I, IRQ0)
714 Return (CRS)
715 }
716 }
717
718 // Serial port 1
719 Device (^SRL1)
720 {
721 Name (_HID, EisaId ("PNP0501"))
722 Name (_UID, 0x02)
723 Method (_STA, 0, NotSerialized)
724 {
725 If (LEqual (SL1B, Zero))
726 {
727 Return (0x00)
728 }
729 Else
730 {
731 Return (0x0F)
732 }
733 }
734 Name (CRS, ResourceTemplate ()
735 {
736 IO (Decode16, 0x02F8, 0x02F8, 0x01, 0x08, _Y16)
737 IRQNoFlags (_Y17) {3}
738 })
739 Method (_CRS, 0, NotSerialized)
740 {
741 CreateWordField (CRS, \_SB.PCI0.SRL1._Y16._MIN, MIN1)
742 CreateWordField (CRS, \_SB.PCI0.SRL1._Y16._MAX, MAX1)
743 CreateWordField (CRS, \_SB.PCI0.SRL1._Y17._INT, IRQ1)
744 Store (SL1B, MIN1)
745 Store (SL1B, MAX1)
746 ShiftLeft (0x01, SL1I, IRQ1)
747 Return (CRS)
748 }
749 }
750
751 // Programmable Interval Timer (i8254)
752 Device (TIMR)
753 {
754 Name (_HID, EisaId ("PNP0100"))
755 Name (_CRS, ResourceTemplate ()
756 {
757 IO (Decode16,
758 0x0040, // Range Minimum
759 0x0040, // Range Maximum
760 0x00, // Alignment
761 0x04, // Length
762 )
763 IO (Decode16,
764 0x0050, // Range Minimum
765 0x0050, // Range Maximum
766 0x10, // Alignment
767 0x04, // Length
768 )
769 })
770 }
771
772 // Programmable Interrupt Controller (i8259)
773 Device (PIC)
774 {
775 Name (_HID, EisaId ("PNP0000"))
776 Name (_CRS, ResourceTemplate ()
777 {
778 IO (Decode16,
779 0x0020, // Range Minimum
780 0x0020, // Range Maximum
781 0x00, // Alignment
782 0x02, // Length
783 )
784 IO (Decode16,
785 0x00A0, // Range Minimum
786 0x00A0, // Range Maximum
787 0x00, // Alignment
788 0x02, // Length
789 )
790 // because in APIC configs PIC connected to pin 0,
791 // and ISA IRQ0 rerouted to pin 2
792 IRQNoFlags ()
793 {2}
794 })
795 }
796
797
798 // Real Time Clock and CMOS (MC146818)
799 Device (RTC)
800 {
801 Name (_HID, EisaId ("PNP0B00"))
802 Name (_CRS, ResourceTemplate ()
803 {
804 IO (Decode16,
805 0x0070, // Range Minimum
806 0x0070, // Range Maximum
807 0x01, // Alignment
808 0x02, // Length
809 )
810 })
811 Method (_STA, 0, NotSerialized)
812 {
813 Return (URTC)
814 }
815 }
816
817 // High Precision Event Timer
818 Device(HPET)
819 {
820 Name (_HID, EISAID("PNP0103"))
821 Name (_CID, EISAID("PNP0C01"))
822 Name(_UID, 0)
823
824 Method (_STA, 0, NotSerialized)
825 {
826 Return(UHPT)
827 }
828
829 Name(CRS, ResourceTemplate()
830 {
831 IRQNoFlags ()
832 {0}
833 IRQNoFlags ()
834 {8}
835 Memory32Fixed (ReadWrite,
836 0xFED00000, // Address Base
837 0x00000400 // Address Length
838 )
839 })
840
841 Method (_CRS, 0, NotSerialized)
842 {
843 Return (CRS)
844 }
845 }
846
847 // System Management Controller
848 Device (SMC)
849 {
850 Name (_HID, EisaId ("APP0001"))
851 Name (_CID, "smc-napa")
852
853 Method (_STA, 0, NotSerialized)
854 {
855 Return (USMC)
856 }
857 Name (CRS, ResourceTemplate ()
858 {
859 IO (Decode16,
860 0x0300, // Range Minimum
861 0x0300, // Range Maximum
862 0x01, // Alignment
863 0x20) // Length
864 IRQNoFlags ()
865 {6}
866
867 })
868 Method (_CRS, 0, NotSerialized)
869 {
870 Return (CRS)
871 }
872 }
873 }
874
875 // NIC
876 Device (GIGE)
877 {
878 /**
879 * Generic NIC, according to
880 * http://download.microsoft.com/download/1/6/1/161ba512-40e2-4cc9-843a-923143f3456c/devids.txt
881 * Needed by some Windows guests.
882 */
883 Name (_HID, EisaId ("PNP8390"))
884
885 Method(_ADR, 0, NotSerialized)
886 {
887 Return (NICA)
888 }
889 /* Name (_PRW, Package (0x02)
890 {
891 0x09,
892 0x04
893 }) */
894
895 /* Wake up on LAN? */
896 Method (EWOL, 1, NotSerialized)
897 {
898 Return (0x00)
899 }
900
901 Method (_STA, 0, NotSerialized)
902 {
903 if (LEqual (NICA, Zero)) {
904 Return (0x00)
905 }
906 else {
907 Return (0x0F)
908 }
909 }
910 }
911
912 // Graphics device
913 Device (GFX0)
914 {
915 Name (_ADR, 0x00020000)
916
917 Scope (\_GPE)
918 {
919 // GPE bit 2 handler
920 // GPE.2 must be set and SCI raised when
921 // display information changes.
922 Method (_L02, 0, NotSerialized)
923 {
924 Notify (\_SB.PCI0.GFX0, 0x81)
925 }
926 }
927
928 Method (_DOS, 1) { }
929
930 Method (_DOD, 0, NotSerialized)
931 {
932 Return (Package()
933 {
934 0x80000100
935 })
936 }
937
938 Device (VGA)
939 {
940 Method (_ADR, 0, Serialized)
941 {
942 Return (0x0100)
943 }
944 }
945 }
946
947 // HDA Audio card
948 Device (HDEF)
949 {
950 Method(_DSM, 4, NotSerialized)
951 {
952 Store (Package (0x04)
953 {
954 "layout-id",
955 Buffer (0x04)
956 {
957 /* 04 */ 0x04, 0x00, 0x00, 0x00
958 },
959
960 "PinConfigurations",
961 Buffer (Zero) {}
962 }, Local0)
963 if (LEqual (Arg0, ToUUID("a0b5b7c6-1318-441c-b0c9-fe695eaf949b")))
964 {
965 If (LEqual (Arg1, One))
966 {
967 if (LEqual(Arg2, Zero))
968 {
969 Store (Buffer (0x01)
970 {
971 0x03
972 }
973 , Local0)
974 Return (Local0)
975 }
976 if (LEqual(Arg2, One))
977 {
978 Return (Local0)
979 }
980 }
981 }
982 Store (Buffer (0x01)
983 {
984 0x0
985 }
986 , Local0)
987 Return (Local0)
988 }
989
990 Method(_ADR, 0, NotSerialized)
991 {
992 Return (HDAA)
993 }
994
995 Method (_STA, 0, NotSerialized)
996 {
997 if (LEqual (HDAA, Zero)) {
998 Return (0x00)
999 }
1000 else {
1001 Return (0x0F)
1002 }
1003 }
1004 }
1005
1006
1007 // Control method battery
1008 Device (BAT0)
1009 {
1010 Name (_HID, EisaId ("PNP0C0A"))
1011 Name (_UID, 0x00)
1012
1013 Scope (\_GPE)
1014 {
1015 // GPE bit 0 handler
1016 // GPE.0 must be set and SCI raised when
1017 // battery info changed and _BIF must be
1018 // re-evaluated
1019 Method (_L00, 0, NotSerialized)
1020 {
1021 Notify (\_SB.PCI0.BAT0, 0x81)
1022 }
1023 }
1024
1025 OperationRegion (CBAT, SystemIO, 0x4040, 0x08)
1026 Field (CBAT, DwordAcc, NoLock, Preserve)
1027 {
1028 IDX0, 32,
1029 DAT0, 32,
1030 }
1031
1032 IndexField (IDX0, DAT0, DwordAcc, NoLock, Preserve)
1033 {
1034 STAT, 32,
1035 PRAT, 32,
1036 RCAP, 32,
1037 PVOL, 32,
1038
1039 UNIT, 32,
1040 DCAP, 32,
1041 LFCP, 32,
1042 BTEC, 32,
1043 DVOL, 32,
1044 DWRN, 32,
1045 DLOW, 32,
1046 GRN1, 32,
1047 GRN2, 32,
1048
1049 BSTA, 32,
1050 APSR, 32,
1051 }
1052
1053 Method (_STA, 0, NotSerialized)
1054 {
1055 return (BSTA)
1056 }
1057
1058 Name (PBIF, Package ()
1059 {
1060 0x01, // Power unit, 1 - mA
1061 0x7fffffff, // Design capacity
1062 0x7fffffff, // Last full charge capacity
1063 0x00, // Battery technology
1064 0xffffffff, // Design voltage
1065 0x00, // Design capacity of Warning
1066 0x00, // Design capacity of Low
1067 0x04, // Battery capacity granularity 1
1068 0x04, // Battery capacity granularity 2
1069 "1", // Model number
1070 "0", // Serial number
1071 "VBOX", // Battery type
1072 "innotek" // OEM Information
1073 })
1074
1075 Name (PBST, Package () {
1076 0, // Battery state
1077 0x7fffffff, // Battery present rate
1078 0x7fffffff, // Battery remaining capacity
1079 0x7fffffff // Battery present voltage
1080 })
1081
1082 // Battery information
1083 Method (_BIF, 0, NotSerialized)
1084 {
1085 Store (UNIT, Index (PBIF, 0,))
1086 Store (DCAP, Index (PBIF, 1,))
1087 Store (LFCP, Index (PBIF, 2,))
1088 Store (BTEC, Index (PBIF, 3,))
1089 Store (DVOL, Index (PBIF, 4,))
1090 Store (DWRN, Index (PBIF, 5,))
1091 Store (DLOW, Index (PBIF, 6,))
1092 Store (GRN1, Index (PBIF, 7,))
1093 Store (GRN2, Index (PBIF, 8,))
1094
1095 DBG ("_BIF:\n")
1096 HEX4 (DerefOf (Index (PBIF, 0,)))
1097 HEX4 (DerefOf (Index (PBIF, 1,)))
1098 HEX4 (DerefOf (Index (PBIF, 2,)))
1099 HEX4 (DerefOf (Index (PBIF, 3,)))
1100 HEX4 (DerefOf (Index (PBIF, 4,)))
1101 HEX4 (DerefOf (Index (PBIF, 5,)))
1102 HEX4 (DerefOf (Index (PBIF, 6,)))
1103 HEX4 (DerefOf (Index (PBIF, 7,)))
1104 HEX4 (DerefOf (Index (PBIF, 8,)))
1105
1106 return (PBIF)
1107 }
1108
1109 // Battery status
1110 Method (_BST, 0, NotSerialized)
1111 {
1112 Store (STAT, Index (PBST, 0,))
1113 Store (PRAT, Index (PBST, 1,))
1114 Store (RCAP, Index (PBST, 2,))
1115 Store (PVOL, Index (PBST, 3,))
1116/*
1117 DBG ("_BST:\n")
1118 HEX4 (DerefOf (Index (PBST, 0,)))
1119 HEX4 (DerefOf (Index (PBST, 1,)))
1120 HEX4 (DerefOf (Index (PBST, 2,)))
1121 HEX4 (DerefOf (Index (PBST, 3,)))
1122*/
1123 return (PBST)
1124 }
1125 }
1126
1127 Device (AC)
1128 {
1129 Name (_HID, "ACPI0003")
1130 Name (_UID, 0x00)
1131 Name (_PCL, Package (0x01)
1132 {
1133 \_SB
1134 })
1135
1136 Method (_PSR, 0, NotSerialized)
1137 {
1138 // DBG ("_PSR:\n")
1139 // HEX4 (\_SB.PCI0.BAT0.APSR)
1140 return (\_SB.PCI0.BAT0.APSR)
1141 }
1142
1143 Method (_STA, 0, NotSerialized)
1144 {
1145 return (0x0f)
1146 }
1147 }
1148 }
1149 }
1150
1151 Scope (\_SB)
1152 {
1153 Scope (PCI0)
1154 {
1155 // PCI0 current resource settings
1156 Name (CRS, ResourceTemplate ()
1157 {
1158 WordBusNumber (ResourceProducer, MinFixed, MaxFixed, PosDecode,
1159 0x0000,
1160 0x0000,
1161 0x00FF,
1162 0x0000,
1163 0x0100)
1164 IO (Decode16, 0x0CF8, 0x0CF8, 0x01, 0x08)
1165 WordIO (ResourceProducer, MinFixed, MaxFixed,
1166 PosDecode, EntireRange,
1167 0x0000,
1168 0x0000,
1169 0x0CF7,
1170 0x0000,
1171 0x0CF8)
1172 WordIO (ResourceProducer, MinFixed, MaxFixed,
1173 PosDecode, EntireRange,
1174 0x0000,
1175 0x0D00,
1176 0xFFFF,
1177 0x0000,
1178 0xF300)
1179
1180 /* Taken from ACPI faq (with some modifications) */
1181 DwordMemory( // descriptor for video RAM behind ISA bus
1182 ResourceProducer, // bit 0 of general flags is 0
1183 PosDecode,
1184 MinFixed, // Range is fixed
1185 MaxFixed, // Range is Fixed
1186 Cacheable,
1187 ReadWrite,
1188 0x00000000, // Granularity
1189 0x000a0000, // Min
1190 0x000bffff, // Max
1191 0x00000000, // Translation
1192 0x00020000 // Range Length
1193 )
1194
1195 DwordMemory( // Consumed-and-produced resource
1196 // (all of low memory space)
1197 ResourceProducer, // bit 0 of general flags is 0
1198 PosDecode, // positive Decode
1199 MinNotFixed, // Range is not fixed
1200 MaxFixed, // Range is fixed
1201 Cacheable,
1202 ReadWrite,
1203 0x00000000, // Granularity
1204 0x00000000, // Min (calculated dynamically)
1205
1206 0xffdfffff, // Max = 4GB - 2MB
1207 0x00000000, // Translation
1208 0x00000000, // Range Length (calculated
1209 // dynamically)
1210 , // Optional field left blank
1211 , // Optional field left blank
1212 MEM3 // Name declaration for this
1213 // descriptor
1214 )
1215 })
1216
1217// Name (TOM, ResourceTemplate () // Memory above 4GB (aka high), appended when needed.
1218// {
1219// QWORDMemory(
1220// ResourceProducer, // bit 0 of general flags is 0
1221// PosDecode, // positive Decode
1222// MinFixed, // Range is fixed
1223// MaxFixed, // Range is fixed
1224// Cacheable,
1225// ReadWrite,
1226// 0x0000000000000000, // _GRA: Granularity.
1227// 0 /*0x0000000100000000*/, // _MIN: Min address, 4GB.
1228// 0 /*0x00000fffffffffff*/, // _MAX: Max possible address, 16TB.
1229// 0x0000000000000000, // _TRA: Translation
1230// 0x0000000000000000, // _LEN: Range length (calculated dynamically)
1231// , // ResourceSourceIndex: Optional field left blank
1232// , // ResourceSource: Optional field left blank
1233// MEM4 // Name declaration for this descriptor.
1234// )
1235// })
1236
1237 Method (_CRS, 0, NotSerialized)
1238 {
1239 CreateDwordField (CRS, \_SB.PCI0.MEM3._MIN, RAMT)
1240 CreateDwordField (CRS, \_SB.PCI0.MEM3._LEN, RAMR)
1241// CreateQwordField (TOM, \_SB.PCI0.MEM4._LEN, TM4L)
1242// CreateQwordField (TOM, \_SB.PCI0.MEM4._LEN, TM4N)
1243// CreateQwordField (TOM, \_SB.PCI0.MEM4._LEN, TM4X)
1244
1245 Store (MEML, RAMT)
1246 Subtract (0xffe00000, RAMT, RAMR)
1247
1248// If (LNotEqual (MEMH, 0x00000000))
1249// {
1250// //
1251// // Update the TOM resource template and append it to CRS.
1252// // This way old < 4GB guest doesn't see anything different.
1253// // (MEMH is the memory above 4GB specified in 64KB units.)
1254// //
1255// // Note: ACPI v2 doesn't do 32-bit integers. IASL may fail on
1256// // seeing 64-bit constants and the code probably wont work.
1257// //
1258// Store (1, TM4N)
1259// ShiftLeft (TM4N, 32, TM4N)
1260//
1261// Store (0x00000fff, TM4X)
1262// ShiftLeft (TM4X, 32, TM4X)
1263// Or (TM4X, 0xffffffff, TM4X)
1264//
1265// Store (MEMH, TM4L)
1266// ShiftLeft (TM4L, 16, TM4L)
1267//
1268// ConcatenateResTemplate (CRS, TOM, Local2)
1269// Return (Local2)
1270// }
1271
1272 Return (CRS)
1273 }
1274 }
1275 }
1276
1277 Scope (\_SB)
1278 {
1279 // Fields within PIIX3 configuration[0x60..0x63] with
1280 // IRQ mappings
1281 Field (\_SB.PCI0.SBRG.PCIC, ByteAcc, NoLock, Preserve)
1282 {
1283 Offset (0x60),
1284 PIRA, 8,
1285 PIRB, 8,
1286 PIRC, 8,
1287 PIRD, 8
1288 }
1289
1290 Name (BUFA, ResourceTemplate ()
1291 {
1292 IRQ (Level, ActiveLow, Shared) {15}
1293 })
1294 CreateWordField (BUFA, 0x01, ICRS)
1295
1296 // Generic status of IRQ routing entry
1297 Method (LSTA, 1, NotSerialized)
1298 {
1299 And (Arg0, 0x80, Local0)
1300// DBG ("LSTA: ")
1301// HEX (Arg0)
1302 If (Local0)
1303 {
1304 Return (0x09)
1305 }
1306 Else
1307 {
1308 Return (0x0B)
1309 }
1310 }
1311
1312 // Generic "current resource settings" for routing entry
1313 Method (LCRS, 1, NotSerialized)
1314 {
1315 And (Arg0, 0x0F, Local0)
1316 ShiftLeft (0x01, Local0, ICRS)
1317// DBG ("LCRS: ")
1318// HEX (ICRS)
1319 Return (BUFA)
1320 }
1321
1322 // Generic "set resource settings" for routing entry
1323 Method (LSRS, 1, NotSerialized)
1324 {
1325 CreateWordField (Arg0, 0x01, ISRS)
1326 FindSetRightBit (ISRS, Local0)
1327 Return (Decrement (Local0))
1328 }
1329
1330 // Generic "disable" for routing entry
1331 Method (LDIS, 1, NotSerialized)
1332 {
1333 Return (Or (Arg0, 0x80))
1334 }
1335
1336 // Link A
1337 Device (LNKA)
1338 {
1339 Name (_HID, EisaId ("PNP0C0F"))
1340 Name (_UID, 0x01)
1341
1342 // Status
1343 Method (_STA, 0, NotSerialized)
1344 {
1345 DBG ("LNKA._STA\n")
1346 Return (LSTA (PIRA))
1347 }
1348
1349 // Possible resource settings
1350 Method (_PRS, 0, NotSerialized)
1351 {
1352 DBG ("LNKA._PRS\n")
1353 Return (PRSA)
1354 }
1355
1356 // Disable
1357 Method (_DIS, 0, NotSerialized)
1358 {
1359 DBG ("LNKA._DIS\n")
1360 Store (LDIS (PIRA), PIRA)
1361 }
1362
1363 // Current resource settings
1364 Method (_CRS, 0, NotSerialized)
1365 {
1366 DBG ("LNKA._CRS\n")
1367 Return (LCRS (PIRA))
1368 }
1369
1370 // Set resource settings
1371 Method (_SRS, 1, NotSerialized)
1372 {
1373 DBG ("LNKA._SRS: ")
1374 HEX (LSRS (Arg0))
1375 Store (LSRS (Arg0), PIRA)
1376 }
1377 }
1378
1379 // Link B
1380 Device (LNKB)
1381 {
1382 Name (_HID, EisaId ("PNP0C0F"))
1383 Name (_UID, 0x02)
1384 Method (_STA, 0, NotSerialized)
1385 {
1386 // DBG ("LNKB._STA\n")
1387 Return (LSTA (PIRB))
1388 }
1389
1390 Method (_PRS, 0, NotSerialized)
1391 {
1392 // DBG ("LNKB._PRS\n")
1393 Return (PRSB)
1394 }
1395
1396 Method (_DIS, 0, NotSerialized)
1397 {
1398 // DBG ("LNKB._DIS\n")
1399 Store (LDIS (PIRB), PIRB)
1400 }
1401
1402 Method (_CRS, 0, NotSerialized)
1403 {
1404 // DBG ("LNKB._CRS\n")
1405 Return (LCRS (PIRB))
1406 }
1407
1408 Method (_SRS, 1, NotSerialized)
1409 {
1410 DBG ("LNKB._SRS: ")
1411 HEX (LSRS (Arg0))
1412 Store (LSRS (Arg0), PIRB)
1413 }
1414 }
1415
1416 // Link C
1417 Device (LNKC)
1418 {
1419 Name (_HID, EisaId ("PNP0C0F"))
1420 Name (_UID, 0x03)
1421 Method (_STA, 0, NotSerialized)
1422 {
1423 // DBG ("LNKC._STA\n")
1424 Return (LSTA (PIRC))
1425 }
1426
1427 Method (_PRS, 0, NotSerialized)
1428 {
1429 // DBG ("LNKC._PRS\n")
1430 Return (PRSC)
1431 }
1432
1433 Method (_DIS, 0, NotSerialized)
1434 {
1435 // DBG ("LNKC._DIS\n")
1436 Store (LDIS (PIRC), PIRC)
1437 }
1438
1439 Method (_CRS, 0, NotSerialized)
1440 {
1441 // DBG ("LNKC._CRS\n")
1442 Return (LCRS (PIRC))
1443 }
1444
1445 Method (_SRS, 1, NotSerialized)
1446 {
1447 DBG ("LNKC._SRS: ")
1448 HEX (LSRS (Arg0))
1449 Store (LSRS (Arg0), PIRC)
1450 }
1451 }
1452
1453 // Link D
1454 Device (LNKD)
1455 {
1456 Name (_HID, EisaId ("PNP0C0F"))
1457 Name (_UID, 0x04)
1458 Method (_STA, 0, NotSerialized)
1459 {
1460 // DBG ("LNKD._STA\n")
1461 Return (LSTA (PIRD))
1462 }
1463
1464 Method (_PRS, 0, NotSerialized)
1465 {
1466 // DBG ("LNKD._PRS\n")
1467 Return (PRSD)
1468 }
1469
1470 Method (_DIS, 0, NotSerialized)
1471 {
1472 // DBG ("LNKD._DIS\n")
1473 Store (LDIS (PIRA), PIRD)
1474 }
1475
1476 Method (_CRS, 0, NotSerialized)
1477 {
1478 // DBG ("LNKD._CRS\n")
1479 Return (LCRS (PIRD))
1480 }
1481
1482 Method (_SRS, 1, NotSerialized)
1483 {
1484 DBG ("LNKD._SRS: ")
1485 HEX (LSRS (Arg0))
1486 Store (LSRS (Arg0), PIRD)
1487 }
1488 }
1489 }
1490
1491 // Sx states
1492 Name (_S0, Package (2) {
1493 0x00,
1494 0x00,
1495 })
1496
1497 // Shift one by the power state number
1498 If (And(PWRS, ShiftLeft(One,1))) {
1499 Name (_S1, Package (2) {
1500 0x01,
1501 0x01,
1502 })
1503 }
1504
1505 If (And(PWRS, ShiftLeft(One,4))) {
1506 Name (_S4, Package (2) {
1507 0x05,
1508 0x05,
1509 })
1510 }
1511
1512 Name (_S5, Package (2) {
1513 0x05,
1514 0x05,
1515 })
1516
1517 Method (_PTS, 1, NotSerialized)
1518 {
1519 DBG ("Prepare to sleep: ")
1520 HEX (Arg0)
1521 }
1522}
1523
1524/*
1525 * Local Variables:
1526 * comment-start: "//"
1527 * End:
1528 */
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