Mateusz Jędrasik
2005-Feb-24 02:30 UTC
acpi_bus_number: can't get _ADR issue on Intel D923XCV Motherboard.
Hi, I have a D925XCV Intel motherboard, with if_sk on it as a builtin ethernet adapter. on bootup of 5.3-RELEASE i recieve some acpi_bus_number: can't get _ADR issues and errors /dmesg follows/. I tried changing pnp os on/off, updated my bios to the most recent release, disabled all integrated devices but the ethernet, im pretty much out of ideas now. If there is any suggestion on what i could perhaphs do, it would be more than welcome, and I gladly would supply any debug information required in the process of the eventual tracking down of the error. I will plug a pci card in there for now, but this is not quite the solution i would be looking for. Also, I presume the audio card is not supported yet? It's to be some realtek chipset, also integrated, afaik. Cheers, //Mateusz -------------- next part -------------- Copyright (c) 1992-2004 The FreeBSD Project. Copyright (c) 1979, 1980, 1983, 1986, 1988, 1989, 1991, 1992, 1993, 1994 The Regents of the University of California. All rights reserved. FreeBSD 5.3-RELEASE #0: Fri Nov 5 04:19:18 UTC 2004 root@harlow.cse.buffalo.edu:/usr/obj/usr/src/sys/GENERIC Timecounter "i8254" frequency 1193182 Hz quality 0 CPU: Intel(R) Pentium(R) 4 CPU 3.00GHz (3000.10-MHz 686-class CPU) Origin = "GenuineIntel" Id = 0xf34 Stepping = 4 Features=0xbfebfbff<FPU,VME,DE,PSE,TSC,MSR,PAE,MCE,CX8,APIC,SEP,MTRR,PGE,MCA,CMOV,PAT,PSE36,CLFLUSH,DTS,ACPI,MMX,FXSR,SSE,SSE2,SS,HTT,TM,PBE> Hyperthreading: 2 logical CPUs real memory = 3353538560 (3198 MB) avail memory = 3280838656 (3128 MB) ACPI APIC Table: <INTEL D925XCV > ioapic0 <Version 2.0> irqs 0-23 on motherboard npx0: [FAST] npx0: <math processor> on motherboard npx0: INT 16 interface acpi0: <INTEL D925XCV> on motherboard acpi_bus_number: can't get _ADR acpi_bus_number: can't get _ADR acpi_bus_number: can't get _ADR acpi_bus_number: can't get _ADR acpi_bus_number: can't get _ADR acpi_bus_number: can't get _ADR acpi_bus_number: can't get _ADR acpi_bus_number: can't get _ADR acpi0: Power Button (fixed) acpi_bus_number: can't get _ADR acpi_bus_number: can't get _ADR Timecounter "ACPI-fast" frequency 3579545 Hz quality 1000 acpi_timer0: <24-bit timer at 3.579545MHz> port 0x408-0x40b on acpi0 cpu0: <ACPI CPU> on acpi0 pcib0: <ACPI Host-PCI bridge> port 0xcf8-0xcff on acpi0 pci0: <ACPI PCI bus> on pcib0 pcib1: <ACPI PCI-PCI bridge> at device 1.0 on pci0 pci1: <ACPI PCI bus> on pcib1 pci1: <display, VGA> at device 0.0 (no driver attached) pci0: <multimedia> at device 27.0 (no driver attached) pcib2: <ACPI PCI-PCI bridge> at device 28.0 on pci0 pci5: <ACPI PCI bus> on pcib2 pcib3: <ACPI PCI-PCI bridge> at device 28.1 on pci0 pci4: <ACPI PCI bus> on pcib3 pci4: <network, ethernet> at device 0.0 (no driver attached) pcib4: <ACPI PCI-PCI bridge> at device 28.2 on pci0 pci3: <ACPI PCI bus> on pcib4 pcib5: <ACPI PCI-PCI bridge> at device 28.3 on pci0 pcib5: could not get PCI interrupt routing table for \\_SB_.PCI0.PEX4 - AE_NOT_FOUND pci2: <ACPI PCI bus> on pcib5 uhci0: <UHCI (generic) USB controller> port 0xcc00-0xcc1f irq 23 at device 29.0 on pci0 uhci0: [GIANT-LOCKED] usb0: <UHCI (generic) USB controller> on uhci0 usb0: USB revision 1.0 uhub0: Intel UHCI root hub, class 9/0, rev 1.00/1.00, addr 1 uhub0: 2 ports with 2 removable, self powered uhci1: <UHCI (generic) USB controller> port 0xd000-0xd01f irq 19 at device 29.1 on pci0 uhci1: [GIANT-LOCKED] usb1: <UHCI (generic) USB controller> on uhci1 usb1: USB revision 1.0 uhub1: Intel UHCI root hub, class 9/0, rev 1.00/1.00, addr 1 uhub1: 2 ports with 2 removable, self powered uhci2: <UHCI (generic) USB controller> port 0xd400-0xd41f irq 18 at device 29.2 on pci0 uhci2: [GIANT-LOCKED] usb2: <UHCI (generic) USB controller> on uhci2 usb2: USB revision 1.0 uhub2: Intel UHCI root hub, class 9/0, rev 1.00/1.00, addr 1 uhub2: 2 ports with 2 removable, self powered uhci3: <UHCI (generic) USB controller> port 0xd800-0xd81f irq 16 at device 29.3 on pci0 uhci3: [GIANT-LOCKED] usb3: <UHCI (generic) USB controller> on uhci3 usb3: USB revision 1.0 uhub3: Intel UHCI root hub, class 9/0, rev 1.00/1.00, addr 1 uhub3: 2 ports with 2 removable, self powered pci0: <serial bus, USB> at device 29.7 (no driver attached) pcib6: <ACPI PCI-PCI bridge> at device 30.0 on pci0 pci6: <ACPI PCI bus> on pcib6 atapci0: <Promise PDC20269 UDMA133 controller> port 0xac00-0xac0f,0xb000-0xb003,0xb400-0xb407,0xb800-0xb803,0xbc00-0xbc07 mem 0xfab10000-0xfab13fff irq 22 at device 1.0 on pci6 ata2: channel #0 on atapci0 ata3: channel #1 on atapci0 fwohci0: <Lucent FW322/323> mem 0xfab14000-0xfab14fff irq 17 at device 5.0 on pci6 fwohci0: OHCI version 1.0 (ROM=0) fwohci0: No. of Isochronous channels is 8. fwohci0: EUI64 00:11:11:00:00:58:d9:c8 fwohci0: Phy 1394a available S400, 3 ports. fwohci0: Link S400, max_rec 2048 bytes. firewire0: <IEEE1394(FireWire) bus> on fwohci0 fwe0: <Ethernet over FireWire> on firewire0 if_fwe0: Fake Ethernet address: 02:11:11:58:d9:c8 fwe0: Ethernet address: 02:11:11:58:d9:c8 fwe0: if_start running deferred for Giant sbp0: <SBP-2/SCSI over FireWire> on firewire0 fwohci0: Initiate bus reset fwohci0: node_id=0xc800ffc0, gen=1, CYCLEMASTER mode firewire0: 1 nodes, maxhop <= 0, cable IRM = 0 (me) firewire0: bus manager 0 (me) isab0: <PCI-ISA bridge> at device 31.0 on pci0 isa0: <ISA bus> on isab0 atapci1: <Intel ICH6 UDMA100 controller> port 0xffa0-0xffaf,0x376,0x170-0x177,0x3f6,0x1f0-0x1f7 at device 31.1 on pci0 ata0: channel #0 on atapci1 ata1: channel #1 on atapci1 atapci2: <Intel ICH6 SATA150 controller> port 0xdc00-0xdc0f,0xe000-0xe003,0xe400-0xe407,0xe800-0xe803,0xec00-0xec07 mem 0xfaafbc00-0xfaafbfff irq 19 at device 31.2 on pci0 ata4: channel #0 on atapci2 ata5: channel #1 on atapci2 pci0: <serial bus, SMBus> at device 31.3 (no driver attached) acpi_button0: <Power Button> on acpi0 atkbdc0: <Keyboard controller (i8042)> port 0x64,0x60 irq 1 on acpi0 atkbd0: <AT Keyboard> irq 1 on atkbdc0 kbd0 at atkbd0 atkbd0: [GIANT-LOCKED] psm0: <PS/2 Mouse> irq 12 on atkbdc0 psm0: [GIANT-LOCKED] psm0: model IntelliMouse, device ID 3 fdc0: <floppy drive controller> port 0x3f7,0x3f4-0x3f5,0x3f2-0x3f3,0x3f0-0x3f1 irq 6 drq 2 on acpi0 fdc0: [FAST] fd0: <1440-KB 3.5" drive> on fdc0 drive 0 sio0: configured irq 4 not in bitmap of probed irqs 0 sio0: port may not be enabled sio0: <16550A-compatible COM port> port 0x3f8-0x3ff irq 4 flags 0x10 on acpi0 sio0: type 16550A ppc0: <ECP parallel printer port> port 0x778-0x77f,0x378-0x37f irq 7 drq 3 on acpi0 ppc0: SMC-like chipset (ECP/EPP/PS2/NIBBLE) in COMPATIBLE mode ppc0: FIFO with 16/16/8 bytes threshold ppbus0: <Parallel port bus> on ppc0 plip0: <PLIP network interface> on ppbus0 lpt0: <Printer> on ppbus0 lpt0: Interrupt-driven port ppi0: <Parallel I/O> on ppbus0 orm0: <ISA Option ROMs> at iomem 0xd7800-0xd87ff,0xd5000-0xd77ff,0xd4000-0xd4fff,0xc0000-0xcf7ff on isa0 pmtimer0 on isa0 sc0: <System console> at flags 0x100 on isa0 sc0: VGA <16 virtual consoles, flags=0x300> sio1: configured irq 3 not in bitmap of probed irqs 0 sio1: port may not be enabled vga0: <Generic ISA VGA> at port 0x3c0-0x3df iomem 0xa0000-0xbffff on isa0 Timecounter "TSC" frequency 3000097613 Hz quality 800 Timecounters tick every 10.000 msec acpi_cpu: throttling enabled, 8 steps (100% to 12.5%), currently 100.0% acd0: DVDR <HL-DT-ST DVDRAM GSA-4120B/A102> at ata0-master UDMA33 afd0: REMOVABLE <IOMEGA ZIP 250 ATAPI/25.Q> at ata0-slave PIO3 ad4: 238418MB <Maxtor 7Y250P0/YAR41BW0> [484406/16/63] at ata2-master UDMA133 ad8: 152627MB <ST3160827AS/3.00> [310101/16/63] at ata4-master SATA150 Mounting root from ufs:/dev/ad8s2a -------------- next part -------------- /* * Intel ACPI Component Architecture * AML Disassembler version 20040527 * * Disassembly of /tmp/acpidump.POZic0, Wed Feb 23 18:25:27 2005 */ DefinitionBlock ("DSDT.aml", "DSDT", 1, "INTEL ", "D925XCV ", 1) { OperationRegion (BIOS, SystemMemory, 0xC7F40064, 0xFF) Field (BIOS, ByteAcc, NoLock, Preserve) { SS1, 1, SS2, 1, SS3, 1, SS4, 1, Offset (0x01), IOST, 16, TMP1, 16, TMP2, 16, TMP3, 8, SMBS, 16, SMLN, 8, TMP4, 16, TMP5, 8, TMP6, 16, TMP7, 8, TOPM, 32, ROMS, 32, TMP8, 32, TMP9, 16, MG1B, 32, MG1L, 32, MG2B, 32, MG2L, 32, ANGE, 8, VEBA, 32, RMBA, 32, VEXT, 1, GCIC, 3, CVPD, 2, DVPD, 2, MVPD, 1, Offset (0x3A), MAEN, 1, MASL, 2, SWAP, 1, ASFF, 1, TPMF, 3, Offset (0x3C), TM10, 8, TM11, 8, ASFA, 8, Offset (0x48), AZBA, 32, AZLN, 32, PXBA, 32, PXLN, 32 } Name (SPIO, 0x2E) Name (IO1B, 0x0680) Name (IO1L, 0x80) Name (PMBS, 0x0400) Name (PMLN, 0x80) Name (GPBS, 0x0500) Name (GPLN, 0x40) Name (APIC, 0x01) Method (RRIO, 4, NotSerialized) { Store ("RRIO", Debug) } Method (RDMA, 3, NotSerialized) { Store ("rDMA", Debug) } Name (PICM, 0x00) Method (_PIC, 1, NotSerialized) { If (Arg0) { Store (0xAA, DBG8) } Else { Store (0xAC, DBG8) } Store (Arg0, PICM) } Method (OSFL, 0, NotSerialized) { Store (0x00, Local0) If (MCTH (\_OS, "Microsoft Windows")) { Store (0x01, Local0) } If (MCTH (\_OS, "Microsoft WindowsME: Millennium Edition")) { Store (0x01, Local0) } Return (Local0) } Method (MCTH, 2, NotSerialized) { If (LLess (SizeOf (Arg0), SizeOf (Arg1))) { Return (Zero) } Add (SizeOf (Arg0), 0x01, Local0) Name (BUF0, Buffer (Local0) {}) Name (BUF1, Buffer (Local0) {}) Store (Arg0, BUF0) Store (Arg1, BUF1) While (Local0) { Decrement (Local0) If (LNot (LEqual (DerefOf (Index (BUF0, Local0)), DerefOf (Index (BUF1, Local0))))) { Return (Zero) } } Return (One) } Name (PRWP, Package (0x02) { Zero, Zero }) Method (GPRW, 2, NotSerialized) { Store (Arg0, Index (PRWP, 0x00)) Store (ShiftLeft (SS1, 0x01), Local0) Or (Local0, ShiftLeft (SS2, 0x02), Local0) Or (Local0, ShiftLeft (SS3, 0x03), Local0) Or (Local0, ShiftLeft (SS4, 0x04), Local0) If (And (ShiftLeft (0x01, Arg1), Local0)) { Store (Arg1, Index (PRWP, 0x01)) } Else { ShiftRight (Local0, 0x01, Local0) FindSetLeftBit (Local0, Index (PRWP, 0x01)) } Return (PRWP) } Name (WAKP, Package (0x02) { Zero, Zero }) OperationRegion (DEB0, SystemIO, 0x80, 0x01) Field (DEB0, ByteAcc, NoLock, Preserve) { DBG8, 8 } OperationRegion (DEB1, SystemIO, 0x90, 0x02) Field (DEB1, WordAcc, NoLock, Preserve) { DBG9, 16 } Scope (\_PR) { Processor (CPU1, 0x01, 0x00000410, 0x06) {} Processor (CPU2, 0x02, 0x00000410, 0x06) {} } Scope (\_SB) { Name (PR00, Package (0x10) { Package (0x04) { 0x0001FFFF, 0x00, LNKA, 0x00 }, Package (0x04) { 0x0002FFFF, 0x00, LNKA, 0x00 }, Package (0x04) { 0x001FFFFF, 0x01, LNKD, 0x00 }, Package (0x04) { 0x001EFFFF, 0x00, LNKB, 0x00 }, Package (0x04) { 0x001EFFFF, 0x01, LNKE, 0x00 }, Package (0x04) { 0x001FFFFF, 0x00, LNKC, 0x00 }, Package (0x04) { 0x001DFFFF, 0x00, LNKH, 0x00 }, Package (0x04) { 0x001DFFFF, 0x01, LNKD, 0x00 }, Package (0x04) { 0x001DFFFF, 0x02, LNKC, 0x00 }, Package (0x04) { 0x001DFFFF, 0x03, LNKA, 0x00 }, Package (0x04) { 0x001CFFFF, 0x00, LNKB, 0x00 }, Package (0x04) { 0x001CFFFF, 0x01, LNKA, 0x00 }, Package (0x04) { 0x001CFFFF, 0x02, LNKC, 0x00 }, Package (0x04) { 0x001CFFFF, 0x03, LNKD, 0x00 }, Package (0x04) { 0x001BFFFF, 0x00, LNKA, 0x00 }, Package (0x04) { 0x001FFFFF, 0x03, LNKA, 0x00 } }) Name (AR00, Package (0x10) { Package (0x04) { 0x0001FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0002FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x001FFFFF, 0x01, 0x00, 0x13 }, Package (0x04) { 0x001EFFFF, 0x00, 0x00, 0x11 }, Package (0x04) { 0x001EFFFF, 0x01, 0x00, 0x14 }, Package (0x04) { 0x001FFFFF, 0x00, 0x00, 0x12 }, Package (0x04) { 0x001DFFFF, 0x00, 0x00, 0x17 }, Package (0x04) { 0x001DFFFF, 0x01, 0x00, 0x13 }, Package (0x04) { 0x001DFFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x001DFFFF, 0x03, 0x00, 0x10 }, Package (0x04) { 0x001CFFFF, 0x00, 0x00, 0x11 }, Package (0x04) { 0x001CFFFF, 0x01, 0x00, 0x10 }, Package (0x04) { 0x001CFFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x001CFFFF, 0x03, 0x00, 0x13 }, Package (0x04) { 0x001BFFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x001FFFFF, 0x03, 0x00, 0x10 } }) Name (PR02, Package (0x11) { Package (0x04) { 0xFFFF, 0x00, LNKF, 0x00 }, Package (0x04) { 0xFFFF, 0x01, LNKG, 0x00 }, Package (0x04) { 0xFFFF, 0x02, LNKH, 0x00 }, Package (0x04) { 0xFFFF, 0x03, LNKE, 0x00 }, Package (0x04) { 0x0001FFFF, 0x00, LNKG, 0x00 }, Package (0x04) { 0x0001FFFF, 0x01, LNKF, 0x00 }, Package (0x04) { 0x0001FFFF, 0x02, LNKE, 0x00 }, Package (0x04) { 0x0001FFFF, 0x03, LNKH, 0x00 }, Package (0x04) { 0x0002FFFF, 0x00, LNKC, 0x00 }, Package (0x04) { 0x0002FFFF, 0x01, LNKD, 0x00 }, Package (0x04) { 0x0002FFFF, 0x02, LNKB, 0x00 }, Package (0x04) { 0x0002FFFF, 0x03, LNKA, 0x00 }, Package (0x04) { 0x0003FFFF, 0x00, LNKD, 0x00 }, Package (0x04) { 0x0003FFFF, 0x01, LNKC, 0x00 }, Package (0x04) { 0x0003FFFF, 0x02, LNKF, 0x00 }, Package (0x04) { 0x0003FFFF, 0x03, LNKG, 0x00 }, Package (0x04) { 0x0005FFFF, 0x00, LNKB, 0x00 } }) Name (AR02, Package (0x11) { Package (0x04) { 0xFFFF, 0x00, 0x00, 0x15 }, Package (0x04) { 0xFFFF, 0x01, 0x00, 0x16 }, Package (0x04) { 0xFFFF, 0x02, 0x00, 0x17 }, Package (0x04) { 0xFFFF, 0x03, 0x00, 0x14 }, Package (0x04) { 0x0001FFFF, 0x00, 0x00, 0x16 }, Package (0x04) { 0x0001FFFF, 0x01, 0x00, 0x15 }, Package (0x04) { 0x0001FFFF, 0x02, 0x00, 0x14 }, Package (0x04) { 0x0001FFFF, 0x03, 0x00, 0x17 }, Package (0x04) { 0x0002FFFF, 0x00, 0x00, 0x12 }, Package (0x04) { 0x0002FFFF, 0x01, 0x00, 0x13 }, Package (0x04) { 0x0002FFFF, 0x02, 0x00, 0x11 }, Package (0x04) { 0x0002FFFF, 0x03, 0x00, 0x10 }, Package (0x04) { 0x0003FFFF, 0x00, 0x00, 0x13 }, Package (0x04) { 0x0003FFFF, 0x01, 0x00, 0x12 }, Package (0x04) { 0x0003FFFF, 0x02, 0x00, 0x15 }, Package (0x04) { 0x0003FFFF, 0x03, 0x00, 0x16 }, Package (0x04) { 0x0005FFFF, 0x00, 0x00, 0x11 } }) Name (PR01, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, LNKA, 0x00 }, Package (0x04) { 0xFFFF, 0x01, LNKB, 0x00 }, Package (0x04) { 0xFFFF, 0x02, LNKC, 0x00 }, Package (0x04) { 0xFFFF, 0x03, LNKD, 0x00 } }) Name (AR01, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0xFFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0xFFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0xFFFF, 0x03, 0x00, 0x13 } }) Name (PR03, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, LNKA, 0x00 }, Package (0x04) { 0xFFFF, 0x01, LNKB, 0x00 }, Package (0x04) { 0xFFFF, 0x02, LNKC, 0x00 }, Package (0x04) { 0xFFFF, 0x03, LNKD, 0x00 } }) Name (AR03, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0xFFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0xFFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0xFFFF, 0x03, 0x00, 0x13 } }) Name (PR04, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, LNKB, 0x00 }, Package (0x04) { 0xFFFF, 0x01, LNKC, 0x00 }, Package (0x04) { 0xFFFF, 0x02, LNKD, 0x00 }, Package (0x04) { 0xFFFF, 0x03, LNKA, 0x00 } }) Name (AR04, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, 0x00, 0x11 }, Package (0x04) { 0xFFFF, 0x01, 0x00, 0x12 }, Package (0x04) { 0xFFFF, 0x02, 0x00, 0x13 }, Package (0x04) { 0xFFFF, 0x03, 0x00, 0x10 } }) Name (PR05, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, LNKC, 0x00 }, Package (0x04) { 0xFFFF, 0x01, LNKD, 0x00 }, Package (0x04) { 0xFFFF, 0x02, LNKA, 0x00 }, Package (0x04) { 0xFFFF, 0x03, LNKB, 0x00 } }) Name (AR05, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, 0x00, 0x12 }, Package (0x04) { 0xFFFF, 0x01, 0x00, 0x13 }, Package (0x04) { 0xFFFF, 0x02, 0x00, 0x10 }, Package (0x04) { 0xFFFF, 0x03, 0x00, 0x11 } }) Name (PRSA, ResourceTemplate () { IRQ (Level, ActiveLow, Shared) {3,4,5,6,7,9,10,11,12,14,15} }) Alias (PRSA, PRSB) Alias (PRSA, PRSC) Alias (PRSA, PRSD) Alias (PRSA, PRSE) Alias (PRSA, PRSF) Alias (PRSA, PRSG) Alias (PRSA, PRSH) Device (PCI0) { Name (_HID, EisaId ("PNP0A08")) Name (_CID, 0x030AD041) Name (_ADR, 0x00) Method (^BN00, 0, NotSerialized) { Return (0x00) } Method (_BBN, 0, NotSerialized) { Return (BN00 ()) } Name (_UID, 0x00) Method (_PRT, 0, NotSerialized) { If (PICM) { Return (AR00) } Return (PR00) } Device (PEGP) { Name (_ADR, 0x00010000) OperationRegion (ORP0, PCI_Config, 0x00, 0xFF) Field (ORP0, AnyAcc, NoLock, Preserve) { RPID, 32, Offset (0x34), CPLT, 8, Offset (0x58), SSLC, 10, Offset (0x5A), SSLS, 7, Offset (0x5C), Offset (0x60), SQID, 16, SPME, 1, SPMP, 1, Offset (0x64), Offset (0xB8), NSLC, 10, Offset (0xBA), NSLS, 7, Offset (0xBC), Offset (0xC0), NQID, 16, NPME, 1, NPMP, 1, Offset (0xC4), Offset (0xDC), , 31, RPSC, 1 } Method (HDDN, 1, NotSerialized) { If (LEqual (RPID, Ones)) { Return (One) } Else { Return (Zero) } } Method (XPMH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { Store (NPME, Local0) While (NPME) { Store (0x01, NPME) } } Else { Store (SPME, Local0) While (SPME) { Store (0x01, SPME) } While (RPSC) { Store (0x01, RPSC) } } Return (Local0) } Method (XHPH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { And (NSLC, NSLS, Local0) And (Local0, 0x0D, Local0) Store (NSLS, NSLS) } Else { And (SSLC, SSLS, Local0) And (Local0, 0x0D, Local0) Store (SSLS, SSLS) } Return (Local0) } Method (SCIC, 2, NotSerialized) { OperationRegion (ORP7, PCI_Config, 0xD8, 0x04) Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, HPCS, 1, PMCS, 1 } Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, ICHC, 2 } OperationRegion (ORP8, PCI_Config, 0xEC, 0x04) Field (ORP8, AnyAcc, NoLock, Preserve) { GPCN, 1, HPCN, 1, PMCN, 1 } Field (ORP8, AnyAcc, NoLock, Preserve) { , 1, MCHC, 2 } If (LNot (HDDN (Arg0))) { If (LNot (LGreater (Arg0, 0x03))) { And (Arg1, 0x03, ICHC) } If (LEqual (Arg0, 0x08)) { And (Arg1, 0x03, MCHC) } } } Method (DP80, 1, NotSerialized) { Store (Arg0, DBG8) Sleep (0x0BB8) Store (0x00, DBG8) } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x09, 0x04)) } Method (_PRT, 0, NotSerialized) { If (PICM) { Return (AR01) } Return (PR01) } } Device (P0P2) { Name (_ADR, 0x001E0000) Method (_PRW, 0, NotSerialized) { Return (GPRW (0x0B, 0x04)) } Method (_PRT, 0, NotSerialized) { If (PICM) { Return (AR02) } Return (PR02) } } Device (AC97) { Name (_ADR, 0x001E0003) OperationRegion (BAR0, PCI_Config, 0x55, 0x01) Field (BAR0, ByteAcc, NoLock, Preserve) { A97W, 1 } Method (_PSW, 1, NotSerialized) { If (Arg0) { Store (0x01, A97W) } Else { Store (0x00, A97W) } } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x05, 0x04)) } } Device (IDE0) { Name (_ADR, 0x001F0001) Scope (\_SB.PCI0) { Name (NATA, Package (0x02) { 0x001F0001, 0x001F0002 }) } Name (REGF, 0x01) Method (_REG, 2, NotSerialized) { If (LEqual (Arg0, 0x02)) { Store (Arg1, REGF) } } OperationRegion (BAR0, PCI_Config, 0x00, 0x0100) Field (BAR0, DWordAcc, NoLock, Preserve) { Offset (0x40), TIMP, 16, TIMS, 16, STMP, 4, STMS, 4, Offset (0x48), UDMP, 2, UDMS, 2, Offset (0x4A), UDTP, 6, Offset (0x4B), UDTS, 6, Offset (0x54), PCB0, 2, SCB0, 2, PCA0, 2, SCA0, 2, , 4, FPB0, 2, FSB0, 2 } Name (TIM0, Package (0x09) { Package (0x04) { 0x78, 0xB4, 0xF0, 0x0384 }, Package (0x04) { 0x23, 0x21, 0x10, 0x00 }, Package (0x04) { 0x0B, 0x09, 0x04, 0x00 }, Package (0x06) { 0x70, 0x49, 0x36, 0x27, 0x19, 0x11 }, Package (0x06) { 0x00, 0x01, 0x02, 0x01, 0x02, 0x01 }, Package (0x06) { 0x00, 0x00, 0x00, 0x01, 0x01, 0x01 }, Package (0x06) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x01 }, Package (0x04) { 0x04, 0x03, 0x02, 0x00 }, Package (0x04) { 0x02, 0x01, 0x00, 0x00 } }) Name (TMD0, Buffer (0x14) {}) CreateDWordField (TMD0, 0x00, PIO0) CreateDWordField (TMD0, 0x04, DMA0) CreateDWordField (TMD0, 0x08, PIO1) CreateDWordField (TMD0, 0x0C, DMA1) CreateDWordField (TMD0, 0x10, CHNF) Name (GTIM, 0x00) Name (GSTM, 0x00) Name (GUDM, 0x00) Name (GUDT, 0x00) Name (GCB0, 0x00) Name (GFB0, 0x00) Device (CHN0) { Name (_ADR, 0x00) OperationRegion (IDE0, SystemIO, 0x01F0, 0x08) Field (IDE0, ByteAcc, NoLock, Preserve) { DATA, 8, FEAT, 8, SECC, 8, SECN, 8, CYLL, 8, CYLH, 8, DVHD, 8, STAT, 8 } Name (ATP0, 0x01) Name (ATP1, 0x01) Method (_GTM, 0, NotSerialized) { Return (GTM (TIMP, STMP, UDMP, UDTP, PCB0, FPB0)) } Method (_STM, 3, NotSerialized) { Store (Arg0, Debug) Store (Arg0, TMD0) Store (TIMP, GTIM) Store (UDTP, GUDT) If (STM ()) { Store (GTIM, TIMP) Store (GSTM, STMP) Store (GUDM, UDMP) Store (GUDT, UDTP) Store (GCB0, PCB0) Store (GFB0, FPB0) } Store (GTF (0x00, Arg1), ATA0) Store (GTF (0x01, Arg2), ATA1) } Device (DRV0) { Name (_ADR, 0x00) Method (_GTF, 0, NotSerialized) { Return (RATA (ATA0)) } } Device (DRV1) { Name (_ADR, 0x01) Method (_GTF, 0, NotSerialized) { Return (RATA (ATA1)) } } } Device (CHN1) { Name (_ADR, 0x01) OperationRegion (IDE1, SystemIO, 0x0170, 0x08) Field (IDE1, ByteAcc, NoLock, Preserve) { DATA, 8, FEAT, 8, SECC, 8, SECN, 8, CYLL, 8, CYLH, 8, DVHD, 8, STAT, 8 } Name (ATS0, 0x01) Name (ATS1, 0x01) Method (_GTM, 0, NotSerialized) { Return (GTM (TIMS, STMS, UDMS, UDTS, SCB0, FSB0)) } Method (_STM, 3, NotSerialized) { Store (Arg0, Debug) Store (Arg0, TMD0) Store (TIMS, GTIM) Store (UDTS, GUDT) If (STM ()) { Store (GTIM, TIMS) Store (GSTM, STMS) Store (GUDM, UDMS) Store (GUDT, UDTS) Store (GCB0, SCB0) Store (GFB0, FSB0) } Store (GTF (0x00, Arg1), ATA2) Store (GTF (0x01, Arg2), ATA3) } Device (DRV0) { Name (_ADR, 0x00) Method (_GTF, 0, NotSerialized) { Return (RATA (ATA2)) } } Device (DRV1) { Name (_ADR, 0x01) Method (_GTF, 0, NotSerialized) { Return (RATA (ATA3)) } } Name (TIM1, Buffer (0x14) {}) CreateDWordField (TIM1, 0x00, MPIO) CreateDWordField (TIM1, 0x04, MDMA) CreateDWordField (TIM1, 0x08, SPIO) CreateDWordField (TIM1, 0x0C, SDMA) CreateDWordField (TIM1, 0x10, FLGS) Method (_PS3, 0, NotSerialized) { If (MCTH (\_OS, "Microsoft Windows")) { Store (_GTM (), TIM1) } } Name (BOOT, 0x00) Method (_PS0, 0, NotSerialized) { If (MCTH (\_OS, "Microsoft Windows")) { If (BOOT) { If (And (DRVI, 0x20)) { PRGT (MPIO, MDMA, FLGS, 0xA0) } If (And (DRVI, 0x80)) { PRGT (SPIO, SDMA, FLGS, 0xB0) } } Store (0x01, BOOT) } } Method (PRGT, 4, NotSerialized) { Store (Arg3, DVHD) If (And (Not (LEqual (Arg0, 0xFFFFFFFF)), Not (LEqual (Arg0, 0x00)))) { While (LEqual (And (STAT, 0x80), 0x80)) {} Store (0x03, FEAT) Store (Match (DerefOf (Index (TIM0, 0x00)), MEQ, Arg0, MTR, 0x00, 0x00), Local0) Or (0x08, DerefOf (Index (DerefOf (Index (TIM0, 0x07)), Local0)), Local0) Store (Local0, SECC) Store (0x00, SECN) Store (0x00, CYLL) Store (0x00, CYLH) Store (Arg3, DVHD) Store (0xEF, STAT) } If (And (Not (LEqual (Arg0, 0xFFFFFFFF)), Not (LEqual (Arg0, 0x00)))) { While (LEqual (And (STAT, 0x80), 0x80)) {} Store (0x03, FEAT) Store (0x00, Local0) If (LEqual (Arg3, 0xA0)) { If (And (Arg2, 0x01)) { Store (0x01, Local0) } } Else { If (And (Arg2, 0x04)) { Store (0x01, Local0) } } If (LEqual (Local0, 0x01)) { Store (Match (DerefOf (Index (TIM0, 0x03)), MEQ, Arg1, MTR, 0x00, 0x00), Local0) Or (0x40, Local0, Local0) } Else { Store (Match (DerefOf (Index (TIM0, 0x00)), MEQ, Arg1, MTR, 0x00, 0x00), Local0) Or (0x20, DerefOf (Index (DerefOf (Index (TIM0, 0x08)), Local0)), Local0) } Store (Local0, SECC) Store (0x00, SECN) Store (0x00, CYLL) Store (0x00, CYLH) Store (Arg3, DVHD) Store (0xEF, STAT) } } } Method (GTM, 6, Serialized) { Store (Ones, PIO0) Store (PIO0, PIO1) Store (PIO0, DMA0) Store (PIO0, DMA1) Store (Zero, CHNF) If (REGF) {} Else { Return (TMD0) } If (And (Arg0, 0x02)) { Or (CHNF, 0x02, CHNF) } ShiftRight (And (Arg0, 0x3300), 0x08, Local5) Store (Match (DerefOf (Index (TIM0, 0x01)), MLE, Local5, MTR, 0x00, 0x00), Local6) Store (DerefOf (Index (DerefOf (Index (TIM0, 0x00)), Local6)), Local7) Store (Local7, DMA0) If (And (Arg0, 0x08)) { Store (0x0384, PIO0) } Else { Store (Local7, PIO0) } If (And (Arg0, 0x20)) { Or (CHNF, 0x08, CHNF) } If (And (Arg0, 0x4000)) { Or (CHNF, 0x10, CHNF) Store (Match (DerefOf (Index (TIM0, 0x02)), MLE, Arg1, MTR, 0x00, 0x00), Local5) Store (DerefOf (Index (DerefOf (Index (TIM0, 0x00)), Local5)), Local6) Store (Local6, DMA1) If (And (Arg0, 0x80)) { Store (0x0384, PIO1) } Else { Store (Local6, PIO1) } } If (And (Arg2, 0x01)) { And (Arg3, 0x03, Local5) If (LAnd (And (Arg5, 0x01), LEqual (Local5, 0x01))) { Store (0x05, Local5) } Else { If (And (Arg4, 0x01)) { Store (0x04, Local5) } } Store (DerefOf (Index (DerefOf (Index (TIM0, 0x03)), Local5)), DMA0) Or (CHNF, 0x01, CHNF) } If (And (Arg2, 0x02)) { And (ShiftRight (Arg3, 0x04), 0x03, Local5) If (LAnd (And (Arg5, 0x02), LEqual (Local5, 0x01))) { Store (0x05, Local5) } Else { If (And (Arg4, 0x02)) { Store (0x04, Local5) } } Store (DerefOf (Index (DerefOf (Index (TIM0, 0x03)), Local5)), DMA1) Or (CHNF, 0x04, CHNF) } Store (TMD0, Debug) Return (TMD0) } Method (STM, 0, Serialized) { If (REGF) {} Else { Return (0x00) } And (GTIM, 0x8044, GTIM) Store (0x00, GSTM) Store (0x00, GUDM) Store (0x00, GCB0) And (GUDT, 0xCC, GUDT) Store (0x00, GFB0) If (And (CHNF, 0x01)) { Store (Match (DerefOf (Index (TIM0, 0x03)), MLE, DMA0, MTR, 0x00, 0x00), Local0) If (LGreater (Local0, 0x05)) { Store (0x05, Local0) } Or (GUDT, DerefOf (Index (DerefOf (Index (TIM0, 0x04)), Local0)), GUDT) Or (GCB0, DerefOf (Index (DerefOf (Index (TIM0, 0x05)), Local0)), GCB0) Or (GFB0, DerefOf (Index (DerefOf (Index (TIM0, 0x06)), Local0)), GFB0) Or (GUDM, 0x01, GUDM) } Else { If (Or (LEqual (PIO0, Ones), LEqual (PIO0, 0x00))) { If (And (LLess (DMA0, Ones), LGreater (DMA0, 0x00))) { Store (DMA0, PIO0) Or (GTIM, 0x08, GTIM) } } } If (And (CHNF, 0x04)) { Store (Match (DerefOf (Index (TIM0, 0x03)), MLE, DMA1, MTR, 0x00, 0x00), Local0) If (LGreater (Local0, 0x05)) { Store (0x05, Local0) } Or (GUDT, ShiftLeft (DerefOf (Index (DerefOf (Index (TIM0, 0x04)), Local0)), 0x04), GUDT) Or (GCB0, ShiftLeft (DerefOf (Index (DerefOf (Index (TIM0, 0x05)), Local0)), 0x01), GCB0) Or (GFB0, ShiftLeft (DerefOf (Index (DerefOf (Index (TIM0, 0x06)), Local0)), 0x01), GFB0) Or (GUDM, 0x02, GUDM) } Else { If (Or (LEqual (PIO1, Ones), LEqual (PIO1, 0x00))) { If (And (LLess (DMA1, Ones), LGreater (DMA1, 0x00))) { Store (DMA1, PIO1) Or (GTIM, 0x80, GTIM) } } } If (And (CHNF, 0x02)) { Or (GTIM, 0x03, GTIM) } If (And (CHNF, 0x08)) { Or (GTIM, 0x30, GTIM) } And (Match (DerefOf (Index (TIM0, 0x00)), MGE, PIO0, MTR, 0x00, 0x00), 0x03, Local0) Store (DerefOf (Index (DerefOf (Index (TIM0, 0x01)), Local0)), Local1) ShiftLeft (Local1, 0x08, Local2) Or (GTIM, Local2, GTIM) If (And (CHNF, 0x10)) { Or (GTIM, 0x4000, GTIM) And (Match (DerefOf (Index (TIM0, 0x00)), MGE, PIO1, MTR, 0x00, 0x00), 0x03, Local0) Store (DerefOf (Index (DerefOf (Index (TIM0, 0x02)), Local0)), GSTM) } Return (0x01) } Name (AT01, Buffer (0x07) { 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0xEF }) Name (AT02, Buffer (0x07) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x90 }) Name (AT03, Buffer (0x07) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xC6 }) Name (AT04, Buffer (0x07) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x91 }) Name (AT05, Buffer (0x07) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xF5 }) Name (ATA0, Buffer (0x1D) {}) Name (ATA1, Buffer (0x1D) {}) Name (ATA2, Buffer (0x1D) {}) Name (ATA3, Buffer (0x1D) {}) Name (ATAB, Buffer (0x1D) {}) CreateByteField (ATAB, 0x00, CMDC) Method (GTFB, 3, Serialized) { Multiply (CMDC, 0x38, Local0) Add (Local0, 0x08, Local1) CreateField (ATAB, Local1, 0x38, CMDX) Multiply (CMDC, 0x07, Local0) CreateByteField (ATAB, Add (Local0, 0x02), A001) CreateByteField (ATAB, Add (Local0, 0x06), A005) Store (Arg0, CMDX) Store (Arg1, A001) Store (Arg2, A005) Increment (CMDC) } Method (GTF, 2, Serialized) { Store (Arg1, Debug) Store (0x00, CMDC) Name (ID49, 0x0C00) Name (ID59, 0x00) Name (ID53, 0x04) Name (ID63, 0x0F00) Name (ID88, 0x0F00) Name (IRDY, 0x01) Name (PIOT, 0x00) Name (DMAT, 0x00) If (LEqual (SizeOf (Arg1), 0x0200)) { CreateWordField (Arg1, 0x62, IW49) Store (IW49, ID49) CreateWordField (Arg1, 0x6A, IW53) Store (IW53, ID53) CreateWordField (Arg1, 0x7E, IW63) Store (IW63, ID63) CreateWordField (Arg1, 0x76, IW59) Store (IW59, ID59) CreateWordField (Arg1, 0xB0, IW88) Store (IW88, ID88) CreateWordField (Arg1, 0xA4, IW82) } Store (0xA0, Local7) If (Arg0) { Store (0xB0, Local7) And (CHNF, 0x08, IRDY) If (And (CHNF, 0x10)) { Store (PIO1, PIOT) } Else { Store (PIO0, PIOT) } If (And (CHNF, 0x04)) { If (And (CHNF, 0x10)) { Store (DMA1, DMAT) } Else { Store (DMA0, DMAT) } } } Else { And (CHNF, 0x02, IRDY) Store (PIO0, PIOT) If (And (CHNF, 0x01)) { Store (DMA0, DMAT) } } If (LAnd (LAnd (And (ID53, 0x04), And (ID88, 0xFF00)), DMAT)) { Store (Match (DerefOf (Index (TIM0, 0x03)), MLE, DMAT, MTR, 0x00, 0x00), Local1) If (LGreater (Local1, 0x05)) { Store (0x05, Local1) } GTFB (AT01, Or (0x40, Local1), Local7) } Else { If (LAnd (And (ID63, 0xFF00), PIOT)) { And (Match (DerefOf (Index (TIM0, 0x00)), MGE, PIOT, MTR, 0x00, 0x00), 0x03, Local0) Or (0x20, DerefOf (Index (DerefOf (Index (TIM0, 0x08)), Local0)), Local1) GTFB (AT01, Local1, Local7) } } If (IRDY) { And (Match (DerefOf (Index (TIM0, 0x00)), MGE, PIOT, MTR, 0x00, 0x00), 0x03, Local0) Or (0x08, DerefOf (Index (DerefOf (Index (TIM0, 0x07)), Local0)), Local1) GTFB (AT01, Local1, Local7) } Else { If (And (ID49, 0x0400)) { GTFB (AT01, 0x01, Local7) } } If (LAnd (And (ID59, 0x0100), And (ID59, 0xFF))) { GTFB (AT03, And (ID59, 0xFF), Local7) } If (LAnd (IW82, 0x02)) { GTFB (AT05, 0x00, Local7) } Store (ATAB, Debug) Return (ATAB) } Method (RATA, 1, NotSerialized) { CreateByteField (Arg0, 0x00, CMDN) Multiply (CMDN, 0x38, Local0) CreateField (Arg0, 0x08, Local0, RETB) Store (RETB, Debug) Return (RETB) } } Device (USB0) { Name (_ADR, 0x001D0000) OperationRegion (BAR0, PCI_Config, 0xC0, 0x05) Field (BAR0, ByteAcc, NoLock, Preserve) { UBL1, 16, Offset (0x04), USBW, 8 } Method (_PSW, 1, NotSerialized) { If (Arg0) { Store (0x03, USBW) } Else { Store (0x00, USBW) } } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x03, 0x03)) } } Device (USB1) { Name (_ADR, 0x001D0001) OperationRegion (BAR0, PCI_Config, 0xC0, 0x05) Field (BAR0, ByteAcc, NoLock, Preserve) { UBL1, 16, Offset (0x04), USBW, 8 } Method (_PSW, 1, NotSerialized) { If (Arg0) { Store (0x03, USBW) } Else { Store (0x00, USBW) } } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x04, 0x03)) } } Device (USB2) { Name (_ADR, 0x001D0002) OperationRegion (BAR0, PCI_Config, 0xC0, 0x05) Field (BAR0, ByteAcc, NoLock, Preserve) { UBL1, 16, Offset (0x04), USBW, 8 } Method (_PSW, 1, NotSerialized) { If (Arg0) { Store (0x03, USBW) } Else { Store (0x00, USBW) } } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x0C, 0x03)) } } Device (USB3) { Name (_ADR, 0x001D0003) OperationRegion (BAR0, PCI_Config, 0xC0, 0x05) Field (BAR0, ByteAcc, NoLock, Preserve) { UBL1, 16, Offset (0x04), USBW, 8 } Method (_PSW, 1, NotSerialized) { If (Arg0) { Store (0x03, USBW) } Else { Store (0x00, USBW) } } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x0E, 0x03)) } } Device (USB7) { Name (_ADR, 0x001D0007) OperationRegion (BAR0, PCI_Config, 0x62, 0x02) Field (BAR0, ByteAcc, NoLock, Preserve) { USBW, 16 } Method (_PSW, 1, NotSerialized) { If (Arg0) { Store (0x7F, USBW) } Else { Store (0x00, USBW) } } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x0D, 0x03)) } } Device (SBRG) { Name (_ADR, 0x001F0000) Device (PIC) { Name (_HID, EisaId ("PNP0000")) Name (_CRS, ResourceTemplate () { IO (Decode16, 0x0020, 0x0020, 0x00, 0x02) IO (Decode16, 0x00A0, 0x00A0, 0x00, 0x02) IRQNoFlags () {2} }) } Device (DMAD) { Name (_HID, EisaId ("PNP0200")) Name (_CRS, ResourceTemplate () { DMA (Compatibility, BusMaster, Transfer8) {4} IO (Decode16, 0x0000, 0x0000, 0x00, 0x10) IO (Decode16, 0x0081, 0x0081, 0x00, 0x03) IO (Decode16, 0x0087, 0x0087, 0x00, 0x01) IO (Decode16, 0x0089, 0x0089, 0x00, 0x03) IO (Decode16, 0x008F, 0x008F, 0x00, 0x01) IO (Decode16, 0x00C0, 0x00C0, 0x00, 0x20) }) } Device (TMR) { Name (_HID, EisaId ("PNP0100")) Name (_CRS, ResourceTemplate () { IO (Decode16, 0x0040, 0x0040, 0x00, 0x04) IRQNoFlags () {0} }) } Device (RTC0) { Name (_HID, EisaId ("PNP0B00")) Name (_CRS, ResourceTemplate () { IO (Decode16, 0x0070, 0x0070, 0x00, 0x02) IRQNoFlags () {8} }) } Device (PS2K) { Name (_HID, EisaId ("PNP0303")) Name (_CID, 0x0B03D041) Method (_STA, 0, NotSerialized) { ShiftLeft (0x01, 0x0A, Local0) If (And (IOST, Local0)) { Return (0x0F) } If (OSFL ()) { Return (0x0B) } Else { Return (0x00) } } Name (_CRS, ResourceTemplate () { IO (Decode16, 0x0060, 0x0060, 0x00, 0x01) IO (Decode16, 0x0064, 0x0064, 0x00, 0x01) IRQNoFlags () {1} }) } Device (PS2M) { Name (_HID, EisaId ("PNP0F03")) Name (_CID, 0x130FD041) Method (_STA, 0, NotSerialized) { ShiftLeft (0x01, 0x0C, Local0) If (And (IOST, Local0)) { Return (0x0F) } If (OSFL ()) { Return (0x0B) } Else { Return (0x00) } } Name (CRS1, ResourceTemplate () { IRQNoFlags () {12} }) Name (CRS2, ResourceTemplate () { IO (Decode16, 0x0060, 0x0060, 0x00, 0x01) IO (Decode16, 0x0064, 0x0064, 0x00, 0x01) IRQNoFlags () {12} }) Method (_CRS, 0, NotSerialized) { ShiftLeft (0x01, 0x0A, Local0) If (And (IOST, Local0)) { Return (CRS1) } Else { Return (CRS2) } } } Device (SPKR) { Name (_HID, EisaId ("PNP0800")) Name (_CRS, ResourceTemplate () { IO (Decode16, 0x0061, 0x0061, 0x00, 0x01) }) } Device (COPR) { Name (_HID, EisaId ("PNP0C04")) Name (_CRS, ResourceTemplate () { IO (Decode16, 0x00F0, 0x00F0, 0x00, 0x10) IRQNoFlags () {13} }) } OperationRegion (SMC1, SystemIO, SPIO, 0x02) Field (SMC1, ByteAcc, Lock, Preserve) { INDX, 8, DATA, 8 } IndexField (INDX, DATA, ByteAcc, Lock, Preserve) { Offset (0x02), CFG, 8, Offset (0x07), LDN, 8, Offset (0x20), SDID, 8, SREV, 8, Offset (0x30), ACTR, 8, Offset (0x60), IOAH, 8, IOAL, 8, Offset (0x70), INTR, 8, Offset (0x72), INT1, 8, Offset (0x74), DMCH, 8, Offset (0xC0), GP40, 8, Offset (0xF0), OPT0, 8, OPT1, 8, OPT2, 8, OPT3, 8, OPT4, 8, OPT5, 8, OPT6, 8, OPT7, 8, OPT8, 8 } Mutex (MUT0, 0x00) Method (ENFG, 0, NotSerialized) { Acquire (MUT0, 0x0FFF) Store (0x55, INDX) } Method (EXFG, 0, NotSerialized) { Store (0xAA, INDX) Release (MUT0) } Method (KCLR, 0, NotSerialized) { Store (0x07, INDX) Store (LDKB, DATA) Store (0xF0, INDX) Store (0x00, DATA) } Name (LDFD, 0x00) Name (LDLP, 0x01) Name (LDU2, 0x02) Name (LDU1, 0x03) Name (LDPW, 0x04) Name (LDMO, 0x05) Name (LDKB, 0x06) Name (LDGP, 0x07) Device (\_SB.PCI0.SBRG.FDC0) { Name (_HID, EisaId ("PNP0700")) Method (_STA, 0, NotSerialized) { If (FDST) { Return (GSTA (LDFD)) } Return (0x00) } Method (_DIS, 0, NotSerialized) { DDIS (LDFD) } Method (_CRS, 0, NotSerialized) { Return (FCRS) } Method (_PRS, 0, NotSerialized) { Return (FPRS) } Method (_SRS, 1, NotSerialized) { DENB (LDFD) } } Device (\_SB.PCI0.SBRG.UAR1) { Name (_HID, EisaId ("PNP0501")) Name (_UID, 0x01) Method (_STA, 0, NotSerialized) { If (U1ST) { Return (GSTA (LDU1)) } Return (0x00) } Method (_DIS, 0, NotSerialized) { DDIS (LDU1) } Method (_CRS, 0, NotSerialized) { Return (PCRS (LDU1, 0x01, 0x08)) } Method (_SRS, 1, NotSerialized) { PSRS (Arg0, LDU1) } Method (_PRS, 0, NotSerialized) { Return (C1PR) } } Device (\_SB.PCI0.SBRG.LPT) { Name (_HID, EisaId ("PNP0400")) Method (_STA, 0, NotSerialized) { ENFG () Store (LDLP, LDN) And (OPT8, 0x04, Local0) EXFG () If (Local0) {} Else { If (LPST) { Return (GSTA (LDLP)) } } Return (Zero) } Method (_DIS, 0, NotSerialized) { DDIS (LDLP) } Method (_CRS, 0, NotSerialized) { Return (PCRS (LDLP, 0x01, 0x08)) } Method (_SRS, 1, NotSerialized) { PSRS (Arg0, LDLP) } Method (_PRS, 0, NotSerialized) { Return (LPPR) } } Device (\_SB.PCI0.SBRG.ECP) { Name (_HID, EisaId ("PNP0401")) Method (_STA, 0, NotSerialized) { ENFG () Store (LDLP, LDN) And (OPT8, 0x04, Local0) EXFG () If (Local0) { If (LPST) { Return (GSTA (LDLP)) } } Return (Zero) } Method (_DIS, 0, NotSerialized) { DDIS (LDLP) } Method (_CRS, 0, NotSerialized) { Return (ECRS (LDLP)) } Method (_SRS, 1, NotSerialized) { ESRS (Arg0, LDLP) } Method (_PRS, 0, NotSerialized) { Return (EPRS) } } Name (FDST, 0x00) Name (U1ST, 0x00) Name (U2ST, 0x00) Name (LPST, 0x00) Method (IODT, 0, NotSerialized) { If (LEqual (GSTA (LDFD), 0x0F)) { Store (0x01, FDST) } If (LEqual (GSTA (LDU1), 0x0F)) { Store (0x01, U1ST) } If (LEqual (GSTA (LDU2), 0x0F)) { Store (0x01, U2ST) } If (LEqual (GSTA (LDLP), 0x0F)) { Store (0x01, LPST) } } Method (GSTA, 1, NotSerialized) { ENFG () Store (Arg0, LDN) If (ACTR) { Store (0x0F, Local0) } Else { If (Or (IOAH, IOAL)) { Store (0x0D, Local0) } Else { Store (0x00, Local0) } } EXFG () Return (Local0) } Method (DDIS, 1, NotSerialized) { ENFG () Store (Arg0, LDN) Store (Zero, ACTR) EXFG () } Method (DENB, 1, NotSerialized) { ENFG () Store (Arg0, LDN) Store (One, ACTR) EXFG () } Method (PCRS, 3, NotSerialized) { CreateByteField (PBUF, 0x02, IOLO) CreateByteField (PBUF, 0x03, IOHI) CreateWordField (PBUF, 0x02, IOHL) CreateWordField (PBUF, 0x04, IORL) CreateByteField (PBUF, 0x06, ALMN) CreateByteField (PBUF, 0x07, LENG) CreateByteField (PBUF, 0x09, IRQL) ENFG () Store (Arg0, LDN) Store (IOAH, IOHI) Store (IOAL, IOLO) Store (IOHL, IORL) Store (Arg1, ALMN) If (LEqual (IOLO, 0xBC)) { Store (0x04, LENG) } Else { Store (Arg2, LENG) } Store (One, Local0) ShiftLeft (Local0, INTR, IRQL) EXFG () Return (PBUF) } Method (PSRS, 2, NotSerialized) { CreateByteField (Arg0, 0x02, POLB) CreateByteField (Arg0, 0x03, POHB) CreateByteField (Arg0, 0x09, PIRQ) ENFG () Store (Arg1, LDN) Store (POLB, IOAL) Store (POHB, IOAH) FindSetRightBit (PIRQ, Local0) Subtract (Local0, 0x01, Local0) Store (Local0, INTR) Store (One, ACTR) EXFG () } Method (ECRS, 1, NotSerialized) { CreateByteField (EBUF, 0x02, EPLO) CreateByteField (EBUF, 0x03, EPHI) CreateWordField (EBUF, 0x02, EPHL) CreateWordField (EBUF, 0x04, EPRL) CreateWordField (EBUF, 0x06, ALM1) CreateWordField (EBUF, 0x0A, E4LO) CreateWordField (EBUF, 0x0C, E4RL) CreateWordField (EBUF, 0x0E, ALM2) CreateWordField (EBUF, 0x11, EIRQ) CreateWordField (EBUF, 0x14, EDMA) ENFG () Store (Arg0, LDN) Store (IOAH, EPHI) Store (IOAL, EPLO) Store (EPHL, EPRL) Add (EPHL, 0x0400, E4LO) Store (E4LO, E4RL) If (LEqual (EPHL, 0x03BC)) { Store (0x0401, ALM1) Store (0x0401, ALM2) } Else { Store (0x0801, ALM1) Store (0x0801, ALM2) } Store (One, Local0) Store (INTR, Local1) ShiftLeft (Local0, Local1, EIRQ) Store (DMCH, Local1) If (LGreater (Local1, 0x03)) { Store (0x00, EDMA) } Else { Store (One, Local0) ShiftLeft (Local0, Local1, EDMA) } EXFG () Return (EBUF) } Method (ESRS, 2, NotSerialized) { CreateByteField (Arg0, 0x02, LOEP) CreateByteField (Arg0, 0x03, HIEP) CreateWordField (Arg0, 0x11, IRQE) CreateWordField (Arg0, 0x14, DMAE) ENFG () Store (Arg1, LDN) Store (LOEP, IOAL) Store (HIEP, IOAH) FindSetRightBit (IRQE, Local0) Subtract (Local0, 0x01, INTR) If (DMAE) { FindSetRightBit (DMAE, Local0) Subtract (Local0, 0x01, DMCH) } Else { Store (0x04, DMCH) } Store (One, ACTR) EXFG () } Name (CSCP, 0x00) PowerResource (URP1, 0x00, 0x0000) { Method (_STA, 0, NotSerialized) { Return (CSCP) } Method (_ON, 0, NotSerialized) { Store (0x01, CSCP) } Method (_OFF, 0, NotSerialized) { Store (0x00, CSCP) } } PowerResource (FDDP, 0x00, 0x0000) { Method (_STA, 0, NotSerialized) { Return (CSCP) } Method (_ON, 0, NotSerialized) { Store (0x01, CSCP) } Method (_OFF, 0, NotSerialized) { Store (0x00, CSCP) } } PowerResource (LPTP, 0x00, 0x0000) { Method (_STA, 0, NotSerialized) { Return (CSCP) } Method (_ON, 0, NotSerialized) { Store (0x01, CSCP) } Method (_OFF, 0, NotSerialized) { Store (0x00, CSCP) } } Name (FCRS, ResourceTemplate () { IO (Decode16, 0x03F0, 0x03F0, 0x01, 0x02) IO (Decode16, 0x03F2, 0x03F2, 0x01, 0x02) IO (Decode16, 0x03F4, 0x03F4, 0x01, 0x02) IO (Decode16, 0x03F7, 0x03F7, 0x01, 0x01) IRQNoFlags () {6} DMA (Compatibility, NotBusMaster, Transfer8) {2} }) Name (PBUF, ResourceTemplate () { IO (Decode16, 0x0000, 0x0000, 0x01, 0x08) IRQNoFlags () {0} }) Name (EBUF, ResourceTemplate () { IO (Decode16, 0x0378, 0x0378, 0x01, 0x08) IO (Decode16, 0x0778, 0x0778, 0x01, 0x04) IRQNoFlags () {7} DMA (Compatibility, NotBusMaster, Transfer8) {} }) Name (FPRS, ResourceTemplate () { StartDependentFn (0x00, 0x00) { IO (Decode16, 0x03F0, 0x03F0, 0x01, 0x02) IO (Decode16, 0x03F2, 0x03F2, 0x01, 0x02) IO (Decode16, 0x03F4, 0x03F4, 0x01, 0x02) IO (Decode16, 0x03F7, 0x03F7, 0x01, 0x01) IRQNoFlags () {6} DMA (Compatibility, NotBusMaster, Transfer8) {2} } EndDependentFn () }) Name (C1PR, ResourceTemplate () { StartDependentFn (0x00, 0x00) { IO (Decode16, 0x03F8, 0x03F8, 0x04, 0x08) IRQNoFlags () {4} } StartDependentFnNoPri () { IO (Decode16, 0x03F8, 0x03F8, 0x04, 0x08) IRQNoFlags () {3,4,10,11} } StartDependentFnNoPri () { IO (Decode16, 0x02F8, 0x02F8, 0x04, 0x08) IRQNoFlags () {3,4,10,11} } StartDependentFnNoPri () { IO (Decode16, 0x03E8, 0x03E8, 0x04, 0x08) IRQNoFlags () {3,4,10,11} } StartDependentFnNoPri () { IO (Decode16, 0x02E8, 0x02E8, 0x04, 0x08) IRQNoFlags () {3,4,10,11} } EndDependentFn () }) Name (LPPR, ResourceTemplate () { StartDependentFn (0x00, 0x00) { IO (Decode16, 0x0378, 0x0378, 0x01, 0x08) IRQNoFlags () {7} } StartDependentFnNoPri () { IO (Decode16, 0x0378, 0x0378, 0x01, 0x08) IRQNoFlags () {5,7} } StartDependentFnNoPri () { IO (Decode16, 0x0278, 0x0278, 0x01, 0x08) IRQNoFlags () {5,7} } StartDependentFnNoPri () { IO (Decode16, 0x03BC, 0x03BC, 0x01, 0x04) IRQNoFlags () {5,7} } EndDependentFn () }) Name (EPRS, ResourceTemplate () { StartDependentFn (0x00, 0x00) { IO (Decode16, 0x0378, 0x0378, 0x01, 0x08) IO (Decode16, 0x0778, 0x0778, 0x01, 0x08) IRQNoFlags () {7} DMA (Compatibility, NotBusMaster, Transfer8) {1} } StartDependentFnNoPri () { IO (Decode16, 0x0378, 0x0378, 0x01, 0x08) IO (Decode16, 0x0778, 0x0778, 0x01, 0x08) IRQNoFlags () {5,7} DMA (Compatibility, NotBusMaster, Transfer8) {1,3} } StartDependentFnNoPri () { IO (Decode16, 0x0278, 0x0278, 0x01, 0x08) IO (Decode16, 0x0678, 0x0678, 0x01, 0x08) IRQNoFlags () {5,7} DMA (Compatibility, NotBusMaster, Transfer8) {1,3} } StartDependentFnNoPri () { IO (Decode16, 0x03BC, 0x03BC, 0x01, 0x04) IO (Decode16, 0x07BC, 0x07BC, 0x01, 0x04) IRQNoFlags () {5,7} DMA (Compatibility, NotBusMaster, Transfer8) {1,3} } StartDependentFnNoPri () { IO (Decode16, 0x0378, 0x0378, 0x01, 0x08) IO (Decode16, 0x0778, 0x0778, 0x01, 0x08) IRQNoFlags () {5,7} DMA (Compatibility, NotBusMaster, Transfer8) {} } StartDependentFnNoPri () { IO (Decode16, 0x0278, 0x0278, 0x01, 0x08) IO (Decode16, 0x0678, 0x0678, 0x01, 0x08) IRQNoFlags () {5,7} DMA (Compatibility, NotBusMaster, Transfer8) {} } StartDependentFnNoPri () { IO (Decode16, 0x03BC, 0x03BC, 0x01, 0x04) IO (Decode16, 0x07BC, 0x07BC, 0x01, 0x04) IRQNoFlags () {5,7} DMA (Compatibility, NotBusMaster, Transfer8) {} } EndDependentFn () }) Device (\_SB.PCI0.SBRG.UAR2) { Method (_HID, 0, NotSerialized) { ENFG () Store (LDU2, LDN) And (OPT1, 0x38, Local0) EXFG () If (Local0) { Return (0x1005D041) } Else { Return (0x0105D041) } } Name (_UID, 0x02) Method (_STA, 0, NotSerialized) { If (U2ST) { Return (GSTA (LDU2)) } Return (0x00) } Method (_DIS, 0, NotSerialized) { DDIS (LDU2) } Method (_CRS, 0, NotSerialized) { Return (PCRS (LDU2, 0x01, 0x08)) } Method (_SRS, 1, NotSerialized) { PSRS (Arg0, LDU2) } Method (_PRS, 0, NotSerialized) { Return (C2PR) } } Name (CNBF, Buffer (0x02) { 0xF8, 0x03 }) Method (UABS, 1, NotSerialized) { ENFG () Store (Arg0, LDN) CreateByteField (CNBF, 0x00, IOLO) CreateByteField (CNBF, 0x01, IOHI) CreateWordField (CNBF, 0x00, IOAD) Store (IOAL, IOLO) Store (IOAH, IOHI) EXFG () Return (IOAD) } PowerResource (URP2, 0x00, 0x0000) { Method (_STA, 0, NotSerialized) { Return (CSCP) } Method (_ON, 0, NotSerialized) { Store (0x01, CSCP) } Method (_OFF, 0, NotSerialized) { Store (0x00, CSCP) } } Name (C2PR, ResourceTemplate () { StartDependentFn (0x00, 0x00) { IO (Decode16, 0x02F8, 0x02F8, 0x04, 0x08) IRQNoFlags () {3} } StartDependentFnNoPri () { IO (Decode16, 0x02F8, 0x02F8, 0x04, 0x08) IRQNoFlags () {3,4,10,11} } StartDependentFnNoPri () { IO (Decode16, 0x03F8, 0x03F8, 0x04, 0x08) IRQNoFlags () {3,4,10,11} } StartDependentFnNoPri () { IO (Decode16, 0x03E8, 0x03E8, 0x04, 0x08) IRQNoFlags () {3,4,10,11} } StartDependentFnNoPri () { IO (Decode16, 0x02E8, 0x02E8, 0x04, 0x08) IRQNoFlags () {3,4,10,11} } EndDependentFn () }) Device (RMSC) { Name (_HID, EisaId ("PNP0C02")) Name (_UID, 0x10) Name (CRS, ResourceTemplate () { IO (Decode16, 0x0010, 0x0010, 0x00, 0x10) IO (Decode16, 0x0022, 0x0022, 0x00, 0x1E) IO (Decode16, 0x0044, 0x0044, 0x00, 0x0A) IO (Decode16, 0x0050, 0x0050, 0x00, 0x10) IO (Decode16, 0x0063, 0x0063, 0x00, 0x01) IO (Decode16, 0x0065, 0x0065, 0x00, 0x01) IO (Decode16, 0x0067, 0x0067, 0x00, 0x09) IO (Decode16, 0x0072, 0x0072, 0x00, 0x0E) IO (Decode16, 0x0080, 0x0080, 0x00, 0x01) IO (Decode16, 0x0084, 0x0084, 0x00, 0x03) IO (Decode16, 0x0088, 0x0088, 0x00, 0x01) IO (Decode16, 0x008C, 0x008C, 0x00, 0x03) IO (Decode16, 0x0090, 0x0090, 0x00, 0x10) IO (Decode16, 0x00A2, 0x00A2, 0x00, 0x1E) IO (Decode16, 0x00E0, 0x00E0, 0x00, 0x10) IO (Decode16, 0x04D0, 0x04D0, 0x00, 0x02) IO (Decode16, 0x0000, 0x0000, 0x00, 0x00) IO (Decode16, 0x0000, 0x0000, 0x00, 0x00) }) Method (_CRS, 0, NotSerialized) { CreateWordField (CRS, 0x82, GP00) CreateWordField (CRS, 0x84, GP01) CreateByteField (CRS, 0x87, GP0L) Store (PMBS, GP00) Store (PMBS, GP01) Store (PMLN, GP0L) If (GPBS) { CreateWordField (CRS, 0x8A, GP20) CreateWordField (CRS, 0x8C, GP21) CreateByteField (CRS, 0x8F, GP2L) Store (GPBS, GP20) Store (GPBS, GP21) Store (GPLN, GP2L) } Return (CRS) } } Device (FWH) { Name (_HID, EisaId ("INT0800")) Name (CRS, ResourceTemplate () { Memory32Fixed (ReadOnly, 0x00000000, 0x00000000) Memory32Fixed (ReadOnly, 0x00000000, 0x00000000) }) CreateDWordField (CRS, 0x04, BS00) CreateDWordField (CRS, 0x08, BL00) CreateDWordField (CRS, 0x10, BS10) CreateDWordField (CRS, 0x14, BL10) Method (_CRS, 0, NotSerialized) { Store (0xFF800000, Local0) FindSetRightBit (FHD0, Local1) Decrement (Local1) If (Local1) { Multiply (Local1, 0x00080000, Local1) } Add (Local0, Local1, Local2) Store (Local2, BS00) Add (BS00, 0x00400000, BS10) Subtract (0x00, BS10, BL00) Store (BL00, BL10) Return (CRS) } } Device (FWHE) { Name (_HID, EisaId ("PNP0C02")) Name (_UID, 0x03) Name (CRS, ResourceTemplate () { Memory32Fixed (ReadOnly, 0x00000000, 0x00000000) }) Method (_CRS, 0, NotSerialized) { CreateDWordField (CRS, 0x04, BS00) CreateDWordField (CRS, 0x08, BL00) If (LEqual (^^FWH.BS00, 0x00)) { ^^FWH._CRS () } Add (^^FWH.BS00, ^^FWH.BL00, BS00) Subtract (^^FWH.BS10, BS00, BL00) Return (CRS) } } OperationRegion (FHR0, PCI_Config, 0xD9, 0x01) Field (FHR0, ByteAcc, NoLock, Preserve) { FHD0, 8 } Device (OMSC) { Name (_HID, EisaId ("PNP0C02")) Name (_UID, 0x00) Name (CRS, ResourceTemplate () { IO (Decode16, 0x0000, 0x0000, 0x00, 0x00) IO (Decode16, 0x0000, 0x0000, 0x00, 0x00) IO (Decode16, 0x0000, 0x0000, 0x00, 0x00) IO (Decode16, 0x0000, 0x0000, 0x00, 0x00) Memory32Fixed (ReadOnly, 0xEEC00000, 0x00004000) Memory32Fixed (ReadOnly, 0x00000000, 0x00000000) Memory32Fixed (ReadOnly, 0x00000000, 0x00000000) Memory32Fixed (ReadOnly, 0xE0000000, 0x10000000) Memory32Fixed (ReadOnly, 0xFED13000, 0x00001000) Memory32Fixed (ReadOnly, 0xFED14000, 0x00004000) Memory32Fixed (ReadOnly, 0xFED18000, 0x00001000) Memory32Fixed (ReadOnly, 0xFED19000, 0x00001000) Memory32Fixed (ReadOnly, 0xFED1C000, 0x00004000) Memory32Fixed (ReadOnly, 0xFED20000, 0x00080000) }) Method (_CRS, 0, NotSerialized) { CreateWordField (CRS, 0x02, GP00) CreateWordField (CRS, 0x04, GP01) CreateByteField (CRS, 0x07, GP0L) Store (PMBS, GP00) Store (PMBS, GP01) Store (PMLN, GP0L) If (LAnd (LNot (LEqual (SPIO, 0x03F0)), LGreater (SPIO, 0xF0))) { CreateWordField (CRS, 0x0A, GP10) CreateWordField (CRS, 0x0C, GP11) CreateByteField (CRS, 0x0F, GPL1) Store (SPIO, GP10) Store (SPIO, GP11) Store (0x02, GPL1) } If (IO1B) { CreateWordField (CRS, 0x12, GP20) CreateWordField (CRS, 0x14, GP21) CreateByteField (CRS, 0x17, GP2L) Store (IO1B, GP20) Store (IO1B, GP21) Store (IO1L, GP2L) } If (GPBS) { CreateWordField (CRS, 0x1A, GP30) CreateWordField (CRS, 0x1C, GP31) CreateByteField (CRS, 0x1F, GP3L) Store (GPBS, GP30) Store (GPBS, GP31) Store (GPLN, GP3L) } CreateDWordField (CRS, 0x34, RLIM) CreateDWordField (CRS, 0x30, RBAS) Store (0xFED1A000, RBAS) Store (0x4000, RLIM) If (APIC) { CreateDWordField (CRS, 0x34, ML01) CreateDWordField (CRS, 0x30, MB01) CreateDWordField (CRS, 0x40, ML02) CreateDWordField (CRS, 0x3C, MB02) Store (0xFEC00000, MB01) Store (0x1000, ML01) Store (0xFEE00000, MB02) Store (0x1000, ML02) } Return (CRS) } } Device (\_SB.RMEM) { Name (_HID, EisaId ("PNP0C01")) Name (_UID, 0x01) Name (CRS, ResourceTemplate () { Memory32Fixed (ReadWrite, 0x00000000, 0x000A0000) Memory32Fixed (ReadOnly, 0x00000000, 0x00000000) Memory32Fixed (ReadOnly, 0x000E0000, 0x00020000) Memory32Fixed (ReadWrite, 0x00100000, 0x00000000) Memory32Fixed (ReadOnly, 0x00000000, 0x00000000) }) Method (_CRS, 0, NotSerialized) { CreateDWordField (CRS, 0x10, BAS1) CreateDWordField (CRS, 0x14, LEN1) CreateDWordField (CRS, 0x1C, BAS2) CreateDWordField (CRS, 0x20, LEN2) CreateDWordField (CRS, 0x2C, LEN3) CreateDWordField (CRS, 0x34, BAS4) CreateDWordField (CRS, 0x38, LEN4) If (OSFL ()) {} Else { If (MG1B) { If (LGreater (MG1B, 0x000C0000)) { Store (0x000C0000, BAS1) Subtract (MG1B, BAS1, LEN1) } } Else { Store (0x000C0000, BAS1) Store (0x00020000, LEN1) } If (Add (MG1B, MG1L, Local0)) { Store (Local0, BAS2) Subtract (0x00100000, BAS2, LEN2) } } Subtract (MG2B, 0x00100000, LEN3) Add (MG2B, MG2L, BAS4) Subtract (0x00, BAS4, LEN4) Return (CRS) } } } Device (IDE1) { Name (_ADR, 0x001F0002) Name (REGF, 0x01) Method (_REG, 2, NotSerialized) { If (LEqual (Arg0, 0x02)) { Store (Arg1, REGF) } } OperationRegion (BAR0, PCI_Config, 0x00, 0x0100) Field (BAR0, DWordAcc, NoLock, Preserve) { ID32, 32, Offset (0x40), TIMP, 16, TIMS, 16, STMP, 4, STMS, 4, Offset (0x48), UDMP, 2, UDMS, 2, Offset (0x4A), UDTP, 6, Offset (0x4B), UDTS, 6, Offset (0x54), PCB0, 2, SCB0, 2, PCA0, 2, SCA0, 2, , 4, FPB0, 2, FSB0, 2, Offset (0x90), MAP1, 3, Offset (0x92), PEN1, 2 } Name (TIM0, Package (0x09) { Package (0x04) { 0x78, 0xB4, 0xF0, 0x0384 }, Package (0x04) { 0x23, 0x21, 0x10, 0x00 }, Package (0x04) { 0x0B, 0x09, 0x04, 0x00 }, Package (0x06) { 0x70, 0x49, 0x36, 0x27, 0x19, 0x11 }, Package (0x06) { 0x00, 0x01, 0x02, 0x01, 0x02, 0x01 }, Package (0x06) { 0x00, 0x00, 0x00, 0x01, 0x01, 0x01 }, Package (0x06) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x01 }, Package (0x04) { 0x04, 0x03, 0x02, 0x00 }, Package (0x04) { 0x02, 0x01, 0x00, 0x00 } }) Name (\PTSV, 0x00) Name (\MPSV, 0x00) Method (_INI, 0, NotSerialized) { Store (MAP1, MPSV) Store (PEN1, PTSV) } Name (TMD0, Buffer (0x14) {}) CreateDWordField (TMD0, 0x00, PIO0) CreateDWordField (TMD0, 0x04, DMA0) CreateDWordField (TMD0, 0x08, PIO1) CreateDWordField (TMD0, 0x0C, DMA1) CreateDWordField (TMD0, 0x10, CHNF) Name (GTIM, 0x00) Name (GSTM, 0x00) Name (GUDM, 0x00) Name (GUDT, 0x00) Name (GCB0, 0x00) Name (GFB0, 0x00) Device (CHN0) { Name (_ADR, 0x00) OperationRegion (IDE0, SystemIO, 0x01F0, 0x08) Field (IDE0, ByteAcc, NoLock, Preserve) { DATA, 8, FEAT, 8, SECC, 8, SECN, 8, CYLL, 8, CYLH, 8, DVHD, 8, STAT, 8 } Name (ATP0, 0x01) Name (ATP1, 0x01) Method (_GTM, 0, NotSerialized) { Return (GTM (TIMP, STMP, UDMP, UDTP, PCB0, FPB0)) } Method (_STM, 3, NotSerialized) { Store (Arg0, Debug) Store (Arg0, TMD0) Store (TIMP, GTIM) Store (UDTP, GUDT) If (STM ()) { Store (GTIM, TIMP) Store (GSTM, STMP) Store (GUDM, UDMP) Store (GUDT, UDTP) Store (GCB0, PCB0) Store (GFB0, FPB0) } Store (GTF (0x00, Arg1), ATA0) Store (GTF (0x01, Arg2), ATA1) } Device (DRV0) { Name (_ADR, 0x00) Method (_GTF, 0, NotSerialized) { Return (RATA (ATA0)) } } Device (DRV1) { Name (_ADR, 0x01) Method (_GTF, 0, NotSerialized) { Return (RATA (ATA1)) } } } Device (CHN1) { Name (_ADR, 0x01) OperationRegion (IDE1, SystemIO, 0x0170, 0x08) Field (IDE1, ByteAcc, NoLock, Preserve) { DATA, 8, FEAT, 8, SECC, 8, SECN, 8, CYLL, 8, CYLH, 8, DVHD, 8, STAT, 8 } Name (ATS0, 0x01) Name (ATS1, 0x01) Method (_GTM, 0, NotSerialized) { Return (GTM (TIMS, STMS, UDMS, UDTS, SCB0, FSB0)) } Method (_STM, 3, NotSerialized) { Store (Arg0, Debug) Store (Arg0, TMD0) Store (TIMS, GTIM) Store (UDTS, GUDT) If (STM ()) { Store (GTIM, TIMS) Store (GSTM, STMS) Store (GUDM, UDMS) Store (GUDT, UDTS) Store (GCB0, SCB0) Store (GFB0, FSB0) } Store (GTF (0x00, Arg1), ATA2) Store (GTF (0x01, Arg2), ATA3) } Device (DRV0) { Name (_ADR, 0x00) Method (_GTF, 0, NotSerialized) { Return (RATA (ATA2)) } } Device (DRV1) { Name (_ADR, 0x01) Method (_GTF, 0, NotSerialized) { Return (RATA (ATA3)) } } Name (TIM1, Buffer (0x14) {}) CreateDWordField (TIM1, 0x00, MPIO) CreateDWordField (TIM1, 0x04, MDMA) CreateDWordField (TIM1, 0x08, SPIO) CreateDWordField (TIM1, 0x0C, SDMA) CreateDWordField (TIM1, 0x10, FLGS) Method (_PS3, 0, NotSerialized) { If (MCTH (\_OS, "Microsoft Windows")) { Store (_GTM (), TIM1) } } Name (BOOT, 0x00) Method (_PS0, 0, NotSerialized) { If (LEqual (ID32, 0xFFFFFFFF)) { Noop } Else { If (LNot (LEqual (MAP1, MPSV))) { Store (MPSV, MAP1) Store (0x21, DBG8) Sleep (0x07D0) } If (LNot (LEqual (PEN1, PTSV))) { And (Not (PTSV), PEN1, PEN1) Sleep (0x01) Store (PTSV, PEN1) Sleep (0x0A) } } If (MCTH (\_OS, "Microsoft Windows")) { If (BOOT) { If (And (DRVI, 0x20)) { PRGT (MPIO, MDMA, FLGS, 0xA0) } If (And (DRVI, 0x80)) { PRGT (SPIO, SDMA, FLGS, 0xB0) } } Store (0x01, BOOT) } } Method (PRGT, 4, NotSerialized) { Store (Arg3, DVHD) If (And (Not (LEqual (Arg0, 0xFFFFFFFF)), Not (LEqual (Arg0, 0x00)))) { While (LEqual (And (STAT, 0x80), 0x80)) {} Store (0x03, FEAT) Store (Match (DerefOf (Index (TIM0, 0x00)), MEQ, Arg0, MTR, 0x00, 0x00), Local0) Or (0x08, DerefOf (Index (DerefOf (Index (TIM0, 0x07)), Local0)), Local0) Store (Local0, SECC) Store (0x00, SECN) Store (0x00, CYLL) Store (0x00, CYLH) Store (Arg3, DVHD) Store (0xEF, STAT) } If (And (Not (LEqual (Arg0, 0xFFFFFFFF)), Not (LEqual (Arg0, 0x00)))) { While (LEqual (And (STAT, 0x80), 0x80)) {} Store (0x03, FEAT) Store (0x00, Local0) If (LEqual (Arg3, 0xA0)) { If (And (Arg2, 0x01)) { Store (0x01, Local0) } } Else { If (And (Arg2, 0x04)) { Store (0x01, Local0) } } If (LEqual (Local0, 0x01)) { Store (Match (DerefOf (Index (TIM0, 0x03)), MEQ, Arg1, MTR, 0x00, 0x00), Local0) Or (0x40, Local0, Local0) } Else { Store (Match (DerefOf (Index (TIM0, 0x00)), MEQ, Arg1, MTR, 0x00, 0x00), Local0) Or (0x20, DerefOf (Index (DerefOf (Index (TIM0, 0x08)), Local0)), Local0) } Store (Local0, SECC) Store (0x00, SECN) Store (0x00, CYLL) Store (0x00, CYLH) Store (Arg3, DVHD) Store (0xEF, STAT) } } } Method (GTM, 6, Serialized) { Store (Ones, PIO0) Store (PIO0, PIO1) Store (PIO0, DMA0) Store (PIO0, DMA1) Store (Zero, CHNF) If (REGF) {} Else { Return (TMD0) } If (And (Arg0, 0x02)) { Or (CHNF, 0x02, CHNF) } ShiftRight (And (Arg0, 0x3300), 0x08, Local5) Store (Match (DerefOf (Index (TIM0, 0x01)), MLE, Local5, MTR, 0x00, 0x00), Local6) Store (DerefOf (Index (DerefOf (Index (TIM0, 0x00)), Local6)), Local7) Store (Local7, DMA0) If (And (Arg0, 0x08)) { Store (0x0384, PIO0) } Else { Store (Local7, PIO0) } If (And (Arg0, 0x20)) { Or (CHNF, 0x08, CHNF) } If (And (Arg0, 0x4000)) { Or (CHNF, 0x10, CHNF) Store (Match (DerefOf (Index (TIM0, 0x02)), MLE, Arg1, MTR, 0x00, 0x00), Local5) Store (DerefOf (Index (DerefOf (Index (TIM0, 0x00)), Local5)), Local6) Store (Local6, DMA1) If (And (Arg0, 0x80)) { Store (0x0384, PIO1) } Else { Store (Local6, PIO1) } } If (And (Arg2, 0x01)) { And (Arg3, 0x03, Local5) If (LAnd (And (Arg5, 0x01), LEqual (Local5, 0x01))) { Store (0x05, Local5) } Else { If (And (Arg4, 0x01)) { Store (0x04, Local5) } } Store (DerefOf (Index (DerefOf (Index (TIM0, 0x03)), Local5)), DMA0) Or (CHNF, 0x01, CHNF) } If (And (Arg2, 0x02)) { And (ShiftRight (Arg3, 0x04), 0x03, Local5) If (LAnd (And (Arg5, 0x02), LEqual (Local5, 0x01))) { Store (0x05, Local5) } Else { If (And (Arg4, 0x02)) { Store (0x04, Local5) } } Store (DerefOf (Index (DerefOf (Index (TIM0, 0x03)), Local5)), DMA1) Or (CHNF, 0x04, CHNF) } Store (TMD0, Debug) Return (TMD0) } Method (STM, 0, Serialized) { If (REGF) {} Else { Return (0x00) } And (GTIM, 0x8044, GTIM) Store (0x00, GSTM) Store (0x00, GUDM) Store (0x00, GCB0) And (GUDT, 0xCC, GUDT) Store (0x00, GFB0) If (And (CHNF, 0x01)) { Store (Match (DerefOf (Index (TIM0, 0x03)), MLE, DMA0, MTR, 0x00, 0x00), Local0) If (LGreater (Local0, 0x05)) { Store (0x05, Local0) } Or (GUDT, DerefOf (Index (DerefOf (Index (TIM0, 0x04)), Local0)), GUDT) Or (GCB0, DerefOf (Index (DerefOf (Index (TIM0, 0x05)), Local0)), GCB0) Or (GFB0, DerefOf (Index (DerefOf (Index (TIM0, 0x06)), Local0)), GFB0) Or (GUDM, 0x01, GUDM) } Else { If (Or (LEqual (PIO0, Ones), LEqual (PIO0, 0x00))) { If (And (LLess (DMA0, Ones), LGreater (DMA0, 0x00))) { Store (DMA0, PIO0) Or (GTIM, 0x08, GTIM) } } } If (And (CHNF, 0x04)) { Store (Match (DerefOf (Index (TIM0, 0x03)), MLE, DMA1, MTR, 0x00, 0x00), Local0) If (LGreater (Local0, 0x05)) { Store (0x05, Local0) } Or (GUDT, ShiftLeft (DerefOf (Index (DerefOf (Index (TIM0, 0x04)), Local0)), 0x04), GUDT) Or (GCB0, ShiftLeft (DerefOf (Index (DerefOf (Index (TIM0, 0x05)), Local0)), 0x01), GCB0) Or (GFB0, ShiftLeft (DerefOf (Index (DerefOf (Index (TIM0, 0x06)), Local0)), 0x01), GFB0) Or (GUDM, 0x02, GUDM) } Else { If (Or (LEqual (PIO1, Ones), LEqual (PIO1, 0x00))) { If (And (LLess (DMA1, Ones), LGreater (DMA1, 0x00))) { Store (DMA1, PIO1) Or (GTIM, 0x80, GTIM) } } } If (And (CHNF, 0x02)) { Or (GTIM, 0x03, GTIM) } If (And (CHNF, 0x08)) { Or (GTIM, 0x30, GTIM) } And (Match (DerefOf (Index (TIM0, 0x00)), MGE, PIO0, MTR, 0x00, 0x00), 0x03, Local0) Store (DerefOf (Index (DerefOf (Index (TIM0, 0x01)), Local0)), Local1) ShiftLeft (Local1, 0x08, Local2) Or (GTIM, Local2, GTIM) If (And (CHNF, 0x10)) { Or (GTIM, 0x4000, GTIM) And (Match (DerefOf (Index (TIM0, 0x00)), MGE, PIO1, MTR, 0x00, 0x00), 0x03, Local0) Store (DerefOf (Index (DerefOf (Index (TIM0, 0x02)), Local0)), GSTM) } Return (0x01) } Name (AT01, Buffer (0x07) { 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0xEF }) Name (AT02, Buffer (0x07) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x90 }) Name (AT03, Buffer (0x07) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xC6 }) Name (AT04, Buffer (0x07) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x91 }) Name (AT05, Buffer (0x07) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xF5 }) Name (ATA0, Buffer (0x1D) {}) Name (ATA1, Buffer (0x1D) {}) Name (ATA2, Buffer (0x1D) {}) Name (ATA3, Buffer (0x1D) {}) Name (ATAB, Buffer (0x1D) {}) CreateByteField (ATAB, 0x00, CMDC) Method (GTFB, 3, Serialized) { Multiply (CMDC, 0x38, Local0) Add (Local0, 0x08, Local1) CreateField (ATAB, Local1, 0x38, CMDX) Multiply (CMDC, 0x07, Local0) CreateByteField (ATAB, Add (Local0, 0x02), A001) CreateByteField (ATAB, Add (Local0, 0x06), A005) Store (Arg0, CMDX) Store (Arg1, A001) Store (Arg2, A005) Increment (CMDC) } Method (GTF, 2, Serialized) { Store (Arg1, Debug) Store (0x00, CMDC) Name (ID49, 0x0C00) Name (ID59, 0x00) Name (ID53, 0x04) Name (ID63, 0x0F00) Name (ID88, 0x0F00) Name (IRDY, 0x01) Name (PIOT, 0x00) Name (DMAT, 0x00) If (LEqual (SizeOf (Arg1), 0x0200)) { CreateWordField (Arg1, 0x62, IW49) Store (IW49, ID49) CreateWordField (Arg1, 0x6A, IW53) Store (IW53, ID53) CreateWordField (Arg1, 0x7E, IW63) Store (IW63, ID63) CreateWordField (Arg1, 0x76, IW59) Store (IW59, ID59) CreateWordField (Arg1, 0xB0, IW88) Store (IW88, ID88) CreateWordField (Arg1, 0xA4, IW82) } Store (0xA0, Local7) If (Arg0) { Store (0xB0, Local7) And (CHNF, 0x08, IRDY) If (And (CHNF, 0x10)) { Store (PIO1, PIOT) } Else { Store (PIO0, PIOT) } If (And (CHNF, 0x04)) { If (And (CHNF, 0x10)) { Store (DMA1, DMAT) } Else { Store (DMA0, DMAT) } } } Else { And (CHNF, 0x02, IRDY) Store (PIO0, PIOT) If (And (CHNF, 0x01)) { Store (DMA0, DMAT) } } If (LAnd (LAnd (And (ID53, 0x04), And (ID88, 0xFF00)), DMAT)) { Store (Match (DerefOf (Index (TIM0, 0x03)), MLE, DMAT, MTR, 0x00, 0x00), Local1) If (LGreater (Local1, 0x05)) { Store (0x05, Local1) } GTFB (AT01, Or (0x40, Local1), Local7) } Else { If (LAnd (And (ID63, 0xFF00), PIOT)) { And (Match (DerefOf (Index (TIM0, 0x00)), MGE, PIOT, MTR, 0x00, 0x00), 0x03, Local0) Or (0x20, DerefOf (Index (DerefOf (Index (TIM0, 0x08)), Local0)), Local1) GTFB (AT01, Local1, Local7) } } If (IRDY) { And (Match (DerefOf (Index (TIM0, 0x00)), MGE, PIOT, MTR, 0x00, 0x00), 0x03, Local0) Or (0x08, DerefOf (Index (DerefOf (Index (TIM0, 0x07)), Local0)), Local1) GTFB (AT01, Local1, Local7) } Else { If (And (ID49, 0x0400)) { GTFB (AT01, 0x01, Local7) } } If (LAnd (And (ID59, 0x0100), And (ID59, 0xFF))) { GTFB (AT03, And (ID59, 0xFF), Local7) } If (LAnd (IW82, 0x02)) { GTFB (AT05, 0x00, Local7) } Store (ATAB, Debug) Return (ATAB) } Method (RATA, 1, NotSerialized) { CreateByteField (Arg0, 0x00, CMDN) Multiply (CMDN, 0x38, Local0) CreateField (Arg0, 0x08, Local0, RETB) Store (RETB, Debug) Return (RETB) } } Device (PEX1) { Name (_ADR, 0x001C0000) OperationRegion (ORP0, PCI_Config, 0x00, 0xFF) Field (ORP0, AnyAcc, NoLock, Preserve) { RPID, 32, Offset (0x34), CPLT, 8, Offset (0x58), SSLC, 10, Offset (0x5A), SSLS, 7, Offset (0x5C), Offset (0x60), SQID, 16, SPME, 1, SPMP, 1, Offset (0x64), Offset (0xB8), NSLC, 10, Offset (0xBA), NSLS, 7, Offset (0xBC), Offset (0xC0), NQID, 16, NPME, 1, NPMP, 1, Offset (0xC4), Offset (0xDC), , 31, RPSC, 1 } Method (HDDN, 1, NotSerialized) { If (LEqual (RPID, Ones)) { Return (One) } Else { Return (Zero) } } Method (XPMH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { Store (NPME, Local0) While (NPME) { Store (0x01, NPME) } } Else { Store (SPME, Local0) While (SPME) { Store (0x01, SPME) } While (RPSC) { Store (0x01, RPSC) } } Return (Local0) } Method (XHPH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { And (NSLC, NSLS, Local0) And (Local0, 0x0D, Local0) Store (NSLS, NSLS) } Else { And (SSLC, SSLS, Local0) And (Local0, 0x0D, Local0) Store (SSLS, SSLS) } Return (Local0) } Method (SCIC, 2, NotSerialized) { OperationRegion (ORP7, PCI_Config, 0xD8, 0x04) Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, HPCS, 1, PMCS, 1 } Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, ICHC, 2 } OperationRegion (ORP8, PCI_Config, 0xEC, 0x04) Field (ORP8, AnyAcc, NoLock, Preserve) { GPCN, 1, HPCN, 1, PMCN, 1 } Field (ORP8, AnyAcc, NoLock, Preserve) { , 1, MCHC, 2 } If (LNot (HDDN (Arg0))) { If (LNot (LGreater (Arg0, 0x03))) { And (Arg1, 0x03, ICHC) } If (LEqual (Arg0, 0x08)) { And (Arg1, 0x03, MCHC) } } } Method (DP80, 1, NotSerialized) { Store (Arg0, DBG8) Sleep (0x0BB8) Store (0x00, DBG8) } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x09, 0x04)) } Method (_PRT, 0, NotSerialized) { If (PICM) { Return (AR03) } Return (PR03) } } Device (PEX2) { Name (_ADR, 0x001C0001) OperationRegion (ORP0, PCI_Config, 0x00, 0xFF) Field (ORP0, AnyAcc, NoLock, Preserve) { RPID, 32, Offset (0x34), CPLT, 8, Offset (0x58), SSLC, 10, Offset (0x5A), SSLS, 7, Offset (0x5C), Offset (0x60), SQID, 16, SPME, 1, SPMP, 1, Offset (0x64), Offset (0xB8), NSLC, 10, Offset (0xBA), NSLS, 7, Offset (0xBC), Offset (0xC0), NQID, 16, NPME, 1, NPMP, 1, Offset (0xC4), Offset (0xDC), , 31, RPSC, 1 } Method (HDDN, 1, NotSerialized) { If (LEqual (RPID, Ones)) { Return (One) } Else { Return (Zero) } } Method (XPMH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { Store (NPME, Local0) While (NPME) { Store (0x01, NPME) } } Else { Store (SPME, Local0) While (SPME) { Store (0x01, SPME) } While (RPSC) { Store (0x01, RPSC) } } Return (Local0) } Method (XHPH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { And (NSLC, NSLS, Local0) And (Local0, 0x0D, Local0) Store (NSLS, NSLS) } Else { And (SSLC, SSLS, Local0) And (Local0, 0x0D, Local0) Store (SSLS, SSLS) } Return (Local0) } Method (SCIC, 2, NotSerialized) { OperationRegion (ORP7, PCI_Config, 0xD8, 0x04) Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, HPCS, 1, PMCS, 1 } Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, ICHC, 2 } OperationRegion (ORP8, PCI_Config, 0xEC, 0x04) Field (ORP8, AnyAcc, NoLock, Preserve) { GPCN, 1, HPCN, 1, PMCN, 1 } Field (ORP8, AnyAcc, NoLock, Preserve) { , 1, MCHC, 2 } If (LNot (HDDN (Arg0))) { If (LNot (LGreater (Arg0, 0x03))) { And (Arg1, 0x03, ICHC) } If (LEqual (Arg0, 0x08)) { And (Arg1, 0x03, MCHC) } } } Method (DP80, 1, NotSerialized) { Store (Arg0, DBG8) Sleep (0x0BB8) Store (0x00, DBG8) } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x09, 0x04)) } Method (_PRT, 0, NotSerialized) { If (PICM) { Return (AR04) } Return (PR04) } } Device (PEX3) { Name (_ADR, 0x001C0002) OperationRegion (ORP0, PCI_Config, 0x00, 0xFF) Field (ORP0, AnyAcc, NoLock, Preserve) { RPID, 32, Offset (0x34), CPLT, 8, Offset (0x58), SSLC, 10, Offset (0x5A), SSLS, 7, Offset (0x5C), Offset (0x60), SQID, 16, SPME, 1, SPMP, 1, Offset (0x64), Offset (0xB8), NSLC, 10, Offset (0xBA), NSLS, 7, Offset (0xBC), Offset (0xC0), NQID, 16, NPME, 1, NPMP, 1, Offset (0xC4), Offset (0xDC), , 31, RPSC, 1 } Method (HDDN, 1, NotSerialized) { If (LEqual (RPID, Ones)) { Return (One) } Else { Return (Zero) } } Method (XPMH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { Store (NPME, Local0) While (NPME) { Store (0x01, NPME) } } Else { Store (SPME, Local0) While (SPME) { Store (0x01, SPME) } While (RPSC) { Store (0x01, RPSC) } } Return (Local0) } Method (XHPH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { And (NSLC, NSLS, Local0) And (Local0, 0x0D, Local0) Store (NSLS, NSLS) } Else { And (SSLC, SSLS, Local0) And (Local0, 0x0D, Local0) Store (SSLS, SSLS) } Return (Local0) } Method (SCIC, 2, NotSerialized) { OperationRegion (ORP7, PCI_Config, 0xD8, 0x04) Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, HPCS, 1, PMCS, 1 } Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, ICHC, 2 } OperationRegion (ORP8, PCI_Config, 0xEC, 0x04) Field (ORP8, AnyAcc, NoLock, Preserve) { GPCN, 1, HPCN, 1, PMCN, 1 } Field (ORP8, AnyAcc, NoLock, Preserve) { , 1, MCHC, 2 } If (LNot (HDDN (Arg0))) { If (LNot (LGreater (Arg0, 0x03))) { And (Arg1, 0x03, ICHC) } If (LEqual (Arg0, 0x08)) { And (Arg1, 0x03, MCHC) } } } Method (DP80, 1, NotSerialized) { Store (Arg0, DBG8) Sleep (0x0BB8) Store (0x00, DBG8) } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x09, 0x04)) } Method (_PRT, 0, NotSerialized) { If (PICM) { Return (AR05) } Return (PR05) } } Device (PEX4) { Name (_ADR, 0x001C0003) OperationRegion (ORP0, PCI_Config, 0x00, 0xFF) Field (ORP0, AnyAcc, NoLock, Preserve) { RPID, 32, Offset (0x34), CPLT, 8, Offset (0x58), SSLC, 10, Offset (0x5A), SSLS, 7, Offset (0x5C), Offset (0x60), SQID, 16, SPME, 1, SPMP, 1, Offset (0x64), Offset (0xB8), NSLC, 10, Offset (0xBA), NSLS, 7, Offset (0xBC), Offset (0xC0), NQID, 16, NPME, 1, NPMP, 1, Offset (0xC4), Offset (0xDC), , 31, RPSC, 1 } Method (HDDN, 1, NotSerialized) { If (LEqual (RPID, Ones)) { Return (One) } Else { Return (Zero) } } Method (XPMH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { Store (NPME, Local0) While (NPME) { Store (0x01, NPME) } } Else { Store (SPME, Local0) While (SPME) { Store (0x01, SPME) } While (RPSC) { Store (0x01, RPSC) } } Return (Local0) } Method (XHPH, 1, NotSerialized) { Store (Zero, Local0) If (HDDN (Arg0)) { Return (Local0) } If (LNot (LLess (Arg0, 0x08))) { And (NSLC, NSLS, Local0) And (Local0, 0x0D, Local0) Store (NSLS, NSLS) } Else { And (SSLC, SSLS, Local0) And (Local0, 0x0D, Local0) Store (SSLS, SSLS) } Return (Local0) } Method (SCIC, 2, NotSerialized) { OperationRegion (ORP7, PCI_Config, 0xD8, 0x04) Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, HPCS, 1, PMCS, 1 } Field (ORP7, AnyAcc, NoLock, Preserve) { , 30, ICHC, 2 } OperationRegion (ORP8, PCI_Config, 0xEC, 0x04) Field (ORP8, AnyAcc, NoLock, Preserve) { GPCN, 1, HPCN, 1, PMCN, 1 } Field (ORP8, AnyAcc, NoLock, Preserve) { , 1, MCHC, 2 } If (LNot (HDDN (Arg0))) { If (LNot (LGreater (Arg0, 0x03))) { And (Arg1, 0x03, ICHC) } If (LEqual (Arg0, 0x08)) { And (Arg1, 0x03, MCHC) } } } Method (DP80, 1, NotSerialized) { Store (Arg0, DBG8) Sleep (0x0BB8) Store (0x00, DBG8) } Method (_PRW, 0, NotSerialized) { Return (GPRW (0x09, 0x04)) } } Device (AZAL) { Name (_ADR, 0x001B0000) Method (_PRW, 0, NotSerialized) { Return (GPRW (0x05, 0x04)) } } Device (SCHP) { Name (_ADR, 0x001F0004) } } } Scope (\_SB) { OperationRegion (\_SB.PCI0.SBRG.IROR, PCI_Config, 0x00, 0xFF) Field (\_SB.PCI0.SBRG.IROR, ByteAcc, NoLock, Preserve) { Offset (0x60), PIRA, 8, PIRB, 8, PIRC, 8, PIRD, 8, Offset (0x68), PIRE, 8, PIRF, 8, PIRG, 8, PIRH, 8 } Name (BUFA, ResourceTemplate () { IRQ (Level, ActiveLow, Shared) {15} }) CreateWordField (BUFA, 0x01, ICRS) Method (LSTA, 1, NotSerialized) { And (Arg0, 0x80, Local0) If (Local0) { Return (0x09) } Else { Return (0x0B) } } Method (LCRS, 1, NotSerialized) { And (Arg0, 0x0F, Local0) ShiftLeft (0x01, Local0, ICRS) Return (BUFA) } Method (LSRS, 1, NotSerialized) { CreateWordField (Arg0, 0x01, ISRS) FindSetRightBit (ISRS, Local0) Return (Decrement (Local0)) } Method (LDIS, 1, NotSerialized) { Return (Or (Arg0, 0x80)) } Device (LNKA) { Name (_HID, EisaId ("PNP0C0F")) Name (_UID, 0x01) Method (_STA, 0, NotSerialized) { Return (LSTA (PIRA)) } Method (_PRS, 0, NotSerialized) { Return (PRSA) } Method (_DIS, 0, NotSerialized) { Store (LDIS (PIRA), PIRA) } Method (_CRS, 0, NotSerialized) { Return (LCRS (PIRA)) } Method (_SRS, 1, NotSerialized) { Store (LSRS (Arg0), PIRA) } } Device (LNKB) { Name (_HID, EisaId ("PNP0C0F")) Name (_UID, 0x02) Method (_STA, 0, NotSerialized) { Return (LSTA (PIRB)) } Method (_PRS, 0, NotSerialized) { Return (PRSB) } Method (_DIS, 0, NotSerialized) { Store (LDIS (PIRB), PIRB) } Method (_CRS, 0, NotSerialized) { Return (LCRS (PIRB)) } Method (_SRS, 1, NotSerialized) { Store (LSRS (Arg0), PIRB) } } Device (LNKC) { Name (_HID, EisaId ("PNP0C0F")) Name (_UID, 0x03) Method (_STA, 0, NotSerialized) { Return (LSTA (PIRC)) } Method (_PRS, 0, NotSerialized) { Return (PRSC) } Method (_DIS, 0, NotSerialized) { Store (LDIS (PIRC), PIRC) } Method (_CRS, 0, NotSerialized) { Return (LCRS (PIRC)) } Method (_SRS, 1, NotSerialized) { Store (LSRS (Arg0), PIRC) } } Device (LNKD) { Name (_HID, EisaId ("PNP0C0F")) Name (_UID, 0x04) Method (_STA, 0, NotSerialized) { Return (LSTA (PIRD)) } Method (_PRS, 0, NotSerialized) { Return (PRSD) } Method (_DIS, 0, NotSerialized) { Store (LDIS (PIRD), PIRD) } Method (_CRS, 0, NotSerialized) { Return (LCRS (PIRD)) } Method (_SRS, 1, NotSerialized) { Store (LSRS (Arg0), PIRD) } } Device (LNKE) { Name (_HID, EisaId ("PNP0C0F")) Name (_UID, 0x05) Method (_STA, 0, NotSerialized) { Return (LSTA (PIRE)) } Method (_PRS, 0, NotSerialized) { Return (PRSE) } Method (_DIS, 0, NotSerialized) { Store (LDIS (PIRE), PIRE) } Method (_CRS, 0, NotSerialized) { Return (LCRS (PIRE)) } Method (_SRS, 1, NotSerialized) { Store (LSRS (Arg0), PIRE) } } Device (LNKF) { Name (_HID, EisaId ("PNP0C0F")) Name (_UID, 0x06) Method (_STA, 0, NotSerialized) { Return (LSTA (PIRF)) } Method (_PRS, 0, NotSerialized) { Return (PRSF) } Method (_DIS, 0, NotSerialized) { Store (LDIS (PIRF), PIRF) } Method (_CRS, 0, NotSerialized) { Return (LCRS (PIRF)) } Method (_SRS, 1, NotSerialized) { Store (LSRS (Arg0), PIRF) } } Device (LNKG) { Name (_HID, EisaId ("PNP0C0F")) Name (_UID, 0x07) Method (_STA, 0, NotSerialized) { Return (LSTA (PIRG)) } Method (_PRS, 0, NotSerialized) { Return (PRSG) } Method (_DIS, 0, NotSerialized) { Store (LDIS (PIRG), PIRG) } Method (_CRS, 0, NotSerialized) { Return (LCRS (PIRG)) } Method (_SRS, 1, NotSerialized) { Store (LSRS (Arg0), PIRG) } } Device (LNKH) { Name (_HID, EisaId ("PNP0C0F")) Name (_UID, 0x08) Method (_STA, 0, NotSerialized) { Return (LSTA (PIRH)) } Method (_PRS, 0, NotSerialized) { Return (PRSH) } Method (_DIS, 0, NotSerialized) { Store (LDIS (PIRH), PIRH) } Method (_CRS, 0, NotSerialized) { Return (LCRS (PIRH)) } Method (_SRS, 1, NotSerialized) { Store (LSRS (Arg0), PIRH) } } } If (\SWAP) { Scope (\) { Name (PRNT, 0x00) Name (SATA, 0x00) Name (IOGP, 0xFFFF) Name (TST1, 0x00) Name (TST2, 0x1234) Name (DBFL, 0x01) Method (DP80, 1, NotSerialized) { If (DBFL) { Store (Arg0, DBG8) Sleep (0x07D0) Store (0x00, DBG8) } } } Scope (\_SB.PCI0.SBRG) { OperationRegion (OP31, SystemIO, \PMBS, 0x40) Field (OP31, ByteAcc, NoLock, Preserve) { Offset (0x28), , 28, G12S, 1, Offset (0x2C), , 28, G12E, 1 } OperationRegion (OP32, PCI_Config, 0x00, 0x0100) Field (OP32, ByteAcc, NoLock, Preserve) { Offset (0xBB), G12R, 2 } OperationRegion (OP33, SystemIO, \IOGP, 0x20) Field (OP33, ByteAcc, NoLock, Preserve) { Offset (0x04), , 4, PWSW, 1 } } Scope (\_SB.PCI0.IDE1) { OperationRegion (OP34, PCI_Config, 0x00, 0x0100) Field (OP34, AnyAcc, NoLock, Preserve) { DVID, 32, Offset (0x09), PRMN, 1, , 1, SECN, 1, Offset (0x10), PCMA, 16, Offset (0x14), PCNA, 16, Offset (0x18), SCMA, 16, Offset (0x1C), SCNA, 16, Offset (0x20), SBMA, 16, Offset (0x42), , 1, IE0, 1, , 3, IE1, 1, Offset (0x54), , 18, SSMD, 2, Offset (0x90), MAP, 2, Offset (0x92), PTEN, 4, PTPR, 4 } Scope (CHN1) { Method (_INI, 0, NotSerialized) { If (LEqual (DVID, 0xFFFFFFFF)) { Store (0x00, SWAP) } Else { Store (0x01, SWAP) } If (SWAP) { If (LEqual (MAP, 0x02)) { Store (0x00, SATA) } Else { Store (0x02, SATA) } Store (SCDP (0x00), PRNT) \_SB.PCI0.SBRG.ENFG () Store (0x07, \_SB.PCI0.SBRG.LDN) Store (0x60, \_SB.PCI0.SBRG.INDX) Store (\_SB.PCI0.SBRG.DATA, IOGP) ShiftLeft (IOGP, 0x08, IOGP) Store (0x61, \_SB.PCI0.SBRG.INDX) Or (\_SB.PCI0.SBRG.DATA, IOGP) \_SB.PCI0.SBRG.EXFG () Store (0x02, \_SB.PCI0.SBRG.G12R) } } Method (SCDP, 1, NotSerialized) { If (SECN) { And (SCMA, 0xFFFE, Local0) } Else { Store (0x0170, Local0) } OperationRegion (OP37, SystemIO, Local0, 0x08) Field (OP37, ByteAcc, NoLock, Preserve) { Offset (0x06), , 4, SDSL, 1, Offset (0x07), SSCM, 8 } Store (Arg0, SDSL) Store (SSCM, Local2) DP80 (Local2) Store (Local2, TST1) If (LEqual (Local2, 0x50)) { Store (0x01, Local1) } Else { Store (0x00, Local1) } Return (Local1) } Method (SRST, 1, NotSerialized) { DP80 (0x50) Store (Arg0, Local0) Store (0x05, Local1) While (Local1) { And (Not (Local0), PTEN, PTEN) Sleep (0x32) Or (Local0, PTEN, PTEN) Sleep (0x64) If (And (And (PTEN, PTPR), Local0)) { If (SCDP (0x00)) { Return (One) } } Else { Decrement (Local1) } } Return (Zero) } Method (CINT, 0, NotSerialized) { If (SECN) { And (SBMA, 0xFFFE, Local7) OperationRegion (OP37, SystemIO, Local7, 0x08) Field (OP37, ByteAcc, NoLock, Preserve) { Offset (0x02), , 2, INTR, 1, Offset (0x03) } Store (0x01, INTR) } } Method (HPS0, 0, NotSerialized) { If (SWAP) { If (PRNT) { Noop } Else { DP80 (0xD0) Store (0x00, \_SB.PCI0.SBRG.PWSW) Sleep (0x0A) If (SATA) { If (LNot (And (SATA, PTEN))) { And (Not (SATA), PTEN, PTEN) Sleep (0x01) Or (SATA, PTEN, PTEN) Sleep (0x0A) Store (PTEN, PTSV) } } Else { Store (0x00, SSMD) Store (0x01, IE0) } } } } Method (HPS3, 0, NotSerialized) { If (SWAP) { DP80 (0xD3) If (SATA) { And (Not (SATA), PTEN, PTEN) Store (PTEN, PTSV) Store (0x01, \_SB.PCI0.SBRG.PWSW) Sleep (0x03E8) } Else { Store (0x01, SSMD) Store (0x00, IE0) Store (0x01, \_SB.PCI0.SBRG.PWSW) Sleep (0x03E8) Store (0x02, SSMD) Sleep (0xC8) Store (0x01, SSMD) Sleep (0x01F4) } } } Scope (DRV0) { Method (_STA, 0, NotSerialized) { If (PRNT) { Return (0x0F) } Else { Return (0x00) } } Method (_EJ0, 1, NotSerialized) { DP80 (0xE0) \_SB.PCI0.IDE1.CHN1.HPS3 () Store (\_SB.PCI0.IDE1.CHN1.SCDP (0x00), PRNT) } } } Method (HSHL, 0, NotSerialized) { If (SWAP) { If (PRNT) { DP80 (0xF0) Notify (\_SB.PCI0.IDE1.CHN1.DRV0, 0x03) } Else { DP80 (0xF1) \_SB.PCI0.IDE1.CHN1.HPS0 () Store (0x0A, Local0) While (Local0) { Sleep (0x03E8) Store (\_SB.PCI0.IDE1.CHN1.SCDP (0x00), PRNT) If (PRNT) { Notify (\_SB.PCI0.IDE1.CHN1.DRV0, 0x01) Return (Ones) } Else { Decrement (Local0) } } } } } } } Scope (\_SI) { OperationRegion (SIOR, SystemIO, 0x06C0, 0x1C) Field (SIOR, ByteAcc, NoLock, Preserve) { Offset (0x10), LDGY, 1, LDBL, 1 } Method (_SST, 1, NotSerialized) { If (LEqual (Arg0, 0x01)) { Store (0x01, LDGY) Store (0x01, LDBL) } If (LEqual (Arg0, 0x02)) { Store (0x01, LDGY) Store (0x00, LDBL) } If (LEqual (Arg0, 0x03)) {} If (LEqual (Arg0, 0x04)) { Store (0x00, LDGY) Store (0x01, LDBL) } } Method (_MSG, 1, NotSerialized) { Noop } } Scope (\_SB) { Scope (PCI0) { OperationRegion (SSMI, SystemIO, 0xB2, 0x02) Field (SSMI, ByteAcc, NoLock, Preserve) { IOB2, 8, IOB3, 8 } Method (_INI, 0, NotSerialized) { Store (0x00, PMEE) Store (0x00, MSEE) Store (0x00, KBDE) Store (0x00, RI1E) \_SB.PCI0.SBRG.IODT () If (CondRefOf (_OSI, Local0)) { Store (0x01, OSYS) } Else { Store (0x00, OSYS) } } Name (CRS, ResourceTemplate () { WordBusNumber (ResourceProducer, MinFixed, MaxFixed, PosDecode, 0x0000, 0x0000, 0x00FF, 0x0000, 0x0100) IO (Decode16, 0x0CF8, 0x0CF8, 0x01, 0x08) WordIO (ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange, 0x0000, 0x0000, 0x0CF7, 0x0000, 0x0CF8) WordIO (ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange, 0x0000, 0x0D00, 0xFFFF, 0x0000, 0xF300) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, 0x000A0000, 0x000BFFFF, 0x00000000, 0x00020000) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000) }) CreateDWordField (CRS, 0x5C, MIN5) CreateDWordField (CRS, 0x60, MAX5) CreateDWordField (CRS, 0x68, LEN5) CreateDWordField (CRS, 0x76, MIN6) CreateDWordField (CRS, 0x7A, MAX6) CreateDWordField (CRS, 0x82, LEN6) Method (_CRS, 0, NotSerialized) { Store (MG1B, MIN5) Store (MG1L, LEN5) Store (MG1L, Local0) If (Local0) { Add (MIN5, Decrement (Local0), MAX5) } Store (MG2B, MIN6) Store (MG2L, LEN6) Store (MG2L, Local0) Add (MIN6, Decrement (Local0), MAX6) Return (CRS) } } } If (SS1) { Name (\_SB.PCI0._S1D, 0x02) Name (\_SB.PCI0.PEGP._S1D, 0x02) Name (\_SB.PCI0.USB0._S1D, 0x02) Name (\_SB.PCI0.USB1._S1D, 0x02) Name (\_SB.PCI0.USB2._S1D, 0x02) Name (\_SB.PCI0.USB3._S1D, 0x02) Name (\_SB.PCI0.USB7._S1D, 0x02) Name (\_SB.PCI0.AC97._S1D, 0x02) } If (SS3) { Name (\_SB.PCI0._S3D, 0x02) Name (\_SB.PCI0.PEGP._S3D, 0x02) Name (\_SB.PCI0.USB0._S3D, 0x02) Name (\_SB.PCI0.USB1._S3D, 0x02) Name (\_SB.PCI0.USB2._S3D, 0x02) Name (\_SB.PCI0.USB3._S3D, 0x02) Name (\_SB.PCI0.USB7._S3D, 0x02) Name (\_SB.PCI0.AC97._S3D, 0x02) } If (SS4) { Name (\_SB.PCI0._S4D, 0x02) Name (\_SB.PCI0.PEGP._S4D, 0x02) Name (\_SB.PCI0.AC97._S4D, 0x02) } Method (_PTS, 1, NotSerialized) { Store (Arg0, DBG8) PTS (Arg0) Store (0x00, Index (WAKP, 0x00)) Store (0x00, Index (WAKP, 0x01)) } OperationRegion (RNTR, SystemIO, 0x06C0, 0x10) Field (RNTR, ByteAcc, NoLock, WriteAsZeros) { PMST, 1, Offset (0x01) } Field (RNTR, ByteAcc, NoLock, Preserve) { Offset (0x04), PMEE, 1, Offset (0x05) } Field (RNTR, ByteAcc, NoLock, WriteAsZeros) { Offset (0x0A), EVST, 8 } Field (RNTR, ByteAcc, NoLock, Preserve) { Offset (0x0E), , 2, RI1E, 1, KBDE, 1, MSEE, 1, Offset (0x0F) } OperationRegion (\_SB.PCI0.SBRG.PMC3, PCI_Config, 0xA4, 0x01) Field (\_SB.PCI0.SBRG.PMC3, ByteAcc, NoLock, Preserve) { AFG3, 1 } OperationRegion (SIOR, SystemIO, 0x06C0, 0x1C) Field (SIOR, ByteAcc, NoLock, Preserve) { Offset (0x10), LDGY, 1, LDBL, 1 } Method (\_SB.PCI0.SBRG.SIOS, 1, NotSerialized) { If (LOr (LEqual (Arg0, 0x01), LEqual (Arg0, 0x03))) { Store (0xFF, EVST) Store (0x01, KBDE) Store (0x01, MSEE) Store (0x01, PMST) Store (0x01, PMEE) } If (LEqual (SDID, 0x74)) { If (LLess (SREV, 0x01)) { Store (0x01, LDGY) Store (0x00, LDBL) } Else { Store (0x00, LDGY) Store (0x01, LDBL) } } Else { Store (0x00, LDGY) Store (0x01, LDBL) } If (LOr (LEqual (Arg0, 0x01), LEqual (Arg0, 0x03))) { ENFG () Store (SDID, Local0) If (LEqual (Local0, 0xF0)) { Store (LDMO, LDN) Store (0x00, ACTR) Store (LDKB, LDN) Store (0x00, ACTR) } Else { Store (0x06, LDN) Store (0x60, OPT0) } EXFG () } If (LEqual (Arg0, 0x05)) { If (LEqual (LAST, 0x02)) { Store (0x00, AFG3) } Else { Store (0x01, AFG3) } } } Name (SLID, 0x01) Method (_WAK, 1, NotSerialized) { ShiftLeft (Arg0, 0x04, DBG8) Store (0x01, SLID) WAK (Arg0) Store (0x01, SLPS) Store (0x01, SLPE) If (DerefOf (Index (WAKP, 0x00))) { Store (0x00, Index (WAKP, 0x01)) } Else { Store (Arg0, Index (WAKP, 0x01)) } Return (WAKP) } Method (\_SB.PCI0.SBRG.SIOW, 1, NotSerialized) { If (LOr (LEqual (Arg0, 0x01), LEqual (Arg0, 0x03))) { ENFG () Store (SDID, Local0) If (LEqual (Local0, 0xF0)) { Store (LDKB, LDN) Store (0x01, ACTR) Store (LDMO, LDN) Store (0x01, ACTR) } Else { Store (0x06, LDN) Store (0x00, OPT0) } EXFG () } Store (0x00, PMEE) Store (0x00, MSEE) Store (0x00, KBDE) Store (0x00, RI1E) } Method (\_SB.PCI0.SBRG.SIOH, 0, NotSerialized) { Noop } Method (\_SB.PCI0.SBRG.UAR1._PRW, 0, NotSerialized) { Return (Package (0x02) { 0x1D, 0x04 }) } Method (\_SB.PCI0.SBRG.UAR1._PSW, 1, NotSerialized) { Store (Arg0, RI1E) } OperationRegion (CBK2, SystemIO, 0x72, 0x02) Field (CBK2, ByteAcc, NoLock, Preserve) { IND, 8, DAT, 8 } IndexField (IND, DAT, ByteAcc, NoLock, Preserve) { Offset (0xB5), LAST, 2, Offset (0xD9), DRVI, 8, Offset (0xFE), , 6, OSYS, 1, PSWP, 1 } OperationRegion (SBIO, SystemIO, 0x0430, 0x08) Field (SBIO, ByteAcc, NoLock, Preserve) { SKIP, 4, SLPE, 1 } Field (SBIO, ByteAcc, NoLock, WriteAsZeros) { Offset (0x04), NONE, 4, SLPS, 1 } Scope (\_GPE) { Method (_L1D, 0, NotSerialized) { \_SB.PCI0.SBRG.SIOH () Notify (\_SB.PWRB, 0x02) } Method (_L1C, 0, NotSerialized) { If (\SWAP) { \_SB.PCI0.IDE1.HSHL () } } } Scope (\_GPE) { Method (_L0B, 0, NotSerialized) { Notify (\_SB.PCI0.P0P2, 0x02) Notify (\_SB.PWRB, 0x02) } Method (_L03, 0, NotSerialized) { Notify (\_SB.PCI0.USB0, 0x02) Notify (\_SB.PWRB, 0x02) } Method (_L04, 0, NotSerialized) { Notify (\_SB.PCI0.USB1, 0x02) Notify (\_SB.PWRB, 0x02) } Method (_L0C, 0, NotSerialized) { Notify (\_SB.PCI0.USB2, 0x02) Notify (\_SB.PWRB, 0x02) } Method (_L0E, 0, NotSerialized) { Notify (\_SB.PCI0.USB3, 0x02) Notify (\_SB.PWRB, 0x02) } Method (_L0D, 0, NotSerialized) { Notify (\_SB.PCI0.USB7, 0x02) Notify (\_SB.PWRB, 0x02) } } Device (\_SB.PWRB) { Name (_HID, EisaId ("PNP0C0C")) Name (_UID, 0xAA) Name (_STA, 0x0B) Method (_PRW, 0, NotSerialized) { Return (GPRW (0x1D, 0x05)) } } If (\ASFF) {} Scope (\_GPE) { Method (_L09, 0, NotSerialized) { If (\_SB.PCI0.PEX1.XPMH (0x00)) { Notify (\_SB.PCI0.PEX1, 0x02) } If (\_SB.PCI0.PEX2.XPMH (0x01)) { Notify (\_SB.PCI0.PEX2, 0x02) } If (\_SB.PCI0.PEX3.XPMH (0x02)) { Notify (\_SB.PCI0.PEX3, 0x02) } If (\_SB.PCI0.PEX4.XPMH (0x03)) { Notify (\_SB.PCI0.PEX4, 0x02) } If (\_SB.PCI0.PEGP.XPMH (0x08)) { Notify (\_SB.PCI0.PEGP, 0x02) } } } Scope (\_SB.PCI0) { Method (_OSC, 5, NotSerialized) { Store (Arg3, Local0) Multiply (Local0, 0x04, Local1) Name (BUF1, Buffer (Local1) {}) Store (Arg4, BUF1) Store (0x03, Local3) CreateDWordField (BUF1, 0x00, CAPB) If (LAnd (CAPB, 0x02)) { And (Local3, 0x0E, Local3) } If (LAnd (CAPB, 0x08)) { And (Local3, 0x0D, Local3) \_SB.PCI0.SBRG.GPMD (0x00) } \_SB.PCI0.PEX1.SCIC (0x00, Local3) \_SB.PCI0.PEX2.SCIC (0x01, Local3) \_SB.PCI0.PEX3.SCIC (0x02, Local3) \_SB.PCI0.PEX4.SCIC (0x03, Local3) \_SB.PCI0.PEGP.SCIC (0x08, Local3) Return (BUF1) } } Scope (\_SB.PCI0) { OperationRegion (SRCR, SystemMemory, 0xFED1C000, 0x4000) Field (SRCR, AnyAcc, NoLock, Preserve) { Offset (0x3418), CHPD, 1, PATD, 1, SATD, 1, SMBD, 1, AZLD, 1, A97D, 1, M97D, 1, ILND, 1, UH0D, 1, UH1D, 1, UH2D, 1, UH3D, 1, , 2, LPCD, 1, EHCD, 1, RP1D, 1, RP2D, 1, RP3D, 1, RP4D, 1, Offset (0x341C) } } Scope (\_SB.PCI0.PEX1) { } Scope (\_SB.PCI0.PEX2) { } Scope (\_SB.PCI0.PEX3) { } Scope (\_SB.PCI0.PEX4) { } Scope (\_SB.PCI0.SBRG) { OperationRegion (OP91, PCI_Config, 0xA0, 0x04) Field (OP91, AnyAcc, NoLock, Preserve) { , 10, XPME, 1 } Method (GPMD, 1, NotSerialized) { Store (Arg0, XPME) } } Scope (\_SB.PCI0.PEGP) { } Method (\_GPE._L05, 0, NotSerialized) { If (LAnd (\_SB.PCI0.AZLD, 0x01)) { Notify (\_SB.PCI0.AC97, 0x02) Notify (\_SB.PWRB, 0x02) } Else { Notify (\_SB.PCI0.AZAL, 0x02) } } Scope (\_SB.PCI0.SBRG) { Device (TPM) { Name (_HID, EisaId ("IFX0101")) Name (_UID, 0x01) Name (_CRS, ResourceTemplate () { IO (Decode16, 0x004E, 0x004E, 0x01, 0x02) IO (Decode16, 0x4700, 0x4700, 0x01, 0x0C) }) Method (_STA, 0, NotSerialized) { If (LEqual (\TPMF, 0x01)) { Return (0x0F) } Else { Return (0x00) } } } } Name (\_S0, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) If (SS1) { Name (\_S1, Package (0x04) { 0x01, 0x00, 0x00, 0x00 }) } If (SS3) { Name (\S3, Package (0x04) { 0x05, 0x00, 0x00, 0x00 }) } If (SS4) { Name (\_S4, Package (0x04) { 0x06, 0x00, 0x00, 0x00 }) } Name (\_S5, Package (0x04) { 0x07, 0x00, 0x00, 0x00 }) Method (PTS, 1, NotSerialized) { If (Arg0) { \_SB.PCI0.SBRG.SIOS (Arg0) } } Method (WAK, 1, NotSerialized) { \_SB.PCI0.SBRG.SIOW (Arg0) } }
bsam@ipt.ru
2005-Feb-24 06:17 UTC
acpi_bus_number: can't get _ADR issue on Intel D923XCV Motherboard.
Hi! On Thu, Feb 24, 2005 at 11:30:25AM +0100, Mateusz J?drasik wrote:> I have a D925XCV Intel motherboard, with if_sk on it as a builtin > ethernet adapter. on bootup of 5.3-RELEASE i recieve some > acpi_bus_number: can't get _ADR issues and errors /dmesg follows/.We have a couple of intel boards with the same diagnostic after installing 5.3-RELEASE. Hence, after upgrading to 5.3-STABLE all of them boot w/o errors. May be it's your case?> Cheers, > //Mateusz-- bsam
John Baldwin
2005-Feb-24 09:46 UTC
acpi_bus_number: can't get _ADR issue on Intel D923XCV Motherboard.
On Thursday 24 February 2005 05:30 am, Mateusz J?drasik wrote:> Hi, > > I have a D925XCV Intel motherboard, with if_sk on it as a builtin > ethernet adapter. on bootup of 5.3-RELEASE i recieve some > acpi_bus_number: can't get _ADR issues and errors /dmesg follows/. > > I tried changing pnp os on/off, updated my bios to the most recent > release, disabled all integrated devices but the ethernet, im pretty > much out of ideas now. > > If there is any suggestion on what i could perhaphs do, it would be more > than welcome, and I gladly would supply any debug information required > in the process of the eventual tracking down of the error. > > I will plug a pci card in there for now, but this is not quite the > solution i would be looking for. Also, I presume the audio card is not > supported yet? It's to be some realtek chipset, also integrated, afaik.Your network device just isn't supported yet: pcib3: <ACPI PCI-PCI bridge> at device 28.1 on pci0 pci4: <ACPI PCI bus> on pcib3 pci4: <network, ethernet> at device 0.0 (no driver attached) It may be very trivial to add support for it. Can you get the output of 'pciconf -lv' for the pci4:0:0 device? Also, do you know if this network adapter is supposed to be a 10/100 adapter or a 10/100/1000 (Gigabit)? -- John Baldwin <jhb@FreeBSD.org> <>< http://www.FreeBSD.org/~jhb/ "Power Users Use the Power to Serve" = http://www.FreeBSD.org