VirtualBox

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

Last change on this file since 26270 was 26183, checked in by vboxsync, 15 years ago

Commit CPU hotplug patches again

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