VirtualBox

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

Last change on this file since 58315 was 57979, checked in by vboxsync, 9 years ago

Parallel ports: Several fixes for multiple parallel ports. Make the second parallel port visible to the guest through ACPI if enabled (and don't expose the first port if it is not enabled), increase the maximum instanbce count to 2 and make it possible to enable a parallel port without having it connected to a host device to make it behave like it is not connected to anything.

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