VirtualBox

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

Last change on this file since 7888 was 6222, checked in by vboxsync, 17 years ago

Continue work on the parallel port device:

  1. Removed the host device interface and replaced it with a parallel port specific one
  2. Report interrupts to the device
  3. Added code for ECP (disabled for now)
  4. Added an entry in the ACPI tables to make parallel port detection on Windows guests work
  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
File size: 29.2 KB
Line 
1// $Id: vbox.dsl 6222 2007-12-30 17:06:27Z vboxsync $
2/// @file
3//
4// VirtualBox ACPI
5//
6// Copyright (C) 2006-2007 innotek GmbH
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// Scope (\_PR)
126// {
127// Processor (CPU1, 0x01, 0x00000000, 0x00) {}
128// }
129
130 Scope (\_SB)
131 {
132 OperationRegion (SYSI, SystemIO, 0x4048, 0x08)
133 Field (SYSI, DwordAcc, NoLock, Preserve)
134 {
135 IDX0, 32,
136 DAT0, 32,
137 }
138
139 IndexField (IDX0, DAT0, DwordAcc, NoLock, Preserve)
140 {
141 MEML, 32,
142 UIOA, 32,
143 Offset (0x80),
144 ININ, 32,
145 Offset (0x200),
146 VAIN, 32,
147 }
148
149 Method (_INI, 0, NotSerialized)
150 {
151 Store (0xbadc0de, VAIN)
152 DBG ("MEML: ")
153 HEX4 (MEML)
154 DBG ("UIOA: ")
155 HEX4 (UIOA)
156 }
157
158 // PCI PIC IRQ Routing table
159 // Must match pci.c:pci_slot_get_pirq
160 Name (PR00, Package ()
161 {
162 Package (0x04) {0x0002FFFF, 0x00, LNKB, 0x00,},
163 Package (0x04) {0x0002FFFF, 0x01, LNKC, 0x00,},
164 Package (0x04) {0x0002FFFF, 0x02, LNKD, 0x00,},
165 Package (0x04) {0x0002FFFF, 0x03, LNKA, 0x00,},
166 Package (0x04) {0x0003FFFF, 0x00, LNKC, 0x00,},
167 Package (0x04) {0x0003FFFF, 0x01, LNKD, 0x00,},
168 Package (0x04) {0x0003FFFF, 0x02, LNKA, 0x00,},
169 Package (0x04) {0x0003FFFF, 0x03, LNKB, 0x00,},
170 Package (0x04) {0x0004FFFF, 0x00, LNKD, 0x00,},
171 Package (0x04) {0x0004FFFF, 0x01, LNKA, 0x00,},
172 Package (0x04) {0x0004FFFF, 0x02, LNKB, 0x00,},
173 Package (0x04) {0x0004FFFF, 0x03, LNKC, 0x00,},
174 Package (0x04) {0x0005FFFF, 0x00, LNKA, 0x00,},
175 Package (0x04) {0x0005FFFF, 0x01, LNKB, 0x00,},
176 Package (0x04) {0x0005FFFF, 0x02, LNKC, 0x00,},
177 Package (0x04) {0x0005FFFF, 0x03, LNKD, 0x00,},
178 Package (0x04) {0x0006FFFF, 0x00, LNKB, 0x00,},
179 Package (0x04) {0x0006FFFF, 0x01, LNKC, 0x00,},
180 Package (0x04) {0x0006FFFF, 0x02, LNKD, 0x00,},
181 Package (0x04) {0x0006FFFF, 0x03, LNKA, 0x00,},
182 Package (0x04) {0x0007FFFF, 0x00, LNKC, 0x00,},
183 Package (0x04) {0x0007FFFF, 0x01, LNKD, 0x00,},
184 Package (0x04) {0x0007FFFF, 0x02, LNKA, 0x00,},
185 Package (0x04) {0x0007FFFF, 0x03, LNKB, 0x00,},
186 Package (0x04) {0x0008FFFF, 0x00, LNKD, 0x00,},
187 Package (0x04) {0x0008FFFF, 0x01, LNKA, 0x00,},
188 Package (0x04) {0x0008FFFF, 0x02, LNKB, 0x00,},
189 Package (0x04) {0x0008FFFF, 0x03, LNKC, 0x00,},
190 Package (0x04) {0x0009FFFF, 0x00, LNKA, 0x00,},
191 Package (0x04) {0x0009FFFF, 0x01, LNKB, 0x00,},
192 Package (0x04) {0x0009FFFF, 0x02, LNKC, 0x00,},
193 Package (0x04) {0x0009FFFF, 0x03, LNKD, 0x00,},
194 Package (0x04) {0x000AFFFF, 0x00, LNKB, 0x00,},
195 Package (0x04) {0x000AFFFF, 0x01, LNKC, 0x00,},
196 Package (0x04) {0x000AFFFF, 0x02, LNKD, 0x00,},
197 Package (0x04) {0x000AFFFF, 0x03, LNKA, 0x00,},
198 Package (0x04) {0x000BFFFF, 0x00, LNKC, 0x00,},
199 Package (0x04) {0x000BFFFF, 0x01, LNKD, 0x00,},
200 Package (0x04) {0x000BFFFF, 0x02, LNKA, 0x00,},
201 Package (0x04) {0x000BFFFF, 0x03, LNKB, 0x00,},
202 Package (0x04) {0x000CFFFF, 0x00, LNKD, 0x00,},
203 Package (0x04) {0x000CFFFF, 0x01, LNKA, 0x00,},
204 Package (0x04) {0x000CFFFF, 0x02, LNKB, 0x00,},
205 Package (0x04) {0x000CFFFF, 0x03, LNKC, 0x00,},
206 Package (0x04) {0x000DFFFF, 0x00, LNKA, 0x00,},
207 Package (0x04) {0x000DFFFF, 0x01, LNKB, 0x00,},
208 Package (0x04) {0x000DFFFF, 0x02, LNKC, 0x00,},
209 Package (0x04) {0x000DFFFF, 0x03, LNKD, 0x00,},
210 Package (0x04) {0x000EFFFF, 0x00, LNKB, 0x00,},
211 Package (0x04) {0x000EFFFF, 0x01, LNKC, 0x00,},
212 Package (0x04) {0x000EFFFF, 0x02, LNKD, 0x00,},
213 Package (0x04) {0x000EFFFF, 0x03, LNKA, 0x00,},
214 Package (0x04) {0x000FFFFF, 0x00, LNKC, 0x00,},
215 Package (0x04) {0x000FFFFF, 0x01, LNKD, 0x00,},
216 Package (0x04) {0x000FFFFF, 0x02, LNKA, 0x00,},
217 Package (0x04) {0x000FFFFF, 0x03, LNKB, 0x00,}
218 })
219
220 // PCI I/O APIC IRQ Routing table
221 // Must match pci.c:pci_slot_get_acpi_pirq
222 Name (PR01, Package ()
223 {
224 Package (0x04) {0x0002FFFF, 0x00, 0x00, 0x12,},
225 Package (0x04) {0x0002FFFF, 0x01, 0x00, 0x13,},
226 Package (0x04) {0x0002FFFF, 0x02, 0x00, 0x14,},
227 Package (0x04) {0x0002FFFF, 0x03, 0x00, 0x15,},
228 Package (0x04) {0x0003FFFF, 0x00, 0x00, 0x13,},
229 Package (0x04) {0x0003FFFF, 0x01, 0x00, 0x14,},
230 Package (0x04) {0x0003FFFF, 0x02, 0x00, 0x15,},
231 Package (0x04) {0x0003FFFF, 0x03, 0x00, 0x16,},
232 Package (0x04) {0x0004FFFF, 0x00, 0x00, 0x14,},
233 Package (0x04) {0x0004FFFF, 0x01, 0x00, 0x15,},
234 Package (0x04) {0x0004FFFF, 0x02, 0x00, 0x16,},
235 Package (0x04) {0x0004FFFF, 0x03, 0x00, 0x17,},
236 Package (0x04) {0x0005FFFF, 0x00, 0x00, 0x15,},
237 Package (0x04) {0x0005FFFF, 0x01, 0x00, 0x16,},
238 Package (0x04) {0x0005FFFF, 0x02, 0x00, 0x17,},
239 Package (0x04) {0x0005FFFF, 0x03, 0x00, 0x10,},
240 Package (0x04) {0x0006FFFF, 0x00, 0x00, 0x16,},
241 Package (0x04) {0x0006FFFF, 0x01, 0x00, 0x17,},
242 Package (0x04) {0x0006FFFF, 0x02, 0x00, 0x10,},
243 Package (0x04) {0x0006FFFF, 0x03, 0x00, 0x11,},
244 Package (0x04) {0x0007FFFF, 0x00, 0x00, 0x17,},
245 Package (0x04) {0x0007FFFF, 0x01, 0x00, 0x10,},
246 Package (0x04) {0x0007FFFF, 0x02, 0x00, 0x11,},
247 Package (0x04) {0x0007FFFF, 0x03, 0x00, 0x12,},
248 Package (0x04) {0x0008FFFF, 0x00, 0x00, 0x10,},
249 Package (0x04) {0x0008FFFF, 0x01, 0x00, 0x11,},
250 Package (0x04) {0x0008FFFF, 0x02, 0x00, 0x12,},
251 Package (0x04) {0x0008FFFF, 0x03, 0x00, 0x13,},
252 Package (0x04) {0x0009FFFF, 0x00, 0x00, 0x11,},
253 Package (0x04) {0x0009FFFF, 0x01, 0x00, 0x12,},
254 Package (0x04) {0x0009FFFF, 0x02, 0x00, 0x13,},
255 Package (0x04) {0x0009FFFF, 0x03, 0x00, 0x14,},
256 Package (0x04) {0x000AFFFF, 0x00, 0x00, 0x12,},
257 Package (0x04) {0x000AFFFF, 0x01, 0x00, 0x13,},
258 Package (0x04) {0x000AFFFF, 0x02, 0x00, 0x14,},
259 Package (0x04) {0x000AFFFF, 0x03, 0x00, 0x15,},
260 Package (0x04) {0x000BFFFF, 0x00, 0x00, 0x13,},
261 Package (0x04) {0x000BFFFF, 0x01, 0x00, 0x14,},
262 Package (0x04) {0x000BFFFF, 0x02, 0x00, 0x15,},
263 Package (0x04) {0x000BFFFF, 0x03, 0x00, 0x16,},
264 Package (0x04) {0x000CFFFF, 0x00, 0x00, 0x14,},
265 Package (0x04) {0x000CFFFF, 0x01, 0x00, 0x15,},
266 Package (0x04) {0x000CFFFF, 0x02, 0x00, 0x16,},
267 Package (0x04) {0x000CFFFF, 0x03, 0x00, 0x17,},
268 Package (0x04) {0x000DFFFF, 0x00, 0x00, 0x15,},
269 Package (0x04) {0x000DFFFF, 0x01, 0x00, 0x16,},
270 Package (0x04) {0x000DFFFF, 0x02, 0x00, 0x17,},
271 Package (0x04) {0x000DFFFF, 0x03, 0x00, 0x10,},
272 Package (0x04) {0x000EFFFF, 0x00, 0x00, 0x16,},
273 Package (0x04) {0x000EFFFF, 0x01, 0x00, 0x17,},
274 Package (0x04) {0x000EFFFF, 0x02, 0x00, 0x10,},
275 Package (0x04) {0x000EFFFF, 0x03, 0x00, 0x11,},
276 Package (0x04) {0x000FFFFF, 0x00, 0x00, 0x17,},
277 Package (0x04) {0x000FFFFF, 0x01, 0x00, 0x10,},
278 Package (0x04) {0x000FFFFF, 0x02, 0x00, 0x11,},
279 Package (0x04) {0x000FFFFF, 0x03, 0x00, 0x12,}
280 })
281
282 // Possible resource settings for PCI link A
283 Name (PRSA, ResourceTemplate ()
284 {
285 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
286 })
287
288 // Possible resource settings for PCI link B
289 Name (PRSB, ResourceTemplate ()
290 {
291 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
292 })
293
294 // Possible resource settings for PCI link C
295 Name (PRSC, ResourceTemplate ()
296 {
297 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
298 })
299
300 // Possible resource settings for PCI link D
301 Name (PRSD, ResourceTemplate ()
302 {
303 IRQ (Level, ActiveLow, Shared) {5,9,10,11}
304 })
305
306 // PCI bus 0
307 Device (PCI0)
308 {
309 Name (_HID, EisaId ("PNP0A03"))
310 Name (_ADR, 0x00) // address
311 Name (_BBN, 0x00) // base bus adddress
312 Name (_UID, 0x00)
313
314 // Method that returns routing table
315 Method (_PRT, 0, NotSerialized)
316 {
317 if (LEqual (LAnd (PICM, UIOA), Zero)) {
318 DBG ("RETURNING PIC\n")
319 Store (0x00, \_SB.PCI0.SBRG.APDE)
320 Store (0x00, \_SB.PCI0.SBRG.APAD)
321 Return (PR00)
322 }
323 else {
324 DBG ("RETURNING APIC\n")
325 Store (0xbe, \_SB.PCI0.SBRG.APDE)
326 Store (0xef, \_SB.PCI0.SBRG.APAD)
327 Return (PR01)
328 }
329 }
330
331 Device (SBRG)
332 {
333 // Address of the PIIX3 (device 1 function 0)
334 Name (_ADR, 0x00010000)
335 OperationRegion (PCIC, PCI_Config, 0x00, 0xff)
336
337 Field (PCIC, ByteAcc, NoLock, Preserve)
338 {
339 Offset (0xad),
340 APAD, 8,
341 Offset (0xde),
342 APDE, 8,
343 }
344
345 // Keyboard device
346 Device (PS2K)
347 {
348 Name (_HID, EisaId ("PNP0303"))
349 Method (_STA, 0, NotSerialized)
350 {
351 Return (0x0F)
352 }
353
354 Name (_CRS, ResourceTemplate ()
355 {
356 IO (Decode16, 0x0060, 0x0060, 0x00, 0x01)
357 IO (Decode16, 0x0064, 0x0064, 0x00, 0x01)
358 IRQNoFlags () {1}
359 })
360 }
361
362 // DMA Controller
363 Device (DMAC)
364 {
365 Name (_HID, EisaId ("PNP0200"))
366 Name (_CRS, ResourceTemplate ()
367 {
368 IO (Decode16, 0x0000, 0x0000, 0x01, 0x10)
369 IO (Decode16, 0x0080, 0x0080, 0x01, 0x10)
370 IO (Decode16, 0x00C0, 0x00C0, 0x01, 0x20)
371 DMA (Compatibility, BusMaster, Transfer8_16) {4}
372 })
373 }
374
375 // Floppy disk controller
376 Device (FDC0)
377 {
378 Name (_HID, EisaId ("PNP0700"))
379
380 // Current resource settings
381 Name (_CRS, ResourceTemplate ()
382 {
383 IO (Decode16, 0x03F0, 0x03F0, 0x01, 0x06)
384 IO (Decode16, 0x03F7, 0x03F7, 0x01, 0x01)
385 IRQNoFlags () {6}
386 DMA (Compatibility, NotBusMaster, Transfer8) {2}
387 })
388
389 // Possible resource settings
390 Name (_PRS, ResourceTemplate ()
391 {
392 IO (Decode16, 0x03F0, 0x03F0, 0x01, 0x06)
393 IO (Decode16, 0x03F7, 0x03F7, 0x01, 0x01)
394 IRQNoFlags () {6}
395 DMA (Compatibility, NotBusMaster, Transfer8) {2}
396 })
397
398 }
399
400 // Mouse device
401 Device (PS2M)
402 {
403 Name (_HID, EisaId ("PNP0F03"))
404 Method (_STA, 0, NotSerialized)
405 {
406 Return (0x0F)
407 }
408
409 Name (_CRS, ResourceTemplate ()
410 {
411 IO (Decode16, 0x0060, 0x0060, 0x00, 0x01)
412 IO (Decode16, 0x0064, 0x0064, 0x00, 0x01)
413 IRQNoFlags () {12}
414 })
415 }
416
417 // Parallel port
418 Device (LPT)
419 {
420 Name (_HID, EisaId ("PNP0400"))
421 Method (_STA, 0, NotSerialized)
422 {
423 Return (0x0F)
424 }
425 Name (_CRS, ResourceTemplate ()
426 {
427 IO (Decode16, 0x0378, 0x0378, 0x08, 0x08)
428 IO (Decode16, 0x0778, 0x0778, 0x08, 0x08)
429 IRQNoFlags () {7}
430 })
431 }
432 }
433
434 // Control method battery
435 Device (BAT0)
436 {
437 Name (_HID, EisaId ("PNP0C0A"))
438 Name (_UID, 0x00)
439
440 Scope (\_GPE)
441 {
442 // GPE bit 0 handler
443 // GPE.0 must be set and SCI raised when
444 // battery info changed and _BIF must be
445 // re-evaluated
446 Method (_L00, 0, NotSerialized)
447 {
448 Notify (\_SB.PCI0.BAT0, 0x81)
449 }
450 }
451
452 OperationRegion (CBAT, SystemIO, 0x4040, 0x08)
453 Field (CBAT, DwordAcc, NoLock, Preserve)
454 {
455 IDX0, 32,
456 DAT0, 32,
457 }
458
459 IndexField (IDX0, DAT0, DwordAcc, NoLock, Preserve)
460 {
461 STAT, 32,
462 PRAT, 32,
463 RCAP, 32,
464 PVOL, 32,
465
466 UNIT, 32,
467 DCAP, 32,
468 LFCP, 32,
469 BTEC, 32,
470 DVOL, 32,
471 DWRN, 32,
472 DLOW, 32,
473 GRN1, 32,
474 GRN2, 32,
475
476 BSTA, 32,
477 APSR, 32,
478 }
479
480 Method (_STA, 0, NotSerialized)
481 {
482 return (BSTA)
483 }
484
485 Name (PBIF, Package ()
486 {
487 0x01, // Power unit, 1 - mA
488 0x7fffffff, // Design capacity
489 0x7fffffff, // Last full charge capacity
490 0x00, // Battery technology
491 0xffffffff, // Design voltage
492 0x00, // Design capacity of Warning
493 0x00, // Design capacity of Low
494 0x04, // Battery capacity granularity 1
495 0x04, // Battery capacity granularity 2
496 "1", // Model number
497 "0", // Serial number
498 "VBOX", // Battery type
499 "innotek" // OEM Information
500 })
501
502 Name (PBST, Package () {
503 0, // Battery state
504 0x7fffffff, // Battery present rate
505 0x7fffffff, // Battery remaining capacity
506 0x7fffffff // Battery present voltage
507 })
508
509 // Battery information
510 Method (_BIF, 0, NotSerialized)
511 {
512 Store (UNIT, Index (PBIF, 0,))
513 Store (DCAP, Index (PBIF, 1,))
514 Store (LFCP, Index (PBIF, 2,))
515 Store (BTEC, Index (PBIF, 3,))
516 Store (DVOL, Index (PBIF, 4,))
517 Store (DWRN, Index (PBIF, 5,))
518 Store (DLOW, Index (PBIF, 6,))
519 Store (GRN1, Index (PBIF, 7,))
520 Store (GRN2, Index (PBIF, 8,))
521
522 DBG ("_BIF:\n")
523 HEX4 (DerefOf (Index (PBIF, 0,)))
524 HEX4 (DerefOf (Index (PBIF, 1,)))
525 HEX4 (DerefOf (Index (PBIF, 2,)))
526 HEX4 (DerefOf (Index (PBIF, 3,)))
527 HEX4 (DerefOf (Index (PBIF, 4,)))
528 HEX4 (DerefOf (Index (PBIF, 5,)))
529 HEX4 (DerefOf (Index (PBIF, 6,)))
530 HEX4 (DerefOf (Index (PBIF, 7,)))
531 HEX4 (DerefOf (Index (PBIF, 8,)))
532
533 return (PBIF)
534 }
535
536 // Battery status
537 Method (_BST, 0, NotSerialized)
538 {
539 Store (STAT, Index (PBST, 0,))
540 Store (PRAT, Index (PBST, 1,))
541 Store (RCAP, Index (PBST, 2,))
542 Store (PVOL, Index (PBST, 3,))
543/*
544 DBG ("_BST:\n")
545 HEX4 (DerefOf (Index (PBST, 0,)))
546 HEX4 (DerefOf (Index (PBST, 1,)))
547 HEX4 (DerefOf (Index (PBST, 2,)))
548 HEX4 (DerefOf (Index (PBST, 3,)))
549*/
550 return (PBST)
551 }
552 }
553
554 Device (AC)
555 {
556 Name (_HID, "ACPI0003")
557 Name (_UID, 0x00)
558 Name (_PCL, Package (0x01)
559 {
560 \_SB
561 })
562
563 Method (_PSR, 0, NotSerialized)
564 {
565 // DBG ("_PSR:\n")
566 // HEX4 (\_SB.PCI0.BAT0.APSR)
567 return (\_SB.PCI0.BAT0.APSR)
568 }
569
570 Method (_STA, 0, NotSerialized)
571 {
572 return (0x0f)
573 }
574 }
575 }
576 }
577
578 Scope (\_SB)
579 {
580 Scope (PCI0)
581 {
582 // PCI0 current resource settings
583 Name (CRS, ResourceTemplate ()
584 {
585 WordBusNumber (ResourceProducer, MinFixed, MaxFixed, PosDecode,
586 0x0000,
587 0x0000,
588 0x00FF,
589 0x0000,
590 0x0100)
591 IO (Decode16, 0x0CF8, 0x0CF8, 0x01, 0x08)
592 WordIO (ResourceProducer, MinFixed, MaxFixed,
593 PosDecode, EntireRange,
594 0x0000,
595 0x0000,
596 0x0CF7,
597 0x0000,
598 0x0CF8)
599 WordIO (ResourceProducer, MinFixed, MaxFixed,
600 PosDecode, EntireRange,
601 0x0000,
602 0x0D00,
603 0xFFFF,
604 0x0000,
605 0xF300)
606
607 /* Taken from ACPI faq (with some modifications) */
608 DwordMemory( // descriptor for video RAM behind ISA bus
609 ResourceProducer, // bit 0 of general flags is 0
610 PosDecode,
611 MinFixed, // Range is fixed
612 MaxFixed, // Range is Fixed
613 Cacheable,
614 ReadWrite,
615 0x00000000, // Granularity
616 0x000a0000, // Min
617 0x000bffff, // Max
618 0x00000000, // Translation
619 0x00020000 // Range Length
620 )
621
622 DwordMemory( // Consumed-and-produced resource
623 // (all of memory space)
624 ResourceProducer, // bit 0 of general flags is 0
625 PosDecode, // positive Decode
626 MinFixed, // Range is fixed
627 MaxFixed, // Range is fixed
628 Cacheable,
629 ReadWrite,
630 0x00000000, // Granularity
631 0x00000000, // Min (calculated dynamically)
632
633 0xffdfffff, // Max = 4GB - 2MB
634 0x00000000, // Translation
635 0xdfdfffff, // Range Length (calculated
636 // dynamically)
637 , // Optional field left blank
638 , // Optional field left blank
639 MEM3 // Name declaration for this
640 // descriptor
641 )
642 })
643
644 Method (_CRS, 0, NotSerialized)
645 {
646 CreateDwordField (CRS, \_SB.PCI0.MEM3._MIN, RAMT)
647 CreateDwordField (CRS, \_SB.PCI0.MEM3._LEN, RAMR)
648 Store (MEML, RAMT)
649 Subtract (0xffe00000, RAMT, RAMR)
650 Return (CRS)
651 }
652 }
653 }
654
655 Scope (\_SB)
656 {
657 // Fields within PIIX3 configuration[0x60..0x63] with
658 // IRQ mappings
659 Field (\_SB.PCI0.SBRG.PCIC, ByteAcc, NoLock, Preserve)
660 {
661 Offset (0x60),
662 PIRA, 8,
663 PIRB, 8,
664 PIRC, 8,
665 PIRD, 8
666 }
667
668 Name (BUFA, ResourceTemplate ()
669 {
670 IRQ (Level, ActiveLow, Shared) {15}
671 })
672 CreateWordField (BUFA, 0x01, ICRS)
673
674 // Generic status of IRQ routing entry
675 Method (LSTA, 1, NotSerialized)
676 {
677 And (Arg0, 0x80, Local0)
678// DBG ("LSTA: ")
679// HEX (Arg0)
680 If (Local0)
681 {
682 Return (0x09)
683 }
684 Else
685 {
686 Return (0x0B)
687 }
688 }
689
690 // Generic "current resource settings" for routing entry
691 Method (LCRS, 1, NotSerialized)
692 {
693 And (Arg0, 0x0F, Local0)
694 ShiftLeft (0x01, Local0, ICRS)
695// DBG ("LCRS: ")
696// HEX (ICRS)
697 Return (BUFA)
698 }
699
700 // Generic "set resource settings" for routing entry
701 Method (LSRS, 1, NotSerialized)
702 {
703 CreateWordField (Arg0, 0x01, ISRS)
704 FindSetRightBit (ISRS, Local0)
705 Return (Decrement (Local0))
706 }
707
708 // Generic "disable" for routing entry
709 Method (LDIS, 1, NotSerialized)
710 {
711 Return (Or (Arg0, 0x80))
712 }
713
714 // Link A
715 Device (LNKA)
716 {
717 Name (_HID, EisaId ("PNP0C0F"))
718 Name (_UID, 0x01)
719
720 // Status
721 Method (_STA, 0, NotSerialized)
722 {
723 DBG ("LNKA._STA\n")
724 Return (LSTA (PIRA))
725 }
726
727 // Possible resource settings
728 Method (_PRS, 0, NotSerialized)
729 {
730 DBG ("LNKA._PRS\n")
731 Return (PRSA)
732 }
733
734 // Disable
735 Method (_DIS, 0, NotSerialized)
736 {
737 DBG ("LNKA._DIS\n")
738 Store (LDIS (PIRA), PIRA)
739 }
740
741 // Current resource settings
742 Method (_CRS, 0, NotSerialized)
743 {
744 DBG ("LNKA._CRS\n")
745 Return (LCRS (PIRA))
746 }
747
748 // Set resource settings
749 Method (_SRS, 1, NotSerialized)
750 {
751 DBG ("LNKA._SRS: ")
752 HEX (LSRS (Arg0))
753 Store (LSRS (Arg0), PIRA)
754 }
755 }
756
757 // Link B
758 Device (LNKB)
759 {
760 Name (_HID, EisaId ("PNP0C0F"))
761 Name (_UID, 0x02)
762 Method (_STA, 0, NotSerialized)
763 {
764 // DBG ("LNKB._STA\n")
765 Return (LSTA (PIRB))
766 }
767
768 Method (_PRS, 0, NotSerialized)
769 {
770 // DBG ("LNKB._PRS\n")
771 Return (PRSB)
772 }
773
774 Method (_DIS, 0, NotSerialized)
775 {
776 // DBG ("LNKB._DIS\n")
777 Store (LDIS (PIRB), PIRB)
778 }
779
780 Method (_CRS, 0, NotSerialized)
781 {
782 // DBG ("LNKB._CRS\n")
783 Return (LCRS (PIRB))
784 }
785
786 Method (_SRS, 1, NotSerialized)
787 {
788 DBG ("LNKB._SRS: ")
789 HEX (LSRS (Arg0))
790 Store (LSRS (Arg0), PIRB)
791 }
792 }
793
794 // Link C
795 Device (LNKC)
796 {
797 Name (_HID, EisaId ("PNP0C0F"))
798 Name (_UID, 0x03)
799 Method (_STA, 0, NotSerialized)
800 {
801 // DBG ("LNKC._STA\n")
802 Return (LSTA (PIRC))
803 }
804
805 Method (_PRS, 0, NotSerialized)
806 {
807 // DBG ("LNKC._PRS\n")
808 Return (PRSC)
809 }
810
811 Method (_DIS, 0, NotSerialized)
812 {
813 // DBG ("LNKC._DIS\n")
814 Store (LDIS (PIRC), PIRC)
815 }
816
817 Method (_CRS, 0, NotSerialized)
818 {
819 // DBG ("LNKC._CRS\n")
820 Return (LCRS (PIRC))
821 }
822
823 Method (_SRS, 1, NotSerialized)
824 {
825 DBG ("LNKC._SRS: ")
826 HEX (LSRS (Arg0))
827 Store (LSRS (Arg0), PIRC)
828 }
829 }
830
831 // Link D
832 Device (LNKD)
833 {
834 Name (_HID, EisaId ("PNP0C0F"))
835 Name (_UID, 0x04)
836 Method (_STA, 0, NotSerialized)
837 {
838 // DBG ("LNKD._STA\n")
839 Return (LSTA (PIRD))
840 }
841
842 Method (_PRS, 0, NotSerialized)
843 {
844 // DBG ("LNKD._PRS\n")
845 Return (PRSD)
846 }
847
848 Method (_DIS, 0, NotSerialized)
849 {
850 // DBG ("LNKD._DIS\n")
851 Store (LDIS (PIRA), PIRD)
852 }
853
854 Method (_CRS, 0, NotSerialized)
855 {
856 // DBG ("LNKD._CRS\n")
857 Return (LCRS (PIRD))
858 }
859
860 Method (_SRS, 1, NotSerialized)
861 {
862 DBG ("LNKD._SRS: ")
863 HEX (LSRS (Arg0))
864 Store (LSRS (Arg0), PIRD)
865 }
866 }
867 }
868
869 // Sx states
870 Name (_S0, Package (2) {
871 0x00,
872 0x00,
873 })
874
875 Name (_S5, Package (2) {
876 0x05,
877 0x05,
878 })
879
880 Method (_PTS, 1, NotSerialized)
881 {
882 DBG ("Prepare to sleep: ")
883 HEX (Arg0)
884 }
885}
886
887/*
888 * Local Variables:
889 * comment-start: "//"
890 * End:
891 */
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