/* * Intel ACPI Component Architecture * AML/ASL+ Disassembler version 20180427 (64-bit version)(RM) * Copyright (c) 2000 - 2018 Intel Corporation * * Disassembling to non-symbolic legacy ASL operators * * Disassembly of DSDT.aml, Tue Aug 4 14:22:04 2020 * * Original Table Header: * Signature "DSDT" * Length 0x00013333 (78643) * Revision 0x02 * Checksum 0xB0 * OEM ID "LENOVO" * OEM Table ID "TP-N1G " * OEM Revision 0x00001510 (5392) * Compiler ID "INTL" * Compiler Version 0x20141107 (538185991) */ DefinitionBlock ("", "DSDT", 2, "LENOVO", "TP-N1G ", 0x00001510) { /* * iASL Warning: There were 11 external control methods found during * disassembly, but only 7 were resolved (4 unresolved). Additional * ACPI tables may be required to properly disassemble the code. This * resulting disassembler output file may not compile because the * disassembler did not know how many arguments to assign to the * unresolved methods. Note: SSDTs can be dynamically loaded at * runtime and may or may not be available via the host OS. * * In addition, the -fe option can be used to specify a file containing * control method external declarations with the associated method * argument counts. Each line of the file must be of the form: * External (, MethodObj, ) * Invocation: * iasl -fe refs.txt -d dsdt.aml * * The following methods were unresolved and many not compile properly * because the disassembler had to guess at the number of arguments * required for each: */ External (_PR_.CFGD, FieldUnitObj) External (_PR_.CLVL, FieldUnitObj) External (_PR_.ELNG, FieldUnitObj) External (_PR_.EMNA, FieldUnitObj) External (_PR_.EPCS, FieldUnitObj) External (_SB_.PCI0.CTCD, MethodObj) // 0 Arguments External (_SB_.PCI0.CTCN, MethodObj) // 0 Arguments External (_SB_.PCI0.CTCU, MethodObj) // 0 Arguments External (_SB_.PCI0.CTNL, FieldUnitObj) External (_SB_.PCI0.GFX0.AINT, MethodObj) // 2 Arguments External (_SB_.PCI0.GFX0.CLID, FieldUnitObj) External (_SB_.PCI0.GFX0.DD1F, UnknownObj) External (_SB_.PCI0.GFX0.DRDY, FieldUnitObj) External (_SB_.PCI0.GFX0.GSCI, MethodObj) // 0 Arguments External (_SB_.PCI0.GFX0.GSSE, FieldUnitObj) External (_SB_.PCI0.GFX0.VLOC, MethodObj) // 1 Arguments External (_SB_.PCI0.PTDP, FieldUnitObj) External (_SB_.PCI0.RP09.PEGP.NVST, MethodObj) // Warning: Unknown method, guessing 0 arguments External (_SB_.PCI0.SAT1.PRIM.GTME, UnknownObj) // Warning: Unknown object External (_SB_.PCI0.SAT1.PRT1, UnknownObj) External (_SB_.PCI0.SAT1.SCND.GTME, UnknownObj) // Warning: Unknown object External (_SB_.PCI0.SAT1.SCND.MSTR, UnknownObj) // Warning: Unknown object External (_SB_.PCI0.XHCI.PS0X, MethodObj) // Warning: Unknown method, guessing 0 arguments External (_SB_.PCI0.XHCI.PS3X, MethodObj) // Warning: Unknown method, guessing 0 arguments External (_SB_.PCI0.XHCI.URTH.INIR, MethodObj) // Warning: Unknown method, guessing 0 arguments External (_SB_.TPM_.PTS_, MethodObj) // 1 Arguments External (PDC0, IntObj) External (PDC1, IntObj) External (PDC2, IntObj) External (PDC3, IntObj) External (PDC4, IntObj) External (PDC5, IntObj) External (PDC6, IntObj) External (PDC7, IntObj) OperationRegion (PRTD, SystemIO, 0x1608, 0x04) Field (PRTD, DWordAcc, NoLock, Preserve) { P80H, 32 } Field (PRTD, ByteAcc, NoLock, Preserve) { P80P, 8 } Method (P8XH, 2, Serialized) { Name (P80B, Buffer (0x04){}) CreateDWordField (P80B, 0x00, P80D) If (LEqual (Arg0, 0x00)) { Store (Or (And (P80D, 0xFFFFFF00), Arg1), P80D) } If (LEqual (Arg0, 0x01)) { Store (Or (And (P80D, 0xFFFF00FF), ShiftLeft (Arg1, 0x08)), P80D) } If (LEqual (Arg0, 0x02)) { Store (Or (And (P80D, 0xFF00FFFF), ShiftLeft (Arg1, 0x10)), P80D) } If (LEqual (Arg0, 0x03)) { Store (Or (And (P80D, 0x00FFFFFF), ShiftLeft (Arg1, 0x18)), P80D) } Store (P80D, P80H) } Method (ADBG, 1, Serialized) { Return (0x00) } Scope (\_PR) { Processor (CPU0, 0x01, 0x00001810, 0x06){} Processor (CPU1, 0x02, 0x00001810, 0x06){} Processor (CPU2, 0x03, 0x00001810, 0x06){} Processor (CPU3, 0x04, 0x00001810, 0x06){} Processor (CPU4, 0x05, 0x00001810, 0x06){} Processor (CPU5, 0x06, 0x00001810, 0x06){} Processor (CPU6, 0x07, 0x00001810, 0x06){} Processor (CPU7, 0x08, 0x00001810, 0x06){} } Scope (\) { Method (PNTF, 1, NotSerialized) { If (And (\_PR.CFGD, 0x0200)) { If (LOr (LAnd (And (PDC0, 0x08), LOr (LEqual (Arg0, 0x80), LEqual (Arg0, 0x82))), LAnd (And (PDC0, 0x10), LEqual (Arg0, 0x81)))) { Notify (\_PR.CPU0, Arg0) } If (LOr (LAnd (And (PDC1, 0x08), LOr (LEqual (Arg0, 0x80), LEqual (Arg0, 0x82))), LAnd (And (PDC1, 0x10), LEqual (Arg0, 0x81)))) { Notify (\_PR.CPU1, Arg0) } If (LOr (LAnd (And (PDC2, 0x08), LOr (LEqual (Arg0, 0x80), LEqual (Arg0, 0x82))), LAnd (And (PDC2, 0x10), LEqual (Arg0, 0x81)))) { Notify (\_PR.CPU2, Arg0) } If (LOr (LAnd (And (PDC3, 0x08), LOr (LEqual (Arg0, 0x80), LEqual (Arg0, 0x82))), LAnd (And (PDC3, 0x10), LEqual (Arg0, 0x81)))) { Notify (\_PR.CPU3, Arg0) } If (LOr (LAnd (And (PDC4, 0x08), LOr (LEqual (Arg0, 0x80), LEqual (Arg0, 0x82))), LAnd (And (PDC4, 0x10), LEqual (Arg0, 0x81)))) { Notify (\_PR.CPU4, Arg0) } If (LOr (LAnd (And (PDC5, 0x08), LOr (LEqual (Arg0, 0x80), LEqual (Arg0, 0x82))), LAnd (And (PDC5, 0x10), LEqual (Arg0, 0x81)))) { Notify (\_PR.CPU5, Arg0) } If (LOr (LAnd (And (PDC6, 0x08), LOr (LEqual (Arg0, 0x80), LEqual (Arg0, 0x82))), LAnd (And (PDC6, 0x10), LEqual (Arg0, 0x81)))) { Notify (\_PR.CPU6, Arg0) } If (LOr (LAnd (And (PDC7, 0x08), LOr (LEqual (Arg0, 0x80), LEqual (Arg0, 0x82))), LAnd (And (PDC7, 0x10), LEqual (Arg0, 0x81)))) { Notify (\_PR.CPU7, Arg0) } } ElseIf (LOr (LEqual (Arg0, 0x80), LOr (LEqual (Arg0, 0x81), LEqual (Arg0, 0x82)))) { Notify (\_PR.CPU0, Arg0) } } } Scope (\_PR.CPU0) { Name (CPC1, Package (0x11) { 0x11, 0x01, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x00, // Bit Offset 0x0000000000000771, // Address 0x04, // Access Size ) }, 0x10, 0x00, 0x00, ResourceTemplate () { Register (SystemIO, 0x08, // Bit Width 0x00, // Bit Offset 0x0000000000001234, // Address 0x02, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x10, // Bit Offset 0x0000000000000774, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x00, // Bit Offset 0x0000000000000774, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x08, // Bit Offset 0x0000000000000774, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (SystemMemory, 0x00, // Bit Width 0x00, // Bit Offset 0x0000000000000000, // Address ,) }, ResourceTemplate () { Register (SystemMemory, 0x00, // Bit Width 0x00, // Bit Offset 0x0000000000000000, // Address ,) }, ResourceTemplate () { Register (SystemMemory, 0x00, // Bit Width 0x00, // Bit Offset 0x0000000000000000, // Address ,) }, ResourceTemplate () { Register (FFixedHW, 0x40, // Bit Width 0x00, // Bit Offset 0x00000000000000E7, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x40, // Bit Width 0x00, // Bit Offset 0x00000000000000E8, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x01, // Bit Width 0x01, // Bit Offset 0x0000000000000777, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x01, // Bit Width 0x00, // Bit Offset 0x0000000000000770, // Address 0x04, // Access Size ) } }) Name (CPC2, Package (0x15) { 0x15, 0x02, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x00, // Bit Offset 0x0000000000000771, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x08, // Bit Offset 0x00000000000000CE, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x10, // Bit Offset 0x0000000000000771, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x18, // Bit Offset 0x0000000000000771, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x08, // Bit Offset 0x0000000000000771, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x10, // Bit Offset 0x0000000000000774, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x00, // Bit Offset 0x0000000000000774, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x08, // Bit Offset 0x0000000000000774, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (SystemMemory, 0x00, // Bit Width 0x00, // Bit Offset 0x0000000000000000, // Address ,) }, ResourceTemplate () { Register (SystemMemory, 0x00, // Bit Width 0x00, // Bit Offset 0x0000000000000000, // Address ,) }, ResourceTemplate () { Register (SystemMemory, 0x00, // Bit Width 0x00, // Bit Offset 0x0000000000000000, // Address ,) }, ResourceTemplate () { Register (FFixedHW, 0x40, // Bit Width 0x00, // Bit Offset 0x00000000000000E7, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x40, // Bit Width 0x00, // Bit Offset 0x00000000000000E8, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x02, // Bit Width 0x01, // Bit Offset 0x0000000000000777, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x01, // Bit Width 0x00, // Bit Offset 0x0000000000000770, // Address 0x04, // Access Size ) }, 0x01, ResourceTemplate () { Register (FFixedHW, 0x0A, // Bit Width 0x20, // Bit Offset 0x0000000000000774, // Address 0x04, // Access Size ) }, ResourceTemplate () { Register (FFixedHW, 0x08, // Bit Width 0x18, // Bit Offset 0x0000000000000774, // Address 0x04, // Access Size ) }, 0x00 }) } OperationRegion (MNVS, SystemMemory, 0xCFFB5018, 0x1000) Field (MNVS, DWordAcc, NoLock, Preserve) { Offset (0xD00), GAPA, 32, GAPL, 32, DCKI, 32, DCKS, 32, VCDL, 1, VCDC, 1, VCDT, 1, VCDD, 1, , 1, VCSS, 1, VCDB, 1, VCIN, 1, VVPO, 8, BRTN, 8, BRLV, 8, CDFL, 8, CDAH, 8, PMOD, 2, PDIR, 1, PDMA, 1, Offset (0xD17), LFDC, 1, Offset (0xD18), C2NA, 1, C3NA, 1, C4NA, 1, C6NA, 1, C7NA, 1, Offset (0xD19), Offset (0xD1A), , 2, , 1, NHPS, 1, NPME, 1, Offset (0xD1B), UOPT, 8, BTID, 32, DPP0, 1, DPP1, 1, DPP2, 1, DPP3, 1, DPP4, 1, DPP5, 1, Offset (0xD21), Offset (0xD22), TCRT, 16, TPSV, 16, TTC1, 16, TTC2, 16, TTSP, 16, SRAH, 8, SRHE, 8, SRE1, 8, SRE2, 8, SRE3, 8, SRE4, 8, SRE5, 8, SRE6, 8, SRU1, 8, SRU2, 8, SRU3, 8, SRU7, 8, SRU4, 8, SRU5, 8, SRU8, 8, SRPB, 8, SRLP, 8, SRSA, 8, SRSM, 8, CWAC, 1, CWAS, 1, CWUE, 1, CWUS, 1, Offset (0xD40), CWAP, 16, CWAT, 16, DBGC, 1, Offset (0xD45), FS1L, 16, FS1M, 16, FS1H, 16, FS2L, 16, FS2M, 16, FS2H, 16, FS3L, 16, FS3M, 16, FS3H, 16, TATC, 1, , 6, TATL, 1, TATW, 8, TNFT, 4, TNTT, 4, TDFA, 4, TDTA, 4, TDFD, 4, TDTD, 4, TCFA, 4, TCTA, 4, TCFD, 4, TCTD, 4, TSFT, 4, TSTT, 4, TIT0, 8, TCR0, 16, TPS0, 16, TIT1, 8, TCR1, 16, TPS1, 16, TIT2, 8, TCR2, 16, TPS2, 16, TIF0, 8, TIF1, 8, TIF2, 8, Offset (0xD78), BTHI, 1, Offset (0xD79), HDIR, 1, HDEH, 1, HDSP, 1, HDPP, 1, HDUB, 1, HDMC, 1, NFCF, 1, Offset (0xD7A), TPME, 8, BIDE, 4, IDET, 4, , 1, , 1, Offset (0xD7D), DTS0, 8, Offset (0xD7F), DT00, 1, DT01, 1, DT02, 1, DT03, 1, Offset (0xD80), LIDB, 1, C4WR, 1, C4AC, 1, ODDX, 1, CMPR, 1, ILNF, 1, PLUX, 1, Offset (0xD81), Offset (0xD8B), WGON, 1, Offset (0xD8C), , 4, , 1, IDMM, 1, Offset (0xD8D), , 3, , 1, , 1, , 1, Offset (0xD8E), Offset (0xD8F), , 4, Offset (0xD90), Offset (0xD91), SWGP, 8, IPMS, 8, IPMB, 120, IPMR, 24, IPMO, 24, IPMA, 8, VIGD, 1, VDSC, 1, VMSH, 1, , 1, VDSP, 1, Offset (0xDAA), Offset (0xDAD), ASFT, 8, PL1L, 8, PL1M, 8, CHKC, 32, CHKE, 32, ATRB, 32, Offset (0xDBD), PPCR, 8, TPCR, 5, Offset (0xDBF), Offset (0xDCE), CTPR, 8, PPCA, 8, TPCA, 5, Offset (0xDD1), BFWB, 296, OSPX, 1, OSC4, 1, CPPX, 1, Offset (0xDF7), SPEN, 1, SCRM, 1, , 1, ETAU, 1, IHBC, 1, APMD, 1, APMF, 1, Offset (0xDF8), FTPS, 8, HIST, 8, LPST, 8, LWST, 8, Offset (0xDFF), PMMD, 8, Offset (0xE20), HPET, 32, PKLI, 16, VLCX, 16, VNIT, 8, VBD0, 8, VBDT, 128, VBPL, 16, VBPH, 16, VBML, 8, VBMH, 8, VEDI, 1024, PDCI, 16, ISCG, 32, ISSP, 1, ISWK, 2, ISFS, 3, Offset (0xEC7), SHA1, 160, LVMD, 8, LWCP, 1, LWEN, 1, IOCP, 1, IOEN, 1, IOST, 1, Offset (0xEDD), USBR, 1, Offset (0xEDE), Offset (0xEDF), Offset (0xEE1), BT2T, 1, Offset (0xEE2), TPPP, 8, TPPC, 8, CTPC, 8, FNWK, 8, Offset (0xEE7), XHCC, 8, FCAP, 16, VSTD, 1, VCQL, 1, VTIO, 1, VMYH, 1, VSTP, 1, VCQH, 1, VDCC, 1, VSFN, 1, VDMC, 1, Offset (0xEEC), CICF, 4, CICM, 4, MCAP, 16, PT1D, 15, Offset (0xEF1), PT2D, 15, Offset (0xEF3) } Field (MNVS, ByteAcc, NoLock, Preserve) { Offset (0xB00), WITM, 8, WSEL, 8, WLS0, 8, WLS1, 8, WLS2, 8, WLS3, 8, WLS4, 8, WLS5, 8, WLS6, 8, WLS7, 8, WLS8, 8, WLS9, 8, WLSA, 8, WLSB, 8, WLSC, 8, WLSD, 8, WENC, 8, WKBD, 8, WPTY, 8, WPAS, 1032, WPNW, 1032, WSPM, 8, WSPS, 8, WSMN, 8, WSMX, 8, WSEN, 8, WSKB, 8, WASB, 8, WASI, 16, WASD, 8, WASS, 32 } Field (MNVS, ByteAcc, NoLock, Preserve) { Offset (0xA00), DBGB, 1024 } OperationRegion (GNVS, SystemMemory, 0xCFFA3000, 0x0600) Field (GNVS, AnyAcc, Lock, Preserve) { OSYS, 16, SMIF, 8, PRM0, 8, PRM1, 8, SCIF, 8, PRM2, 8, PRM3, 8, LCKF, 8, PRM4, 8, PRM5, 8, P80D, 32, PWRS, 8, DBGS, 8, THOF, 8, ACT1, 8, ACTT, 8, PSVT, 8, TC1V, 8, TC2V, 8, TSPV, 8, CRTT, 8, DTSE, 8, DTS1, 8, DTS2, 8, DTSF, 8, Offset (0x1E), Offset (0x1F), Offset (0x20), Offset (0x21), Offset (0x22), Offset (0x23), Offset (0x24), Offset (0x25), REVN, 8, APIC, 8, TCNT, 8, PCP0, 8, PCP1, 8, PPCM, 8, PPMF, 32, C67L, 8, NATP, 8, CMAP, 8, CMBP, 8, LPTP, 8, FDCP, 8, CMCP, 8, CIRP, 8, SMSC, 8, W381, 8, SMC1, 8, EMAE, 8, EMAP, 16, EMAL, 16, MEFE, 8, DSTS, 8, MORD, 8, TCGP, 8, PPRP, 32, PPRQ, 8, LPPR, 8, IDEM, 8, BID, 16, PLID, 8, BTYP, 8, OSCC, 8, NEXP, 8, SBV1, 8, SBV2, 8, ECON, 8, DSEN, 8, GPIC, 8, CTYP, 8, L01C, 8, VFN0, 8, VFN1, 8, VFN2, 8, VFN3, 8, VFN4, 8, VFN5, 8, VFN6, 8, VFN7, 8, VFN8, 8, VFN9, 8, ATMC, 8, PTMC, 8, PNHM, 32, TBAL, 32, TBAH, 32, RTIP, 8, TSOD, 8, PFLV, 8, BREV, 8, BBID, 8, PDTS, 8, PKGA, 8, PAMT, 8, AC0F, 8, AC1F, 8, DTS3, 8, DTS4, 8, LTR1, 8, LTR2, 8, LTR3, 8, LTR4, 8, LTR5, 8, LTR6, 8, LTR7, 8, LTR8, 8, LTR9, 8, LTRA, 8, LTRB, 8, LTRC, 8, LTRD, 8, LTRE, 8, LTRF, 8, LTRG, 8, LTRH, 8, LTRI, 8, LTRJ, 8, LTRK, 8, OBF1, 8, OBF2, 8, OBF3, 8, OBF4, 8, OBF5, 8, OBF6, 8, OBF7, 8, OBF8, 8, OBF9, 8, OBFA, 8, OBFB, 8, OBFC, 8, OBFD, 8, OBFE, 8, OBFF, 8, OBFG, 8, OBFH, 8, OBFI, 8, OBFJ, 8, OBFK, 8, XTUB, 32, XTUS, 32, XMPB, 32, DDRF, 8, RTD3, 8, PEP0, 8, PEP3, 8, DPTF, 8, SADE, 8, SACR, 8, SAHT, 8, CTDP, 8, LPMP, 8, LPMV, 8, ECEU, 8, TGFG, 16, MEMD, 8, ATRA, 8, PTRA, 8, MEMC, 8, MEMH, 8, FND1, 8, FND2, 8, AMBD, 8, AMAT, 8, AMPT, 8, AMCT, 8, AMHT, 8, SKDE, 8, SKAT, 8, SKPT, 8, SKCT, 8, SKHT, 8, EFDE, 8, EFAT, 8, EFPT, 8, EFCT, 8, EFHT, 8, VRDE, 8, VRAT, 8, VRPT, 8, VRCT, 8, VRHT, 8, DPAP, 8, DPPP, 8, DPCP, 8, DCMP, 8, TRTV, 8, LPOE, 8, LPOP, 8, LPOS, 8, LPOW, 8, LPER, 8, PPSZ, 32, DISE, 8, BGMA, 64, BGMS, 8, BGIA, 16, IRMC, 8, NFCE, 8, CHEN, 8, S0ID, 8, CTDB, 8, DKSM, 8, SIO1, 16, SIO2, 16, SPBA, 16, SEC0, 32, SEC1, 32, SEC2, 32, SEC3, 32, SEC4, 32, SEC5, 32, SEC6, 32, SEC7, 32, SEC8, 32, Offset (0x1F4), WIFD, 8, WFAT, 8, WFPT, 8, WFCT, 8, WFHT, 8, PWRE, 8, PWRP, 8, Offset (0x203), XHPR, 8, RIC0, 8, DVS0, 8, DVS1, 8, DVS2, 8, DVS3, 8, GBSX, 8, IUBE, 8, IUCE, 8, IUDE, 8, ECNO, 8, AUDD, 16, IC0D, 16, IC1D, 16, IC1S, 16, VRRD, 16, PSCP, 8, I20D, 16, I21D, 16, RCG0, 16, ECDB, 8, P2ME, 8, SSH0, 16, SSL0, 16, SSD0, 16, FMH0, 16, FML0, 16, FMD0, 16, FPH0, 16, FPL0, 16, FPD0, 16, SSH1, 16, SSL1, 16, SSD1, 16, FMH1, 16, FML1, 16, FMD1, 16, FPH1, 16, FPL1, 16, FPD1, 16, M0C0, 16, M1C0, 16, M2C0, 16, M0C1, 16, M1C1, 16, M2C1, 16, M0C2, 16, M1C2, 16, M0C3, 16, M1C3, 16, M0C4, 16, M1C4, 16, M0C5, 16, M1C5, 16, TBSF, 8, GIRQ, 32, DMTP, 8, DMTD, 8, DMSH, 8, LANP, 8, SHSB, 8, PLCS, 8, PLVL, 16, GN1E, 8, G1AT, 8, G1PT, 8, G1CT, 8, G1HT, 8, GN2E, 8, G2AT, 8, G2PT, 8, G2CT, 8, G2HT, 8, WWSD, 8, CVSD, 8, SSDD, 8, INLD, 8, IFAT, 8, IFPT, 8, IFCT, 8, IFHT, 8, SDWE, 8, USBH, 8, BCV4, 8, WTV0, 8, WTV1, 8, APFU, 8, SOHP, 8, GP5F, 8, NOHP, 8, TBSE, 8, WKFN, 8, PEPC, 32, VRSD, 16, PB1E, 8, GNID, 8, WAND, 8, WWAT, 8, WWPT, 8, WWCT, 8, WWHT, 8, Offset (0x2A3), MPL0, 16, CHGE, 8, SAC3, 8, MEM3, 8, AMC3, 8, SKC3, 8, EFC3, 8, VRC3, 8, WFC3, 8, G1C3, 8, G2C3, 8, IFC3, 8, WWC3, 8, WGC3, 8, SPST, 8, PERE, 8, Offset (0x2B7), GN3E, 8, G3AT, 8, G3PT, 8, G3CT, 8, G3HT, 8, GN4E, 8, G4AT, 8, G4PT, 8, G4CT, 8, G4HT, 8, GN5E, 8, G5AT, 8, G5PT, 8, G5CT, 8, G5HT, 8, GN6E, 8, G6AT, 8, G6PT, 8, G6CT, 8, G6HT, 8, ECLP, 8, G3C3, 8, G4C3, 8, G5C3, 8, G6C3, 8, TSP1, 8, TSP2, 8, TSP3, 8, TSP4, 8, TSP5, 8, TSP6, 8, TSP7, 8, TSP8, 8, SSP1, 8, SSP2, 8, SSP3, 8, SSP4, 8, SSP5, 8, SSP6, 8, SSP7, 8, SSP8, 8, MEMS, 8, Offset (0x2F8), S1DE, 8, S1AT, 8, S1PT, 8, S1CT, 8, S1HT, 8, S2DE, 8, S2AT, 8, S2PT, 8, S2CT, 8, S2HT, 8, S3DE, 8, S3AT, 8, S3PT, 8, S3CT, 8, S3HT, 8, S4DE, 8, S4AT, 8, S4PT, 8, S4CT, 8, S4HT, 8, S5DE, 8, S5AT, 8, S5PT, 8, S5CT, 8, S5HT, 8, S6DE, 8, S6AT, 8, S6PT, 8, S6CT, 8, S6HT, 8, S7DE, 8, S7AT, 8, S7PT, 8, S7CT, 8, S7HT, 8, S1S3, 8, S2S3, 8, S3S3, 8, S4S3, 8, S5S3, 8, S6S3, 8, S7S3, 8, PSME, 8, PDT1, 8, PLM1, 16, PTW1, 16, PDT2, 8, PLM2, 16, PTW2, 16, DDT1, 8, DDP1, 8, DLI1, 16, DPL1, 16, DTW1, 16, DMI1, 16, DMA1, 16, DMT1, 16, DDT2, 8, DDP2, 8, DLI2, 16, DPL2, 16, DTW2, 16, DMI2, 16, DMA2, 16, DMT2, 16, WIFE, 8, DOM1, 8, LIM1, 16, TIM1, 16, DOM2, 8, LIM2, 16, TIM2, 16, DOM3, 8, LIM3, 16, TIM3, 16, TRD0, 8, TRL0, 8, TRD1, 8, TRL1, 8, WDM1, 8, CID1, 16, WDM2, 8, CID2, 16, Offset (0x364), APPE, 8, MPL1, 16, MPL2, 16, SDS0, 8, SDS1, 8, SDS2, 8, SDS3, 8, SDS4, 8, SDS5, 8, SDS6, 8, SDS7, 8, SDS8, 8, SDS9, 8, SDSA, 8, TPLB, 8, TPLH, 16, WTVX, 8, WITX, 8, GPTD, 8, GDBT, 16, UTKX, 8, SPTD, 8, GEXN, 8, TBTS, 8, AICS, 8, TARS, 8, FPAT, 8, FPEN, 8, FPGN, 32, FPLV, 8, CPAD, 16, CPAB, 8, TNAT, 8, CPGN, 32, CF2T, 8, ATLB, 32, SDM0, 8, SDM1, 8, SDM2, 8, SDM3, 8, SDM4, 8, SDM5, 8, SDM6, 8, SDM7, 8, SDM8, 8, SDM9, 8, SDMA, 8, USTP, 8, SSHI, 16, SSLI, 16, SSDI, 16, FMHI, 16, FMLI, 16, FMDI, 16, FPHI, 16, FPLI, 16, FPDI, 16, M0CI, 16, M1CI, 16, M0CS, 16, M1CS, 16, M0CU, 16, M1CU, 16, CAMT, 8, DS4D, 16, IVDF, 8, EIDF, 8, GFPS, 32, GFPI, 32, GNSM, 8, GNSC, 8, GGNR, 32, GBTW, 32, GBTK, 32, GBTI, 32, GPDI, 32, GPLI, 32, CL00, 8, CL01, 8, CL02, 8, CL03, 8, L0EN, 8, L1EN, 8, L2EN, 8, L3EN, 8, CDIV, 8, C0TP, 8, C0CV, 8, C0GP, 8, C0IB, 8, C0IA, 16, C0P0, 8, C0P1, 8, C0P2, 8, C0P3, 8, C0G0, 8, C0G1, 8, C0G2, 8, C0G3, 8, C0F0, 8, C0F1, 8, C0F2, 8, C0F3, 8, C0A0, 8, C0A1, 8, C0A2, 8, C0A3, 8, C0I0, 8, C0I1, 8, C0I2, 8, C0I3, 8, C0PL, 8, C1TP, 8, C1CV, 8, C1GP, 8, C1IB, 8, C1IA, 16, C1P0, 8, C1P1, 8, C1P2, 8, C1P3, 8, C1G0, 8, C1G1, 8, C1G2, 8, C1G3, 8, C1F0, 8, C1F1, 8, C1F2, 8, C1F3, 8, C1A0, 8, C1A1, 8, C1A2, 8, C1A3, 8, C1I0, 8, C1I1, 8, C1I2, 8, C1I3, 8, C1PL, 8, C2TP, 8, C2CV, 8, C2GP, 8, C2IB, 8, C2IA, 16, C2P0, 8, C2P1, 8, C2P2, 8, C2P3, 8, C2G0, 8, C2G1, 8, C2G2, 8, C2G3, 8, C2F0, 8, C2F1, 8, C2F2, 8, C2F3, 8, C2A0, 8, C2A1, 8, C2A2, 8, C2A3, 8, C2I0, 8, C2I1, 8, C2I2, 8, C2I3, 8, C2PL, 8, C3TP, 8, C3CV, 8, C3GP, 8, C3IB, 8, C3IA, 16, C3P0, 8, C3P1, 8, C3P2, 8, C3P3, 8, C3G0, 8, C3G1, 8, C3G2, 8, C3G3, 8, C3F0, 8, C3F1, 8, C3F2, 8, C3F3, 8, C3A0, 8, C3A1, 8, C3A2, 8, C3A3, 8, C3I0, 8, C3I1, 8, C3I2, 8, C3I3, 8, C3PL, 8, L0SM, 8, L0H0, 8, L0H1, 8, L0H2, 8, L0H3, 8, L0H4, 8, L0H5, 8, L0H6, 8, L0H7, 8, L0H8, 8, L0PL, 8, L0M0, 8, L0M1, 8, L0M2, 8, L0M3, 8, L0M4, 8, L0M5, 8, L0M6, 8, L0M7, 8, L0M8, 8, L0M9, 8, L0MA, 8, L0MB, 8, L0MC, 8, L0MD, 8, L0ME, 8, L0MF, 8, L0DI, 8, L0BS, 8, L0A0, 16, L0A1, 16, L0A2, 16, L0A3, 16, L0A4, 16, L0A5, 16, L0A6, 16, L0A7, 16, L0A8, 16, L0A9, 16, L0AA, 16, L0AB, 16, L0D0, 8, L0D1, 8, L0D2, 8, L0D3, 8, L0D4, 8, L0D5, 8, L0D6, 8, L0D7, 8, L0D8, 8, L0D9, 8, L0DA, 8, L0DB, 8, L0DV, 8, L0CV, 8, L0LU, 8, L0NL, 8, L0EE, 8, L0VC, 8, L0FS, 8, L0DG, 8, L0C0, 8, L0C1, 8, L0C2, 8, L0C3, 8, L0CK, 32, L0CL, 8, L1SM, 8, L1H0, 8, L1H1, 8, L1H2, 8, L1H3, 8, L1H4, 8, L1H5, 8, L1H6, 8, L1H7, 8, L1H8, 8, L1PL, 8, L1M0, 8, L1M1, 8, L1M2, 8, L1M3, 8, L1M4, 8, L1M5, 8, L1M6, 8, L1M7, 8, L1M8, 8, L1M9, 8, L1MA, 8, L1MB, 8, L1MC, 8, L1MD, 8, L1ME, 8, L1MF, 8, L1DI, 8, L1BS, 8, L1A0, 16, L1A1, 16, L1A2, 16, L1A3, 16, L1A4, 16, L1A5, 16, L1A6, 16, L1A7, 16, L1A8, 16, L1A9, 16, L1AA, 16, L1AB, 16, L1D0, 8, L1D1, 8, L1D2, 8, L1D3, 8, L1D4, 8, L1D5, 8, L1D6, 8, L1D7, 8, L1D8, 8, L1D9, 8, L1DA, 8, L1DB, 8, L1DV, 8, L1CV, 8, L1LU, 8, L1NL, 8, L1EE, 8, L1VC, 8, L1FS, 8, L1DG, 8, L1C0, 8, L1C1, 8, L1C2, 8, L1C3, 8, L1CK, 32, L1CL, 8, L2SM, 8, L2H0, 8, L2H1, 8, L2H2, 8, L2H3, 8, L2H4, 8, L2H5, 8, L2H6, 8, L2H7, 8, L2H8, 8, L2PL, 8, L2M0, 8, L2M1, 8, L2M2, 8, L2M3, 8, L2M4, 8, L2M5, 8, L2M6, 8, L2M7, 8, L2M8, 8, L2M9, 8, L2MA, 8, L2MB, 8, L2MC, 8, L2MD, 8, L2ME, 8, L2MF, 8, L2DI, 8, L2BS, 8, L2A0, 16, L2A1, 16, L2A2, 16, L2A3, 16, L2A4, 16, L2A5, 16, L2A6, 16, L2A7, 16, L2A8, 16, L2A9, 16, L2AA, 16, L2AB, 16, L2D0, 8, L2D1, 8, L2D2, 8, L2D3, 8, L2D4, 8, L2D5, 8, L2D6, 8, L2D7, 8, L2D8, 8, L2D9, 8, L2DA, 8, L2DB, 8, L2DV, 8, L2CV, 8, L2LU, 8, L2NL, 8, L2EE, 8, L2VC, 8, L2FS, 8, L2DG, 8, L2C0, 8, L2C1, 8, L2C2, 8, L2C3, 8, L2CK, 32, L2CL, 8, L3SM, 8, L3H0, 8, L3H1, 8, L3H2, 8, L3H3, 8, L3H4, 8, L3H5, 8, L3H6, 8, L3H7, 8, L3H8, 8, L3PL, 8, L3M0, 8, L3M1, 8, L3M2, 8, L3M3, 8, L3M4, 8, L3M5, 8, L3M6, 8, L3M7, 8, L3M8, 8, L3M9, 8, L3MA, 8, L3MB, 8, L3MC, 8, L3MD, 8, L3ME, 8, L3MF, 8, L3DI, 8, L3BS, 8, L3A0, 16, L3A1, 16, L3A2, 16, L3A3, 16, L3A4, 16, L3A5, 16, L3A6, 16, L3A7, 16, L3A8, 16, L3A9, 16, L3AA, 16, L3AB, 16, L3D0, 8, L3D1, 8, L3D2, 8, L3D3, 8, L3D4, 8, L3D5, 8, L3D6, 8, L3D7, 8, L3D8, 8, L3D9, 8, L3DA, 8, L3DB, 8, L3DV, 8, L3CV, 8, L3LU, 8, L3NL, 8, L3EE, 8, L3VC, 8, L3FS, 8, L3DG, 8, L3C0, 8, L3C1, 8, L3C2, 8, L3C3, 8, L3CK, 32, L3CL, 8, ECR1, 8, Offset (0x5AA), I2SC, 8, ODV0, 8, ODV1, 8, ODV2, 8, ODV3, 8, ODV4, 8, ODV5, 8, UBCB, 32, EMOD, 8, WIFC, 8, Offset (0x5BE), TPLS, 8, TPDB, 8, TPDH, 16, TPDS, 8, AG1L, 64, AG1H, 64, AG2L, 64, AG2H, 64, AG3L, 64, AG3H, 64, HEFE, 8, XDCE, 8, STXE, 8, STX0, 8, STX1, 8, STX2, 8, STX3, 8, STX4, 8, STX5, 8, STX6, 8, STX7, 8, STX8, 8, STX9, 8 } Scope (\_SB) { Method (_INI, 0, NotSerialized) // _INI: Initialize { If (CondRefOf (\_OSI, Local0)) { If (\_OSI ("Windows 2001")) { Store (0x01, \WNTF) Store (0x01, \WXPF) Store (0x00, \WSPV) Store (0x07D1, OSYS) } If (\_OSI ("Windows 2001 SP1")) { Store (0x01, \WSPV) Store (0x07D1, OSYS) } If (\_OSI ("Windows 2001 SP2")) { Store (0x02, \WSPV) Store (0x07D2, OSYS) } If (\_OSI ("Windows 2006")) { Store (0x01, \WVIS) Store (0x07D6, OSYS) } If (\_OSI ("Windows 2009")) { Store (0x01, \WIN7) Store (0x07D9, OSYS) } If (\_OSI ("Windows 2012")) { Store (0x01, \WIN8) Store (0x07DC, OSYS) } If (\_OSI ("Windows 2013")) { Store (0x01, \WIN8) Store (0x07DD, OSYS) } If (\_OSI ("Windows 2015")) { Store (0x01, \WIN8) Store (0x07DF, OSYS) } If (\_OSI ("Linux")) { Store (0x01, \LNUX) Store (0x03E8, OSYS) } If (\_OSI ("FreeBSD")) { Store (0x01, \LNUX) Store (0x03E8, OSYS) } } ElseIf (LEqual (\SCMP (\_OS, "Microsoft Windows NT"), Zero)) { Store (0x01, \WNTF) } If (LGreaterEqual (\_REV, 0x02)) { Store (0x01, \H8DR) } Store (0x01, \OSIF) Store (\_SB.PCI0.LPC.EC.AC._PSR (), \PWRS) \_SB.PCI0.LPC.MOU.MHID () If (\LNUX) { \_SB.PCI0.LPC.EC.SAUM (0x02) \UCMS (0x1C) } Store (\SRAH, \_SB.PCI0.RID) If (VIGD) { Store (\SRHE, \_SB.PCI0.GFX0.RID) } Else { Store (\SRHE, \_SB.PCI0.PEG0.RID) } Store (\SRE1, \_SB.PCI0.EXP1.RID) Store (\SRE2, \_SB.PCI0.EXP2.RID) Store (\SRE3, \_SB.PCI0.EXP3.RID) Store (\SRE4, \_SB.PCI0.EXP5.RID) Store (\SRE4, \_SB.PCI0.RP09.RID) Store (\SRLP, \_SB.PCI0.LPC.RID) Store (\SRSA, \_SB.PCI0.SAT1.RID) Store (\SRSM, \_SB.PCI0.SMBU.RID) Store (\_SB.PCI0.LPC.EC.CMMD, \PMMD) If (LGreaterEqual (\PMMD, 0x07)) { Store (0x00, \PMMD) } Store (\_SB.PCI0.LPC.EC.CMMD, \LVMD) If (LOr (LEqual (\LVMD, 0x00), LGreaterEqual (\LVMD, 0x07))) { Store (0x01, \LVMD) } ElseIf (LOr (LEqual (\LVMD, 0x02), LEqual (\LVMD, 0x03))) { Store (0x02, \LVMD) } Else { Store (0x03, \LVMD) } } Name (OSCP, 0x00) Method (_OSC, 4, Serialized) // _OSC: Operating System Capabilities { CreateDWordField (Arg3, 0x00, STS0) CreateDWordField (Arg3, 0x04, CAP0) If (LEqual (Arg0, ToUUID ("0811b06e-4a27-44f9-8d60-3cbbc22e7b48") /* Platform-wide Capabilities */)) { If (LEqual (Arg1, One)) { Store (CAP0, OSCP) If (And (CAP0, 0x04)) { If (LNot (VMSH)) { If (LEqual (RTD3, 0x00)) { And (CAP0, 0xFB, CAP0) Or (STS0, 0x10, STS0) } } } If (And (CAP0, 0x20)) { Store (0x01, \CPPX) } Else { And (CAP0, 0x9F, CAP0) Or (STS0, 0x10, STS0) } } Else { And (STS0, 0xFFFFFF00, STS0) Or (STS0, 0x0A, STS0) } } Else { And (STS0, 0xFFFFFF00, STS0) Or (STS0, 0x06, STS0) } Return (Arg3) } Device (LNKA) { Name (_HID, EisaId ("PNP0C0F")) // _HID: Hardware ID Name (_UID, 0x01) // _UID: Unique ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LNot (VPIR (\_SB.PCI0.LPC.PIRA))) { Return (0x09) } Else { Return (0x0B) } } Name (_PRS, ResourceTemplate () // _PRS: Possible Resource Settings { IRQ (Level, ActiveLow, Shared, ) {3,4,5,6,7,9,10,11} }) Method (_DIS, 0, NotSerialized) // _DIS: Disable Device { Or (\_SB.PCI0.LPC.PIRA, 0x80, \_SB.PCI0.LPC.PIRA) } Name (BUFA, ResourceTemplate () { IRQ (Level, ActiveLow, Shared, _Y00) {} }) CreateWordField (BUFA, \_SB.LNKA._Y00._INT, IRA1) // _INT: Interrupts Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.LPC.PIRA, 0x8F, Local0) If (VPIR (Local0)) { ShiftLeft (0x01, Local0, IRA1) } Else { Store (0x00, IRA1) } Return (BUFA) } Method (_SRS, 1, NotSerialized) // _SRS: Set Resource Settings { CreateWordField (Arg0, 0x01, IRA2) FindSetRightBit (IRA2, Local0) And (\_SB.PCI0.LPC.PIRA, 0x70, Local1) Or (Local1, Decrement (Local0), Local1) Store (Local1, \_SB.PCI0.LPC.PIRA) } } Device (LNKB) { Name (_HID, EisaId ("PNP0C0F")) // _HID: Hardware ID Name (_UID, 0x02) // _UID: Unique ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LNot (VPIR (\_SB.PCI0.LPC.PIRB))) { Return (0x09) } Else { Return (0x0B) } } Name (_PRS, ResourceTemplate () // _PRS: Possible Resource Settings { IRQ (Level, ActiveLow, Shared, ) {3,4,5,6,7,9,10,11} }) Method (_DIS, 0, NotSerialized) // _DIS: Disable Device { Or (\_SB.PCI0.LPC.PIRB, 0x80, \_SB.PCI0.LPC.PIRB) } Name (BUFB, ResourceTemplate () { IRQ (Level, ActiveLow, Shared, _Y01) {} }) CreateWordField (BUFB, \_SB.LNKB._Y01._INT, IRB1) // _INT: Interrupts Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.LPC.PIRB, 0x8F, Local0) If (VPIR (Local0)) { ShiftLeft (0x01, Local0, IRB1) } Else { Store (0x00, IRB1) } Return (BUFB) } Method (_SRS, 1, NotSerialized) // _SRS: Set Resource Settings { CreateWordField (Arg0, 0x01, IRB2) FindSetRightBit (IRB2, Local0) And (\_SB.PCI0.LPC.PIRB, 0x70, Local1) Or (Local1, Decrement (Local0), Local1) Store (Local1, \_SB.PCI0.LPC.PIRB) } } Device (LNKC) { Name (_HID, EisaId ("PNP0C0F")) // _HID: Hardware ID Name (_UID, 0x03) // _UID: Unique ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LNot (VPIR (\_SB.PCI0.LPC.PIRC))) { Return (0x09) } Else { Return (0x0B) } } Name (_PRS, ResourceTemplate () // _PRS: Possible Resource Settings { IRQ (Level, ActiveLow, Shared, ) {3,4,5,6,7,9,10,11} }) Method (_DIS, 0, NotSerialized) // _DIS: Disable Device { Or (\_SB.PCI0.LPC.PIRC, 0x80, \_SB.PCI0.LPC.PIRC) } Name (BUFC, ResourceTemplate () { IRQ (Level, ActiveLow, Shared, _Y02) {} }) CreateWordField (BUFC, \_SB.LNKC._Y02._INT, IRC1) // _INT: Interrupts Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.LPC.PIRC, 0x8F, Local0) If (VPIR (Local0)) { ShiftLeft (0x01, Local0, IRC1) } Else { Store (0x00, IRC1) } Return (BUFC) } Method (_SRS, 1, NotSerialized) // _SRS: Set Resource Settings { CreateWordField (Arg0, 0x01, IRC2) FindSetRightBit (IRC2, Local0) And (\_SB.PCI0.LPC.PIRC, 0x70, Local1) Or (Local1, Decrement (Local0), Local1) Store (Local1, \_SB.PCI0.LPC.PIRC) } } Device (LNKD) { Name (_HID, EisaId ("PNP0C0F")) // _HID: Hardware ID Name (_UID, 0x04) // _UID: Unique ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LNot (VPIR (\_SB.PCI0.LPC.PIRD))) { Return (0x09) } Else { Return (0x0B) } } Name (_PRS, ResourceTemplate () // _PRS: Possible Resource Settings { IRQ (Level, ActiveLow, Shared, ) {3,4,5,6,7,9,10,11} }) Method (_DIS, 0, NotSerialized) // _DIS: Disable Device { Or (\_SB.PCI0.LPC.PIRD, 0x80, \_SB.PCI0.LPC.PIRD) } Name (BUFD, ResourceTemplate () { IRQ (Level, ActiveLow, Shared, _Y03) {} }) CreateWordField (BUFD, \_SB.LNKD._Y03._INT, IRD1) // _INT: Interrupts Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.LPC.PIRD, 0x8F, Local0) If (VPIR (Local0)) { ShiftLeft (0x01, Local0, IRD1) } Else { Store (0x00, IRD1) } Return (BUFD) } Method (_SRS, 1, NotSerialized) // _SRS: Set Resource Settings { CreateWordField (Arg0, 0x01, IRD2) FindSetRightBit (IRD2, Local0) And (\_SB.PCI0.LPC.PIRD, 0x70, Local1) Or (Local1, Decrement (Local0), Local1) Store (Local1, \_SB.PCI0.LPC.PIRD) } } Device (LNKE) { Name (_HID, EisaId ("PNP0C0F")) // _HID: Hardware ID Name (_UID, 0x05) // _UID: Unique ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LNot (VPIR (\_SB.PCI0.LPC.PIRE))) { Return (0x09) } Else { Return (0x0B) } } Name (_PRS, ResourceTemplate () // _PRS: Possible Resource Settings { IRQ (Level, ActiveLow, Shared, ) {3,4,5,6,7,9,10,11} }) Method (_DIS, 0, NotSerialized) // _DIS: Disable Device { Or (\_SB.PCI0.LPC.PIRE, 0x80, \_SB.PCI0.LPC.PIRE) } Name (BUFE, ResourceTemplate () { IRQ (Level, ActiveLow, Shared, _Y04) {} }) CreateWordField (BUFE, \_SB.LNKE._Y04._INT, IRE1) // _INT: Interrupts Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.LPC.PIRE, 0x8F, Local0) If (VPIR (Local0)) { ShiftLeft (0x01, Local0, IRE1) } Else { Store (0x00, IRE1) } Return (BUFE) } Method (_SRS, 1, NotSerialized) // _SRS: Set Resource Settings { CreateWordField (Arg0, 0x01, IRE2) FindSetRightBit (IRE2, Local0) And (\_SB.PCI0.LPC.PIRE, 0x70, Local1) Or (Local1, Decrement (Local0), Local1) Store (Local1, \_SB.PCI0.LPC.PIRE) } } Device (LNKF) { Name (_HID, EisaId ("PNP0C0F")) // _HID: Hardware ID Name (_UID, 0x06) // _UID: Unique ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LNot (VPIR (\_SB.PCI0.LPC.PIRF))) { Return (0x09) } Else { Return (0x0B) } } Name (_PRS, ResourceTemplate () // _PRS: Possible Resource Settings { IRQ (Level, ActiveLow, Shared, ) {3,4,5,6,7,9,10,11} }) Method (_DIS, 0, NotSerialized) // _DIS: Disable Device { Or (\_SB.PCI0.LPC.PIRF, 0x80, \_SB.PCI0.LPC.PIRF) } Name (BUFF, ResourceTemplate () { IRQ (Level, ActiveLow, Shared, _Y05) {} }) CreateWordField (BUFF, \_SB.LNKF._Y05._INT, IRF1) // _INT: Interrupts Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.LPC.PIRF, 0x8F, Local0) If (VPIR (Local0)) { ShiftLeft (0x01, Local0, IRF1) } Else { Store (0x00, IRF1) } Return (BUFF) } Method (_SRS, 1, NotSerialized) // _SRS: Set Resource Settings { CreateWordField (Arg0, 0x01, IRF2) FindSetRightBit (IRF2, Local0) And (\_SB.PCI0.LPC.PIRF, 0x70, Local1) Or (Local1, Decrement (Local0), Local1) Store (Local1, \_SB.PCI0.LPC.PIRF) } } Device (LNKG) { Name (_HID, EisaId ("PNP0C0F")) // _HID: Hardware ID Name (_UID, 0x07) // _UID: Unique ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LNot (VPIR (\_SB.PCI0.LPC.PIRG))) { Return (0x09) } Else { Return (0x0B) } } Name (_PRS, ResourceTemplate () // _PRS: Possible Resource Settings { IRQ (Level, ActiveLow, Shared, ) {3,4,5,6,7,9,10,11} }) Method (_DIS, 0, NotSerialized) // _DIS: Disable Device { Or (\_SB.PCI0.LPC.PIRG, 0x80, \_SB.PCI0.LPC.PIRG) } Name (BUFG, ResourceTemplate () { IRQ (Level, ActiveLow, Shared, _Y06) {} }) CreateWordField (BUFG, \_SB.LNKG._Y06._INT, IRG1) // _INT: Interrupts Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.LPC.PIRG, 0x8F, Local0) If (VPIR (Local0)) { ShiftLeft (0x01, Local0, IRG1) } Else { Store (0x00, IRG1) } Return (BUFG) } Method (_SRS, 1, NotSerialized) // _SRS: Set Resource Settings { CreateWordField (Arg0, 0x01, IRG2) FindSetRightBit (IRG2, Local0) And (\_SB.PCI0.LPC.PIRG, 0x70, Local1) Or (Local1, Decrement (Local0), Local1) Store (Local1, \_SB.PCI0.LPC.PIRG) } } Device (LNKH) { Name (_HID, EisaId ("PNP0C0F")) // _HID: Hardware ID Name (_UID, 0x08) // _UID: Unique ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LNot (VPIR (\_SB.PCI0.LPC.PIRH))) { Return (0x09) } Else { Return (0x0B) } } Name (_PRS, ResourceTemplate () // _PRS: Possible Resource Settings { IRQ (Level, ActiveLow, Shared, ) {3,4,5,6,7,9,10,11} }) Method (_DIS, 0, NotSerialized) // _DIS: Disable Device { Or (\_SB.PCI0.LPC.PIRH, 0x80, \_SB.PCI0.LPC.PIRH) } Name (BUFH, ResourceTemplate () { IRQ (Level, ActiveLow, Shared, _Y07) {} }) CreateWordField (BUFH, \_SB.LNKH._Y07._INT, IRH1) // _INT: Interrupts Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.LPC.PIRH, 0x8F, Local0) If (VPIR (Local0)) { ShiftLeft (0x01, Local0, IRH1) } Else { Store (0x00, IRH1) } Return (BUFH) } Method (_SRS, 1, NotSerialized) // _SRS: Set Resource Settings { CreateWordField (Arg0, 0x01, IRH2) FindSetRightBit (IRH2, Local0) And (\_SB.PCI0.LPC.PIRH, 0x70, Local1) Or (Local1, Decrement (Local0), Local1) Store (Local1, \_SB.PCI0.LPC.PIRH) } } Method (VPIR, 1, NotSerialized) { Store (0x01, Local0) If (And (Arg0, 0x80)) { Store (0x00, Local0) } Else { And (Arg0, 0x0F, Local1) If (LLess (Local1, 0x03)) { Store (0x00, Local0) } ElseIf (LOr (LEqual (Local1, 0x08), LEqual (Local1, 0x0D))) { Store (0x00, Local0) } } Return (Local0) } Device (MEM) { Name (_HID, EisaId ("PNP0C01")) // _HID: Hardware ID Name (MEMS, ResourceTemplate () { Memory32Fixed (ReadWrite, 0x00000000, // Address Base 0x000A0000, // Address Length ) Memory32Fixed (ReadOnly, 0x000C0000, // Address Base 0x00000000, // Address Length _Y08) Memory32Fixed (ReadOnly, 0x000C4000, // Address Base 0x00000000, // Address Length _Y09) Memory32Fixed (ReadOnly, 0x000C8000, // Address Base 0x00000000, // Address Length _Y0A) Memory32Fixed (ReadOnly, 0x000CC000, // Address Base 0x00000000, // Address Length _Y0B) Memory32Fixed (ReadOnly, 0x000D0000, // Address Base 0x00000000, // Address Length _Y0C) Memory32Fixed (ReadOnly, 0x000D4000, // Address Base 0x00000000, // Address Length _Y0D) Memory32Fixed (ReadOnly, 0x000D8000, // Address Base 0x00000000, // Address Length _Y0E) Memory32Fixed (ReadOnly, 0x000DC000, // Address Base 0x00000000, // Address Length _Y0F) Memory32Fixed (ReadOnly, 0x000E0000, // Address Base 0x00000000, // Address Length _Y10) Memory32Fixed (ReadOnly, 0x000E4000, // Address Base 0x00000000, // Address Length _Y11) Memory32Fixed (ReadOnly, 0x000E8000, // Address Base 0x00000000, // Address Length _Y12) Memory32Fixed (ReadOnly, 0x000EC000, // Address Base 0x00000000, // Address Length _Y13) Memory32Fixed (ReadOnly, 0x000F0000, // Address Base 0x00010000, // Address Length ) Memory32Fixed (ReadWrite, 0x00100000, // Address Base 0x01EE0000, // Address Length _Y14) Memory32Fixed (ReadOnly, 0xFEC00000, // Address Base 0x00140000, // Address Length ) Memory32Fixed (ReadOnly, 0xFED4C000, // Address Base 0x012B4000, // Address Length ) }) CreateDWordField (MEMS, \_SB.MEM._Y08._LEN, MC0L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y09._LEN, MC4L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y0A._LEN, MC8L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y0B._LEN, MCCL) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y0C._LEN, MD0L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y0D._LEN, MD4L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y0E._LEN, MD8L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y0F._LEN, MDCL) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y10._LEN, ME0L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y11._LEN, ME4L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y12._LEN, ME8L) // _LEN: Length CreateDWordField (MEMS, \_SB.MEM._Y13._LEN, MECL) // _LEN: Length CreateBitField (MEMS, \_SB.MEM._Y08._RW, MC0W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y09._RW, MC4W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y0A._RW, MC8W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y0B._RW, MCCW) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y0C._RW, MD0W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y0D._RW, MD4W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y0E._RW, MD8W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y0F._RW, MDCW) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y10._RW, ME0W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y11._RW, ME4W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y12._RW, ME8W) // _RW_: Read-Write Status CreateBitField (MEMS, \_SB.MEM._Y13._RW, MECW) // _RW_: Read-Write Status CreateDWordField (MEMS, \_SB.MEM._Y14._BAS, MEB1) // _BAS: Base Address CreateDWordField (MEMS, \_SB.MEM._Y14._LEN, MEL1) // _LEN: Length Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { And (\_SB.PCI0.PAM1, 0x03, Local0) If (Local0) { Store (0x4000, MC0L) If (And (Local0, 0x02)) { Store (0x01, MC0W) } } And (\_SB.PCI0.PAM1, 0x30, Local0) If (Local0) { Store (0x4000, MC4L) If (And (Local0, 0x20)) { Store (0x01, MC4W) } } And (\_SB.PCI0.PAM2, 0x03, Local0) If (Local0) { Store (0x4000, MC8L) If (And (Local0, 0x02)) { Store (0x01, MC8W) } } And (\_SB.PCI0.PAM2, 0x30, Local0) If (Local0) { Store (0x4000, MCCL) If (And (Local0, 0x20)) { Store (0x01, MCCW) } } And (\_SB.PCI0.PAM3, 0x03, Local0) If (Local0) { Store (0x4000, MD0L) If (And (Local0, 0x02)) { Store (0x01, MD0W) } } And (\_SB.PCI0.PAM3, 0x30, Local0) If (Local0) { Store (0x4000, MD4L) If (And (Local0, 0x20)) { Store (0x01, MD4W) } } And (\_SB.PCI0.PAM4, 0x03, Local0) If (Local0) { Store (0x4000, MD8L) If (And (Local0, 0x02)) { Store (0x01, MD8W) } } And (\_SB.PCI0.PAM4, 0x30, Local0) If (Local0) { Store (0x4000, MDCL) If (And (Local0, 0x20)) { Store (0x01, MDCW) } } And (\_SB.PCI0.PAM5, 0x03, Local0) If (Local0) { Store (0x4000, ME0L) If (And (Local0, 0x02)) { Store (0x01, ME0W) } } And (\_SB.PCI0.PAM5, 0x30, Local0) If (Local0) { Store (0x4000, ME4L) If (And (Local0, 0x20)) { Store (0x01, ME4W) } } And (\_SB.PCI0.PAM6, 0x03, Local0) If (Local0) { Store (0x4000, ME8L) If (And (Local0, 0x02)) { Store (0x01, ME8W) } } And (\_SB.PCI0.PAM6, 0x30, Local0) If (Local0) { Store (0x4000, MECL) If (And (Local0, 0x20)) { Store (0x01, MECW) } } Subtract (\MEMX, MEB1, MEL1) Return (MEMS) } } Device (LID) { Name (_HID, EisaId ("PNP0C0D")) // _HID: Hardware ID Method (_LID, 0, NotSerialized) // _LID: Lid Status { If (LAnd (LEqual (\ILNF, 0x00), LEqual (\PLUX, 0x00))) { If (\H8DR) { Return (\_SB.PCI0.LPC.EC.HPLD) } ElseIf (And (\RBEC (0x46), 0x04)) { Return (0x01) } Else { Return (0x00) } } Else { Return (0x01) } } Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake { If (\LWCP) { Return (Package (0x02) { 0x17, 0x04 }) } Else { Return (Package (0x02) { 0x17, 0x03 }) } } Method (_PSW, 1, NotSerialized) // _PSW: Power State Wake { If (\H8DR) { If (Arg0) { Store (0x01, \_SB.PCI0.LPC.EC.HWLO) } Else { Store (0x00, \_SB.PCI0.LPC.EC.HWLO) } } ElseIf (Arg0) { \MBEC (0x32, 0xFF, 0x04) } Else { \MBEC (0x32, 0xFB, 0x00) } If (\LWCP) { If (Arg0) { Store (0x01, \LWEN) } Else { Store (0x00, \LWEN) } } } } Device (SLPB) { Name (_HID, EisaId ("PNP0C0E")) // _HID: Hardware ID Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake { Return (Package (0x02) { 0x17, 0x03 }) } Method (_PSW, 1, NotSerialized) // _PSW: Power State Wake { If (\H8DR) { If (Arg0) { Store (0x01, \_SB.PCI0.LPC.EC.HWFN) Store (0x01, \_SB.PCI0.LPC.EC.HWLU) } Else { Store (0x00, \_SB.PCI0.LPC.EC.HWFN) Store (0x00, \_SB.PCI0.LPC.EC.HWLU) } } ElseIf (Arg0) { \MBEC (0x32, 0xFF, 0x10) \MBEC (0x33, 0xFE, 0x01) } Else { \MBEC (0x32, 0xEF, 0x00) \MBEC (0x33, 0xFE, 0x00) } } } Scope (\_SB) { Device (LWMI) { Name (_HID, "PNP0C14") // _HID: Hardware ID Name (_UID, 0x00) // _UID: Unique ID Name (_WDG, Buffer (0x78) { /* 0000 */ 0x0F, 0x32, 0x64, 0x59, 0xD7, 0xA1, 0x4B, 0x40, /* 0008 */ 0xA1, 0x31, 0x1E, 0x5C, 0xFE, 0x46, 0xFA, 0x47, /* 0010 */ 0x41, 0x41, 0x01, 0x00, 0x7E, 0x04, 0xA1, 0xBE, /* 0018 */ 0x86, 0x7E, 0xEC, 0x49, 0xA6, 0x8B, 0x80, 0xB6, /* 0020 */ 0xE7, 0x56, 0x78, 0x5E, 0x42, 0x42, 0x01, 0x02, /* 0028 */ 0x66, 0x8E, 0x31, 0xCE, 0x90, 0x8F, 0x63, 0x4E, /* 0030 */ 0xB1, 0x27, 0xE4, 0x40, 0x62, 0xF3, 0x2C, 0x72, /* 0038 */ 0x42, 0x43, 0x01, 0x02, 0x46, 0x71, 0x3C, 0xF1, /* 0040 */ 0xF3, 0xCC, 0x2D, 0x46, 0xAB, 0xB9, 0x15, 0x02, /* 0048 */ 0x38, 0xBE, 0x03, 0xB5, 0xA0, 0x00, 0x01, 0x08, /* 0050 */ 0x96, 0x92, 0xDC, 0xA6, 0xF7, 0xC0, 0x23, 0x47, /* 0058 */ 0xB2, 0x99, 0xA4, 0x6B, 0x0B, 0xF6, 0x6B, 0x53, /* 0060 */ 0xA1, 0x00, 0x01, 0x08, 0x21, 0x12, 0x90, 0x05, /* 0068 */ 0x66, 0xD5, 0xD1, 0x11, 0xB2, 0xF0, 0x00, 0xA0, /* 0070 */ 0xC9, 0x06, 0x29, 0x10, 0x4D, 0x4F, 0x01, 0x00 }) Method (WQAA, 1, NotSerialized) { If (LEqual (Arg0, 0x00)) { Return (Package (0x01) { "AIZS1" }) } } Method (WMBB, 3, NotSerialized) { If (LEqual (Arg0, 0x00)) { If (LEqual (Arg1, 0x01)) { If (LEqual (\_SB.PCI0.LPC.EC.PTRG, 0x00)) { Return (0x10) } Else { Return (0x11) } } } Return (0x00) } Method (WMBC, 3, NotSerialized) { If (LEqual (Arg0, 0x00)) { If (LEqual (Arg1, 0x01)) { If (LEqual (\_SB.PCI0.LPC.EC.CMMD, 0x06)) { Return (0x20) } Else { Return (0x1F) } } } Return (0x00) } Method (_WED, 1, NotSerialized) // _Wxx: Wake Event { If (LEqual (Arg0, 0xA0)) { If (LEqual (\_SB.PCI0.LPC.EC.PTRG, 0x00)) { Return (0x10) } Else { Return (0x11) } } If (LEqual (Arg0, 0xA1)) { If (LEqual (\_SB.PCI0.LPC.EC.CMMD, 0x06)) { Return (0x20) } Else { Return (0x1F) } } Return (0x00) } Name (WQMO, Buffer (0x054A) { /* 0000 */ 0x46, 0x4F, 0x4D, 0x42, 0x01, 0x00, 0x00, 0x00, /* 0008 */ 0x3A, 0x05, 0x00, 0x00, 0x54, 0x1A, 0x00, 0x00, /* 0010 */ 0x44, 0x53, 0x00, 0x01, 0x1A, 0x7D, 0xDA, 0x54, /* 0018 */ 0x18, 0xCE, 0x8C, 0x00, 0x01, 0x06, 0x18, 0x42, /* 0020 */ 0x10, 0x0D, 0x10, 0x22, 0x21, 0x04, 0x12, 0x01, /* 0028 */ 0xA1, 0xC8, 0x2C, 0x0C, 0x86, 0x10, 0x38, 0x2E, /* 0030 */ 0x84, 0x1C, 0x40, 0x48, 0x1C, 0x14, 0x4A, 0x08, /* 0038 */ 0x84, 0xFA, 0x13, 0xC8, 0xAF, 0x00, 0x84, 0x0E, /* 0040 */ 0x05, 0xC8, 0x14, 0x60, 0x50, 0x80, 0x53, 0x04, /* 0048 */ 0x11, 0xF4, 0x2A, 0xC0, 0xA6, 0x00, 0x93, 0x02, /* 0050 */ 0x2C, 0x0A, 0xD0, 0x2E, 0xC0, 0xB2, 0x00, 0xDD, /* 0058 */ 0x02, 0xA4, 0xC3, 0x12, 0x91, 0xE0, 0x28, 0x31, /* 0060 */ 0xE0, 0x28, 0x9D, 0xD8, 0xC2, 0x0D, 0x1B, 0xBC, /* 0068 */ 0x50, 0x14, 0xCD, 0x20, 0x4A, 0x82, 0xCA, 0x05, /* 0070 */ 0xF8, 0x46, 0x10, 0x78, 0xB9, 0x02, 0x24, 0x4F, /* 0078 */ 0x40, 0x9A, 0x05, 0x18, 0x16, 0x60, 0x5D, 0x80, /* 0080 */ 0xEC, 0x21, 0x50, 0xA9, 0x43, 0x40, 0xC9, 0x19, /* 0088 */ 0x02, 0x6A, 0x00, 0xAD, 0x4E, 0x40, 0xF8, 0x95, /* 0090 */ 0x4E, 0x09, 0x49, 0x10, 0xCE, 0x58, 0xC5, 0xE3, /* 0098 */ 0x6B, 0x16, 0x4D, 0xCF, 0x49, 0xCE, 0x31, 0xE4, /* 00A0 */ 0x78, 0x5C, 0xE8, 0x41, 0x70, 0x69, 0x12, 0x40, /* 00A8 */ 0x98, 0xF4, 0x21, 0x4B, 0x0C, 0x0C, 0x6A, 0xDC, /* 00B0 */ 0x1E, 0x8B, 0x5D, 0x8C, 0x1A, 0x35, 0x52, 0x36, /* 00B8 */ 0x20, 0x43, 0x94, 0x04, 0x87, 0x1A, 0xB5, 0x25, /* 00C0 */ 0x0A, 0x30, 0x3F, 0x0E, 0xCD, 0xAE, 0xED, 0xB1, /* 00C8 */ 0x10, 0x48, 0x26, 0x6D, 0x28, 0x28, 0x29, 0x10, /* 00D0 */ 0x1A, 0xDB, 0x99, 0x7A, 0x46, 0x11, 0x8F, 0xD4, /* 00D8 */ 0x30, 0x09, 0x3C, 0x0A, 0x86, 0xC6, 0x09, 0x8A, /* 00E0 */ 0x1D, 0x3D, 0x7A, 0x18, 0x51, 0x0F, 0xF0, 0x24, /* 00E8 */ 0x4E, 0xD1, 0xC2, 0xC7, 0x27, 0x8C, 0xA0, 0x87, /* 00F0 */ 0x92, 0xE0, 0x64, 0xCF, 0xFB, 0x5C, 0xA2, 0x45, /* 00F8 */ 0x28, 0x08, 0x49, 0x83, 0x8F, 0x71, 0x04, 0x6D, /* 0100 */ 0x0D, 0x58, 0x13, 0x35, 0x54, 0xA4, 0xC0, 0x91, /* 0108 */ 0xCE, 0x24, 0x62, 0xE4, 0x10, 0x09, 0x8C, 0x9B, /* 0110 */ 0xE0, 0xFF, 0x7F, 0x18, 0x5C, 0x06, 0x84, 0x3C, /* 0118 */ 0x8E, 0x5F, 0xC3, 0x39, 0x8F, 0x04, 0x76, 0x2F, /* 0120 */ 0xC0, 0x9A, 0x00, 0x73, 0x02, 0xB4, 0x0D, 0x4E, /* 0128 */ 0xCE, 0x04, 0x28, 0x13, 0x20, 0x4C, 0x80, 0xC6, /* 0130 */ 0x29, 0xE8, 0x0E, 0xD0, 0x18, 0x9E, 0xBC, 0xA1, /* 0138 */ 0x08, 0x2B, 0x52, 0x88, 0x0A, 0xA1, 0x28, 0x62, /* 0140 */ 0x88, 0x28, 0x21, 0xDE, 0x01, 0x42, 0x1F, 0x51, /* 0148 */ 0xD4, 0x20, 0xE1, 0xA2, 0x07, 0x09, 0x17, 0x24, /* 0150 */ 0x6E, 0xFB, 0xA7, 0x00, 0x76, 0x78, 0x40, 0x8F, /* 0158 */ 0xE7, 0xA0, 0x4E, 0xF0, 0x90, 0x82, 0x9C, 0x57, /* 0160 */ 0x02, 0x4F, 0xF6, 0xD0, 0x1E, 0x15, 0xCE, 0xE2, /* 0168 */ 0xC5, 0xE0, 0x38, 0x3C, 0x9D, 0x04, 0x8E, 0xA4, /* 0170 */ 0x00, 0xA2, 0x05, 0x10, 0xC3, 0xA3, 0x8E, 0x0A, /* 0178 */ 0x3E, 0x11, 0x78, 0x68, 0x47, 0xE9, 0x29, 0x1A, /* 0180 */ 0xE4, 0x10, 0x8E, 0xE0, 0x01, 0xE2, 0x51, 0xC0, /* 0188 */ 0x63, 0x60, 0x77, 0x04, 0x9F, 0x2C, 0x7C, 0x36, /* 0190 */ 0xC0, 0xBB, 0x06, 0xD4, 0xA5, 0xE0, 0x91, 0x80, /* 0198 */ 0x4D, 0x39, 0x1C, 0x66, 0xBC, 0x3E, 0x3C, 0x84, /* 01A0 */ 0x3B, 0x81, 0xF3, 0x3E, 0x12, 0x06, 0x71, 0x44, /* 01A8 */ 0x07, 0x87, 0x1D, 0xE6, 0xC9, 0x1C, 0xD9, 0xDB, /* 01B0 */ 0x44, 0xB3, 0xF7, 0x08, 0x42, 0x70, 0x3C, 0xBE, /* 01B8 */ 0x42, 0x30, 0xCF, 0x90, 0x44, 0xFE, 0x20, 0x50, /* 01C0 */ 0x23, 0x33, 0xB4, 0x07, 0x7C, 0x5A, 0xEF, 0x05, /* 01C8 */ 0x3E, 0x49, 0x98, 0xC0, 0x47, 0x04, 0x6F, 0x52, /* 01D0 */ 0xE3, 0x01, 0x02, 0x8A, 0x8F, 0x1D, 0x64, 0xFA, /* 01D8 */ 0x9E, 0xAF, 0x09, 0x86, 0x1F, 0x38, 0x1A, 0xDA, /* 01E0 */ 0xF7, 0x07, 0xA6, 0x1A, 0x52, 0x23, 0x32, 0xC1, /* 01E8 */ 0xA8, 0x10, 0xFA, 0x62, 0x58, 0xD4, 0xB8, 0xE9, /* 01F0 */ 0x81, 0x82, 0xFF, 0xFF, 0xCF, 0x12, 0xEF, 0x15, /* 01F8 */ 0xBE, 0x25, 0xBC, 0x35, 0xB0, 0xA1, 0x9C, 0x91, /* 0200 */ 0xFF, 0x2B, 0x1E, 0x19, 0xFC, 0x03, 0x09, 0xEE, /* 0208 */ 0x54, 0x01, 0xF7, 0x44, 0xF2, 0xA8, 0xE0, 0xEB, /* 0210 */ 0x40, 0xF4, 0x20, 0xBD, 0x23, 0x69, 0x18, 0xF1, /* 0218 */ 0x4E, 0x0B, 0x07, 0x14, 0x23, 0xCE, 0xF3, 0x86, /* 0220 */ 0x4F, 0x03, 0x60, 0x94, 0x77, 0xA2, 0x01, 0x05, /* 0228 */ 0xFA, 0x03, 0x07, 0x6E, 0xA8, 0xFC, 0x48, 0x03, /* 0230 */ 0x4C, 0x46, 0xC0, 0xC3, 0x3D, 0x2D, 0x4C, 0x20, /* 0238 */ 0xF1, 0xEB, 0x97, 0xA8, 0x87, 0x00, 0x85, 0xF1, /* 0240 */ 0xE9, 0x05, 0x78, 0x8F, 0xED, 0xC1, 0x00, 0x2C, /* 0248 */ 0xFF, 0xFF, 0xD3, 0x0B, 0x38, 0x8E, 0x21, 0x46, /* 0250 */ 0x2E, 0xFA, 0x68, 0x40, 0x8E, 0x2F, 0x60, 0xB8, /* 0258 */ 0xB5, 0x1C, 0xFD, 0x5B, 0x8B, 0x2F, 0x2E, 0xBE, /* 0260 */ 0xAF, 0x84, 0x39, 0x87, 0x18, 0x3E, 0x3C, 0xBD, /* 0268 */ 0xB4, 0x3C, 0xBE, 0xF8, 0x9A, 0x12, 0xE6, 0x68, /* 0270 */ 0x1E, 0x5F, 0x0C, 0x14, 0xEA, 0x05, 0xC6, 0x18, /* 0278 */ 0x51, 0x83, 0xC4, 0x09, 0x16, 0xF4, 0x01, 0x26, /* 0280 */ 0x48, 0x8C, 0x48, 0x41, 0xE2, 0x3C, 0xBE, 0x80, /* 0288 */ 0x39, 0xD8, 0x71, 0x40, 0x67, 0x0D, 0x1F, 0x5F, /* 0290 */ 0x00, 0x7E, 0x08, 0x84, 0xD0, 0xFF, 0xFF, 0x00, /* 0298 */ 0x02, 0xB6, 0x39, 0xBC, 0x32, 0xE0, 0x4E, 0x20, /* 02A0 */ 0xC0, 0x43, 0xFE, 0x3A, 0x75, 0x9A, 0xB1, 0x74, /* 02A8 */ 0x10, 0xD9, 0x58, 0xA9, 0x07, 0x45, 0xC5, 0x52, /* 02B0 */ 0xE9, 0x1C, 0x71, 0x32, 0x3E, 0x9E, 0xA0, 0xA0, /* 02B8 */ 0x74, 0xB6, 0xE3, 0xF2, 0x28, 0x24, 0x0E, 0x42, /* 02C0 */ 0xC3, 0xF1, 0x91, 0x8D, 0xC0, 0x51, 0x10, 0x0F, /* 02C8 */ 0xDE, 0xA7, 0x1D, 0x3B, 0x39, 0x07, 0xA0, 0x46, /* 02D0 */ 0xEF, 0xD9, 0x1C, 0x03, 0x26, 0xDA, 0xA9, 0x87, /* 02D8 */ 0x1E, 0x16, 0xF0, 0x43, 0x8B, 0x79, 0x5A, 0x9E, /* 02E0 */ 0x85, 0x6F, 0x19, 0x3E, 0x82, 0x80, 0xC3, 0x27, /* 02E8 */ 0x34, 0x41, 0x8A, 0xE1, 0x0D, 0xC6, 0x78, 0x51, /* 02F0 */ 0x30, 0xCA, 0xF3, 0x97, 0x07, 0xC2, 0x4E, 0x43, /* 02F8 */ 0x7C, 0x0C, 0x3E, 0x7B, 0x70, 0x02, 0x9F, 0x0E, /* 0300 */ 0xE0, 0x4F, 0x01, 0x7B, 0x3A, 0x00, 0x0B, 0x90, /* 0308 */ 0xAF, 0x03, 0x3E, 0x38, 0x3C, 0x12, 0xB0, 0x39, /* 0310 */ 0x3C, 0xF4, 0xF9, 0xC8, 0xC7, 0xE0, 0xB9, 0x88, /* 0318 */ 0x91, 0xEB, 0x73, 0xE3, 0xFF, 0xBF, 0xAC, 0x71, /* 0320 */ 0xA1, 0x06, 0xEA, 0x43, 0x13, 0x3B, 0x2A, 0xE0, /* 0328 */ 0x4E, 0x4D, 0x18, 0x58, 0x0F, 0x9D, 0xC3, 0x1A, /* 0330 */ 0x2D, 0xEC, 0xC9, 0x3E, 0x44, 0xF8, 0x02, 0xE2, /* 0338 */ 0x99, 0x19, 0x23, 0xAC, 0x8F, 0x1E, 0xE0, 0x00, /* 0340 */ 0xC4, 0x0F, 0xE7, 0x25, 0xC0, 0x13, 0x30, 0x20, /* 0348 */ 0x1B, 0xCF, 0xE3, 0x00, 0x58, 0xA6, 0x86, 0x1B, /* 0350 */ 0xC5, 0x63, 0xC4, 0xCB, 0x0D, 0x3B, 0x87, 0xC4, /* 0358 */ 0xF2, 0x19, 0x07, 0xCE, 0x79, 0x85, 0x41, 0x3C, /* 0360 */ 0x06, 0x44, 0x49, 0xE0, 0x88, 0xC7, 0x23, 0x2A, /* 0368 */ 0x7F, 0xA1, 0x12, 0xB6, 0x64, 0x0A, 0xE3, 0xE3, /* 0370 */ 0x11, 0xF0, 0x16, 0x7C, 0x3C, 0x02, 0xF1, 0x10, /* 0378 */ 0x5E, 0x42, 0x18, 0xE2, 0xD1, 0x86, 0x79, 0x0A, /* 0380 */ 0x63, 0xE7, 0x23, 0x30, 0xFC, 0xFF, 0xCF, 0x47, /* 0388 */ 0xD8, 0xB3, 0x89, 0xEF, 0x88, 0xBE, 0x10, 0x05, /* 0390 */ 0x79, 0x25, 0x7A, 0x39, 0x32, 0xCA, 0x23, 0xE2, /* 0398 */ 0x5B, 0xD0, 0x9B, 0xC5, 0xF3, 0x91, 0xA1, 0x8C, /* 03A0 */ 0x17, 0xE5, 0xDD, 0x28, 0xE2, 0x3B, 0xC5, 0x23, /* 03A8 */ 0xA3, 0xAF, 0x8A, 0x3E, 0x0E, 0x19, 0x2C, 0x50, /* 03B0 */ 0xD0, 0x27, 0x0B, 0x4F, 0x20, 0x58, 0x8C, 0xE7, /* 03B8 */ 0x23, 0x30, 0x47, 0x3B, 0x1F, 0x01, 0x34, 0x39, /* 03C0 */ 0xD6, 0xE0, 0x8E, 0x2C, 0xF0, 0x2E, 0x0D, 0x98, /* 03C8 */ 0x43, 0x03, 0x3F, 0x20, 0xC1, 0xF8, 0xFF, 0x1F, /* 03D0 */ 0x90, 0x80, 0x43, 0x80, 0x03, 0x12, 0x15, 0x7F, /* 03D8 */ 0x40, 0x02, 0xA8, 0x26, 0xE3, 0x80, 0x04, 0x34, /* 03E0 */ 0xFE, 0xFF, 0x07, 0x24, 0xE0, 0x75, 0x94, 0xC1, /* 03E8 */ 0x1D, 0x90, 0xC0, 0x7C, 0xCA, 0x81, 0x75, 0x42, /* 03F0 */ 0xC2, 0x4B, 0x3F, 0x99, 0xA3, 0xC4, 0x1E, 0xCE, /* 03F8 */ 0x01, 0x9D, 0x30, 0x2F, 0xF6, 0x98, 0xF3, 0x11, /* 0400 */ 0xEC, 0x03, 0xD1, 0x2B, 0xB9, 0x0F, 0x44, 0x06, /* 0408 */ 0x79, 0x20, 0xF7, 0x14, 0xC2, 0xBC, 0x93, 0xFB, /* 0410 */ 0x72, 0x64, 0x20, 0x1F, 0x28, 0xA2, 0x3E, 0x8E, /* 0418 */ 0xFA, 0x7E, 0x14, 0xE1, 0x59, 0xE8, 0xE1, 0xDC, /* 0420 */ 0x37, 0xD1, 0xF7, 0x8B, 0xFF, 0x7F, 0xAC, 0x80, /* 0428 */ 0x8F, 0xA4, 0xBE, 0x48, 0x84, 0x89, 0x12, 0x24, /* 0430 */ 0xD4, 0xF3, 0x11, 0x98, 0x23, 0xBF, 0x4E, 0x74, /* 0438 */ 0x1A, 0xF0, 0xF9, 0x08, 0x78, 0xB8, 0x3C, 0x1F, /* 0440 */ 0x01, 0x5A, 0x83, 0x1F, 0x73, 0x20, 0x01, 0x1F, /* 0448 */ 0xEB, 0x7B, 0xC3, 0xE9, 0x38, 0xE8, 0xD9, 0x1C, /* 0450 */ 0xE8, 0xCC, 0xE8, 0xA1, 0x02, 0xE6, 0xFF, 0xFF, /* 0458 */ 0x50, 0x81, 0xBB, 0x4F, 0xC0, 0x85, 0x09, 0x71, /* 0460 */ 0x60, 0xFC, 0xB4, 0x03, 0x9C, 0x8E, 0xB2, 0xD8, /* 0468 */ 0x19, 0xBC, 0x6D, 0x60, 0x8E, 0x56, 0xC0, 0xE4, /* 0470 */ 0xCC, 0x84, 0x3B, 0x4B, 0x78, 0x08, 0x7C, 0x00, /* 0478 */ 0x8F, 0x20, 0xA7, 0xE7, 0xE1, 0x9F, 0x14, 0xEE, /* 0480 */ 0x98, 0xC2, 0xC7, 0x84, 0x1D, 0x00, 0x0F, 0x70, /* 0488 */ 0x94, 0xA1, 0x27, 0x75, 0x4B, 0x86, 0x41, 0x1D, /* 0490 */ 0xD6, 0x01, 0x5F, 0xFF, 0xFF, 0x93, 0x10, 0xBC, /* 0498 */ 0xE3, 0x0C, 0x98, 0xAE, 0xE8, 0x86, 0x39, 0x8C, /* 04A0 */ 0x27, 0x96, 0x77, 0x85, 0x10, 0x8F, 0x33, 0xEC, /* 04A8 */ 0xE2, 0xF0, 0x38, 0xF3, 0xE0, 0xE8, 0x0B, 0xBB, /* 04B0 */ 0x2F, 0x32, 0x3E, 0x3D, 0x1A, 0xCF, 0xC7, 0x19, /* 04B8 */ 0x03, 0xBF, 0xD3, 0x18, 0xE8, 0x6D, 0xDD, 0x98, /* 04C0 */ 0x6F, 0x92, 0xBE, 0xCD, 0x18, 0xF2, 0x71, 0x06, /* 04C8 */ 0xCC, 0xB1, 0x8F, 0x33, 0x00, 0x4D, 0xA2, 0x1F, /* 04D0 */ 0x67, 0xA0, 0xFC, 0xFF, 0x8F, 0x33, 0xB8, 0xC3, /* 04D8 */ 0xA0, 0x8F, 0x33, 0xC0, 0x65, 0x1A, 0x4F, 0x6C, /* 04E0 */ 0xE0, 0xB9, 0x50, 0xC0, 0x3E, 0xCF, 0x80, 0xFB, /* 04E8 */ 0xE8, 0x09, 0xD6, 0x03, 0x0D, 0x60, 0x48, 0xA1, /* 04F0 */ 0x4D, 0x9F, 0x1A, 0x8D, 0x5A, 0x35, 0x28, 0x53, /* 04F8 */ 0xA3, 0x4C, 0x83, 0x5A, 0x7D, 0x2A, 0x35, 0x66, /* 0500 */ 0xCC, 0xC8, 0xB8, 0xFC, 0x3A, 0xD0, 0xF1, 0xC0, /* 0508 */ 0x51, 0x40, 0x68, 0x8C, 0x37, 0x82, 0x40, 0x2C, /* 0510 */ 0xD4, 0x03, 0x08, 0x8B, 0x09, 0x42, 0x25, 0x9B, /* 0518 */ 0x80, 0x08, 0xEC, 0x00, 0x20, 0xFA, 0xFF, 0x03, /* 0520 */ 0x59, 0x86, 0x0D, 0x10, 0x16, 0x02, 0x84, 0x4A, /* 0528 */ 0xF2, 0x01, 0xC8, 0x04, 0x82, 0x08, 0xC8, 0x21, /* 0530 */ 0x95, 0x80, 0x30, 0x89, 0xEF, 0x07, 0x81, 0x58, /* 0538 */ 0xDA, 0xAB, 0x41, 0x20, 0x16, 0xE8, 0x05, 0x84, /* 0540 */ 0xC5, 0x03, 0xA1, 0xC1, 0xD6, 0x2D, 0x10, 0xFF, /* 0548 */ 0xFF, 0x01 }) } } Device (PCI0) { Name (_BBN, 0x00) // _BBN: BIOS Bus Number Name (_ADR, 0x00) // _ADR: Address Name (RID, 0x00) Name (_S3D, 0x02) // _S3D: S3 Device State Name (LRRT, Package (0x24) { Package (0x04) { 0x0001FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x0001FFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0x0001FFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0x0001FFFF, 0x03, \_SB.LNKD, 0x00 }, Package (0x04) { 0x0002FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x0004FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x0005FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x0008FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x0013FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x0014FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x0014FFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0x0014FFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0x0014FFFF, 0x03, \_SB.LNKD, 0x00 }, Package (0x04) { 0x0016FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x0016FFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0x0016FFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0x0016FFFF, 0x03, \_SB.LNKD, 0x00 }, Package (0x04) { 0x0017FFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x001CFFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x001CFFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0x001CFFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0x001CFFFF, 0x03, \_SB.LNKD, 0x00 }, Package (0x04) { 0x001DFFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x001DFFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0x001DFFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0x001DFFFF, 0x03, \_SB.LNKD, 0x00 }, Package (0x04) { 0x001EFFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x001EFFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0x001EFFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0x001EFFFF, 0x03, \_SB.LNKD, 0x00 }, Package (0x04) { 0x001FFFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0x001FFFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0x001FFFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0x001FFFFF, 0x03, \_SB.LNKD, 0x00 }, Package (0x04) { 0x001FFFFF, 0x04, \_SB.LNKA, 0x00 }, Package (0x04) { 0x001FFFFF, 0x06, \_SB.LNKC, 0x00 } }) Name (ARRT, Package (0x2B) { Package (0x04) { 0x0001FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0001FFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0x0001FFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x0001FFFF, 0x03, 0x00, 0x13 }, Package (0x04) { 0x0002FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0004FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0005FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0008FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0013FFFF, 0x00, 0x00, 0x14 }, Package (0x04) { 0x0014FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0014FFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0x0014FFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x0014FFFF, 0x03, 0x00, 0x13 }, Package (0x04) { 0x0015FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0015FFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0x0015FFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x0015FFFF, 0x03, 0x00, 0x13 }, Package (0x04) { 0x0016FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0016FFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0x0016FFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x0016FFFF, 0x03, 0x00, 0x13 }, Package (0x04) { 0x0017FFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x0019FFFF, 0x00, 0x00, 0x20 }, Package (0x04) { 0x0019FFFF, 0x01, 0x00, 0x21 }, Package (0x04) { 0x0019FFFF, 0x02, 0x00, 0x22 }, Package (0x04) { 0x001CFFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x001CFFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0x001CFFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x001CFFFF, 0x03, 0x00, 0x13 }, Package (0x04) { 0x001DFFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x001DFFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0x001DFFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x001DFFFF, 0x03, 0x00, 0x13 }, Package (0x04) { 0x001EFFFF, 0x00, 0x00, 0x14 }, Package (0x04) { 0x001EFFFF, 0x01, 0x00, 0x15 }, Package (0x04) { 0x001EFFFF, 0x02, 0x00, 0x16 }, Package (0x04) { 0x001EFFFF, 0x03, 0x00, 0x17 }, Package (0x04) { 0x001FFFFF, 0x00, 0x00, 0x10 }, Package (0x04) { 0x001FFFFF, 0x01, 0x00, 0x11 }, Package (0x04) { 0x001FFFFF, 0x02, 0x00, 0x12 }, Package (0x04) { 0x001FFFFF, 0x03, 0x00, 0x13 }, Package (0x04) { 0x001FFFFF, 0x04, 0x00, 0x14 }, Package (0x04) { 0x001FFFFF, 0x06, 0x00, 0x16 } }) Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table { If (\GPIC) { ADBG ("APIC mode") Return (ARRT) } Else { ADBG ("8259 mode") Return (LRRT) } } Name (_HID, EisaId ("PNP0A08")) // _HID: Hardware ID Name (_CID, EisaId ("PNP0A03")) // _CID: Compatible ID OperationRegion (MHCS, PCI_Config, 0x40, 0xC0) Field (MHCS, DWordAcc, NoLock, Preserve) { Offset (0x40), PAM0, 8, PAM1, 8, PAM2, 8, PAM3, 8, PAM4, 8, PAM5, 8, PAM6, 8, Offset (0x7C), , 20, TLUD, 12 } Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings { WordBusNumber (ResourceProducer, MinFixed, MaxFixed, PosDecode, 0x0000, // Granularity 0x0000, // Range Minimum 0x00FF, // Range Maximum 0x0000, // Translation Offset 0x0100, // Length ,, _Y22) IO (Decode16, 0x0CF8, // Range Minimum 0x0CF8, // Range Maximum 0x01, // Alignment 0x08, // Length ) WordIO (ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange, 0x0000, // Granularity 0x0000, // Range Minimum 0x0CF7, // Range Maximum 0x0000, // Translation Offset 0x0CF8, // Length ,, , TypeStatic, DenseTranslation) WordIO (ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange, 0x0000, // Granularity 0x0D00, // Range Minimum 0xFFFF, // Range Maximum 0x0000, // Translation Offset 0xF300, // Length ,, , TypeStatic, DenseTranslation) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000A0000, // Range Minimum 0x000BFFFF, // Range Maximum 0x00000000, // Translation Offset 0x00020000, // Length ,, , AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000C0000, // Range Minimum 0x000C3FFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y15, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000C4000, // Range Minimum 0x000C7FFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y16, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000C8000, // Range Minimum 0x000CBFFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y17, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000CC000, // Range Minimum 0x000CFFFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y18, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000D0000, // Range Minimum 0x000D3FFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y19, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000D4000, // Range Minimum 0x000D7FFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y1A, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000D8000, // Range Minimum 0x000DBFFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y1B, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000DC000, // Range Minimum 0x000DFFFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y1C, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000E0000, // Range Minimum 0x000E3FFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y1D, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000E4000, // Range Minimum 0x000E7FFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y1E, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000E8000, // Range Minimum 0x000EBFFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y1F, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x000EC000, // Range Minimum 0x000EFFFF, // Range Maximum 0x00000000, // Translation Offset 0x00004000, // Length ,, _Y20, AddressRangeMemory, TypeStatic) DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite, 0x00000000, // Granularity 0x00100000, // Range Minimum 0xFEBFFFFF, // Range Maximum 0x00000000, // Translation Offset 0xFEB00000, // Length ,, _Y21, AddressRangeMemory, TypeStatic) }) CreateDWordField (_CRS, \_SB.PCI0._Y15._LEN, C0LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y16._LEN, C4LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y17._LEN, C8LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y18._LEN, CCLN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y19._LEN, D0LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y1A._LEN, D4LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y1B._LEN, D8LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y1C._LEN, DCLN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y1D._LEN, E0LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y1E._LEN, E4LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y1F._LEN, E8LN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y20._LEN, ECLN) // _LEN: Length CreateDWordField (_CRS, \_SB.PCI0._Y21._MIN, XXMN) // _MIN: Minimum Base Address CreateDWordField (_CRS, \_SB.PCI0._Y21._MAX, XXMX) // _MAX: Maximum Base Address CreateDWordField (_CRS, \_SB.PCI0._Y21._LEN, XXLN) // _LEN: Length CreateWordField (_CRS, \_SB.PCI0._Y22._MAX, B0MX) // _MAX: Maximum Base Address CreateWordField (_CRS, \_SB.PCI0._Y22._LEN, B0LN) // _LEN: Length Method (_INI, 0, Serialized) // _INI: Initialize { Store (0x3F, B0MX) Store (Add (0x3F, 0x01), B0LN) If (LNot (\OSIF)) { \_SB._INI () } ShiftLeft (TLUD, 0x14, Local0) Store (Local0, \MEMX) Store (Local0, XXMN) Add (Subtract (XXMX, XXMN), 0x01, XXLN) If (And (PAM1, 0x03)) { Store (0x00, C0LN) } If (And (PAM1, 0x30)) { Store (0x00, C4LN) } If (And (PAM2, 0x03)) { Store (0x00, C8LN) } If (And (PAM2, 0x30)) { Store (0x00, CCLN) } If (And (PAM3, 0x03)) { Store (0x00, D0LN) } If (And (PAM3, 0x30)) { Store (0x00, D4LN) } If (And (PAM4, 0x03)) { Store (0x00, D8LN) } If (And (PAM4, 0x30)) { Store (0x00, DCLN) } If (And (PAM5, 0x03)) { Store (0x00, E0LN) } If (And (PAM5, 0x30)) { Store (0x00, E4LN) } If (And (PAM6, 0x03)) { Store (0x00, E8LN) } If (And (PAM6, 0x30)) { Store (0x00, ECLN) } } Name (SUPP, 0x00) Name (CTRL, 0x00) Method (_OSC, 4, NotSerialized) // _OSC: Operating System Capabilities { CreateDWordField (Arg3, 0x00, CDW1) CreateDWordField (Arg3, 0x04, CDW2) CreateDWordField (Arg3, 0x08, CDW3) If (LEqual (Arg0, ToUUID ("33db4d5b-1ff7-401c-9657-7441c03dd766") /* PCI Host Bridge Device */)) { Store (CDW2, SUPP) Store (CDW3, CTRL) And (CTRL, 0x0D, CTRL) If (LNot (And (CDW1, 0x01))) { If (And (CTRL, 0x01)) { Store (0x01, \NHPS) } If (And (CTRL, 0x04)) { If (\_SB.PCI0.EXP1.PMEX) { Store (0x00, \_SB.PCI0.EXP1.PMEX) Store (0x01, \_SB.PCI0.EXP1.PMSX) } If (\_SB.PCI0.EXP2.PMEX) { Store (0x00, \_SB.PCI0.EXP2.PMEX) Store (0x01, \_SB.PCI0.EXP2.PMSX) } If (\_SB.PCI0.EXP3.PMEX) { Store (0x00, \_SB.PCI0.EXP3.PMEX) Store (0x01, \_SB.PCI0.EXP3.PMSX) } If (\_SB.PCI0.EXP5.PMEX) { Store (0x00, \_SB.PCI0.EXP5.PMEX) Store (0x01, \_SB.PCI0.EXP5.PMSX) } If (\_SB.PCI0.RP09.PMEX) { Store (0x00, \_SB.PCI0.RP09.PMEX) Store (0x01, \_SB.PCI0.RP09.PMSX) } Store (0x00, \_SB.PCI0.LPC.EXPE) Store (0x01, \NPME) } } If (LNotEqual (Arg1, 0x01)) { Or (CDW1, 0x0A, CDW1) } If (LNotEqual (CDW3, CTRL)) { Or (CDW1, 0x10, CDW1) } Store (CTRL, CDW3) } Else { Or (CDW1, 0x06, CDW1) } Return (Arg3) } OperationRegion (HBUS, PCI_Config, 0x00, 0x0100) Field (HBUS, DWordAcc, NoLock, Preserve) { Offset (0x40), EPEN, 1, , 11, EPBR, 20, Offset (0x48), MHEN, 1, , 14, MHBR, 17, Offset (0x50), GCLK, 1, Offset (0x60), PXEN, 1, PXSZ, 2, , 23, PXBR, 6, Offset (0x68), DIEN, 1, , 11, DIBR, 20, Offset (0x70), , 20, MEBR, 12 } Name (EP_B, 0x00) Name (MH_B, 0x00) Name (PC_B, 0x00) Name (PC_L, 0x00) Name (DM_B, 0x00) Method (GEPB, 0, Serialized) { If (LEqual (EP_B, 0x00)) { ShiftLeft (\_SB.PCI0.EPBR, 0x0C, EP_B) } Return (EP_B) } Method (GMHB, 0, Serialized) { If (LEqual (MH_B, 0x00)) { ShiftLeft (\_SB.PCI0.MHBR, 0x0F, MH_B) } Return (MH_B) } Method (GPCB, 0, Serialized) { If (LEqual (PC_B, 0x00)) { ShiftLeft (\_SB.PCI0.PXBR, 0x1A, PC_B) } Return (PC_B) } Method (GPCL, 0, Serialized) { If (LEqual (PC_L, 0x00)) { ShiftRight (0x10000000, \_SB.PCI0.PXSZ, PC_L) } Return (PC_L) } Method (GDMB, 0, Serialized) { If (LEqual (DM_B, 0x00)) { ShiftLeft (\_SB.PCI0.DIBR, 0x0C, DM_B) } Return (DM_B) } Scope (\_SB.PCI0) { Method (WHIT, 0, NotSerialized) { Return (Package (0x01) { Package (0x05) { "?*", "?*", 0x00, 0x02, 0x02 } }) } Method (SELF, 0, NotSerialized) { Return (Package (0x02) { "LENOVO", "TP-N1G " }) } } Device (LPC) { Name (_ADR, 0x001F0000) // _ADR: Address Name (_S3D, 0x03) // _S3D: S3 Device State Name (RID, 0x00) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (PCIC (Arg0)) { Return (PCID (Arg0, Arg1, Arg2, Arg3)) } Return (0x00) } Device (SIO) { Name (_HID, EisaId ("PNP0C02")) // _HID: Hardware ID Name (_UID, 0x00) // _UID: Unique ID Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { Name (BUF, ResourceTemplate () { IO (Decode16, 0x0010, // Range Minimum 0x0010, // Range Maximum 0x01, // Alignment 0x10, // Length ) IO (Decode16, 0x0090, // Range Minimum 0x0090, // Range Maximum 0x01, // Alignment 0x10, // Length ) IO (Decode16, 0x0024, // Range Minimum 0x0024, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x0028, // Range Minimum 0x0028, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x002C, // Range Minimum 0x002C, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x0030, // Range Minimum 0x0030, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x0034, // Range Minimum 0x0034, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x0038, // Range Minimum 0x0038, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x003C, // Range Minimum 0x003C, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x00A4, // Range Minimum 0x00A4, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x00A8, // Range Minimum 0x00A8, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x00AC, // Range Minimum 0x00AC, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x00B0, // Range Minimum 0x00B0, // Range Maximum 0x01, // Alignment 0x06, // Length ) IO (Decode16, 0x00B8, // Range Minimum 0x00B8, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x00BC, // Range Minimum 0x00BC, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x0050, // Range Minimum 0x0050, // Range Maximum 0x01, // Alignment 0x04, // Length ) IO (Decode16, 0x0072, // Range Minimum 0x0072, // Range Maximum 0x01, // Alignment 0x06, // Length ) IO (Decode16, 0x1800, // Range Minimum 0x1800, // Range Maximum 0x01, // Alignment 0xA0, // Length ) IO (Decode16, 0x0800, // Range Minimum 0x0800, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x0880, // Range Minimum 0x0880, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x0900, // Range Minimum 0x0900, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x0980, // Range Minimum 0x0980, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x0A00, // Range Minimum 0x0A00, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x0A80, // Range Minimum 0x0A80, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x0B00, // Range Minimum 0x0B00, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x0B80, // Range Minimum 0x0B80, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x15E0, // Range Minimum 0x15E0, // Range Maximum 0x01, // Alignment 0x10, // Length ) IO (Decode16, 0x1600, // Range Minimum 0x1600, // Range Maximum 0x01, // Alignment 0x80, // Length ) IO (Decode16, 0x1640, // Range Minimum 0x1640, // Range Maximum 0x01, // Alignment 0x20, // Length ) Memory32Fixed (ReadWrite, 0xF8000000, // Address Base 0x04000000, // Address Length ) Memory32Fixed (ReadWrite, 0xFED10000, // Address Base 0x00004000, // Address Length ) Memory32Fixed (ReadWrite, 0xFED18000, // Address Base 0x00001000, // Address Length ) Memory32Fixed (ReadWrite, 0xFED19000, // Address Base 0x00001000, // Address Length ) Memory32Fixed (ReadWrite, 0xFEB00000, // Address Base 0x00100000, // Address Length ) Memory32Fixed (ReadWrite, 0xFED20000, // Address Base 0x00020000, // Address Length ) Memory32Fixed (ReadOnly, 0xFED90000, // Address Base 0x00004000, // Address Length ) Memory32Fixed (ReadWrite, 0x00000000, // Address Base 0x00000000, // Address Length _Y23) }) CreateDWordField (BUF, \_SB.PCI0.LPC.SIO._CRS._Y23._BAS, SXB) // _BAS: Base Address Store (\SXRB, SXB) CreateDWordField (BUF, \_SB.PCI0.LPC.SIO._CRS._Y23._LEN, SXL) // _LEN: Length Store (\SXRS, SXL) Return (BUF) } } OperationRegion (LPCS, PCI_Config, 0x00, 0x0100) Field (LPCS, AnyAcc, NoLock, Preserve) { Offset (0x60), PIRA, 8, PIRB, 8, PIRC, 8, PIRD, 8, SERQ, 8, Offset (0x68), PIRE, 8, PIRF, 8, PIRG, 8, PIRH, 8, Offset (0x80), XU1A, 3, , 1, XU2A, 3, Offset (0x81), XPA, 2, , 2, XFA, 1, Offset (0x82), XU1E, 1, XU2E, 1, XPE, 1, XFE, 1, Offset (0x84), XG1E, 1, , 1, XG1A, 14, Offset (0x88), XG2E, 1, , 1, XG2A, 14, Offset (0xA0), , 2, CLKR, 1, , 7, EXPE, 1, Offset (0xA2), Offset (0xAC), Offset (0xAD), Offset (0xAE), XUSB, 1, Offset (0xB8), GR00, 2, , 10, GR06, 2 } OperationRegion (GDIO, SystemMemory, 0xFDAF04C0, 0x10) Field (GDIO, DWordAcc, NoLock, Preserve) { , 30, DOI0, 1, Offset (0x04), , 30, DOI1, 1, Offset (0x08), , 30, DOI2, 1, Offset (0x0C), , 30, DOI3, 1 } OperationRegion (LPIO, SystemIO, 0x0800, 0x0400) Field (LPIO, DWordAcc, NoLock, Preserve) { Offset (0x180), , 3, XHPD, 1, Offset (0x1B0), , 31, GLIS, 1, Offset (0x308), Offset (0x30C) } OperationRegion (GBIO, SystemMemory, 0xFDAF0558, 0x0C) Field (GBIO, DWordAcc, NoLock, Preserve) { NFCP, 1, Offset (0x08), , 1, NFCI, 1, Offset (0x0C) } OperationRegion (GNIO, SystemMemory, 0xFDAE0570, 0x04) Field (GNIO, DWordAcc, NoLock, Preserve) { , 1, NFCD, 1, Offset (0x04) } OperationRegion (PMIO, SystemIO, 0x1800, 0x0100) Field (PMIO, AnyAcc, NoLock, Preserve) { Offset (0x2A), , 6, XHPE, 1, Offset (0x42), , 1, SWGE, 1, Offset (0x64), , 9, Offset (0x8C), SCIS, 1, , 6 } Device (PIC) { Name (_HID, EisaId ("PNP0000")) // _HID: Hardware ID Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings { IO (Decode16, 0x0020, // Range Minimum 0x0020, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x00A0, // Range Minimum 0x00A0, // Range Maximum 0x01, // Alignment 0x02, // Length ) IO (Decode16, 0x04D0, // Range Minimum 0x04D0, // Range Maximum 0x01, // Alignment 0x02, // Length ) IRQNoFlags () {2} }) } Device (TIMR) { Name (_HID, EisaId ("PNP0100")) // _HID: Hardware ID Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings { IO (Decode16, 0x0040, // Range Minimum 0x0040, // Range Maximum 0x01, // Alignment 0x04, // Length ) IRQNoFlags () {0} }) } Device (HPET) { Name (_HID, EisaId ("PNP0103")) // _HID: Hardware ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LAnd (\WNTF, LNot (\WXPF))) { Return (0x00) } Else { Return (0x0F) } Return (0x00) } Name (BUF0, ResourceTemplate () { Memory32Fixed (ReadOnly, 0xFED00000, // Address Base 0x00000400, // Address Length _Y24) }) Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings { CreateDWordField (BUF0, \_SB.PCI0.LPC.HPET._Y24._BAS, HPT0) // _BAS: Base Address Store (\HPET, HPT0) Return (BUF0) } } Device (SPKR) { Name (_HID, EisaId ("PNP0800")) // _HID: Hardware ID Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings { IO (Decode16, 0x0061, // Range Minimum 0x0061, // Range Maximum 0x01, // Alignment 0x01, // Length ) }) } Device (RTC) { Name (_HID, EisaId ("PNP0B00")) // _HID: Hardware ID Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings { IO (Decode16, 0x0070, // Range Minimum 0x0070, // Range Maximum 0x01, // Alignment 0x02, // Length ) IRQNoFlags () {8} }) } Device (KBD) { Method (_HID, 0, NotSerialized) // _HID: Hardware ID { If (\WIN8) { Return (0x7100AE30) } Return (0x0303D041) } Name (_CID, EisaId ("PNP0303")) // _CID: Compatible ID Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings { IO (Decode16, 0x0060, // Range Minimum 0x0060, // Range Maximum 0x01, // Alignment 0x01, // Length ) IO (Decode16, 0x0064, // Range Minimum 0x0064, // Range Maximum 0x01, // Alignment 0x01, // Length ) IRQNoFlags () {1} }) } Device (MOU) { Name (_HID, EisaId ("LEN004F")) // _HID: Hardware ID Name (_CID, EisaId ("PNP0F13")) // _CID: Compatible ID Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings { IRQNoFlags () {12} }) Method (MHID, 0, NotSerialized) { If (\_SB.PCI0.LPC.NFCD) { Store (0x4F00AE30, _HID) } Else { Store (0x5C00AE30, _HID) } } } OperationRegion (IMGA, SystemIO, 0x15E0, 0x10) Field (IMGA, ByteAcc, NoLock, Preserve) { Offset (0x01), Offset (0x02), Offset (0x03), WAKR, 16, Offset (0x0C), GAIX, 8, Offset (0x0E), GADT, 8, Offset (0x10) } IndexField (GAIX, GADT, ByteAcc, NoLock, Preserve) { Offset (0x60), EPWG, 1, , 1, CSON, 1, DSCI, 1, DSCS, 1, DLAN, 1, Offset (0xC2), GAID, 8 } Device (CWDT) { Name (_HID, EisaId ("INT3F0D")) // _HID: Hardware ID Name (_CID, EisaId ("PNP0C02")) // _CID: Compatible ID Name (BUF0, ResourceTemplate () { IO (Decode16, 0x1854, // Range Minimum 0x1854, // Range Maximum 0x04, // Alignment 0x04, // Length ) }) Method (_STA, 0, Serialized) // _STA: Status { Return (0x0F) } Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings { Return (BUF0) } } Device (EC) { Name (_HID, EisaId ("PNP0C09")) // _HID: Hardware ID Name (_UID, 0x00) // _UID: Unique ID Name (_GPE, 0x16) // _GPE: General Purpose Events Method (_REG, 2, NotSerialized) // _REG: Region Availability { If (LEqual (Arg0, 0x03)) { Store (Arg1, \H8DR) } } OperationRegion (ECOR, EmbeddedControl, 0x00, 0x0100) Field (ECOR, ByteAcc, NoLock, Preserve) { HDBM, 1, , 1, , 1, HFNE, 1, , 1, , 1, HLDM, 1, Offset (0x01), BBLS, 1, BTCM, 1, , 1, , 1, , 1, HBPR, 1, BTPC, 1, Offset (0x02), HDUE, 1, , 4, SNLK, 1, Offset (0x03), , 5, HAUM, 2, Offset (0x05), HSPA, 1, Offset (0x06), HSUN, 8, HSRP, 8, Offset (0x0C), HLCL, 8, , 4, CALM, 1, Offset (0x0E), HFNS, 2, Offset (0x0F), , 6, NULS, 1, Offset (0x10), HAM0, 8, HAM1, 8, HAM2, 8, HAM3, 8, HAM4, 8, HAM5, 8, HAM6, 8, HAM7, 8, HAM8, 8, HAM9, 8, HAMA, 8, HAMB, 8, HAMC, 8, HAMD, 8, HAME, 8, HAMF, 8, Offset (0x23), HANT, 8, Offset (0x26), , 2, HANA, 2, Offset (0x27), Offset (0x28), , 1, SKEM, 1, Offset (0x29), Offset (0x2A), HATR, 8, HT0H, 8, HT0L, 8, HT1H, 8, HT1L, 8, HFSP, 8, , 6, HMUT, 1, Offset (0x31), , 2, HUWB, 1, , 3, VPON, 1, VRST, 1, HWPM, 1, HWLB, 1, HWLO, 1, HWDK, 1, HWFN, 1, HWBT, 1, HWRI, 1, HWBU, 1, HWLU, 1, Offset (0x34), , 3, PIBS, 1, , 3, HPLO, 1, Offset (0x36), HWAC, 16, HB0S, 7, HB0A, 1, HB1S, 7, HB1A, 1, HCMU, 1, , 2, OVRQ, 1, DCBD, 1, DCWL, 1, DCWW, 1, HB1I, 1, , 1, KBLT, 1, BTPW, 1, FNKC, 1, HUBS, 1, BDPW, 1, BDDT, 1, HUBB, 1, Offset (0x46), , 1, BTWK, 1, HPLD, 1, , 1, HPAC, 1, BTST, 1, Offset (0x47), HPBU, 1, , 1, HBID, 1, , 3, HBCS, 1, HPNF, 1, , 1, GSTS, 1, , 2, HLBU, 1, DOCD, 1, HCBL, 1, Offset (0x49), SLUL, 1, Offset (0x4C), HTMH, 8, HTML, 8, HWAK, 16, HMPR, 8, , 7, HMDN, 1, Offset (0x78), TMP0, 8, Offset (0x80), Offset (0x81), HIID, 8, Offset (0x83), HFNI, 8, HSPD, 16, Offset (0x88), TSL0, 7, TSR0, 1, TSL1, 7, TSR1, 1, TSL2, 7, TSR2, 1, TSL3, 7, TSR3, 1, Offset (0x8D), HDAA, 3, HDAB, 3, HDAC, 2, Offset (0xB0), HDEN, 32, HDEP, 32, HDEM, 8, HDES, 8, Offset (0xC1), CMMD, 8, Offset (0xC8), ATMX, 8, HWAT, 8, Offset (0xCC), PWMH, 8, PWML, 8, Offset (0xDE), DCID, 8, PTRG, 1, DKAC, 1, Offset (0xED), , 4, HDDD, 1, Offset (0xFE), DIST, 1 } Method (_INI, 0, NotSerialized) // _INI: Initialize { If (\H8DR) { Store (0x00, HSPA) } Else { \MBEC (0x05, 0xFE, 0x00) } \_SB.PCI0.LPC.EC.HKEY.WGIN () } Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings { IO (Decode16, 0x0062, // Range Minimum 0x0062, // Range Maximum 0x01, // Alignment 0x01, // Length ) IO (Decode16, 0x0066, // Range Minimum 0x0066, // Range Maximum 0x01, // Alignment 0x01, // Length ) }) Method (LED, 2, NotSerialized) { Or (Arg0, Arg1, Local0) If (\H8DR) { Store (Local0, HLCL) } Else { \WBEC (0x0C, Local0) } } Name (BAON, 0x00) Name (WBON, 0x00) Method (BEEP, 1, NotSerialized) { If (LEqual (Arg0, 0x05)) { Store (0x00, WBON) } Store (WBON, Local2) If (BAON) { If (LEqual (Arg0, 0x00)) { Store (0x00, BAON) If (WBON) { Store (0x03, Local0) Store (0x08, Local1) } Else { Store (0x00, Local0) Store (0x00, Local1) } } Else { Store (0xFF, Local0) Store (0xFF, Local1) If (LEqual (Arg0, 0x11)) { Store (0x00, WBON) } If (LEqual (Arg0, 0x10)) { Store (0x01, WBON) } } } Else { Store (Arg0, Local0) Store (0xFF, Local1) If (LEqual (Arg0, 0x0F)) { Store (Arg0, Local0) Store (0x08, Local1) Store (0x01, BAON) } If (LEqual (Arg0, 0x11)) { Store (0x00, Local0) Store (0x00, Local1) Store (0x00, WBON) } If (LEqual (Arg0, 0x10)) { Store (0x03, Local0) Store (0x08, Local1) Store (0x01, WBON) } } If (LEqual (Arg0, 0x03)) { Store (0x00, WBON) If (Local2) { Store (0x07, Local0) If (LOr (LEqual (\SPS, 0x03), LEqual (\SPS, 0x04))) { Store (0x00, Local2) Store (0xFF, Local0) Store (0xFF, Local1) } } } If (LEqual (Arg0, 0x07)) { If (Local2) { Store (0x00, Local2) Store (0xFF, Local0) Store (0xFF, Local1) } } If (\H8DR) { If (LAnd (Local2, LNot (WBON))) { Store (0x00, HSRP) Store (0x00, HSUN) Sleep (0x64) } If (LNotEqual (Local1, 0xFF)) { Store (Local1, HSRP) } If (LNotEqual (Local0, 0xFF)) { Store (Local0, HSUN) } } Else { If (LAnd (Local2, LNot (WBON))) { \WBEC (0x07, 0x00) \WBEC (0x06, 0x00) Sleep (0x64) } If (LNotEqual (Local1, 0xFF)) { \WBEC (0x07, Local1) } If (LNotEqual (Local0, 0xFF)) { \WBEC (0x06, Local0) } } If (LEqual (Arg0, 0x03)){} If (LEqual (Arg0, 0x07)) { Sleep (0x01F4) } } Method (EVNT, 1, NotSerialized) { If (\H8DR) { If (Arg0) { Or (HAM5, 0x04, HAM5) } Else { And (HAM5, 0xFB, HAM5) } } ElseIf (Arg0) { \MBEC (0x15, 0xFF, 0x04) } Else { \MBEC (0x15, 0xFB, 0x00) } } Name (USPS, 0x00) PowerResource (PUBS, 0x03, 0x0000) { Method (_STA, 0, NotSerialized) // _STA: Status { If (\H8DR) { Store (HUBS, Local0) } Else { And (\RBEC (0x3B), 0x10, Local0) } If (Local0) { Return (0x01) } Else { Return (0x00) } } Method (_ON, 0, NotSerialized) // _ON_: Power On { Store (0x64, Local0) While (LAnd (USPS, Local0)) { Sleep (0x01) Decrement (Local0) } If (\H8DR) { Store (0x01, HUBS) } Else { \MBEC (0x3B, 0xFF, 0x10) } } Method (_OFF, 0, NotSerialized) // _OFF: Power Off { Store (0x01, USPS) If (\H8DR) { Store (0x00, HUBS) } Else { \MBEC (0x3B, 0xEF, 0x00) } Sleep (0x14) Store (0x00, USPS) } } Method (CHKS, 0, NotSerialized) { Store (0x03E8, Local0) While (HMPR) { Sleep (0x01) Decrement (Local0) If (LNot (Local0)) { Return (0x8080) } } If (HMDN) { Return (Zero) } Return (0x8081) } Method (LPMD, 0, NotSerialized) { Store (0x00, Local0) Store (0x00, Local1) Store (0x00, Local2) If (\H8DR) { If (HPAC) { If (HPLO) { Store (\LPST, Local0) } ElseIf (LLess (HWAT, 0x5A)) { If (HB0A) { If (LOr (And (HB0S, 0x10), LLess (And (HB0S, 0x07), 0x02))) { Store (0x01, Local1) } } Else { Store (0x01, Local1) } If (HB1A) { If (LOr (And (HB1S, 0x10), LLess (And (HB1S, 0x07), 0x02))) { Store (0x01, Local2) } } Else { Store (0x01, Local2) } If (LAnd (Local1, Local2)) { Store (\LPST, Local0) } } } } ElseIf (And (\RBEC (0x46), 0x10)) { If (And (\RBEC (0x34), 0x80)) { Store (\LPST, Local0) } ElseIf (LLess (\RBEC (0xC9), 0x5A)) { Store (\RBEC (0x38), Local3) If (And (Local3, 0x80)) { If (LOr (And (Local3, 0x10), LLess (And (Local3, 0x07), 0x02))) { Store (0x01, Local1) } } Else { Store (0x01, Local2) } Store (\RBEC (0x39), Local3) If (And (Local3, 0x80)) { If (LOr (And (Local3, 0x10), LLess (And (Local3, 0x07), 0x02))) { Store (0x01, Local1) } } Else { Store (0x01, Local2) } If (LAnd (Local1, Local2)) { Store (\LPST, Local0) } } } Return (Local0) } Method (CLPM, 0, NotSerialized) { If (And (\_PR.CFGD, 0x01)) { If (LOr (\OSPX, \CPPX)) { \PNTF (0x80) } Else { Store (LPMD (), Local0) If (Local0) { \STEP (0x04) } Else { \STEP (0x05) } } } } Mutex (MCPU, 0x00) Method (_Q10, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x01)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1001) } } Method (_Q11, 0, NotSerialized) // _Qxx: EC Query { Noop } Method (_Q12, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x02)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1002) } } Method (_Q13, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.DHKC) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1004) } Else { Notify (\_SB.SLPB, 0x80) } } Method (_Q64, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x10)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1005) } } Method (_Q65, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x20)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1006) } } Method (_Q16, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x40)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1007) } } Method (_Q17, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x80)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1008) } } Method (_Q18, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x0100)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1009) } Noop } Method (_Q1A, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x0400)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x100B) } } Method (_Q1B, 0, NotSerialized) // _Qxx: EC Query { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x100C) } Method (_Q62, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x1000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x100D) } } Method (_Q60, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x2000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x100E) } } Method (_Q61, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x4000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x100F) } } Method (_Q1F, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x00020000)) { If (And (PKLI, 0x0C00)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1012) } } \UCMS (0x0E) } Method (_Q1C, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x01000000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1019) } } Method (_Q1D, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x02000000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x101A) } } Method (_Q66, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x10000000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x101D) } } Method (_Q67, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x20000000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x101E) } } Method (_Q68, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x40000000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x101F) } } Method (_Q69, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x80000000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1020) } } Method (_Q26, 0, NotSerialized) // _Qxx: EC Query { If (VIGD) { If (\WVIS) { \VBTD () } \_SB.PCI0.LPC.EC.BRNS () } Else { \UCMS (0x12) } ADBG ("AC_A0") \_SB.PCI0.LPC.EC.HKEY.DYTC (0x000F4001) ADBG ("AC_A1") Sleep (0x01F4) Notify (AC, 0x80) Notify (\_TZ.THM0, 0x80) If (\WXPF) { Acquire (MCPU, 0xFFFF) } Store (0x01, PWRS) If (And (\_PR.CFGD, 0x01)) { If (LOr (\OSPX, \CPPX)) { \PNTF (0x80) } } If (\WXPF) { Sleep (0x64) } If (\OSC4) { \PNTF (0x81) } If (\WXPF) { Release (MCPU) } \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6040) ATMC () } Method (_Q27, 0, NotSerialized) // _Qxx: EC Query { If (VIGD) { If (\WVIS) { \VBTD () } \_SB.PCI0.LPC.EC.BRNS () } Else { \UCMS (0x12) } If (LEqual (\_SB.LID._LID (), 0x00)) { ADBG ("AC_D0") \_SB.PCI0.LPC.EC.HKEY.DYTC (0x001F4001) ADBG ("AC_D1") } Sleep (0x01F4) Notify (AC, 0x80) Notify (\_TZ.THM0, 0x80) If (\WXPF) { Acquire (MCPU, 0xFFFF) } Store (0x00, PWRS) If (And (\_PR.CFGD, 0x01)) { If (LOr (\OSPX, \CPPX)) { \PNTF (0x80) } } If (\WXPF) { Sleep (0x64) } If (\OSC4) { \PNTF (0x81) } If (\WXPF) { Release (MCPU) } \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6040) ATMC () } Method (_Q2A, 0, NotSerialized) // _Qxx: EC Query { ADBG ("LIDO") \VCMS (0x01, \_SB.LID._LID ()) ADBG ("LIDO0") \_SB.PCI0.LPC.EC.HKEY.DYTC (0x000F4001) ADBG ("LIDO1") If (LEqual (\ILNF, 0x00)) { If (\IOST) { If (LNot (\ISOC (0x00))) { Store (0x00, \IOST) \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x60D0) } } \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x5002) If (LEqual (\PLUX, 0x00)) { If (VIGD) { \_SB.PCI0.GFX0.VLOC (0x01) } Notify (\_SB.LID, 0x80) } } } Method (_Q2B, 0, NotSerialized) // _Qxx: EC Query { ADBG ("LIDC") \UCMS (0x0D) \VCMS (0x01, \_SB.LID._LID ()) If (LEqual (\_SB.PCI0.LPC.EC.AC._PSR (), 0x00)) { ADBG ("LIDC0") \_SB.PCI0.LPC.EC.HKEY.DYTC (0x001F4001) ADBG ("LIDC1") } If (LEqual (\ILNF, 0x00)) { If (LAnd (\IOEN, LNot (\IOST))) { If (LNot (\ISOC (0x01))) { Store (0x01, \IOST) \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x60D0) } } \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x5001) If (LEqual (\PLUX, 0x00)) { If (VIGD) { \_SB.PCI0.GFX0.VLOC (0x00) } Notify (\_SB.LID, 0x80) } } } Method (_Q3D, 0, NotSerialized) // _Qxx: EC Query { } Method (_Q48, 0, NotSerialized) // _Qxx: EC Query { If (And (\_PR.CFGD, 0x01)) { If (LOr (\OSPX, \CPPX)) { \PNTF (0x80) } Else { \STEP (0x04) } Store (0x01, \_SB.PCI0.LPC.EC.CALM) } } Method (_Q49, 0, NotSerialized) // _Qxx: EC Query { If (And (\_PR.CFGD, 0x01)) { If (LOr (\OSPX, \CPPX)) { \PNTF (0x80) } Else { \STEP (0x05) } } } Method (_Q7F, 0, NotSerialized) // _Qxx: EC Query { Fatal (0x01, 0x80010000, 0x4B87) } Method (_Q4E, 0, NotSerialized) // _Qxx: EC Query { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6011) } Method (_Q4F, 0, NotSerialized) // _Qxx: EC Query { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6012) } Method (_Q7A, 0, NotSerialized) // _Qxx: EC Query { Notify (\_SB.LWMI, 0xA0) } Method (_Q46, 0, NotSerialized) // _Qxx: EC Query { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6012) } Method (_Q2E, 0, NotSerialized) // _Qxx: EC Query { Notify (\_SB.LWMI, 0xA1) Store (\_SB.PCI0.LPC.EC.CMMD, Local0) If (LAnd (LNotEqual (Local0, 0x00), LLessEqual (Local0, 0x06))) { If (LNotEqual (Local0, \PMMD)) { Store (Local0, \PMMD) \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x60C0) } } If (LOr (LEqual (Local0, 0x00), LGreaterEqual (Local0, 0x07))) { Store (0x01, Local1) } ElseIf (LOr (LEqual (Local0, 0x02), LEqual (Local0, 0x03))) { Store (0x02, Local1) } Else { Store (0x03, Local1) } If (LNotEqual (Local1, \LVMD)) { Store (Local1, \LVMD) Sleep (0x0A) \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x60F0) } } Method (_Q22, 0, NotSerialized) // _Qxx: EC Query { CLPM () If (HB0A) { Notify (BAT0, 0x80) } If (HB1A) { Notify (BAT1, 0x80) } } Method (_Q4A, 0, NotSerialized) // _Qxx: EC Query { CLPM () Notify (BAT0, 0x81) } Method (_Q4B, 0, NotSerialized) // _Qxx: EC Query { CLPM () Notify (BAT0, 0x80) } Method (_Q4D, 0, NotSerialized) // _Qxx: EC Query { CLPM () If (\BT2T) { If (LEqual (^BAT1.SBLI, 0x01)) { Sleep (0x0A) If (LAnd (HB1A, LEqual (SLUL, 0x00))) { Store (0x01, ^BAT1.XB1S) Notify (\_SB.PCI0.LPC.EC.BAT1, 0x01) } } ElseIf (LEqual (SLUL, 0x01)) { Store (0x00, ^BAT1.XB1S) Notify (\_SB.PCI0.LPC.EC.BAT1, 0x03) } } If (And (^BAT1.B1ST, ^BAT1.XB1S)) { Notify (BAT1, 0x80) } } Method (_Q24, 0, NotSerialized) // _Qxx: EC Query { CLPM () Notify (BAT0, 0x80) } Method (_Q25, 0, NotSerialized) // _Qxx: EC Query { If (And (^BAT1.B1ST, ^BAT1.XB1S)) { CLPM () Notify (BAT1, 0x80) } } Method (BATW, 1, NotSerialized) { If (\BT2T) { Store (\_SB.PCI0.LPC.EC.BAT1.XB1S, Local0) If (LAnd (HB1A, LNot (SLUL))) { Store (0x01, Local1) } Else { Store (0x00, Local1) } If (XOr (Local0, Local1)) { Store (Local1, \_SB.PCI0.LPC.EC.BAT1.XB1S) Notify (\_SB.PCI0.LPC.EC.BAT1, 0x01) } } } Field (ECOR, ByteAcc, NoLock, Preserve) { Offset (0xA0), SBRC, 16, SBFC, 16, SBAE, 16, SBRS, 16, SBAC, 16, SBVO, 16, SBAF, 16, SBBS, 16 } Field (ECOR, ByteAcc, NoLock, Preserve) { Offset (0xA0), SBBM, 16, SBMD, 16, SBCC, 16 } Field (ECOR, ByteAcc, NoLock, Preserve) { Offset (0xA0), SBDC, 16, SBDV, 16, SBOM, 16, SBSI, 16, SBDT, 16, SBSN, 16 } Field (ECOR, ByteAcc, NoLock, Preserve) { Offset (0xA0), SBCH, 32 } Field (ECOR, ByteAcc, NoLock, Preserve) { Offset (0xA0), SBMN, 128 } Field (ECOR, ByteAcc, NoLock, Preserve) { Offset (0xA0), SBDN, 128 } Mutex (BATM, 0x00) Method (GBIF, 3, NotSerialized) { Acquire (BATM, 0xFFFF) If (Arg2) { Or (Arg0, 0x01, HIID) Store (SBBM, Local7) ShiftRight (Local7, 0x0F, Local7) XOr (Local7, 0x01, Index (Arg1, 0x00)) Store (Arg0, HIID) If (Local7) { Multiply (SBFC, 0x0A, Local1) } Else { Store (SBFC, Local1) } Store (Local1, Index (Arg1, 0x02)) Or (Arg0, 0x02, HIID) If (Local7) { Multiply (SBDC, 0x0A, Local0) } Else { Store (SBDC, Local0) } Store (Local0, Index (Arg1, 0x01)) Divide (Local1, 0x14, Local2, Index (Arg1, 0x05)) If (Local7) { Store (0xC8, Index (Arg1, 0x06)) } ElseIf (SBDV) { Divide (0x00030D40, SBDV, Local2, Index (Arg1, 0x06)) } Else { Store (0x00, Index (Arg1, 0x06)) } Store (SBDV, Index (Arg1, 0x04)) Store (SBSN, Local0) Name (SERN, Buffer (0x06) { " " }) Store (0x04, Local2) While (Local0) { Divide (Local0, 0x0A, Local1, Local0) Add (Local1, 0x30, Index (SERN, Local2)) Decrement (Local2) } Store (SERN, Index (Arg1, 0x0A)) Or (Arg0, 0x06, HIID) Store (SBDN, Index (Arg1, 0x09)) Or (Arg0, 0x04, HIID) Name (BTYP, Buffer (0x05) { 0x00, 0x00, 0x00, 0x00, 0x00 }) Store (SBCH, BTYP) Store (BTYP, Index (Arg1, 0x0B)) Or (Arg0, 0x05, HIID) Store (SBMN, Index (Arg1, 0x0C)) } Else { Store (0xFFFFFFFF, Index (Arg1, 0x01)) Store (0x00, Index (Arg1, 0x05)) Store (0x00, Index (Arg1, 0x06)) Store (0xFFFFFFFF, Index (Arg1, 0x02)) } Release (BATM) Return (Arg1) } Name (B0I0, 0x00) Name (B0I1, 0x00) Name (B0I2, 0x00) Name (B0I3, 0x00) Name (B1I0, 0x00) Name (B1I1, 0x00) Name (B1I2, 0x00) Name (B1I3, 0x00) Method (GBST, 4, NotSerialized) { Acquire (BATM, 0xFFFF) If (And (Arg1, 0x20)) { Store (0x02, Local0) } ElseIf (And (Arg1, 0x40)) { Store (0x01, Local0) } Else { Store (0x00, Local0) } If (And (Arg1, 0x07)){} Else { Or (Local0, 0x04, Local0) } If (LEqual (And (Arg1, 0x07), 0x07)) { Store (0x04, Local0) Store (0x00, Local1) Store (0x00, Local2) Store (0x00, Local3) } Else { Store (Arg0, HIID) Store (SBVO, Local3) If (Arg2) { Multiply (SBRC, 0x0A, Local2) } Else { Store (SBRC, Local2) } Store (SBAC, Local1) If (LGreaterEqual (Local1, 0x8000)) { If (And (Local0, 0x01)) { Subtract (0x00010000, Local1, Local1) } Else { Store (0x00, Local1) } } ElseIf (LNot (And (Local0, 0x02))) { Store (0x00, Local1) } If (Arg2) { Multiply (Local3, Local1, Local1) Divide (Local1, 0x03E8, Local7, Local1) } } Store (ShiftLeft (0x01, ShiftRight (Arg0, 0x04)), Local5) Or (BSWA, BSWR, BSWA) If (LEqual (And (\_SB.PCI0.LPC.EC.BSWA, Local5), 0x00)) { Store (Local0, Index (Arg3, 0x00)) Store (Local1, Index (Arg3, 0x01)) Store (Local2, Index (Arg3, 0x02)) Store (Local3, Index (Arg3, 0x03)) If (LEqual (Arg0, 0x00)) { Store (Local0, B0I0) Store (Local1, B0I1) Store (Local2, B0I2) Store (Local3, B0I3) } Else { Store (Local0, B1I0) Store (Local1, B1I1) Store (Local2, B1I2) Store (Local3, B1I3) } } Else { If (\_SB.PCI0.LPC.EC.AC._PSR ()) { If (LEqual (Arg0, 0x00)) { Store (B0I0, Index (Arg3, 0x00)) Store (B0I1, Index (Arg3, 0x01)) Store (B0I2, Index (Arg3, 0x02)) Store (B0I3, Index (Arg3, 0x03)) } Else { Store (B1I0, Index (Arg3, 0x00)) Store (B1I1, Index (Arg3, 0x01)) Store (B1I2, Index (Arg3, 0x02)) Store (B1I3, Index (Arg3, 0x03)) } } Else { Store (Local0, Index (Arg3, 0x00)) Store (Local1, Index (Arg3, 0x01)) Store (Local2, Index (Arg3, 0x02)) Store (Local3, Index (Arg3, 0x03)) } If (LAnd (LEqual (And (Local0, 0x04), 0x00), LAnd (LGreater (Local2, 0x00), LGreater (Local3, 0x00)))) { And (BSWA, Not (Local5), BSWA) Store (Local0, Index (Arg3, 0x00)) Store (Local1, Index (Arg3, 0x01)) Store (Local2, Index (Arg3, 0x02)) Store (Local3, Index (Arg3, 0x03)) } } Release (BATM) Return (Arg3) } Name (BSWR, 0x00) Name (BSWA, 0x00) Device (BAT0) { Name (_HID, EisaId ("PNP0C0A")) // _HID: Hardware ID Name (_UID, 0x00) // _UID: Unique ID Name (_PCL, Package (0x01) // _PCL: Power Consumer List { \_SB }) Name (B0ST, 0x00) Name (BT0I, Package (0x0D) { 0x00, 0xFFFFFFFF, 0xFFFFFFFF, 0x01, 0x2A30, 0x00, 0x00, 0x01, 0x01, "", "", "", "" }) Name (BT0P, Package (0x04){}) Method (_STA, 0, NotSerialized) // _STA: Status { If (\H8DR) { Store (HB0A, B0ST) } ElseIf (And (\RBEC (0x38), 0x80)) { Store (0x01, B0ST) } Else { Store (0x00, B0ST) } If (B0ST) { Return (0x1F) } Else { Return (0x0F) } } Method (_BIF, 0, NotSerialized) // _BIF: Battery Information { Store (0x00, Local7) Store (0x0A, Local6) While (LAnd (LNot (Local7), Local6)) { If (HB0A) { If (LEqual (And (HB0S, 0x07), 0x07)) { Sleep (0x03E8) Decrement (Local6) } Else { Store (0x01, Local7) } } Else { Store (0x00, Local6) } } Return (GBIF (0x00, BT0I, Local7)) } Method (_BST, 0, NotSerialized) // _BST: Battery Status { XOr (DerefOf (Index (BT0I, 0x00)), 0x01, Local0) Return (GBST (0x00, HB0S, Local0, BT0P)) } Method (_BTP, 1, NotSerialized) // _BTP: Battery Trip Point { And (HAM4, 0xEF, HAM4) If (Arg0) { Store (Arg0, Local1) If (LNot (DerefOf (Index (BT0I, 0x00)))) { Divide (Local1, 0x0A, Local0, Local1) } And (Local1, 0xFF, HT0L) And (ShiftRight (Local1, 0x08), 0xFF, HT0H) Or (HAM4, 0x10, HAM4) } } } Device (BAT1) { Name (_HID, EisaId ("PNP0C0A")) // _HID: Hardware ID Name (_UID, 0x01) // _UID: Unique ID Name (_PCL, Package (0x01) // _PCL: Power Consumer List { \_SB }) Name (B1ST, 0x00) Name (SBLI, 0x01) Name (XB1S, 0x00) Name (BT1I, Package (0x0D) { 0x00, 0xFFFFFFFF, 0xFFFFFFFF, 0x01, 0x2A30, 0x00, 0x00, 0x01, 0x01, "", "", "", "" }) Name (BT1P, Package (0x04){}) Method (_STA, 0, NotSerialized) // _STA: Status { If (\H8DR) { If (HB1A) { Store (0x01, B1ST) If (\BT2T) { If (SLUL) { Store (0x01, SBLI) Store (0x00, XB1S) } Else { Store (0x00, SBLI) Store (0x01, XB1S) } } Else { Store (0x01, XB1S) } } Else { Store (0x00, B1ST) If (\BT2T) { Store (0x01, SBLI) Store (0x00, XB1S) } Else { Store (0x00, XB1S) } } } ElseIf (And (\RBEC (0x39), 0x80)) { Store (0x01, B1ST) If (\BT2T) { If (And (\RBEC (0x49), 0x01)) { Store (0x01, SBLI) Store (0x00, XB1S) } Else { Store (0x00, SBLI) Store (0x01, XB1S) } } Else { Store (0x01, XB1S) } } Else { Store (0x00, B1ST) If (\BT2T) { Store (0x01, SBLI) Store (0x00, XB1S) } Else { Store (0x00, XB1S) } } If (B1ST) { If (XB1S) { Return (0x1F) } ElseIf (\WNTF) { Return (0x00) } Else { Return (0x1F) } } ElseIf (\WNTF) { Return (0x00) } Else { Return (0x0F) } } Method (_BIF, 0, NotSerialized) // _BIF: Battery Information { Store (0x00, Local7) Store (0x0A, Local6) While (LAnd (LNot (Local7), Local6)) { If (HB1A) { If (LEqual (And (HB1S, 0x07), 0x07)) { Sleep (0x03E8) Decrement (Local6) } Else { Store (0x01, Local7) } } Else { Store (0x00, Local6) } } Return (GBIF (0x10, BT1I, Local7)) } Method (_BST, 0, NotSerialized) // _BST: Battery Status { XOr (DerefOf (Index (BT1I, 0x00)), 0x01, Local0) Return (GBST (0x10, HB1S, Local0, BT1P)) } Method (_BTP, 1, NotSerialized) // _BTP: Battery Trip Point { And (HAM4, 0xDF, HAM4) If (Arg0) { Store (Arg0, Local1) If (LNot (DerefOf (Index (BT1I, 0x00)))) { Divide (Local1, 0x0A, Local0, Local1) } And (Local1, 0xFF, HT1L) And (ShiftRight (Local1, 0x08), 0xFF, HT1H) Or (HAM4, 0x20, HAM4) } } } Device (AC) { Name (_HID, "ACPI0003") // _HID: Hardware ID Name (_UID, 0x00) // _UID: Unique ID Name (_PCL, Package (0x01) // _PCL: Power Consumer List { \_SB }) Method (_PSR, 0, NotSerialized) // _PSR: Power Source { If (\H8DR) { Return (HPAC) } ElseIf (And (\RBEC (0x46), 0x10)) { Return (0x01) } Else { Return (0x00) } } Method (_STA, 0, NotSerialized) // _STA: Status { Return (0x0F) } } Device (HKEY) { Name (_HID, EisaId ("LEN0068")) // _HID: Hardware ID Method (_STA, 0, NotSerialized) // _STA: Status { Return (0x0F) } Method (_INI, 0, NotSerialized) // _INI: Initialize { ADBG ("_INI0") Store (0x00, \_SB.PCI0.LPC.EC.HKEY.ANGN) \_SB.PCI0.LPC.EC.HKEY.DYTC (0x000F0001) ADBG ("_INI1") } Method (MHKV, 0, NotSerialized) { Return (0x0100) } Name (DHKC, 0x00) Name (DHKB, 0x01) Name (DHKH, 0x00) Name (DHKW, 0x00) Name (DHKS, 0x00) Name (DHKD, 0x00) Name (DHKN, 0x0808) Name (DHKT, 0x00) Name (DHWW, 0x00) Name (DSML, 0x00) Mutex (XDHK, 0x00) Method (MHKA, 0, NotSerialized) { Return (0xFFFFFFFB) } Method (MHKN, 0, NotSerialized) { Return (DHKN) } Method (MHKK, 1, NotSerialized) { If (DHKC) { Return (And (DHKN, Arg0)) } Else { Return (Zero) } } Method (MHKM, 2, NotSerialized) { Acquire (XDHK, 0xFFFF) If (LGreater (Arg0, 0x20)) { Noop } Else { ShiftLeft (One, Decrement (Arg0), Local0) If (And (Local0, 0xFFFFFFFB)) { If (Arg1) { Or (Local0, DHKN, DHKN) } Else { And (DHKN, XOr (Local0, 0xFFFFFFFF), DHKN) } } Else { Noop } } Release (XDHK) } Method (MHKS, 0, NotSerialized) { Notify (\_SB.SLPB, 0x80) } Method (MHKC, 1, NotSerialized) { Store (Arg0, DHKC) } Method (MHKP, 0, NotSerialized) { Acquire (XDHK, 0xFFFF) If (DHWW) { Store (DHWW, Local1) Store (Zero, DHWW) } ElseIf (DHKW) { Store (DHKW, Local1) Store (Zero, DHKW) } ElseIf (DHKD) { Store (DHKD, Local1) Store (Zero, DHKD) } ElseIf (DHKS) { Store (DHKS, Local1) Store (Zero, DHKS) } ElseIf (DHKT) { Store (DHKT, Local1) Store (Zero, DHKT) } Else { Store (DHKH, Local1) Store (Zero, DHKH) } Release (XDHK) Return (Local1) } Method (MHKE, 1, Serialized) { Store (Arg0, DHKB) Acquire (XDHK, 0xFFFF) Store (Zero, DHKH) Store (Zero, DHKW) Store (Zero, DHKS) Store (Zero, DHKD) Store (Zero, DHKT) Store (Zero, DHWW) Release (XDHK) } Method (MHKQ, 1, Serialized) { If (DHKB) { If (DHKC) { Acquire (XDHK, 0xFFFF) If (LLess (Arg0, 0x1000)){} ElseIf (LLess (Arg0, 0x2000)) { Store (Arg0, DHKH) } ElseIf (LLess (Arg0, 0x3000)) { Store (Arg0, DHKW) } ElseIf (LLess (Arg0, 0x4000)) { Store (Arg0, DHKS) } ElseIf (LLess (Arg0, 0x5000)) { Store (Arg0, DHKD) } ElseIf (LLess (Arg0, 0x6000)) { Store (Arg0, DHKH) } ElseIf (LLess (Arg0, 0x7000)) { Store (Arg0, DHKT) } ElseIf (LLess (Arg0, 0x8000)) { Store (Arg0, DHWW) } Else { } Release (XDHK) Notify (HKEY, 0x80) } ElseIf (LEqual (Arg0, 0x1004)) { Notify (\_SB.SLPB, 0x80) } } } Method (MHKB, 1, NotSerialized) { If (LEqual (Arg0, 0x00)) { \_SB.PCI0.LPC.EC.BEEP (0x11) Store (0x00, \LIDB) } ElseIf (LEqual (Arg0, 0x01)) { \_SB.PCI0.LPC.EC.BEEP (0x10) Store (0x01, \LIDB) } Else { } } Method (MHKD, 0, NotSerialized) { If (LEqual (\PLUX, 0x00)) { If (VIGD) { \_SB.PCI0.GFX0.VLOC (0x00) } } } Method (MHQC, 1, NotSerialized) { If (\WNTF) { If (LEqual (Arg0, 0x00)) { Return (\CWAC) } ElseIf (LEqual (Arg0, 0x01)) { Return (\CWAP) } ElseIf (LEqual (Arg0, 0x02)) { Return (\CWAT) } Else { Noop } } Else { Noop } Return (0x00) } Method (MHGC, 0, NotSerialized) { If (\WNTF) { Acquire (XDHK, 0xFFFF) If (CKC4 (0x00)) { Store (0x03, Local0) } Else { Store (0x04, Local0) } Release (XDHK) Return (Local0) } Else { Noop } Return (0x00) } Method (MHSC, 1, NotSerialized) { If (LAnd (\CWAC, \WNTF)) { Acquire (XDHK, 0xFFFF) If (\OSC4) { If (LEqual (Arg0, 0x03)) { If (LNot (\CWAS)) { \PNTF (0x81) Store (0x01, \CWAS) } } ElseIf (LEqual (Arg0, 0x04)) { If (\CWAS) { \PNTF (0x81) Store (0x00, \CWAS) } } Else { Noop } } Release (XDHK) } Else { Noop } } Method (CKC4, 1, NotSerialized) { Store (0x00, Local0) If (\C4WR) { If (LNot (\C4AC)) { Or (Local0, 0x01, Local0) } } If (\C4NA) { Or (Local0, 0x02, Local0) } If (LAnd (\CWAC, \CWAS)) { Or (Local0, 0x04, Local0) } And (Local0, Not (Arg0), Local0) Return (Local0) } Method (MHQE, 0, NotSerialized) { Return (\C4WR) } Method (MHGE, 0, NotSerialized) { If (LAnd (\C4WR, \C4AC)) { Return (0x04) } Return (0x03) } Method (MHSE, 1, NotSerialized) { If (\C4WR) { Store (\C4AC, Local0) If (LEqual (Arg0, 0x03)) { Store (0x00, \C4AC) If (XOr (Local0, \C4AC)) { If (\OSC4) { \PNTF (0x81) } } } ElseIf (LEqual (Arg0, 0x04)) { Store (0x01, \C4AC) If (XOr (Local0, \C4AC)) { If (\OSC4) { \PNTF (0x81) } } } } } Method (UAWO, 1, NotSerialized) { Return (\UAWS (Arg0)) } Method (MLCG, 1, NotSerialized) { Store (\KBLS (0x00, 0x00), Local0) Return (Local0) } Method (MLCS, 1, NotSerialized) { Store (\KBLS (0x01, Arg0), Local0) If (LNot (And (Local0, 0x80000000))) { If (And (Arg0, 0x00010000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6001) } Else { If (LAnd (LNot (DSML), And (Arg0, 0x0100))) { Store (0x01, DSML) } If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x00020000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1012) } } } Return (Local0) } Method (DSSG, 1, NotSerialized) { Or (0x0400, \PDCI, Local0) Return (Local0) } Method (DSSS, 1, NotSerialized) { Or (\PDCI, Arg0, \PDCI) } Method (SBSG, 1, NotSerialized) { Return (\SYBC (0x00, 0x00)) } Method (SBSS, 1, NotSerialized) { Return (\SYBC (0x01, Arg0)) } Method (PBLG, 1, NotSerialized) { Store (\BRLV, Local0) Or (Local0, 0x0F00, Local1) Return (Local1) } Method (PBLS, 1, NotSerialized) { Store (Arg0, \BRLV) If (\VIGD) { \_SB.PCI0.LPC.EC.BRNS () } Else { \VBRC (\BRLV) } If (LNot (\NBCF)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6050) } Return (0x00) } Method (PMSG, 1, NotSerialized) { Store (\PRSM (0x00, 0x00), Local0) Return (Local0) } Method (PMSS, 1, NotSerialized) { \PRSM (0x01, Arg0) Return (0x00) } Method (ISSG, 1, NotSerialized) { Store (\ISSP, Local0) If (\ISSP) { Or (Local0, 0x01000000, Local0) Or (Local0, ShiftLeft (\ISFS, 0x19), Local0) } Or (Local0, 0x80, Local0) Or (Local0, And (\ISCG, 0x30), Local0) Return (Local0) } Method (ISSS, 1, NotSerialized) { Store (Arg0, \ISCG) Return (0x00) } Method (FFSG, 1, NotSerialized) { Return (0x00) } Method (FFSS, 1, NotSerialized) { Return (0x80000000) } Method (GMKS, 0, NotSerialized) { Return (\FNSC (0x02, 0x00)) } Method (SMKS, 1, NotSerialized) { Return (\FNSC (0x03, And (Arg0, 0x00010001))) } Method (INSG, 1, NotSerialized) { Store (\IOEN, Local0) Or (Local0, ShiftLeft (\IOST, 0x07), Local0) Or (Local0, ShiftLeft (\IOCP, 0x08), Local0) Or (Local0, 0x10000000, Local0) Return (Local0) } Method (INSS, 1, NotSerialized) { If (And (Arg0, 0x10000000)) { If (\IOCP) { Store (ShiftRight (And (Arg0, 0x80), 0x07), Local0) If (LNot (\EZRC (Local0))) { Store (Local0, \IOST) } } Return (0x00) } If (LAnd (\IOCP, And (Arg0, 0x01))) { Store (0x01, \IOEN) } Else { Store (0x00, \IOEN) If (\IOST) { If (LNot (\ISOC (0x00))) { Store (0x00, \IOST) } } } Return (0x00) } Method (GMMS, 1, NotSerialized) { Store (0x00040000, Local0) Store (\PMMD, Local1) If (LGreaterEqual (Local1, 0x06)) { Or (Local0, 0x03, Local0) } ElseIf (LGreaterEqual (Local1, 0x05)) { Or (Local0, 0x05, Local0) } ElseIf (LGreaterEqual (Local1, 0x04)) { Or (Local0, 0x04, Local0) } ElseIf (LGreaterEqual (Local1, 0x03)) { Or (Local0, 0x02, Local0) } ElseIf (LGreaterEqual (Local1, 0x01)) { Or (Local0, 0x01, Local0) } Return (Local0) } Method (GTMS, 1, NotSerialized) { Store (0x00010000, Local0) Or (Local0, \LVMD, Local0) Return (Local0) } Method (SSPI, 1, NotSerialized) { If (LEqual (Arg0, 0x00)) { Store (0x0100, Local0) Return (Local0) } ElseIf (LEqual (Arg0, 0x0100)) { Store (0x01, Local0) Return (Local0) } } Method (GTCS, 1, NotSerialized) { If (LEqual (Arg0, 0x00)) { Store (0x0100, Local0) Return (Local0) } ElseIf (LEqual (Arg0, 0x0100)) { If (\_SB.PCI0.LPC.EC.DIST) { Store (0x00, Local0) } Else { Store (0x01, Local0) } Return (Local0) } } Method (STCS, 1, NotSerialized) { If (LEqual (Arg0, 0x00)) { Store (0x0100, Local0) Return (Local0) } ElseIf (LEqual (Arg0, 0x0100)) { Store (0x01, \_SB.PCI0.LPC.EC.DIST) Return (0x00) } ElseIf (LEqual (Arg0, 0x0101)) { Store (0x00, \_SB.PCI0.LPC.EC.DIST) Return (0x00) } } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Name (INDV, 0x00) Method (MHQI, 0, NotSerialized) { If (And (\IPMS, 0x01)) { Or (INDV, 0x01, INDV) } If (And (\IPMS, 0x02)) { Or (INDV, 0x02, INDV) } If (And (\IPMS, 0x04)) { Or (INDV, 0x0100, INDV) } If (And (\IPMS, 0x08)) { Or (INDV, 0x0200, INDV) } If (And (\IPMS, 0x10)) { Or (INDV, 0x04, INDV) } Return (INDV) } Method (MHGI, 1, NotSerialized) { Name (RETB, Buffer (0x10){}) CreateByteField (RETB, 0x00, MHGS) ShiftLeft (0x01, Arg0, Local0) If (And (INDV, Local0)) { If (LEqual (Arg0, 0x00)) { CreateField (RETB, 0x08, 0x78, BRBU) Store (\IPMB, BRBU) Store (0x10, MHGS) } ElseIf (LEqual (Arg0, 0x01)) { CreateField (RETB, 0x08, 0x18, RRBU) Store (\IPMR, RRBU) Store (0x04, MHGS) } ElseIf (LEqual (Arg0, 0x08)) { CreateField (RETB, 0x10, 0x18, ODBU) CreateByteField (RETB, 0x01, MHGZ) Store (\IPMO, ODBU) If (LAnd (LEqual (^^BSTS, 0x00), LEqual (^^BDEV, 0x03))) { Or (0x01, MHGZ, MHGZ) Or (0x02, MHGZ, MHGZ) } Store (0x05, MHGS) } ElseIf (LEqual (Arg0, 0x09)) { CreateField (RETB, 0x10, 0x08, AUBU) Store (\IPMA, AUBU) Store (0x01, Index (RETB, 0x01)) Store (0x03, MHGS) } ElseIf (LEqual (Arg0, 0x02)) { Store (\VDYN (0x00, 0x00), Local1) And (Local1, 0x0F, Index (RETB, 0x02)) ShiftRight (Local1, 0x04, Local1) And (Local1, 0x0F, Index (RETB, 0x01)) Store (0x03, MHGS) } } Return (RETB) } Method (MHSI, 2, NotSerialized) { ShiftLeft (0x01, Arg0, Local0) If (And (INDV, Local0)) { If (LEqual (Arg0, 0x08)) { If (Arg1) { If (\H8DR) { Store (^^HPBU, Local1) } Else { And (\RBEC (0x47), 0x01, Local1) } If (LNot (Local1)) { Store (^^BGID (0x00), ^^BDEV) ^^NBIN (Local1) } } } ElseIf (LEqual (Arg0, 0x02)) { \VDYN (0x01, Arg1) } } } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q6A, 0, NotSerialized) // _Qxx: EC Query { If (HDMC) { Noop } ElseIf (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x04000000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x101B) } } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (MMTG, 0, NotSerialized) { Store (0x0101, Local0) If (HDMC) { Or (Local0, 0x00010000, Local0) } Return (Local0) } Method (MMTS, 1, NotSerialized) { If (HDMC) { Noop } ElseIf (LEqual (Arg0, 0x02)) { \_SB.PCI0.LPC.EC.LED (0x0E, 0x80) } ElseIf (LEqual (Arg0, 0x03)) { \_SB.PCI0.LPC.EC.LED (0x0E, 0xC0) } Else { \_SB.PCI0.LPC.EC.LED (0x0E, 0x00) } } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (PWMC, 0, NotSerialized) { Return (0x01) } Method (PWMG, 0, NotSerialized) { Store (\_SB.PCI0.LPC.EC.PWMH, Local0) ShiftLeft (Local0, 0x08, Local0) Or (Local0, \_SB.PCI0.LPC.EC.PWML, Local0) Return (Local0) } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q45, 0, NotSerialized) // _Qxx: EC Query { If (DOCD) { Sleep (0x64) \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x4010) Notify (\_SB.PCI0.XHCI.URTH.HSP3, 0x09) Notify (\_SB.PCI0.XHCI.URTH.SSP3, 0x09) } Else { Sleep (0x64) \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x4011) Notify (\_SB.PCI0.XHCI.URTH.HSP3, 0x09) Notify (\_SB.PCI0.XHCI.URTH.SSP3, 0x09) } } Method (DKID, 0, NotSerialized) { Store (\_SB.PCI0.LPC.DOI0, Local0) Store (\_SB.PCI0.LPC.DOI1, Local1) Store (\_SB.PCI0.LPC.DOI2, Local2) Store (\_SB.PCI0.LPC.DOI3, Local3) Or (Local0, ShiftLeft (Local1, 0x01), Local0) Or (Local0, ShiftLeft (Local2, 0x02), Local0) Or (Local0, ShiftLeft (Local3, 0x03), Local0) Return (Local0) } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (GDKS, 0, NotSerialized) { Store (0x00, Local0) If (LEqual (\_SB.PCI0.LPC.EC.DOCD, 0x01)) { If (LEqual (\_SB.PCI0.LPC.EC.DCID, 0x03)) { If (LNot (\_SB.PCI0.LPC.EC.DKAC)) { Or (Local0, 0x08, Local0) } Or (Local0, 0x01, Local0) Or (Local0, 0x00090000, Local0) } } Return (Local0) } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q3F, 0, NotSerialized) // _Qxx: EC Query { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6000) } Method (_Q74, 0, NotSerialized) // _Qxx: EC Query { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6060) } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (NUMG, 0, NotSerialized) { Store (0x00, Local0) Return (Local0) } } } } Device (PEG0) { Name (_ADR, 0x00010000) // _ADR: Address Name (_S3D, 0x03) // _S3D: S3 Device State Name (RID, 0x00) Device (PEGP) { Name (_ADR, 0x00) // _ADR: Address } } Device (PEG1) { Name (_ADR, 0x00010001) // _ADR: Address Device (PEGP) { Name (_ADR, 0x00) // _ADR: Address } } Device (PEG2) { Name (_ADR, 0x00010002) // _ADR: Address Device (PEGP) { Name (_ADR, 0x00) // _ADR: Address } } Device (GFX0) { Name (_ADR, 0x00020000) // _ADR: Address Name (RID, 0x00) } Device (IGBE) { Name (_ADR, 0x001F0006) // _ADR: Address Name (_S3D, 0x03) // _S3D: S3 Device State Name (RID, 0x00) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (PCIC (Arg0)) { Return (PCID (Arg0, Arg1, Arg2, Arg3)) } Return (0x00) } Name (_PRW, Package (0x02) // _PRW: Power Resources for Wake { 0x6D, 0x04 }) } Device (EXP1) { Name (_ADR, 0x001C0000) // _ADR: Address Name (RID, 0x00) Method (_INI, 0, NotSerialized) // _INI: Initialize { Store (LTR1, LTRN) Store (PML1, LMSL) Store (PNL1, LNSL) Store (OBF1, OBFN) } Name (LPRT, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0xFFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0xFFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0xFFFF, 0x03, \_SB.LNKD, 0x00 } }) Name (APRT, 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 } }) Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table { If (\GPIC) { Return (APRT) } Else { Return (LPRT) } } OperationRegion (PXCS, PCI_Config, 0x00, 0x0480) Field (PXCS, AnyAcc, NoLock, Preserve) { VDID, 32, Offset (0x50), L0SE, 1, , 3, LDIS, 1, Offset (0x51), Offset (0x52), , 13, LASX, 1, Offset (0x5A), ABPX, 1, , 2, PDCX, 1, , 2, PDSX, 1, Offset (0x5B), Offset (0x60), Offset (0x62), PSPX, 1, Offset (0xA4), D3HT, 2, Offset (0xD8), , 30, HPEX, 1, PMEX, 1, Offset (0xE2), , 2, L23E, 1, L23R, 1, Offset (0x324), , 3, LEDM, 1, Offset (0x420), , 30, DPGE, 1 } Field (PXCS, AnyAcc, NoLock, WriteAsZeros) { Offset (0xDC), , 30, HPSX, 1, PMSX, 1 } Name (LTRV, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (LEqual (Arg0, ToUUID ("e5c937d0-3553-4d7a-9117-ea4d19c3434d") /* Device Labeling Interface */)) { Switch (ToInteger (Arg2)) { Case (0x00) { Name (OPTS, Buffer (0x02) { 0x00, 0x00 }) CreateBitField (OPTS, 0x00, FUN0) CreateBitField (OPTS, 0x04, FUN4) CreateBitField (OPTS, 0x06, FUN6) CreateBitField (OPTS, 0x08, FUN8) CreateBitField (OPTS, 0x09, FUN9) If (LGreaterEqual (Arg1, 0x02)) { Store (0x01, FUN0) If (LTRE) { Store (0x01, FUN6) } If (OBFF) { Store (0x01, FUN4) } If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Store (0x01, FUN8) Store (0x01, FUN9) } } } Return (OPTS) } Case (0x04) { If (LGreaterEqual (Arg1, 0x02)) { If (OBFN) { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00 }) } Else { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) } } } Case (0x06) { If (LGreaterEqual (Arg1, 0x02)) { If (LTRN) { If (LOr (LEqual (LMSL, 0x00), LEqual (LNSL, 0x00))) { If (LEqual (PCHS, SPTH)) { Store (0x0846, LMSL) Store (0x0846, LNSL) } ElseIf (LEqual (PCHS, SPTL)) { Store (0x1003, LMSL) Store (0x1003, LNSL) } } Store (And (ShiftRight (LMSL, 0x0A), 0x07), Index (LTRV, 0x00)) Store (And (LMSL, 0x03FF), Index (LTRV, 0x01)) Store (And (ShiftRight (LNSL, 0x0A), 0x07), Index (LTRV, 0x02)) Store (And (LNSL, 0x03FF), Index (LTRV, 0x03)) Return (LTRV) } Else { Return (0x00) } } } Case (0x08) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (0x01) } } } Case (0x09) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (Package (0x05) { 0xC350, Ones, Ones, 0xC350, Ones }) } } } } } Return (Buffer (0x01) { 0x00 }) } Device (PXSX) { Name (_ADR, 0x00) // _ADR: Address } Method (HPME, 0, Serialized) { If (LAnd (LNotEqual (VDID, 0xFFFFFFFF), LEqual (PMSX, 0x01))) { Store (0x01, PMSX) Store (0x01, PSPX) } } } Device (EXP2) { Name (_ADR, 0x001C0001) // _ADR: Address Name (RID, 0x00) Method (_INI, 0, NotSerialized) // _INI: Initialize { Store (LTR2, LTRN) Store (PML2, LMSL) Store (PNL2, LNSL) Store (OBF2, OBFN) } Name (_PRW, Package (0x02) // _PRW: Power Resources for Wake { 0x69, 0x04 }) Name (LPRT, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, \_SB.LNKB, 0x00 }, Package (0x04) { 0xFFFF, 0x01, \_SB.LNKC, 0x00 }, Package (0x04) { 0xFFFF, 0x02, \_SB.LNKD, 0x00 }, Package (0x04) { 0xFFFF, 0x03, \_SB.LNKA, 0x00 } }) Name (APRT, 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 } }) Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table { If (\GPIC) { Return (APRT) } Else { Return (LPRT) } } OperationRegion (PXCS, PCI_Config, 0x00, 0x0480) Field (PXCS, AnyAcc, NoLock, Preserve) { VDID, 32, Offset (0x50), L0SE, 1, , 3, LDIS, 1, Offset (0x51), Offset (0x52), , 13, LASX, 1, Offset (0x5A), ABPX, 1, , 2, PDCX, 1, , 2, PDSX, 1, Offset (0x5B), Offset (0x60), Offset (0x62), PSPX, 1, Offset (0xA4), D3HT, 2, Offset (0xD8), , 30, HPEX, 1, PMEX, 1, Offset (0xE2), , 2, L23E, 1, L23R, 1, Offset (0x324), , 3, LEDM, 1, Offset (0x420), , 30, DPGE, 1 } Field (PXCS, AnyAcc, NoLock, WriteAsZeros) { Offset (0xDC), , 30, HPSX, 1, PMSX, 1 } Name (LTRV, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (LEqual (Arg0, ToUUID ("e5c937d0-3553-4d7a-9117-ea4d19c3434d") /* Device Labeling Interface */)) { Switch (ToInteger (Arg2)) { Case (0x00) { Name (OPTS, Buffer (0x02) { 0x00, 0x00 }) CreateBitField (OPTS, 0x00, FUN0) CreateBitField (OPTS, 0x04, FUN4) CreateBitField (OPTS, 0x06, FUN6) CreateBitField (OPTS, 0x08, FUN8) CreateBitField (OPTS, 0x09, FUN9) If (LGreaterEqual (Arg1, 0x02)) { Store (0x01, FUN0) If (LTRE) { Store (0x01, FUN6) } If (OBFF) { Store (0x01, FUN4) } If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Store (0x01, FUN8) Store (0x01, FUN9) } } } Return (OPTS) } Case (0x04) { If (LGreaterEqual (Arg1, 0x02)) { If (OBFN) { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00 }) } Else { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) } } } Case (0x06) { If (LGreaterEqual (Arg1, 0x02)) { If (LTRN) { If (LOr (LEqual (LMSL, 0x00), LEqual (LNSL, 0x00))) { If (LEqual (PCHS, SPTH)) { Store (0x0846, LMSL) Store (0x0846, LNSL) } ElseIf (LEqual (PCHS, SPTL)) { Store (0x1003, LMSL) Store (0x1003, LNSL) } } Store (And (ShiftRight (LMSL, 0x0A), 0x07), Index (LTRV, 0x00)) Store (And (LMSL, 0x03FF), Index (LTRV, 0x01)) Store (And (ShiftRight (LNSL, 0x0A), 0x07), Index (LTRV, 0x02)) Store (And (LNSL, 0x03FF), Index (LTRV, 0x03)) Return (LTRV) } Else { Return (0x00) } } } Case (0x08) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (0x01) } } } Case (0x09) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (Package (0x05) { 0xC350, Ones, Ones, 0xC350, Ones }) } } } } } Return (Buffer (0x01) { 0x00 }) } Device (PXSX) { Name (_ADR, 0x00) // _ADR: Address } Method (HPME, 0, Serialized) { If (LAnd (LNotEqual (VDID, 0xFFFFFFFF), LEqual (PMSX, 0x01))) { Store (0x01, PMSX) Store (0x01, PSPX) } } } Device (EXP3) { Name (_ADR, 0x001C0002) // _ADR: Address Name (RID, 0x00) Method (_INI, 0, NotSerialized) // _INI: Initialize { Store (LTR3, LTRN) Store (PML3, LMSL) Store (PNL3, LNSL) Store (OBF3, OBFN) } Name (LPRT, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, \_SB.LNKC, 0x00 }, Package (0x04) { 0xFFFF, 0x01, \_SB.LNKD, 0x00 }, Package (0x04) { 0xFFFF, 0x02, \_SB.LNKA, 0x00 }, Package (0x04) { 0xFFFF, 0x03, \_SB.LNKB, 0x00 } }) Name (APRT, 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 } }) Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table { If (\GPIC) { Return (APRT) } Else { Return (LPRT) } } OperationRegion (PXCS, PCI_Config, 0x00, 0x0480) Field (PXCS, AnyAcc, NoLock, Preserve) { VDID, 32, Offset (0x50), L0SE, 1, , 3, LDIS, 1, Offset (0x51), Offset (0x52), , 13, LASX, 1, Offset (0x5A), ABPX, 1, , 2, PDCX, 1, , 2, PDSX, 1, Offset (0x5B), Offset (0x60), Offset (0x62), PSPX, 1, Offset (0xA4), D3HT, 2, Offset (0xD8), , 30, HPEX, 1, PMEX, 1, Offset (0xE2), , 2, L23E, 1, L23R, 1, Offset (0x324), , 3, LEDM, 1, Offset (0x420), , 30, DPGE, 1 } Field (PXCS, AnyAcc, NoLock, WriteAsZeros) { Offset (0xDC), , 30, HPSX, 1, PMSX, 1 } Name (LTRV, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (LEqual (Arg0, ToUUID ("e5c937d0-3553-4d7a-9117-ea4d19c3434d") /* Device Labeling Interface */)) { Switch (ToInteger (Arg2)) { Case (0x00) { Name (OPTS, Buffer (0x02) { 0x00, 0x00 }) CreateBitField (OPTS, 0x00, FUN0) CreateBitField (OPTS, 0x04, FUN4) CreateBitField (OPTS, 0x06, FUN6) CreateBitField (OPTS, 0x08, FUN8) CreateBitField (OPTS, 0x09, FUN9) If (LGreaterEqual (Arg1, 0x02)) { Store (0x01, FUN0) If (LTRE) { Store (0x01, FUN6) } If (OBFF) { Store (0x01, FUN4) } If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Store (0x01, FUN8) Store (0x01, FUN9) } } } Return (OPTS) } Case (0x04) { If (LGreaterEqual (Arg1, 0x02)) { If (OBFN) { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00 }) } Else { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) } } } Case (0x06) { If (LGreaterEqual (Arg1, 0x02)) { If (LTRN) { If (LOr (LEqual (LMSL, 0x00), LEqual (LNSL, 0x00))) { If (LEqual (PCHS, SPTH)) { Store (0x0846, LMSL) Store (0x0846, LNSL) } ElseIf (LEqual (PCHS, SPTL)) { Store (0x1003, LMSL) Store (0x1003, LNSL) } } Store (And (ShiftRight (LMSL, 0x0A), 0x07), Index (LTRV, 0x00)) Store (And (LMSL, 0x03FF), Index (LTRV, 0x01)) Store (And (ShiftRight (LNSL, 0x0A), 0x07), Index (LTRV, 0x02)) Store (And (LNSL, 0x03FF), Index (LTRV, 0x03)) Return (LTRV) } Else { Return (0x00) } } } Case (0x08) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (0x01) } } } Case (0x09) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (Package (0x05) { 0xC350, Ones, Ones, 0xC350, Ones }) } } } } } Return (Buffer (0x01) { 0x00 }) } Device (PXSX) { Name (_ADR, 0x00) // _ADR: Address } Method (HPME, 0, Serialized) { If (LAnd (LNotEqual (VDID, 0xFFFFFFFF), LEqual (PMSX, 0x01))) { Store (0x01, PMSX) Store (0x01, PSPX) } } } Device (EXP5) { Name (_ADR, 0x001C0004) // _ADR: Address Name (RID, 0x00) Method (_INI, 0, NotSerialized) // _INI: Initialize { Store (LTR5, LTRN) Store (PML5, LMSL) Store (PNL5, LNSL) Store (OBF5, OBFN) } Name (LPRT, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, \_SB.LNKA, 0x00 }, Package (0x04) { 0xFFFF, 0x01, \_SB.LNKB, 0x00 }, Package (0x04) { 0xFFFF, 0x02, \_SB.LNKC, 0x00 }, Package (0x04) { 0xFFFF, 0x03, \_SB.LNKD, 0x00 } }) Name (APRT, 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 } }) Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table { If (\GPIC) { Return (APRT) } Else { Return (LPRT) } } OperationRegion (PXCS, PCI_Config, 0x00, 0x0480) Field (PXCS, AnyAcc, NoLock, Preserve) { VDID, 32, Offset (0x50), L0SE, 1, , 3, LDIS, 1, Offset (0x51), Offset (0x52), , 13, LASX, 1, Offset (0x5A), ABPX, 1, , 2, PDCX, 1, , 2, PDSX, 1, Offset (0x5B), Offset (0x60), Offset (0x62), PSPX, 1, Offset (0xA4), D3HT, 2, Offset (0xD8), , 30, HPEX, 1, PMEX, 1, Offset (0xE2), , 2, L23E, 1, L23R, 1, Offset (0x324), , 3, LEDM, 1, Offset (0x420), , 30, DPGE, 1 } Field (PXCS, AnyAcc, NoLock, WriteAsZeros) { Offset (0xDC), , 30, HPSX, 1, PMSX, 1 } Name (LTRV, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (LEqual (Arg0, ToUUID ("e5c937d0-3553-4d7a-9117-ea4d19c3434d") /* Device Labeling Interface */)) { Switch (ToInteger (Arg2)) { Case (0x00) { Name (OPTS, Buffer (0x02) { 0x00, 0x00 }) CreateBitField (OPTS, 0x00, FUN0) CreateBitField (OPTS, 0x04, FUN4) CreateBitField (OPTS, 0x06, FUN6) CreateBitField (OPTS, 0x08, FUN8) CreateBitField (OPTS, 0x09, FUN9) If (LGreaterEqual (Arg1, 0x02)) { Store (0x01, FUN0) If (LTRE) { Store (0x01, FUN6) } If (OBFF) { Store (0x01, FUN4) } If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Store (0x01, FUN8) Store (0x01, FUN9) } } } Return (OPTS) } Case (0x04) { If (LGreaterEqual (Arg1, 0x02)) { If (OBFN) { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00 }) } Else { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) } } } Case (0x06) { If (LGreaterEqual (Arg1, 0x02)) { If (LTRN) { If (LOr (LEqual (LMSL, 0x00), LEqual (LNSL, 0x00))) { If (LEqual (PCHS, SPTH)) { Store (0x0846, LMSL) Store (0x0846, LNSL) } ElseIf (LEqual (PCHS, SPTL)) { Store (0x1003, LMSL) Store (0x1003, LNSL) } } Store (And (ShiftRight (LMSL, 0x0A), 0x07), Index (LTRV, 0x00)) Store (And (LMSL, 0x03FF), Index (LTRV, 0x01)) Store (And (ShiftRight (LNSL, 0x0A), 0x07), Index (LTRV, 0x02)) Store (And (LNSL, 0x03FF), Index (LTRV, 0x03)) Return (LTRV) } Else { Return (0x00) } } } Case (0x08) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (0x01) } } } Case (0x09) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (Package (0x05) { 0xC350, Ones, Ones, 0xC350, Ones }) } } } } } Return (Buffer (0x01) { 0x00 }) } Device (PXSX) { Name (_ADR, 0x00) // _ADR: Address } Method (HPME, 0, Serialized) { If (LAnd (LNotEqual (VDID, 0xFFFFFFFF), LEqual (PMSX, 0x01))) { Store (0x01, PMSX) Store (0x01, PSPX) } } } Device (RP09) { Name (_ADR, 0x001D0000) // _ADR: Address Name (RID, 0x00) Method (_INI, 0, NotSerialized) // _INI: Initialize { Store (PML9, LMSL) Store (PNL9, LNSL) } Name (_PRW, Package (0x02) // _PRW: Power Resources for Wake { 0x69, 0x04 }) Name (LPRT, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, \_SB.LNKD, 0x00 }, Package (0x04) { 0xFFFF, 0x01, \_SB.LNKA, 0x00 }, Package (0x04) { 0xFFFF, 0x02, \_SB.LNKB, 0x00 }, Package (0x04) { 0xFFFF, 0x03, \_SB.LNKC, 0x00 } }) Name (APRT, Package (0x04) { Package (0x04) { 0xFFFF, 0x00, 0x00, 0x13 }, Package (0x04) { 0xFFFF, 0x01, 0x00, 0x10 }, Package (0x04) { 0xFFFF, 0x02, 0x00, 0x11 }, Package (0x04) { 0xFFFF, 0x03, 0x00, 0x12 } }) Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table { If (\GPIC) { Return (APRT) } Else { Return (LPRT) } } OperationRegion (PXCS, PCI_Config, 0x00, 0x0480) Field (PXCS, AnyAcc, NoLock, Preserve) { VDID, 32, Offset (0x50), L0SE, 1, , 3, LDIS, 1, Offset (0x51), Offset (0x52), , 13, LASX, 1, Offset (0x5A), ABPX, 1, , 2, PDCX, 1, , 2, PDSX, 1, Offset (0x5B), Offset (0x60), Offset (0x62), PSPX, 1, Offset (0xA4), D3HT, 2, Offset (0xD8), , 30, HPEX, 1, PMEX, 1, Offset (0xE2), , 2, L23E, 1, L23R, 1, Offset (0x324), , 3, LEDM, 1, Offset (0x420), , 30, DPGE, 1 } Field (PXCS, AnyAcc, NoLock, WriteAsZeros) { Offset (0xDC), , 30, HPSX, 1, PMSX, 1 } Name (LTRV, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (LEqual (Arg0, ToUUID ("e5c937d0-3553-4d7a-9117-ea4d19c3434d") /* Device Labeling Interface */)) { Switch (ToInteger (Arg2)) { Case (0x00) { Name (OPTS, Buffer (0x02) { 0x00, 0x00 }) CreateBitField (OPTS, 0x00, FUN0) CreateBitField (OPTS, 0x04, FUN4) CreateBitField (OPTS, 0x06, FUN6) CreateBitField (OPTS, 0x08, FUN8) CreateBitField (OPTS, 0x09, FUN9) If (LGreaterEqual (Arg1, 0x02)) { Store (0x01, FUN0) If (LTRE) { Store (0x01, FUN6) } If (OBFF) { Store (0x01, FUN4) } If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Store (0x01, FUN8) Store (0x01, FUN9) } } } Return (OPTS) } Case (0x04) { If (LGreaterEqual (Arg1, 0x02)) { If (OBFN) { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00 }) } Else { Return (Buffer (0x10) { /* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) } } } Case (0x06) { If (LGreaterEqual (Arg1, 0x02)) { If (LTRN) { If (LOr (LEqual (LMSL, 0x00), LEqual (LNSL, 0x00))) { If (LEqual (PCHS, SPTH)) { Store (0x0846, LMSL) Store (0x0846, LNSL) } ElseIf (LEqual (PCHS, SPTL)) { Store (0x1003, LMSL) Store (0x1003, LNSL) } } Store (And (ShiftRight (LMSL, 0x0A), 0x07), Index (LTRV, 0x00)) Store (And (LMSL, 0x03FF), Index (LTRV, 0x01)) Store (And (ShiftRight (LNSL, 0x0A), 0x07), Index (LTRV, 0x02)) Store (And (LNSL, 0x03FF), Index (LTRV, 0x03)) Return (LTRV) } Else { Return (0x00) } } } Case (0x08) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (0x01) } } } Case (0x09) { If (LEqual (ECR1, 0x01)) { If (LGreaterEqual (Arg1, 0x03)) { Return (Package (0x05) { 0xC350, Ones, Ones, 0xC350, Ones }) } } } } } Return (Buffer (0x01) { 0x00 }) } Device (PXSX) { Name (_ADR, 0x00) // _ADR: Address } Method (HPME, 0, Serialized) { If (LAnd (LNotEqual (VDID, 0xFFFFFFFF), LEqual (PMSX, 0x01))) { Store (0x01, PMSX) Store (0x01, PSPX) } } } Device (SAT1) { Name (_ADR, 0x00170000) // _ADR: Address Name (_S3D, 0x03) // _S3D: S3 Device State Name (RID, 0x00) } Device (SMBU) { Name (_ADR, 0x001F0004) // _ADR: Address Name (_S3D, 0x03) // _S3D: S3 Device State Name (RID, 0x00) Device (CP) { Name (_HID, EisaId ("ETDFF00")) // _HID: Hardware ID Method (_STA, 0, NotSerialized) // _STA: Status { If (LAnd (LGreaterEqual (OSYS, 0x07DD), LEqual (\_SB.PCI0.LPC.NFCD, 0x00))) { Return (0x0F) } Else { Return (0x00) } } Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { Name (RBUF, ResourceTemplate () { I2cSerialBusV2 (0x0015, DeviceInitiated, 0x00061A80, AddressingMode7Bit, "\\_SB.PCI0.SMBU", 0x00, ResourceConsumer, , Exclusive, ) }) Name (EBUF, Buffer (0x02) { 0x79, 0x00 Return (RBUF) } Else { Return (EBUF) } } } Device (NFC) { Name (_HID, EisaId ("BCM2F36")) // _HID: Hardware ID Name (_CID, EisaId ("BCM2F36")) // _CID: Compatible ID Name (_UID, 0x00) // _UID: Unique ID } Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (PCIC (Arg0)) { Return (PCID (Arg0, Arg1, Arg2, Arg3)) } Return (0x00) } OperationRegion (SMBP, PCI_Config, 0x50, 0x04) Field (SMBP, DWordAcc, NoLock, Preserve) { , 5, TCOB, 11, Offset (0x04) } Name (TCBV, 0x00) Method (TCBS, 0, NotSerialized) { If (LEqual (TCBV, 0x00)) { Store (ShiftLeft (\_SB.PCI0.SMBU.TCOB, 0x05), TCBV) } Return (TCBV) } OperationRegion (TCBA, SystemIO, TCBS (), 0x10) Field (TCBA, ByteAcc, NoLock, Preserve) { Offset (0x04), , 9, CPSC, 1 } Scope (\_SB.PCI0.SMBU.NFC) { Method (_STA, 0, NotSerialized) // _STA: Status { If (LOr (\_SB.PCI0.LPC.NFCD, \NFCF)) { Return (0x00) } Else { Return (0x0F) } } Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { Name (RBUF, ResourceTemplate () I2cSerialBusV2 (0x0077, DeviceInitiated, 0x00061A80, AddressingMode7Bit, "\\_SB.PCI0.SMBU", 0x00, ResourceConsumer, , Exclusive, ) }) Name (EBUF, Buffer (0x02) { 0x79, 0x00 }) If (LGreater (OSYS, 0x07D9)) { Return (RBUF) } Else { Return (EBUF) } } Method (GPEN, 0, NotSerialized) { Store (0x01, \_GPE.GPFG) } Method (SNFC, 1, NotSerialized) { If (Arg0) { Store (0x01, \_SB.PCI0.LPC.NFCP) } Else { Store (0x00, \_SB.PCI0.LPC.NFCP) } } } } Device (XHCI) { Name (_ADR, 0x00140000) // _ADR: Address Name (RID, 0x00) Device (URTH) { Name (_ADR, 0x00) // _ADR: Address Device (HSP0) { Name (_ADR, 0x01) // _ADR: Address } Device (HSP1) { Name (_ADR, 0x02) // _ADR: Address } Device (HSP2) { Name (_ADR, 0x03) // _ADR: Address } Device (HSP3) { Name (_ADR, 0x04) // _ADR: Address } Device (HSP4) { Name (_ADR, 0x05) // _ADR: Address } Device (HSP5) { Name (_ADR, 0x06) // _ADR: Address } Device (HSP6) { Name (_ADR, 0x07) // _ADR: Address } Device (HSP7) { Name (_ADR, 0x08) // _ADR: Address Device (WCAM) { Name (_ADR, 0x08) // _ADR: Address } } Device (HSP8) { Name (_ADR, 0x09) // _ADR: Address } Device (HSP9) { Name (_ADR, 0x0A) // _ADR: Address } Device (HSPA) { Name (_ADR, 0x0B) // _ADR: Address } Device (HSPB) { Name (_ADR, 0x0C) // _ADR: Address } Device (SSP0) { Name (_ADR, 0x0D) // _ADR: Address } Device (SSP1) { Name (_ADR, 0x0E) // _ADR: Address } Device (SSP2) { Name (_ADR, 0x0F) // _ADR: Address } Device (SSP3) { Name (_ADR, 0x10) // _ADR: Address } Device (SSP4) { Name (_ADR, 0x11) // _ADR: Address } Device (SSP5) { Name (_ADR, 0x12) // _ADR: Address } } Name (_PR0, Package (0x01) // _PR0: Power Resources for D0 { \_SB.PCI0.LPC.EC.PUBS }) Name (_PR1, Package (0x01) // _PR1: Power Resources for D1 { \_SB.PCI0.LPC.EC.PUBS }) Name (_PR2, Package (0x01) // _PR2: Power Resources for D2 { \_SB.PCI0.LPC.EC.PUBS }) Name (_PRW, Package (0x03) // _PRW: Power Resources for Wake { 0x6D, 0x03, \_SB.PCI0.LPC.EC.PUBS }) Scope (\_SB.PCI0) { Scope (\_SB.PCI0.XHCI) { OperationRegion (XPRT, PCI_Config, 0x00, 0x0100) Field (XPRT, AnyAcc, NoLock, Preserve) { DVID, 16, Offset (0x10), XADL, 32, XADH, 32, Offset (0xA2), , 2, D3HE, 1, Offset (0xA8), , 13, MW13, 1, MW14, 1, Offset (0xAC), Offset (0xB0), , 13, MB13, 1, MB14, 1, Offset (0xB4), Offset (0xD0), PR2, 32, PR2M, 32, PR3, 32, PR3M, 32 } Field (XPRT, ByteAcc, NoLock, Preserve) { Offset (0x74), D0D3, 2, Offset (0x75), PMEE, 1, , 6, PMES, 1 } Name (XFLT, 0x00) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { ADBG ("_DSM") ShiftLeft (XADH, 0x20, Local0) Or (Local0, XADL, Local0) And (Local0, 0xFFFFFFFFFFFFFFF0, Local0) OperationRegion (XMIO, SystemMemory, Local0, 0x9000) Field (XMIO, AnyAcc, Lock, Preserve) { Offset (0x550), PCCS, 1, , 4, PPLS, 4, PTPP, 1, Offset (0x8420), PRTM, 2 } If (PCIC (Arg0)) { Return (PCID (Arg0, Arg1, Arg2, Arg3)) } If (LEqual (Arg0, ToUUID ("ac340cb7-e901-45bf-b7e6-2b34ec931e23"))) { If (LEqual (Arg1, 0x03)) { Store (Arg1, XFLT) } If (LAnd (LGreater (PRTM, 0x00), LOr (LEqual (Arg1, 0x05), LEqual (Arg1, 0x06)))) { ADBG ("SSIC") If (LOr (LOr (LEqual (PCCS, 0x00), LEqual (PTPP, 0x00)), LAnd (LGreaterEqual (PPLS, 0x04), LLessEqual (PPLS, 0x0F)))) { If (LEqual (PPLS, 0x08)) { Store (One, D3HE) } Else { Store (Zero, D3HE) } } Else { Store (One, D3HE) } } } Return (0x00) } Method (_S3D, 0, NotSerialized) // _S3D: S3 Device State { Return (0x03) } Method (_S4D, 0, NotSerialized) // _S4D: S4 Device State { Return (0x03) } Method (_S3W, 0, NotSerialized) // _S3W: S3 Device Wake State { Return (0x03) } Method (_S4W, 0, NotSerialized) // _S4W: S4 Device Wake State { Return (0x03) } Method (_S0W, 0, NotSerialized) // _S0W: S0 Device Wake State { If (LEqual (XFLT, Zero)) { Return (0x00) } Else { Return (0x03) } } Method (_DSW, 3, NotSerialized) // _DSW: Device Sleep Wake { Store (Arg0, PMEE) } Method (_INI, 0, NotSerialized) // _INI: Initialize { If (CondRefOf (\_SB.PCI0.XHCI.URTH.INIR)) { \_SB.PCI0.XHCI.URTH.INIR () } } OperationRegion (XHCP, SystemMemory, Add (\_SB.PCI0.GPCB (), 0x000A0000), 0x0100) Field (XHCP, AnyAcc, Lock, Preserve) { Offset (0x04), PDBM, 16, Offset (0x10), MEMB, 64 } Name (XRST, Zero) Method (_PS0, 0, Serialized) // _PS0: Power State 0 { If (LEqual (^DVID, 0xFFFF)) { Return (Zero) } Store (^MEMB, Local2) Store (^PDBM, Local1) And (^PDBM, Not (0x06), ^PDBM) Store (^D0D3, Local3) Store (0x00, ^D0D3) Store (\XWMB, ^MEMB) Or (Local1, 0x02, ^PDBM) OperationRegion (MC11, SystemMemory, \XWMB, 0x9000) Field (MC11, DWordAcc, Lock, Preserve) { Offset (0x81C4), , 2, UPSW, 2 } Store (0x00, UPSW) And (^PDBM, Not (0x02), ^PDBM) Store (Local2, ^MEMB) Store (Local1, ^PDBM) If (CondRefOf (\_SB.PCI0.XHCI.PS0X)) { \_SB.PCI0.XHCI.PS0X () } If (LAnd (UWAB, LEqual (D0D3, 0x00))) { Store (0x01, MPMC) While (PMFS) { Sleep (0x0A) } } } Method (_PS3, 0, Serialized) // _PS3: Power State 3 { If (LEqual (^DVID, 0xFFFF)) { Return (Zero) } Store (^MEMB, Local2) Store (^PDBM, Local1) And (^PDBM, Not (0x06), ^PDBM) Store (0x00, ^D0D3) Store (\XWMB, ^MEMB) Or (Local1, 0x02, ^PDBM) OperationRegion (MC11, SystemMemory, \XWMB, 0x9000) Field (MC11, DWordAcc, Lock, Preserve) { Offset (0x81C4), , 2, UPSW, 2 } Store (0x03, UPSW) And (^PDBM, Not (0x02), ^PDBM) Store (0x03, ^D0D3) Store (Local2, ^MEMB) Store (Local1, ^PDBM) If (CondRefOf (\_SB.PCI0.XHCI.PS3X)) { \_SB.PCI0.XHCI.PS3X () } If (LAnd (UWAB, LEqual (D0D3, 0x03))) { Store (0x03, MPMC) While (PMFS) { Sleep (0x0A) } } } Method (CUID, 1, Serialized) { If (LEqual (Arg0, ToUUID ("7c9512a9-1705-4cb4-af7d-506a2423ab71"))) { Return (0x01) } Return (0x00) } Scope (\_SB.PCI0.XHCI.URTH) { Method (_PS0, 0, Serialized) // _PS0: Power State 0 { If (LEqual (\_SB.PCI0.XHCI.DVID, 0xFFFF)) { Return (Zero) } If (CondRefOf (\_SB.PCI0.XHCI.URTH.PS0X)) { \_SB.PCI0.XHCI.URTH.PS0X () } } Method (_PS2, 0, Serialized) // _PS2: Power State 2 { If (LEqual (\_SB.PCI0.XHCI.DVID, 0xFFFF)) { Return (Zero) } If (CondRefOf (\_SB.PCI0.XHCI.URTH.PS2X)) { \_SB.PCI0.XHCI.URTH.PS2X () } } Method (_PS3, 0, Serialized) // _PS3: Power State 3 { If (LEqual (\_SB.PCI0.XHCI.DVID, 0xFFFF)) { Return (Zero) } If (CondRefOf (\_SB.PCI0.XHCI.URTH.PS3X)) { \_SB.PCI0.XHCI.URTH.PS3X () } } } } } Scope (\) { Name (UPC0, Package (0x04) { 0xFF, 0x00, 0x00, 0x00 }) Name (PLD0, Buffer (0x10) { /* 0000 */ 0x81, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x99, 0x12, 0x80, 0x00, 0x03, 0x00, 0x00, 0x00 }) Name (UPC1, Package (0x04) { 0x00, 0xFF, 0x00, 0x00 }) Name (PLD1, Buffer (0x10) { /* 0000 */ 0x81, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x30, 0x1C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) Name (UPC2, Package (0x04) { 0xFF, 0x00, 0x00, 0x00 }) Name (PLD2, Buffer (0x10) { /* 0000 */ 0x81, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x99, 0x10, 0x00, 0x01, 0x03, 0x00, 0x00, 0x00 }) Name (UPC3, Package (0x04) { 0xFF, 0x00, 0x00, 0x00 }) Name (PLD3, Buffer (0x10) { /* 0000 */ 0x81, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x91, 0x10, 0x80, 0x01, 0x03, 0x00, 0x00, 0x00 }) Name (UPCI, Package (0x04) { 0x00, 0xFF, 0x00, 0x00 }) Name (PLDI, Buffer (0x10) { /* 0000 */ 0x81, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x30, 0x1C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) Name (PLDC, Buffer (0x14) { /* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0008 */ 0x24, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* 0010 */ 0xDD, 0x00, 0x95, 0x00 }) } Scope (\_SB.PCI0.XHCI.URTH.HSP0) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPC0, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLD0, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP1) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPC1, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLD1, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP2) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPC2, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLD2, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP3) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) If (LEqual (\_SB.PCI0.LPC.EC.DOCD, 0x01)) { CopyObject (\UPCI, UPCP) } Else { CopyObject (\UPC3, UPCP) } Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) If (LEqual (\_SB.PCI0.LPC.EC.DOCD, 0x01)) { Store (\PLDI, PLDP) } Else { Store (\PLD3, PLDP) } Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP4) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP5) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP6) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP7) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP8) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP9) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSPA) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSPB) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.SSP0) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPC0, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLD0, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.SSP1) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPC1, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLD1, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.SSP2) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPC2, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLD2, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.SSP3) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.SSP4) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.SSP5) { Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Name (UPCP, Package (0x04) { 0x00, 0x00, 0x00, 0x00 }) CopyObject (\UPCI, UPCP) Return (UPCP) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Name (PLDP, Buffer (0x10){}) Store (\PLDI, PLDP) Return (PLDP) } } Scope (\_SB.PCI0.XHCI.URTH.HSP7.WCAM) { Method (_STA, 0, NotSerialized) // _STA: Status { If (\WIN8) { Return (0x0F) } Else { Return (0x00) } } Method (_UPC, 0, Serialized) // _UPC: USB Port Capabilities { Return (\UPCI) } Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device { Return (\PLDC) } } } Device (HDEF) { Name (_ADR, 0x001F0003) // _ADR: Address Name (_S3D, 0x03) // _S3D: S3 Device State Name (RID, 0x00) Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method { ADBG ("HDAS _DSM") If (PCIC (Arg0)) { Return (PCID (Arg0, Arg1, Arg2, Arg3)) } Return (0x00) } } Device (HECI) { Name (_ADR, 0x00160000) // _ADR: Address Name (_S3D, 0x03) // _S3D: S3 Device State Name (RID, 0x00) Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (PCIC (Arg0)) { Return (PCID (Arg0, Arg1, Arg2, Arg3)) } Return (0x00) } } } Scope (\_SB.PCI0.LPC.EC) { Name (BDEV, 0xFF) Name (BSTS, 0x00) Name (BHKE, 0x00) Method (_Q2C, 0, NotSerialized) // _Qxx: EC Query { If (LEqual (BSTS, 0x00)) { Store (BGID (0x00), BDEV) NBRE (BDEV) } } Method (_Q2D, 0, NotSerialized) // _Qxx: EC Query { Store (BGID (0x00), BDEV) NBIN (BDEV) } Method (_Q38, 0, NotSerialized) // _Qxx: EC Query { Store (BGID (0x00), Local0) If (LEqual (Local0, 0x0F)) { BDIS () \BHDP (0x01, 0x00) NBEJ (BDEV) Store (Local0, BDEV) If (LEqual (\BIDE, 0x03)) { Store (0x00, \_SB.PCI0.SAT1.PRIM.GTME) Store (0x00, \_SB.PCI0.SAT1.SCND.GTME) } } ElseIf (HPBU){} Else { Store (Local0, BDEV) NBIN (Local0) } } Method (NBRE, 1, NotSerialized) { If (LLess (Arg0, 0x0C)) { If (LEqual (\BIDE, 0x03)) { Notify (\_SB.PCI0.SAT1.SCND.MSTR, 0x03) } Else { Notify (\_SB.PCI0.SAT1.PRT1, 0x03) } } } Method (NBEJ, 1, NotSerialized) { If (LEqual (BSTS, 0x00)) { If (LLess (Arg0, 0x0C)) { If (LEqual (\BIDE, 0x03)) { Notify (\_SB.PCI0.SAT1.SCND.MSTR, 0x01) } Else { Notify (\_SB.PCI0.SAT1.PRT1, 0x01) } } } BEEP (0x00) Store (0x00, BSTS) } Method (NBIN, 1, NotSerialized) { If (LLess (Arg0, 0x0C)) { BEN (0x01) If (LEqual (\BIDE, 0x03)) { Notify (\_SB.PCI0.SAT1.SCND.MSTR, 0x01) } Else { Notify (\_SB.PCI0.SAT1.PRT1, 0x01) } } BEEP (0x00) Store (0x00, BSTS) } Method (BEJ0, 1, NotSerialized) { If (Arg0) { BDIS () \BHDP (0x01, 0x00) Store (0x01, BSTS) If (BHKE) { Store (0x00, BHKE) \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x3003) } } Else { Store (0x00, BSTS) } } Method (BEJ3, 1, NotSerialized) { If (Arg0) { BDIS () Store (0x01, BSTS) } Else { Store (0x00, BSTS) } } Method (BPTS, 1, NotSerialized) { Store (0x01, HDBM) If (LNotEqual (BSTS, 0x00)) { Store (0x0F, BDEV) Store (0x00, BSTS) } Store (0x00, BHKE) BUWK (0x00) } Method (BWAK, 1, NotSerialized) { BUWK (0x00) Store (BGID (0x00), Local0) If (LEqual (BSTS, 0x00)) { If (LNotEqual (Local0, BDEV)) { NBEJ (BDEV) Store (Local0, BDEV) NBIN (Local0) } ElseIf (LOr (\LFDC, LNotEqual (BDEV, 0x0D))) { If (LNotEqual (Local0, 0x0F)) { If (HPBU) { If (LLessEqual (Arg0, 0x02)){} Else { NBRE (Local0) } } } } } If (LLess (BDEV, 0x0C)) { \UBIS (0x00) } Else { \UBIS (0x01) } } Method (BDIS, 0, NotSerialized) { If (LNot (\_SB.PCI0.LPC.CSON)) { If (LNot (\_SB.PCI0.LPC.GLIS)) { \UBIS (0x01) } Store (0x01, \_SB.PCI0.LPC.CSON) Store (0x0F, \IDET) } } Method (BPON, 1, NotSerialized) { If (\_SB.PCI0.LPC.CSON) { Store (0x00, \_SB.PCI0.LPC.CSON) If (\_SB.PCI0.LPC.GLIS) { \UBIS (0x00) } } } Method (BEN, 1, NotSerialized) { If (\_SB.PCI0.LPC.CSON) { BPON (Arg0) If (Arg0) { IRDY () } } } Method (BSTA, 1, NotSerialized) { If (\_SB.PCI0.LPC.CSON) { Return (0x00) } BINI () If (LEqual (Arg0, 0x01)) { Return (LLess (BDEV, 0x0C)) } Return (0x00) } Method (BUWK, 1, NotSerialized) { If (\H8DR) { If (Arg0) { Store (0x01, \_SB.PCI0.LPC.EC.HWBU) } Else { Store (0x00, \_SB.PCI0.LPC.EC.HWBU) } } ElseIf (Arg0) { \MBEC (0x32, 0xFF, 0x80) } Else { \MBEC (0x32, 0x7F, 0x00) } } Method (BINI, 0, NotSerialized) { If (LEqual (BDEV, 0xFF)) { Store (BGID (0x00), BDEV) } } Method (BGID, 1, NotSerialized) { If (Arg0) { Store (0xFF, Local0) } Else { If (\H8DR) { Store (HPBU, Local1) Store (HBID, Local2) } Else { Store (RBEC (0x47), Local2) And (Local2, 0x01, Local1) And (Local2, 0x04, Local2) ShiftRight (Local2, 0x02, Local2) } If (Local2) { Store (0x0F, Local0) } ElseIf (HDUB) { Store (0x0F, Local0) } ElseIf (LOr (LEqual (\IDET, 0x03), LEqual (\IDET, 0x06))) { Store (\IDET, Local0) } Else { Store (0x07, Local0) } If (LEqual (Local0, 0x0F)){} } If (LAnd (\HDUB, LLess (Local0, 0x0C))) { Store (0x0F, Local0) } Return (Local0) } Method (IRDY, 0, NotSerialized) { Store (0x01F4, Local0) Store (0x3C, Local1) Store (Zero, Local2) While (Local1) { Sleep (Local0) Store (\BCHK (), Local3) If (LNot (Local3)) { Break } If (LEqual (Local3, 0x02)) { Store (One, Local2) Break } Decrement (Local1) } Return (Local2) } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q43, 0, NotSerialized) // _Qxx: EC Query { \UCMS (0x18) } Method (SAUM, 1, NotSerialized) { If (LGreater (Arg0, 0x03)) { Noop } ElseIf (\H8DR) { Store (Arg0, HAUM) } Else { \MBEC (0x03, 0x9F, ShiftLeft (Arg0, 0x05)) } } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (GSMS, 1, NotSerialized) { Return (\AUDC (0x00, 0x00)) } Method (SSMS, 1, NotSerialized) { Return (\AUDC (0x01, And (Arg0, 0x01))) } Method (SHDA, 1, NotSerialized) { Return (\AUDC (0x02, And (Arg0, 0x01))) } } Scope (\_SB.PCI0.LPC.EC) { Name (BRTW, Package (0x12) { 0x64, 0x64, 0x05, 0x0A, 0x14, 0x19, 0x1E, 0x23, 0x28, 0x2D, 0x32, 0x37, 0x3C, 0x41, 0x46, 0x50, 0x5A, 0x64 }) Name (BRTB, Package (0x04) { Package (0x16) { 0x1E, 0x03, 0x03, 0x06, 0x0A, 0x0E, 0x11, 0x16, 0x1B, 0x21, 0x28, 0x32, 0x41, 0x54, 0x73, 0xA2, 0xD5, 0xFF, 0xDC, 0xDC, 0x03, 0x03 }, Package (0x16) { 0x19, 0x03, 0x03, 0x06, 0x0B, 0x0F, 0x17, 0x21, 0x2E, 0x3A, 0x43, 0x50, 0x5F, 0x78, 0x95, 0xC1, 0xDC, 0xFF, 0xDC, 0xDC, 0x03, 0x03 }, Package (0x16) { 0x1B, 0x03, 0x03, 0x06, 0x0A, 0x0E, 0x13, 0x18, 0x1F, 0x27, 0x31, 0x3A, 0x48, 0x5E, 0x82, 0xB4, 0xE2, 0xFF, 0xDC, 0xDC, 0x03, 0x03 }, Package (0x16) { 0x28, 0x03, 0x03, 0x04, 0x06, 0x08, 0x0A, 0x0C, 0x11, 0x18, 0x20, 0x2C, 0x3B, 0x50, 0x6C, 0x92, 0xC1, 0xFF, 0x0393, 0x0393, 0x03, 0x03 } }) Name (BRTD, Package (0x04) { Package (0x65) { 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1C, 0x1D, 0x1F, 0x21, 0x22, 0x24, 0x26, 0x28, 0x2A, 0x2C, 0x2E, 0x30, 0x33, 0x35, 0x37, 0x3A, 0x3C, 0x3F, 0x41, 0x44, 0x46, 0x49, 0x4C, 0x4F, 0x51, 0x54, 0x57, 0x5A, 0x5D, 0x61, 0x64, 0x67, 0x6A, 0x6E, 0x71, 0x75, 0x78, 0x7C, 0x80, 0x83, 0x87, 0x8B, 0x8F, 0x93, 0x97, 0x9B, 0x9F, 0xA3, 0xA8, 0xAC, 0xB0, 0xB5, 0xB9, 0xBE, 0xC3, 0xC7, 0xCC, 0xCE, 0xD1, 0xD3, 0xD6, 0xD8, 0xDB, 0xDD, 0xE0, 0xE2, 0xE5, 0xE7, 0xEA, 0xEC, 0xEF, 0xF2, 0xF4, 0xF7, 0xFA, 0xFC, 0xFF }, Package (0x65) { 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F, 0x20, 0x21, 0x22, 0x23, 0x25, 0x26, 0x28, 0x2A, 0x2C, 0x2E, 0x2F, 0x31, 0x33, 0x35, 0x37, 0x3A, 0x3C, 0x3E, 0x40, 0x42, 0x45, 0x47, 0x4A, 0x4C, 0x4E, 0x51, 0x54, 0x56, 0x59, 0x5C, 0x5E, 0x61, 0x64, 0x67, 0x6A, 0x6D, 0x70, 0x73, 0x76, 0x79, 0x7D, 0x80, 0x83, 0x86, 0x8A, 0x8D, 0x91, 0x94, 0x98, 0x9C, 0x9F, 0xA3, 0xA7, 0xAB, 0xAF, 0xB4, 0xB8, 0xBC, 0xC1, 0xC5, 0xCA, 0xCE, 0xD3, 0xD8, 0xDC, 0xE1, 0xE6, 0xEB, 0xF0, 0xF5, 0xFA, 0xFF }, Package (0x65) { 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1C, 0x1D, 0x1F, 0x21, 0x22, 0x24, 0x26, 0x28, 0x2A, 0x2C, 0x2E, 0x30, 0x33, 0x35, 0x37, 0x3A, 0x3C, 0x3F, 0x41, 0x44, 0x46, 0x49, 0x4C, 0x4F, 0x51, 0x54, 0x57, 0x5A, 0x5D, 0x61, 0x64, 0x67, 0x6A, 0x6E, 0x71, 0x75, 0x78, 0x7C, 0x80, 0x83, 0x87, 0x8B, 0x8F, 0x93, 0x97, 0x9B, 0x9F, 0xA3, 0xA8, 0xAC, 0xB0, 0xB5, 0xB9, 0xBE, 0xC3, 0xC7, 0xCC, 0xCE, 0xD1, 0xD3, 0xD6, 0xD8, 0xDB, 0xDD, 0xE0, 0xE2, 0xE5, 0xE7, 0xEA, 0xEC, 0xEF, 0xF2, 0xF4, 0xF7, 0xFA, 0xFC, 0xFF }, Package (0x65) { 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1C, 0x1D, 0x1F, 0x21, 0x22, 0x24, 0x26, 0x28, 0x2A, 0x2C, 0x2E, 0x30, 0x33, 0x35, 0x37, 0x3A, 0x3C, 0x3F, 0x41, 0x44, 0x46, 0x49, 0x4C, 0x4F, 0x51, 0x54, 0x57, 0x5A, 0x5D, 0x61, 0x64, 0x67, 0x6A, 0x6E, 0x71, 0x75, 0x78, 0x7C, 0x80, 0x83, 0x87, 0x8B, 0x8F, 0x93, 0x97, 0x9B, 0x9F, 0xA3, 0xA8, 0xAC, 0xB0, 0xB5, 0xB9, 0xBE, 0xC3, 0xC7, 0xCC, 0xCE, 0xD1, 0xD3, 0xD6, 0xD8, 0xDB, 0xDD, 0xE0, 0xE2, 0xE5, 0xE7, 0xEA, 0xEC, 0xEF, 0xF2, 0xF4, 0xF7, 0xFA, 0xFC, 0xFF } }) Method (_Q14, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x8000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1010) } If (\VIGD) { Notify (\_SB.PCI0.GFX0.DD1F, 0x86) } } Method (_Q15, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x00010000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1011) } If (\VIGD) { Notify (\_SB.PCI0.GFX0.DD1F, 0x87) } Return (Zero) } Method (BRNS, 0, NotSerialized) { Add (\BRLV, 0x02, Local0) Store (\BRTN, Local3) If (\_SB.PCI0.GFX0.DRDY) { Store (DerefOf (Index (DerefOf (Index (BRTB, Local3)), Local0)), Local2) \_SB.PCI0.GFX0.AINT (0x01, Local2) } Else { \UCMS (0x12) } } Method (BRCF, 1, NotSerialized) { If (LLess (Arg0, 0x00)) { Return (0x00) } If (LGreater (Arg0, 0x64)) { Return (0x0F) } Add (Arg0, 0x03, Local0) Multiply (Local0, 0x0F, Local0) Divide (Local0, 0x64, Local0, Local1) Return (Local1) } Method (BRCD, 1, NotSerialized) { Store (DerefOf (Index (DerefOf (Index (BRTD, \BRTN)), Arg0)), Local0) Return (Local0) } Method (BFRQ, 0, NotSerialized) { Store (0x80000100, Local0) Store (DerefOf (Index (DerefOf (Index (BRTB, \BRTN)), 0x13)), Local1) Or (ShiftLeft (Local1, 0x09), Local0, Local0) Store (DerefOf (Index (DerefOf (Index (BRTB, \BRTN)), 0x15)), Local1) Or (Local1, Local0, Local0) Return (Local0) } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q19, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x00800000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1018) } \UCMS (0x03) } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q63, 0, NotSerialized) // _Qxx: EC Query { If (\_SB.PCI0.LPC.EC.HKEY.MHKK (0x00080000)) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x1014) } \UCMS (0x0B) } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q70, 0, NotSerialized) // _Qxx: EC Query { FNST () } Method (_Q72, 0, NotSerialized) // _Qxx: EC Query { FNST () } Method (_Q73, 0, NotSerialized) // _Qxx: EC Query { FNST () } Method (FNST, 0, NotSerialized) { If (\H8DR) { Store (HFNS, Local0) Store (HFNE, Local1) } Else { And (\RBEC (0x0E), 0x03, Local0) And (\RBEC (0x00), 0x08, Local1) } If (Local1) { If (LEqual (Local0, 0x00)) { \UCMS (0x11) } If (LEqual (Local0, 0x01)) { \UCMS (0x0F) } If (LEqual (Local0, 0x02)) { \UCMS (0x10) } \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6005) } } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (GHSL, 1, NotSerialized) { Return (\FNSC (0x00, 0x00)) } Method (SHSL, 1, NotSerialized) { Return (\FNSC (0x01, And (Arg0, 0x00010001))) } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Name (WGFL, 0x00) Method (WSIF, 0, NotSerialized) { Return (0x00) } Method (WLSW, 0, NotSerialized) { Return (0x10010001) } Method (GWAN, 0, NotSerialized) { Store (0x00, Local0) If (And (WGFL, 0x01)) { Or (Local0, 0x01, Local0) } If (And (WGFL, 0x08)) { Return (Local0) } If (WPWS ()) { Or (Local0, 0x02, Local0) } Or (Local0, 0x04, Local0) Return (Local0) } Method (SWAN, 1, NotSerialized) { If (And (Arg0, 0x02)) { WPWC (0x01) } Else { WPWC (0x00) } } Method (GBDC, 0, NotSerialized) { Store (0x00, Local0) If (And (WGFL, 0x10)) { Or (Local0, 0x01, Local0) } If (And (WGFL, 0x80)) { Return (Local0) } If (BPWS ()) { Or (Local0, 0x02, Local0) } Or (Local0, 0x04, Local0) Return (Local0) } Method (SBDC, 1, NotSerialized) { If (And (Arg0, 0x02)) { BPWC (0x01) } Else { BPWC (0x00) } } Method (WPWS, 0, NotSerialized) { If (\H8DR) { Store (\_SB.PCI0.LPC.EC.DCWW, Local0) } Else { Store (ShiftRight (And (\RBEC (0x3A), 0x40), 0x06), Local0) } Return (Local0) } Method (WPWC, 1, NotSerialized) { If (LAnd (Arg0, LAnd (And (WGFL, 0x01), LNot (And (WGFL, 0x08))))) { If (\H8DR) { Store (One, \_SB.PCI0.LPC.EC.DCWW) } Else { \MBEC (0x3A, 0xFF, 0x40) } Or (WGFL, 0x02, WGFL) } Else { If (\H8DR) { Store (Zero, \_SB.PCI0.LPC.EC.DCWW) } Else { \MBEC (0x3A, 0xBF, 0x00) } And (WGFL, Not (0x02), WGFL) } } Method (BPWS, 0, NotSerialized) { If (\H8DR) { Store (\_SB.PCI0.LPC.EC.DCBD, Local0) } Else { Store (ShiftRight (And (\RBEC (0x3A), 0x10), 0x04), Local0) } Return (Local0) } Method (BPWC, 1, NotSerialized) { If (LAnd (Arg0, LAnd (And (WGFL, 0x10), LNot (And (WGFL, 0x80))))) { If (\H8DR) { Store (One, \_SB.PCI0.LPC.EC.DCBD) } Else { \MBEC (0x3A, 0xFF, 0x10) } Or (WGFL, 0x20, WGFL) } Else { If (\H8DR) { Store (Zero, \_SB.PCI0.LPC.EC.DCBD) } Else { \MBEC (0x3A, 0xEF, 0x00) } And (WGFL, Not (0x20), WGFL) } } Method (WGIN, 0, NotSerialized) { Store (0x00, WGFL) Store (\WGSV (0x01), WGFL) If (\WIN8) { If (LAnd (WGFL, 0x10)) { BPWC (0x01) } } If (WPWS ()) { Or (WGFL, 0x02, WGFL) } If (BPWS ()) { Or (WGFL, 0x20, WGFL) } } Method (WGPS, 1, NotSerialized) { If (LGreaterEqual (Arg0, 0x04)) { \BLTH (0x05) } } Method (WGWK, 1, NotSerialized) { Noop } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q41, 0, NotSerialized) // _Qxx: EC Query { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x7000) } } Device (WMI1) { Name (_HID, EisaId ("PNP0C14")) // _HID: Hardware ID Name (_UID, 0x01) // _UID: Unique ID Name (_WDG, Buffer (0xB4) { /* 0000 */ 0x0E, 0x23, 0xF5, 0x51, 0x77, 0x96, 0xCD, 0x46, /* 0008 */ 0xA1, 0xCF, 0xC0, 0xB2, 0x3E, 0xE3, 0x4D, 0xB7, /* 0010 */ 0x41, 0x30, 0x50, 0x05, 0x64, 0x9A, 0x47, 0x98, /* 0018 */ 0xF5, 0x33, 0x33, 0x4E, 0xA7, 0x07, 0x8E, 0x25, /* 0020 */ 0x1E, 0xBB, 0xC3, 0xA1, 0x41, 0x31, 0x01, 0x06, /* 0028 */ 0xEF, 0x54, 0x4B, 0x6A, 0xED, 0xA5, 0x33, 0x4D, /* 0030 */ 0x94, 0x55, 0xB0, 0xD9, 0xB4, 0x8D, 0xF4, 0xB3, /* 0038 */ 0x41, 0x32, 0x01, 0x06, 0xB6, 0xEB, 0xF1, 0x74, /* 0040 */ 0x7A, 0x92, 0x7D, 0x4C, 0x95, 0xDF, 0x69, 0x8E, /* 0048 */ 0x21, 0xE8, 0x0E, 0xB5, 0x41, 0x33, 0x01, 0x06, /* 0050 */ 0xFF, 0x04, 0xEF, 0x7E, 0x28, 0x43, 0x7C, 0x44, /* 0058 */ 0xB5, 0xBB, 0xD4, 0x49, 0x92, 0x5D, 0x53, 0x8D, /* 0060 */ 0x41, 0x34, 0x01, 0x06, 0x9E, 0x15, 0xDB, 0x8A, /* 0068 */ 0x32, 0x1E, 0x5C, 0x45, 0xBC, 0x93, 0x30, 0x8A, /* 0070 */ 0x7E, 0xD9, 0x82, 0x46, 0x41, 0x35, 0x01, 0x01, /* 0078 */ 0xFD, 0xD9, 0x51, 0x26, 0x1C, 0x91, 0x69, 0x4B, /* 0080 */ 0xB9, 0x4E, 0xD0, 0xDE, 0xD5, 0x96, 0x3B, 0xD7, /* 0088 */ 0x41, 0x36, 0x01, 0x06, 0x1A, 0x65, 0x64, 0x73, /* 0090 */ 0x2F, 0x13, 0xE7, 0x4F, 0xAD, 0xAA, 0x40, 0xC6, /* 0098 */ 0xC7, 0xEE, 0x2E, 0x3B, 0x41, 0x37, 0x01, 0x06, /* 00A0 */ 0x21, 0x12, 0x90, 0x05, 0x66, 0xD5, 0xD1, 0x11, /* 00A8 */ 0xB2, 0xF0, 0x00, 0xA0, 0xC9, 0x06, 0x29, 0x10, /* 00B0 */ 0x42, 0x41, 0x01, 0x00 }) Name (RETN, Package (0x05) { "Success", "Not Supported", "Invalid Parameter", "Access Denied", "System Busy" }) Name (ITEM, Package (0x5D) { Package (0x02) { 0x0E, "WakeOnLAN" }, Package (0x02) { 0x00, "EthernetLANOptionROM" }, Package (0x02) { 0x00, "USBBIOSSupport" }, Package (0x02) { 0x00, "AlwaysOnUSB" }, Package (0x02) { 0x01, "TrackPoint" }, Package (0x02) { 0x01, "TouchPad" }, Package (0x02) { 0x00, "FnSticky" }, Package (0x02) { 0x04, "ThinkPadNumLock" }, Package (0x02) { 0x0C, "PowerOnNumLock" }, Package (0x02) { 0x05, "BootDisplayDevice" }, Package (0x02) { 0x00, "SpeedStep" }, Package (0x02) { 0x09, "AdaptiveThermalManagementAC" }, Package (0x02) { 0x09, "AdaptiveThermalManagementBattery" }, Package (0x02) { 0x06, "CDROMSpeed" }, Package (0x02) { 0x01, "CPUPowerManagement" }, Package (0x02) { 0x00, "PowerControlBeep" }, Package (0x02) { 0x00, "LowBatteryAlarm" }, Package (0x02) { 0x00, "PasswordBeep" }, Package (0x02) { 0x00, "KeyboardBeep" }, Package (0x02) { 0x00, "ExtendedMemoryTest" }, Package (0x02) { 0x07, "SATAControllerMode" }, Package (0x02) { 0x00, "CoreMultiProcessing" }, Package (0x02) { 0x00, "VirtualizationTechnology" }, Package (0x02) { 0x00, "LockBIOSSetting" }, Package (0x02) { 0x0B, "MinimumPasswordLength" }, Package (0x02) { 0x00, "BIOSPasswordAtUnattendedBoot" }, Package (0x02) { 0x00, "FingerprintPredesktopAuthentication" }, Package (0x02) { 0x08, "FingerprintReaderPriority" }, Package (0x02) { 0x03, "FingerprintSecurityMode" }, Package (0x02) { 0x02, "SecurityChip" }, Package (0x02) { 0x00, "BIOSUpdateByEndUsers" }, Package (0x02) { 0x00, "DataExecutionPrevention" }, Package (0x02) { 0x00, "EthernetLANAccess" }, Package (0x02) { 0x00, "WirelessLANAccess" }, Package (0x02) { 0x00, "WirelessWANAccess" }, Package (0x02) { 0x00, "BluetoothAccess" }, Package (0x02) { 0x00, "WirelessUSBAccess" }, Package (0x02) { 0x00, "ModemAccess" }, Package (0x02) { 0x00, "USBPortAccess" }, Package (0x02) { 0x00, "IEEE1394Access" }, Package (0x02) { 0x00, "ExpressCardAccess" }, Package (0x02) { 0x00, "PCIExpressSlotAccess" }, Package (0x02) { 0x00, "UltrabayAccess" }, Package (0x02) { 0x00, "MemoryCardSlotAccess" }, Package (0x02) { 0x00, "SmartCardSlotAccess" }, Package (0x02) { 0x00, "IntegratedCameraAccess" }, Package (0x02) { 0x00, "MicrophoneAccess" }, Package (0x02) { 0x0A, "BootMode" }, Package (0x02) { 0x00, "StartupOptionKeys" }, Package (0x02) { 0x00, "BootDeviceListF12Option" }, Package (0x02) { 0x64, "BootOrder" }, Package (0x02) { 0x00, "WiMAXAccess" }, Package (0x02) { 0x0D, "GraphicsDevice" }, Package (0x02) { 0x00, "TXTFeature" }, Package (0x02) { 0x00, "VTdFeature" }, Package (0x02) { 0x0F, "AMTControl" }, Package (0x02) { 0x00, "FingerprintPasswordAuthentication" }, Package (0x02) { 0x00, "FingerprintReaderAccess" }, Package (0x02) { 0x00, "OsDetectionForSwitchableGraphics" }, Package (0x02) { 0x0F, "ComputraceModuleActivation" }, Package (0x02) { 0x01, "PCIExpressPowerManagement" }, Package (0x02) { 0x00, "Reserved" }, Package (0x02) { 0x00, "eSATAPortAccess" }, Package (0x02) { 0x00, "HardwarePasswordManager" }, Package (0x02) { 0x00, "HyperThreadingTechnology" }, Package (0x02) { 0x00, "FnCtrlKeySwap" }, Package (0x02) { 0x00, "BIOSPasswordAtReboot" }, Package (0x02) { 0x00, "OnByAcAttach" }, Package (0x02) { 0x64, "NetworkBoot" }, Package (0x02) { 0x00, "BootOrderLock" }, Package (0x02) { 0x10, "SharedDisplayPriority" }, Package (0x02) { 0x11, "ExpressCardSpeed" }, Package (0x02) { 0x00, "RapidStartTechnology" }, Package (0x02) { 0x12, "KeyboardIllumination" }, Package (0x02) { 0x00, "IPv4NetworkStack" }, Package (0x02) { 0x00, "IPv6NetworkStack" }, Package (0x02) { 0x13, "UefiPxeBootPriority" }, Package (0x02) { 0x00, "PhysicalPresenceForTpmProvision" }, Package (0x02) { 0x00, "PhysicalPresenceForTpmClear" }, Package (0x02) { 0x00, "SecureRollBackPrevention" }, Package (0x02) { 0x00, "SecureBoot" }, Package (0x02) { 0x00, "NfcAccess" }, Package (0x02) { 0x00, "BottomCoverTamperDetected" }, Package (0x02) { 0x00, "PasswordCountExceededError" }, Package (0x02) { 0x00, "BIOSPasswordAtBootDeviceList" }, Package (0x02) { 0x14, "TotalGraphicsMemory" }, Package (0x02) { 0x15, "BootTimeExtension" }, Package (0x02) { 0x00, "FnKeyAsPrimary" }, Package (0x02) { 0x00, "WiGig" }, Package (0x02) { 0x00, "BIOSPasswordAtPowerOn" }, Package (0x02) { 0x16, "SGXControl" }, Package (0x02) { 0x00, "WiGigWake" }, Package (0x02) { 0x00, "InternalStorageTamper" } }) Name (VSEL, Package (0x17) { Package (0x02) { "Disable", "Enable" }, Package (0x02) { "Disable", "Automatic" }, Package (0x04) { "Active", "Inactive", "Disable", "Enable" }, Package (0x02) { "Normal", "High" }, Package (0x02) { "Independent", "Synchronized" }, Package (0x04) { "LCD", "DisplayPort", "HDMI", "DockDisplay" }, Package (0x03) { "High", "Normal", "Silent" }, Package (0x02) { "Compatibility", "AHCI" }, Package (0x02) { "External", "InternalOnly" }, Package (0x02) { "MaximizePerformance", "Balanced" }, Package (0x02) { "Quick", "Diagnostics" }, Package (0x0A) { "Disable", "4", "5", "6", "7", "8", "9", "10", "11", "12" }, Package (0x03) { "Auto", "On", "Off" }, Package (0x03) { "IntegratedGfx", "DiscreteGfx", "SwitchableGfx" }, Package (0x04) { "Disable", "ACOnly", "ACandBattery", "Enable" }, Package (0x03) { "Disable", "Enable", "Disable" }, Package (0x02) { "HDMI", "DockDisplay" }, Package (0x02) { "Generation1", "Automatic" }, Package (0x03) { "ThinkLightOnly", "BacklightOnly", "Both" }, Package (0x02) { "IPv6First", "IPv4First" }, Package (0x02) { "256MB", "512MB" }, Package (0x0B) { "Disable", "1", "2", "3", "", "5", "", "", "", "", "10" }, Package (0x03) { "Disable", "Enable", "SoftwareControl" } }) Name (VLST, Package (0x11) { "HDD0", "HDD1", "HDD2", "HDD3", "HDD4", "PCILAN", "ATAPICD0", "ATAPICD1", "ATAPICD2", "USBFDD", "USBCD", "USBHDD", "OtherHDD", "OtherCD", "NVMe0", "NVMe1", "NODEV" }) Name (PENC, Package (0x02) { "ascii", "scancode" }) Name (PKBD, Package (0x03) { "us", "fr", "gr" }) Name (PTYP, Package (0x08) { "pap", "pop", "uhdp1", "mhdp1", "uhdp2", "mhdp2", "uhdp3", "mhdp3" }) Mutex (MWMI, 0x00) Name (PCFG, Buffer (0x18){}) Name (IBUF, Buffer (0x0100){}) Name (ILEN, 0x00) Name (PSTR, Buffer (0x81){}) Method (WQA0, 1, NotSerialized) { Acquire (MWMI, 0xFFFF) If (LNotEqual (\WMIS (0x00, Arg0), 0x00)) { Release (MWMI) Return ("") } Store (DerefOf (Index (ITEM, \WITM)), Local0) Store (DerefOf (Index (Local0, 0x00)), Local1) Store (DerefOf (Index (Local0, 0x01)), Local2) If (LLess (Local1, 0x64)) { Concatenate (Local2, ",", Local6) Store (DerefOf (Index (VSEL, Local1)), Local3) Concatenate (Local6, DerefOf (Index (Local3, \WSEL)), Local7) } Else { Store (SizeOf (VLST), Local3) If (LLessEqual (\WLS0, Local3)) { Concatenate (Local2, ",", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS0)), Local2) } If (LLessEqual (\WLS1, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS1)), Local2) } If (LLessEqual (\WLS2, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS2)), Local2) } If (LLessEqual (\WLS3, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS3)), Local2) } If (LLessEqual (\WLS4, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS4)), Local2) } If (LLessEqual (\WLS5, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS5)), Local2) } If (LLessEqual (\WLS6, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS6)), Local2) } If (LLessEqual (\WLS7, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS7)), Local2) } If (LLessEqual (\WLS8, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS8)), Local2) } If (LLessEqual (\WLS9, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLS9)), Local2) } If (LLessEqual (\WLSA, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLSA)), Local2) } If (LLessEqual (\WLSB, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLSB)), Local2) } If (LLessEqual (\WLSC, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLSC)), Local2) } If (LLessEqual (\WLSD, Local3)) { Concatenate (Local2, ":", Local7) Concatenate (Local7, DerefOf (Index (VLST, \WLSD)), Local2) } Store (Local2, Local7) } Release (MWMI) Return (Local7) } Method (WMA1, 3, NotSerialized) { Acquire (MWMI, 0xFFFF) If (LEqual (SizeOf (Arg2), 0x00)) { Store (0x02, Local0) } Else { Store (CARG (Arg2), Local0) If (LEqual (Local0, 0x00)) { Store (WSET (ITEM, VSEL), Local0) If (LEqual (Local0, 0x00)) { Store (\WMIS (0x01, 0x00), Local0) } } } Release (MWMI) Return (DerefOf (Index (RETN, Local0))) } Method (WMA2, 3, NotSerialized) { Acquire (MWMI, 0xFFFF) Store (CARG (Arg2), Local0) If (LEqual (Local0, 0x00)) { If (LNotEqual (ILEN, 0x00)) { Store (CPAS (IBUF, 0x00), Local0) } If (LEqual (Local0, 0x00)) { Store (\WMIS (0x02, 0x00), Local0) } } Release (MWMI) Return (DerefOf (Index (RETN, Local0))) } Method (WMA3, 3, NotSerialized) { Acquire (MWMI, 0xFFFF) Store (CARG (Arg2), Local0) If (LEqual (Local0, 0x00)) { If (LNotEqual (ILEN, 0x00)) { Store (CPAS (IBUF, 0x00), Local0) } If (LEqual (Local0, 0x00)) { Store (\WMIS (0x03, 0x00), Local0) } } Release (MWMI) Return (DerefOf (Index (RETN, Local0))) } Method (WMA4, 3, NotSerialized) { Acquire (MWMI, 0xFFFF) Store (CARG (Arg2), Local0) If (LEqual (Local0, 0x00)) { If (LNotEqual (ILEN, 0x00)) { Store (CPAS (IBUF, 0x00), Local0) } If (LEqual (Local0, 0x00)) { Store (\WMIS (0x04, 0x00), Local0) } } Release (MWMI) Return (DerefOf (Index (RETN, Local0))) } Method (WQA5, 1, NotSerialized) { Acquire (MWMI, 0xFFFF) Store (\WMIS (0x05, 0x00), Local0) Store (\WSPM, Index (PCFG, 0x00)) Store (\WSPS, Index (PCFG, 0x04)) Store (\WSMN, Index (PCFG, 0x08)) Store (\WSMX, Index (PCFG, 0x0C)) Store (\WSEN, Index (PCFG, 0x10)) Store (\WSKB, Index (PCFG, 0x14)) Release (MWMI) Return (PCFG) } Method (WMA6, 3, NotSerialized) { Acquire (MWMI, 0xFFFF) If (LEqual (SizeOf (Arg2), 0x00)) { Store (0x02, Local0) } Else { Store (CARG (Arg2), Local0) If (LEqual (Local0, 0x00)) { If (LNotEqual (ILEN, 0x00)) { Store (SPAS (IBUF), Local0) } If (LEqual (Local0, 0x00)) { Store (\WMIS (0x06, 0x00), Local0) } } } Release (MWMI) Return (DerefOf (Index (RETN, Local0))) } Method (WMA7, 3, NotSerialized) { If (LEqual (SizeOf (Arg2), 0x00)) { Return ("") } Store (CARG (Arg2), Local0) If (LEqual (Local0, 0x00)) { Store (GITM (IBUF, ITEM), Local1) If (LEqual (Local1, Ones)) { Return ("") } Store (DerefOf (Index (ITEM, Local1)), Local0) Store (DerefOf (Index (Local0, 0x00)), Local1) If (LLess (Local1, 0x64)) { Store (DerefOf (Index (VSEL, Local1)), Local3) Store (DerefOf (Index (Local3, 0x00)), Local2) Store (SizeOf (Local3), Local4) Store (0x01, Local5) While (LLess (Local5, Local4)) { Store (DerefOf (Index (Local3, Local5)), Local6) If (LNotEqual (SizeOf (Local6), 0x00)) { Concatenate (Local2, ",", Local7) Concatenate (Local7, Local6, Local2) } Increment (Local5) } } Else { Store (DerefOf (Index (VLST, 0x00)), Local2) Store (SizeOf (VLST), Local4) Store (0x01, Local5) While (LLess (Local5, Local4)) { Store (DerefOf (Index (VLST, Local5)), Local6) Concatenate (Local2, ",", Local7) Concatenate (Local7, Local6, Local2) Increment (Local5) } } } Return (Local2) } Method (CARG, 1, NotSerialized) { Store (SizeOf (Arg0), Local0) If (LEqual (Local0, 0x00)) { Store (0x00, IBUF) Store (0x00, ILEN) Return (0x00) } If (LNotEqual (ObjectType (Arg0), 0x02)) { Return (0x02) } If (LGreaterEqual (Local0, 0xFF)) { Return (0x02) } Store (Arg0, IBUF) Decrement (Local0) Store (DerefOf (Index (IBUF, Local0)), Local1) If (LOr (LEqual (Local1, 0x3B), LEqual (Local1, 0x2A))) { Store (0x00, Index (IBUF, Local0)) Store (Local0, ILEN) } Else { Store (SizeOf (Arg0), ILEN) } Return (0x00) } Method (SCMP, 3, NotSerialized) { Store (SizeOf (Arg0), Local0) If (LEqual (Local0, 0x00)) { Return (0x00) } Increment (Local0) Name (STR1, Buffer (Local0){}) Store (Arg0, STR1) Decrement (Local0) Store (0x00, Local1) Store (Arg2, Local2) While (LLess (Local1, Local0)) { Store (DerefOf (Index (STR1, Local1)), Local3) Store (DerefOf (Index (Arg1, Local2)), Local4) If (LNotEqual (Local3, Local4)) { Return (0x00) } Increment (Local1) Increment (Local2) } Store (DerefOf (Index (Arg1, Local2)), Local4) If (LEqual (Local4, 0x00)) { Return (0x01) } If (LOr (LEqual (Local4, 0x2C), LEqual (Local4, 0x3A))) { Return (0x01) } Return (0x00) } Method (GITM, 2, NotSerialized) { Store (0x00, Local0) Store (SizeOf (Arg1), Local1) While (LLess (Local0, Local1)) { Store (DerefOf (Index (DerefOf (Index (Arg1, Local0)), 0x01)), Local3) If (SCMP (Local3, Arg0, 0x00)) { Return (Local0) } Increment (Local0) } Return (Ones) } Method (GSEL, 3, NotSerialized) { Store (0x00, Local0) Store (SizeOf (Arg0), Local1) While (LLess (Local0, Local1)) { Store (DerefOf (Index (Arg0, Local0)), Local2) If (SCMP (Local2, Arg1, Arg2)) { Return (Local0) } Increment (Local0) } Return (Ones) } Method (SLEN, 2, NotSerialized) { Store (DerefOf (Index (Arg0, Arg1)), Local0) Return (SizeOf (Local0)) } Method (CLRP, 0, NotSerialized) { Store (0x00, \WPAS) Store (0x00, \WPNW) } Method (GPAS, 2, NotSerialized) { Store (Arg1, Local0) Store (0x00, Local1) While (LLessEqual (Local1, 0x80)) { Store (DerefOf (Index (Arg0, Local0)), Local2) If (LOr (LEqual (Local2, 0x2C), LEqual (Local2, 0x00))) { Store (0x00, Index (PSTR, Local1)) Return (Local1) } Store (Local2, Index (PSTR, Local1)) Increment (Local0) Increment (Local1) } Store (0x00, Index (PSTR, Local1)) Return (Ones) } Method (CPAS, 2, NotSerialized) { CLRP () Store (Arg1, Local0) Store (GPAS (Arg0, Local0), Local1) If (LEqual (Local1, Ones)) { Return (0x02) } If (LEqual (Local1, 0x00)) { Return (0x02) } Store (PSTR, \WPAS) Add (Local0, Local1, Local0) Increment (Local0) Store (GSEL (PENC, Arg0, Local0), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WENC) If (LEqual (Local6, 0x00)) { Add (Local0, SLEN (PENC, 0x00), Local0) If (LNotEqual (DerefOf (Index (Arg0, Local0)), 0x2C)) { Return (0x02) } Increment (Local0) Store (GSEL (PKBD, Arg0, Local0), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WKBD) } Return (0x00) } Method (SPAS, 1, NotSerialized) { CLRP () Store (GSEL (PTYP, Arg0, 0x00), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WPTY) Store (SLEN (PTYP, Local6), Local0) If (LNotEqual (DerefOf (Index (Arg0, Local0)), 0x2C)) { Return (0x02) } Increment (Local0) Store (GPAS (Arg0, Local0), Local1) If (LOr (LEqual (Local1, Ones), LEqual (Local1, 0x00))) { Return (0x02) } Store (PSTR, \WPAS) Add (Local0, Local1, Local0) If (LNotEqual (DerefOf (Index (Arg0, Local0)), 0x2C)) { Return (0x02) } Increment (Local0) Store (GPAS (Arg0, Local0), Local1) If (LEqual (Local1, Ones)) { Return (0x02) } If (LEqual (Local1, 0x00)) { Store (0x00, PSTR) } Store (PSTR, \WPNW) Add (Local0, Local1, Local0) Increment (Local0) Store (GSEL (PENC, Arg0, Local0), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WENC) If (LEqual (Local6, 0x00)) { Add (Local0, SLEN (PENC, 0x00), Local0) If (LNotEqual (DerefOf (Index (Arg0, Local0)), 0x2C)) { Return (0x02) } Increment (Local0) Store (GSEL (PKBD, Arg0, Local0), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WKBD) } Return (0x00) } Method (WSET, 2, NotSerialized) { Store (ILEN, Local0) Increment (Local0) Store (GITM (IBUF, Arg0), Local1) If (LEqual (Local1, Ones)) { Return (0x02) } Store (Local1, \WITM) Store (DerefOf (Index (Arg0, Local1)), Local3) Store (DerefOf (Index (Local3, 0x01)), Local4) Store (SizeOf (Local4), Local2) Increment (Local2) Store (DerefOf (Index (Local3, 0x00)), Local4) If (LLess (Local4, 0x64)) { Store (DerefOf (Index (Arg1, Local4)), Local5) Store (GSEL (Local5, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WSEL) Add (Local2, SLEN (Local5, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } Else { Store (0x3F, \WLS0) Store (0x3F, \WLS1) Store (0x3F, \WLS2) Store (0x3F, \WLS3) Store (0x3F, \WLS4) Store (0x3F, \WLS5) Store (0x3F, \WLS6) Store (0x3F, \WLS7) Store (0x3F, \WLS8) Store (0x3F, \WLS9) Store (0x3F, \WLSA) Store (0x3F, \WLSB) Store (0x3F, \WLSC) Store (0x3F, \WLSD) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS0) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS1) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS2) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS3) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS4) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS5) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS6) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS7) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS8) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLS9) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLSA) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLSB) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLSC) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } If (LAnd (LLess (Local2, Local0), LEqual (Local4, 0x3A))) { Increment (Local2) Store (GSEL (VLST, IBUF, Local2), Local6) If (LEqual (Local6, Ones)) { Return (0x02) } Store (Local6, \WLSD) Add (Local2, SLEN (VLST, Local6), Local2) Store (DerefOf (Index (IBUF, Local2)), Local4) } } If (LAnd (LEqual (Local4, 0x2C), LLess (Local2, Local0))) { Increment (Local2) Store (CPAS (IBUF, Local2), Local0) If (LNotEqual (Local0, 0x00)) { Return (Local0) } } Return (0x00) } Name (WQBA, Buffer (0x089D) { /* 0000 */ 0x46, 0x4F, 0x4D, 0x42, 0x01, 0x00, 0x00, 0x00, /* 0008 */ 0x8D, 0x08, 0x00, 0x00, 0xF2, 0x36, 0x00, 0x00, /* 0010 */ 0x44, 0x53, 0x00, 0x01, 0x1A, 0x7D, 0xDA, 0x54, /* 0018 */ 0xA8, 0xC9, 0x9A, 0x00, 0x01, 0x06, 0x18, 0x42, /* 0020 */ 0x10, 0x13, 0x10, 0x0A, 0x0D, 0x21, 0x02, 0x0B, /* 0028 */ 0x83, 0x50, 0x4C, 0x18, 0x14, 0xA0, 0x45, 0x41, /* 0030 */ 0xC8, 0x05, 0x14, 0x95, 0x02, 0x21, 0xC3, 0x02, /* 0038 */ 0x14, 0x0B, 0x70, 0x2E, 0x40, 0xBA, 0x00, 0xE5, /* 0040 */ 0x28, 0x72, 0x0C, 0x22, 0x02, 0xF7, 0xEF, 0x0F, /* 0048 */ 0x31, 0x0E, 0x88, 0x14, 0x40, 0x48, 0x26, 0x84, /* 0050 */ 0x44, 0x00, 0x53, 0x21, 0x70, 0x84, 0xA0, 0x5F, /* 0058 */ 0x01, 0x08, 0x1D, 0xA2, 0xC9, 0xA0, 0x00, 0xA7, /* 0060 */ 0x08, 0x82, 0xB4, 0x65, 0x01, 0xBA, 0x05, 0xF8, /* 0068 */ 0x16, 0xA0, 0x1D, 0x42, 0x68, 0x15, 0x0A, 0x30, /* 0070 */ 0x29, 0xC0, 0x27, 0x98, 0x2C, 0x0A, 0x90, 0x0D, /* 0078 */ 0x26, 0xDB, 0x70, 0x64, 0x18, 0x4C, 0xE4, 0x18, /* 0080 */ 0x50, 0x62, 0xC6, 0x80, 0xD2, 0x39, 0x05, 0xD9, /* 0088 */ 0x04, 0x16, 0x74, 0xA1, 0x28, 0x9A, 0x46, 0x94, /* 0090 */ 0x04, 0x07, 0x75, 0x0C, 0x11, 0x82, 0x97, 0x2B, /* 0098 */ 0x40, 0xF2, 0x04, 0xA4, 0x79, 0x5E, 0xB2, 0x3E, /* 00A0 */ 0x08, 0x0D, 0x81, 0x8D, 0x80, 0x47, 0x91, 0x00, /* 00A8 */ 0xC2, 0x62, 0x2C, 0x53, 0xE2, 0x61, 0x50, 0x1E, /* 00B0 */ 0x40, 0x24, 0x67, 0xA8, 0x28, 0x60, 0x7B, 0x9D, /* 00B8 */ 0x88, 0x86, 0x75, 0x9C, 0x4C, 0x12, 0x1C, 0x6A, /* 00C0 */ 0x94, 0x96, 0x28, 0xC0, 0xFC, 0xC8, 0x34, 0x91, /* 00C8 */ 0x63, 0x6B, 0x7A, 0xC4, 0x82, 0x64, 0xD2, 0x86, /* 00D0 */ 0x82, 0x1A, 0xBA, 0xA7, 0x75, 0x52, 0x9E, 0x68, /* 00D8 */ 0xC4, 0x83, 0x32, 0x4C, 0x02, 0x8F, 0x82, 0xA1, /* 00E0 */ 0x71, 0x82, 0xB2, 0x20, 0xE4, 0x60, 0xA0, 0x28, /* 00E8 */ 0xC0, 0x93, 0xF0, 0x1C, 0x8B, 0x17, 0x20, 0x7C, /* 00F0 */ 0xC6, 0xE4, 0x28, 0x10, 0x23, 0x81, 0x8F, 0x04, /* 00F8 */ 0x1E, 0xCD, 0x31, 0x63, 0x81, 0xC2, 0x05, 0x3C, /* 0100 */ 0x9F, 0x63, 0x88, 0x1C, 0xF7, 0x50, 0x63, 0x1C, /* 0108 */ 0x45, 0xE4, 0x04, 0xEF, 0x00, 0x51, 0x8C, 0x56, /* 0110 */ 0xD0, 0xBC, 0x85, 0x18, 0x2C, 0x9A, 0xC1, 0x7A, /* 0118 */ 0x06, 0x27, 0x83, 0x4E, 0xF0, 0xFF, 0x3F, 0x02, /* 0120 */ 0x2E, 0x03, 0x42, 0x1E, 0x05, 0x58, 0x1D, 0x94, /* 0128 */ 0xA6, 0x61, 0x82, 0xEE, 0x05, 0xBC, 0x1A, 0x1A, /* 0130 */ 0x13, 0xA0, 0x11, 0x43, 0xCA, 0x04, 0x38, 0xBB, /* 0138 */ 0x2F, 0x68, 0x46, 0x6D, 0x09, 0x30, 0x27, 0x40, /* 0140 */ 0x9B, 0x00, 0x6F, 0x08, 0x42, 0x39, 0xCF, 0x28, /* 0148 */ 0xC7, 0x72, 0x8A, 0x51, 0x1E, 0x06, 0x62, 0xBE, /* 0150 */ 0x0C, 0x04, 0x8D, 0x12, 0x23, 0xE6, 0xB9, 0xC4, /* 0158 */ 0x35, 0x6C, 0x84, 0x18, 0x21, 0x4F, 0x21, 0x50, /* 0160 */ 0xDC, 0xF6, 0x07, 0x41, 0x06, 0x8D, 0x1B, 0xBD, /* 0168 */ 0x4F, 0x0B, 0x67, 0x75, 0x02, 0x47, 0xFF, 0xA4, /* 0170 */ 0x60, 0x02, 0x4F, 0xF9, 0xC0, 0x9E, 0x0D, 0x4E, /* 0178 */ 0xE0, 0x58, 0xA3, 0xC6, 0x38, 0x95, 0x04, 0x8E, /* 0180 */ 0xFD, 0x80, 0x90, 0x06, 0x10, 0x45, 0x82, 0x47, /* 0188 */ 0x9D, 0x16, 0x7C, 0x2E, 0xF0, 0xD0, 0x0E, 0xDA, /* 0190 */ 0x73, 0x3C, 0x81, 0x20, 0x87, 0x70, 0x04, 0x4F, /* 0198 */ 0x0C, 0x0F, 0x04, 0x1E, 0x03, 0xBB, 0x29, 0xF8, /* 01A0 */ 0x08, 0xE0, 0x13, 0x02, 0xDE, 0x35, 0xA0, 0xAE, /* 01A8 */ 0x06, 0x0F, 0x06, 0x6C, 0xD0, 0xE1, 0x30, 0xE3, /* 01B0 */ 0xF5, 0xF0, 0xC3, 0x9D, 0xC0, 0x49, 0x3E, 0x60, /* 01B8 */ 0xF0, 0xC3, 0x86, 0x07, 0x87, 0x9B, 0xE7, 0xC9, /* 01C0 */ 0x1C, 0x59, 0xA9, 0x02, 0xCC, 0x1E, 0x0E, 0x74, /* 01C8 */ 0x90, 0xF0, 0x69, 0x83, 0x9D, 0x01, 0x30, 0xF2, /* 01D0 */ 0x07, 0x81, 0x1A, 0x99, 0xA1, 0x3D, 0xEE, 0x97, /* 01D8 */ 0x0E, 0x43, 0x3E, 0x27, 0x1C, 0x16, 0x13, 0x7B, /* 01E0 */ 0xEA, 0xA0, 0xE3, 0x01, 0xFF, 0x65, 0xE4, 0x39, /* 01E8 */ 0xC3, 0xD3, 0xF7, 0x7C, 0x4D, 0x30, 0xEC, 0xC0, /* 01F0 */ 0xD1, 0x03, 0x31, 0xF4, 0xC3, 0xC6, 0x61, 0x9C, /* 01F8 */ 0x86, 0xEF, 0x1F, 0x3E, 0x2F, 0xC0, 0x38, 0x05, /* 0200 */ 0x78, 0xE4, 0xFE, 0xFF, 0x1F, 0x52, 0x7C, 0x9A, /* 0208 */ 0xE0, 0x47, 0x0B, 0x9F, 0x26, 0xD8, 0xF5, 0xE0, /* 0210 */ 0x34, 0x9E, 0x03, 0x3C, 0x9C, 0xB3, 0xF2, 0x61, /* 0218 */ 0x02, 0x6C, 0xF7, 0x13, 0x36, 0xA2, 0x77, 0x0B, /* 0220 */ 0x8F, 0x06, 0x7B, 0x0A, 0x00, 0xDF, 0xF9, 0x05, /* 0228 */ 0x9C, 0x77, 0x0D, 0x36, 0x58, 0x18, 0xE7, 0x17, /* 0230 */ 0xE0, 0x71, 0x42, 0xF0, 0x10, 0xF8, 0x41, 0xC2, /* 0238 */ 0x43, 0xE0, 0x03, 0x78, 0xFE, 0x38, 0x43, 0x2B, /* 0240 */ 0x9D, 0x17, 0x72, 0x60, 0xF0, 0xCE, 0x39, 0x30, /* 0248 */ 0x46, 0xC1, 0xF3, 0x3C, 0x36, 0x4C, 0xA0, 0x20, /* 0250 */ 0xAF, 0x01, 0x85, 0x7A, 0x16, 0x50, 0x18, 0x9F, /* 0258 */ 0x6A, 0x80, 0xD7, 0xFF, 0xFF, 0x54, 0x03, 0x5C, /* 0260 */ 0x0E, 0x07, 0xB8, 0x93, 0x03, 0xDC, 0x7B, 0x01, /* 0268 */ 0xBB, 0x38, 0x3C, 0xD7, 0xC0, 0x15, 0x7D, 0xAE, /* 0270 */ 0x81, 0x7A, 0x6F, 0x29, 0x6E, 0x8C, 0xBA, 0xC6, /* 0278 */ 0x04, 0x79, 0x14, 0x78, 0xA4, 0x89, 0xF2, 0x3C, /* 0280 */ 0xF3, 0x2E, 0x13, 0xE1, 0xD9, 0xC6, 0xD7, 0x1A, /* 0288 */ 0x4F, 0x21, 0x8E, 0xAF, 0x35, 0x46, 0x7C, 0x99, /* 0290 */ 0x78, 0xB7, 0x31, 0xEE, 0xC1, 0x3D, 0xD6, 0x3C, /* 0298 */ 0xE4, 0x18, 0xE4, 0x68, 0x22, 0xBC, 0x18, 0x04, /* 02A0 */ 0x7C, 0xBC, 0xF1, 0xB1, 0x06, 0xBC, 0x62, 0x5E, /* 02A8 */ 0x28, 0xB2, 0x70, 0xAC, 0x01, 0x34, 0xFE, 0xFF, /* 02B0 */ 0x8F, 0x35, 0xC0, 0x0D, 0xEB, 0x01, 0x05, 0x7C, /* 02B8 */ 0x47, 0x06, 0x76, 0x43, 0x81, 0x77, 0x42, 0x01, /* 02C0 */ 0xFC, 0x24, 0x7E, 0x01, 0xE8, 0xC8, 0xE1, 0xB4, /* 02C8 */ 0x20, 0xB2, 0xF1, 0x06, 0xF0, 0x29, 0x80, 0xAA, /* 02D0 */ 0x01, 0xD2, 0x34, 0x61, 0x13, 0x4C, 0x4F, 0x2E, /* 02D8 */ 0x78, 0x1F, 0x09, 0x9C, 0x9B, 0x44, 0xC9, 0x87, /* 02E0 */ 0x45, 0xE1, 0x9C, 0xF5, 0x20, 0x42, 0x41, 0x0C, /* 02E8 */ 0xE8, 0x20, 0xC7, 0x09, 0xF4, 0x19, 0xC5, 0x07, /* 02F0 */ 0x91, 0x13, 0x7D, 0x22, 0xF4, 0xA0, 0x3C, 0x8C, /* 02F8 */ 0x77, 0x14, 0x76, 0x02, 0xF1, 0x61, 0xC2, 0x63, /* 0300 */ 0xF7, 0x31, 0x81, 0xFF, 0x63, 0x3C, 0x1B, 0xA3, /* 0308 */ 0x5B, 0x0D, 0x86, 0xFE, 0xFF, 0xE7, 0x14, 0x0E, /* 0310 */ 0xE6, 0x83, 0x08, 0x27, 0xA8, 0xEB, 0x26, 0x01, /* 0318 */ 0x32, 0x7D, 0x47, 0x05, 0x50, 0x00, 0xF9, 0x5E, /* 0320 */ 0xE0, 0x73, 0xC0, 0xB3, 0x01, 0x1B, 0xC3, 0xA3, /* 0328 */ 0x80, 0xD1, 0x8C, 0xCE, 0xC3, 0x4F, 0x16, 0x15, /* 0330 */ 0x77, 0xB2, 0x14, 0xC4, 0x93, 0x75, 0x94, 0xC9, /* 0338 */ 0xA2, 0x67, 0xE2, 0x7B, 0x85, 0x67, 0xF4, 0xA6, /* 0340 */ 0xE5, 0x39, 0x7A, 0xC2, 0xBE, 0x87, 0xC0, 0x3A, /* 0348 */ 0x0C, 0x84, 0x7C, 0x30, 0xF0, 0x34, 0x0C, 0xE7, /* 0350 */ 0xC9, 0x72, 0x38, 0x4F, 0x96, 0x8F, 0xC5, 0xD7, /* 0358 */ 0x10, 0xF0, 0x09, 0x9C, 0x2D, 0xC8, 0xE1, 0x31, /* 0360 */ 0xB1, 0x46, 0x45, 0xAF, 0x42, 0x1E, 0x1E, 0xBF, /* 0368 */ 0x1C, 0x78, 0x3E, 0xCF, 0x08, 0x47, 0xF9, 0x24, /* 0370 */ 0x81, 0xC3, 0x78, 0x26, 0xF1, 0x10, 0x7D, 0x2B, /* 0378 */ 0x82, 0x35, 0x91, 0x93, 0xF6, 0x6D, 0xE1, 0x64, /* 0380 */ 0x83, 0xBE, 0x9E, 0x61, 0x6E, 0x45, 0xB0, 0xFF, /* 0388 */ 0xFF, 0xB7, 0x22, 0x38, 0x17, 0x34, 0x98, 0x99, /* 0390 */ 0xEE, 0x55, 0xA8, 0x58, 0xF7, 0x2A, 0x40, 0xEC, /* 0398 */ 0xB0, 0x5E, 0x7B, 0x7C, 0xB0, 0x82, 0x7B, 0xAF, /* 03A0 */ 0x82, 0x7B, 0xA9, 0x7A, 0x56, 0x38, 0xC6, 0xF0, /* 03A8 */ 0x0F, 0x53, 0x31, 0x4E, 0xE9, 0xB5, 0xD3, 0x40, /* 03B0 */ 0x61, 0xA2, 0xC4, 0x7B, 0xAF, 0xF2, 0x18, 0xDF, /* 03B8 */ 0xAB, 0xD8, 0x15, 0x2A, 0x4C, 0xAC, 0x97, 0x2B, /* 03C0 */ 0xA3, 0xBE, 0x4E, 0x84, 0x0B, 0x14, 0x24, 0xD2, /* 03C8 */ 0xAB, 0x55, 0x94, 0xC8, 0xF1, 0x0D, 0xF9, 0x5E, /* 03D0 */ 0x05, 0x5E, 0x39, 0xF7, 0x2A, 0x90, 0xFD, 0xFF, /* 03D8 */ 0xEF, 0x55, 0x80, 0x79, 0xB4, 0xF7, 0x2A, 0x30, /* 03E0 */ 0x5E, 0x1B, 0xD8, 0x0D, 0x09, 0x16, 0xD0, 0x8B, /* 03E8 */ 0x15, 0x60, 0x28, 0xF3, 0xC5, 0x8A, 0xE6, 0xBD, /* 03F0 */ 0x58, 0x21, 0xFE, 0xFF, 0xE7, 0x12, 0xA6, 0xE7, /* 03F8 */ 0x62, 0x45, 0xE6, 0x09, 0xFF, 0x66, 0x05, 0x70, /* 0400 */ 0xFA, 0xFF, 0x7F, 0xB3, 0x02, 0x8C, 0xDD, 0x8B, /* 0408 */ 0x30, 0x47, 0x2B, 0x78, 0x29, 0x6F, 0x56, 0x34, /* 0410 */ 0xCE, 0x32, 0x14, 0x70, 0x41, 0x14, 0xC6, 0x37, /* 0418 */ 0x2B, 0xC0, 0xD1, 0x75, 0x05, 0x37, 0x64, 0xB8, /* 0420 */ 0x60, 0x51, 0x82, 0xF9, 0x10, 0xE2, 0xE9, 0x1C, /* 0428 */ 0xF1, 0x43, 0xC2, 0x4B, 0xC0, 0x63, 0x8E, 0x07, /* 0430 */ 0xFC, 0x40, 0xE0, 0xCB, 0x15, 0x98, 0xFE, 0xFF, /* 0438 */ 0x04, 0x3E, 0xF9, 0x9E, 0xE5, 0xDB, 0xD4, 0x7B, /* 0440 */ 0x2F, 0x3F, 0x60, 0xBD, 0x57, 0xF9, 0xF0, 0x1B, /* 0448 */ 0xEB, 0x9D, 0xE1, 0xE5, 0xCA, 0x23, 0x89, 0x72, /* 0450 */ 0x12, 0xA1, 0x7C, 0xB7, 0x7A, 0xAF, 0x32, 0x4A, /* 0458 */ 0xC4, 0x17, 0x62, 0x9F, 0x82, 0x0D, 0x6D, 0x94, /* 0460 */ 0xA7, 0x8A, 0xE8, 0xC6, 0x7B, 0xB9, 0x02, 0xAF, /* 0468 */ 0xA4, 0xCB, 0x15, 0x40, 0x93, 0xE1, 0xBF, 0x5C, /* 0470 */ 0x81, 0xEF, 0xE6, 0x80, 0xBD, 0x26, 0xC1, 0xF9, /* 0478 */ 0xFF, 0x5F, 0x93, 0xF8, 0xF5, 0x0A, 0xF0, 0x93, /* 0480 */ 0xFD, 0x7A, 0x45, 0x73, 0x5F, 0xAF, 0x50, 0xA2, /* 0488 */ 0x20, 0xA4, 0x08, 0x48, 0x33, 0x05, 0xCF, 0xFD, /* 0490 */ 0x0A, 0xE0, 0xC4, 0xFF, 0xFF, 0x7E, 0x05, 0x58, /* 0498 */ 0x0E, 0x77, 0xBF, 0x02, 0x7A, 0xB7, 0x23, 0xF0, /* 04A0 */ 0xA2, 0xBC, 0x1D, 0x61, 0xAF, 0x58, 0xF8, 0x8C, /* 04A8 */ 0x57, 0x2C, 0x1A, 0x66, 0x25, 0x8A, 0xB7, 0x26, /* 04B0 */ 0x0A, 0xE3, 0x2B, 0x16, 0x30, 0xF9, 0xFF, 0x5F, /* 04B8 */ 0xB1, 0x80, 0xD9, 0x41, 0x14, 0x37, 0x6A, 0xB8, /* 04C0 */ 0x17, 0x27, 0xDF, 0x7A, 0x3C, 0xDF, 0x88, 0xBE, /* 04C8 */ 0xC3, 0x60, 0x4E, 0x58, 0x30, 0x6E, 0x58, 0xF0, /* 04D0 */ 0x87, 0xF4, 0x30, 0xEC, 0x93, 0xC4, 0x3B, 0x96, /* 04D8 */ 0x8F, 0x56, 0x06, 0x79, 0x03, 0x7E, 0xB2, 0x7A, /* 04E0 */ 0xB0, 0x8A, 0x62, 0x84, 0x80, 0xC7, 0xF3, 0x2E, /* 04E8 */ 0xEC, 0xA3, 0xD5, 0x9B, 0x96, 0x51, 0x62, 0xC7, /* 04F0 */ 0xF2, 0x85, 0xEA, 0x59, 0xCB, 0xD7, 0x2C, 0x43, /* 04F8 */ 0xC4, 0x7D, 0x20, 0xF6, 0x0D, 0x0B, 0xB0, 0xFD, /* 0500 */ 0xFF, 0xBF, 0x61, 0x01, 0x8E, 0x2E, 0x0E, 0xFC, /* 0508 */ 0xE0, 0x80, 0xBD, 0x61, 0x01, 0x3E, 0x67, 0x0A, /* 0510 */ 0x9E, 0x1B, 0x16, 0xB0, 0xF9, 0xFF, 0xDF, 0xB0, /* 0518 */ 0x00, 0xFE, 0xFF, 0xFF, 0x6F, 0x58, 0xC0, 0xE1, /* 0520 */ 0x76, 0x85, 0xBD, 0x65, 0x61, 0x6F, 0x2F, 0x64, /* 0528 */ 0x15, 0x34, 0xD4, 0x4A, 0x14, 0xFC, 0x7B, 0x65, /* 0530 */ 0x18, 0x7A, 0xC3, 0x02, 0x1C, 0x8D, 0xDB, 0xA3, /* 0538 */ 0x06, 0xC7, 0xD9, 0xE0, 0x49, 0x02, 0x73, 0xAE, /* 0540 */ 0xC6, 0xCD, 0xE6, 0xE0, 0x02, 0x47, 0xE8, 0x1D, /* 0548 */ 0x54, 0x73, 0x67, 0x97, 0x14, 0x18, 0xB7, 0x2C, /* 0550 */ 0xB8, 0x97, 0xAA, 0x87, 0x86, 0x28, 0x07, 0xF1, /* 0558 */ 0x2A, 0xFC, 0x60, 0xF5, 0x28, 0x75, 0x64, 0x8F, /* 0560 */ 0x57, 0x4F, 0xC3, 0x3E, 0x66, 0xF9, 0x96, 0x65, /* 0568 */ 0xA8, 0x08, 0x6F, 0x59, 0xEC, 0x0C, 0x11, 0x2F, /* 0570 */ 0x56, 0x94, 0x10, 0xEF, 0x15, 0xA1, 0x7D, 0xE7, /* 0578 */ 0x32, 0xF8, 0xA3, 0xB1, 0x51, 0x83, 0xBE, 0x1C, /* 0580 */ 0xBF, 0x65, 0xC1, 0xFB, 0xFF, 0xDF, 0xB2, 0xE0, /* 0588 */ 0x8B, 0xFC, 0xAB, 0xE8, 0x44, 0xE0, 0x5B, 0x16, /* 0590 */ 0xC0, 0x8F, 0x60, 0x10, 0x72, 0x32, 0x70, 0xF4, /* 0598 */ 0x79, 0x01, 0x3F, 0x80, 0x87, 0x11, 0x0F, 0x89, /* 05A0 */ 0x05, 0x18, 0x38, 0xBD, 0x2F, 0xF9, 0x4C, 0xC1, /* 05A8 */ 0x0F, 0x18, 0x3E, 0x53, 0xB0, 0xEB, 0x41, 0xF4, /* 05B0 */ 0xC7, 0x00, 0x9F, 0x4B, 0x30, 0x83, 0x03, 0xFF, /* 05B8 */ 0xB5, 0xE2, 0xD0, 0x3D, 0x8A, 0xD7, 0x07, 0x13, /* 05C0 */ 0x78, 0x70, 0xFC, 0xFF, 0x3F, 0x38, 0xB8, 0x77, /* 05C8 */ 0x86, 0x23, 0xF2, 0x1D, 0xC6, 0x83, 0x03, 0xDB, /* 05D0 */ 0x41, 0x00, 0x38, 0x0C, 0x0E, 0x1F, 0x6A, 0x70, /* 05D8 */ 0xE8, 0xF1, 0x18, 0x38, 0xA4, 0xCF, 0x63, 0xEC, /* 05E0 */ 0xC2, 0xF0, 0x90, 0xE3, 0xA1, 0x81, 0x0D, 0xD0, /* 05E8 */ 0x43, 0x03, 0x96, 0x93, 0x78, 0x0A, 0x39, 0x34, /* 05F0 */ 0x30, 0x4B, 0x18, 0x1A, 0x50, 0x8A, 0x37, 0x34, /* 05F8 */ 0xFA, 0xFF, 0x1F, 0x1A, 0x1F, 0x92, 0x0F, 0x0B, /* 0600 */ 0x31, 0x9F, 0x72, 0x22, 0xBC, 0x2F, 0xF8, 0x04, /* 0608 */ 0xC5, 0xD0, 0x5F, 0x53, 0x7C, 0xBB, 0xF0, 0x4D, /* 0610 */ 0x10, 0x37, 0x3E, 0x70, 0x5D, 0x3A, 0x3D, 0x3E, /* 0618 */ 0xE0, 0x73, 0xE4, 0xF2, 0xF8, 0x70, 0x47, 0x27, /* 0620 */ 0x8F, 0x0F, 0x86, 0xCB, 0xAB, 0x0C, 0x39, 0x9A, /* 0628 */ 0xF8, 0x68, 0xC5, 0x86, 0x07, 0xB6, 0x9B, 0x9E, /* 0630 */ 0x87, 0x07, 0x7C, 0xAE, 0x9B, 0x60, 0xBC, 0x42, /* 0638 */ 0xF2, 0x6B, 0x09, 0x8C, 0x13, 0x14, 0xFE, 0xBA, /* 0640 */ 0x09, 0xDE, 0xFF, 0xFF, 0x75, 0x13, 0x78, 0x8E, /* 0648 */ 0x82, 0x6B, 0xBD, 0x64, 0xD3, 0x20, 0xAF, 0x1C, /* 0650 */ 0xC5, 0x7A, 0x11, 0x50, 0x18, 0x9F, 0xD9, 0x00, /* 0658 */ 0x47, 0x63, 0x7D, 0x66, 0x03, 0xCB, 0xBD, 0x80, /* 0660 */ 0xDD, 0xD8, 0xE0, 0x9E, 0xD6, 0x60, 0xDF, 0x1D, /* 0668 */ 0x1E, 0xCE, 0x1E, 0xD3, 0x1E, 0xD5, 0x1E, 0xD0, /* 0670 */ 0x7C, 0xC4, 0x8E, 0xF1, 0x96, 0x16, 0x24, 0x4E, /* 0678 */ 0x84, 0xD7, 0x81, 0xA7, 0x35, 0x5F, 0x32, 0xE2, /* 0680 */ 0x05, 0x7A, 0x5A, 0x33, 0x46, 0x9C, 0x97, 0x36, /* 0688 */ 0x23, 0xBE, 0x52, 0x84, 0x78, 0x58, 0xF3, 0xC9, /* 0690 */ 0xCD, 0x78, 0x0F, 0x13, 0xE1, 0xC2, 0xBC, 0xB0, /* 0698 */ 0x3D, 0xAD, 0x81, 0xE3, 0xFF, 0x7F, 0x5A, 0x83, /* 06A0 */ 0x23, 0xE7, 0x8A, 0x0D, 0xD0, 0xE4, 0xA2, 0x8F, /* 06A8 */ 0x3B, 0xA4, 0x80, 0xE5, 0xDA, 0xC0, 0x6E, 0x29, /* 06B0 */ 0xF0, 0x2E, 0xD8, 0xC0, 0xF9, 0xFF, 0x7F, 0x44, /* 06B8 */ 0x01, 0x5F, 0x96, 0x0B, 0x36, 0xCD, 0x71, 0xC1, /* 06C0 */ 0x46, 0x71, 0x58, 0x0D, 0x90, 0xE6, 0x09, 0xFF, /* 06C8 */ 0x7A, 0x0D, 0xFE, 0x49, 0xF8, 0x7A, 0x0D, 0xD8, /* 06D0 */ 0xBE, 0xC5, 0xE2, 0xAE, 0xD7, 0xC0, 0xEA, 0xFF, /* 06D8 */ 0x7F, 0xBD, 0x06, 0x96, 0x82, 0x47, 0x4A, 0xEF, /* 06E0 */ 0xD4, 0xE0, 0xBA, 0x69, 0xE3, 0x41, 0xDF, 0xB4, /* 06E8 */ 0x61, 0x0A, 0xBE, 0x45, 0xD1, 0x28, 0xE4, 0x8A, /* 06F0 */ 0xB6, 0x10, 0x0A, 0xE3, 0x5B, 0x14, 0xE0, 0x08, /* 06F8 */ 0xFB, 0x2D, 0x0A, 0x2C, 0x17, 0xA7, 0xB7, 0x28, /* 0700 */ 0xFC, 0x0C, 0x3C, 0x68, 0xDF, 0x75, 0x18, 0xA6, /* 0708 */ 0xEF, 0xD0, 0xF0, 0x4F, 0x4D, 0xCF, 0x4D, 0x0F, /* 0710 */ 0x4E, 0x0F, 0xCD, 0x3E, 0x48, 0xF9, 0x70, 0xF0, /* 0718 */ 0xFC, 0xF4, 0xFF, 0x8F, 0xF1, 0x5E, 0xE7, 0x9B, /* 0720 */ 0xD4, 0x6B, 0x94, 0x2F, 0x30, 0xC7, 0x10, 0x31, /* 0728 */ 0xCA, 0xCB, 0xB4, 0x21, 0xE2, 0xF9, 0xD4, 0xE4, /* 0730 */ 0xB3, 0x42, 0xDC, 0x10, 0x0F, 0xD1, 0x46, 0x88, /* 0738 */ 0xFA, 0x3C, 0xED, 0x09, 0xBD, 0x46, 0x81, 0x57, /* 0740 */ 0xD0, 0x35, 0x0A, 0xA0, 0xC9, 0xFD, 0x08, 0x77, /* 0748 */ 0x8D, 0x02, 0xCB, 0xBD, 0x81, 0x9D, 0x87, 0xF8, /* 0750 */ 0x95, 0xC8, 0xD7, 0x06, 0x18, 0xF7, 0x28, 0x38, /* 0758 */ 0xFF, 0xFF, 0x7B, 0x14, 0x60, 0x23, 0xCC, 0x3D, /* 0760 */ 0x8A, 0x06, 0xB9, 0x47, 0xA1, 0x4E, 0x26, 0xBE, /* 0768 */ 0xD4, 0x79, 0xA2, 0xE0, 0x08, 0x7F, 0x91, 0x42, /* 0770 */ 0xC5, 0x26, 0x51, 0xE8, 0xC3, 0x10, 0x2A, 0xE6, /* 0778 */ 0x61, 0x84, 0x82, 0x18, 0xD0, 0x19, 0x4E, 0x14, /* 0780 */ 0x68, 0x15, 0x27, 0x0A, 0x72, 0x8B, 0xF1, 0xA4, /* 0788 */ 0x1E, 0xA3, 0x00, 0x5F, 0xCB, 0xF4, 0x50, 0x79, /* 0790 */ 0xE4, 0xA1, 0x52, 0x10, 0x0F, 0xD5, 0x71, 0x86, /* 0798 */ 0x8A, 0x9E, 0xA4, 0xE7, 0x8F, 0xF9, 0xFF, 0x1F, /* 07A0 */ 0x1C, 0xB0, 0x07, 0x29, 0x80, 0x17, 0x0A, 0x6D, /* 07A8 */ 0xFA, 0xD4, 0x68, 0xD4, 0xAA, 0x41, 0x99, 0x1A, /* 07B0 */ 0x65, 0x1A, 0xD4, 0xEA, 0x53, 0xA9, 0x31, 0x63, /* 07B8 */ 0xE7, 0x50, 0x4B, 0x3B, 0x4B, 0x50, 0x31, 0x8B, /* 07C0 */ 0xD1, 0x68, 0x1C, 0x05, 0x84, 0xCA, 0xFE, 0x9B, /* 07C8 */ 0x0B, 0xC4, 0x21, 0x9F, 0x3A, 0x02, 0x74, 0xB0, /* 07D0 */ 0x17, 0x95, 0x80, 0x2C, 0x6B, 0x6D, 0x02, 0x71, /* 07D8 */ 0x7C, 0x13, 0x10, 0x8D, 0x80, 0x48, 0xCB, 0x63, /* 07E0 */ 0x42, 0x40, 0xCE, 0x0D, 0x22, 0x20, 0xAB, 0x58, /* 07E8 */ 0x93, 0x80, 0xAC, 0xF9, 0x01, 0x23, 0x70, 0xEB, /* 07F0 */ 0xD4, 0x01, 0xC4, 0x52, 0x82, 0xD0, 0x44, 0x0B, /* 07F8 */ 0x17, 0xA8, 0xE3, 0x81, 0x68, 0x30, 0x84, 0x46, /* 0800 */ 0x40, 0x0E, 0x46, 0x21, 0x20, 0xCB, 0xF8, 0x74, /* 0808 */ 0x0B, 0xDC, 0x02, 0xAC, 0x00, 0x31, 0xF9, 0x20, /* 0810 */ 0x54, 0xB0, 0x17, 0x50, 0xA6, 0x1E, 0x44, 0x40, /* 0818 */ 0x56, 0xBA, 0x56, 0x01, 0x59, 0x37, 0x88, 0x80, /* 0820 */ 0xFE, 0xFF, 0x2F, 0x83, 0x32, 0x03, 0xCE, 0x32, /* 0828 */ 0xBA, 0x01, 0x62, 0x0A, 0x1F, 0x0A, 0x02, 0xB1, /* 0830 */ 0x26, 0x3D, 0xA0, 0x4C, 0x20, 0x88, 0xAE, 0x1C, /* 0838 */ 0xC4, 0x0F, 0x10, 0x93, 0x06, 0x22, 0x20, 0xC7, /* 0840 */ 0x39, 0x98, 0x08, 0xDC, 0x71, 0x14, 0x01, 0x52, /* 0848 */ 0x47, 0xC3, 0xA5, 0x20, 0x54, 0xFC, 0xF3, 0x44, /* 0850 */ 0x20, 0x16, 0x64, 0x09, 0x8C, 0x82, 0xD0, 0x08, /* 0858 */ 0x9A, 0x40, 0x98, 0x3C, 0x4F, 0x20, 0x2C, 0xD4, /* 0860 */ 0x9F, 0x5C, 0xA7, 0x15, 0xA2, 0x6A, 0x88, 0xD4, /* 0868 */ 0x15, 0x08, 0x0B, 0xFC, 0x30, 0xD0, 0x60, 0x9C, /* 0870 */ 0x1E, 0x44, 0x40, 0x4E, 0xFA, 0xA7, 0x0A, 0x44, /* 0878 */ 0x72, 0x83, 0x08, 0xC8, 0xF9, 0x9F, 0x22, 0x02, /* 0880 */ 0x77, 0xEA, 0xD7, 0x84, 0x86, 0x4F, 0xBE, 0x58, /* 0888 */ 0x41, 0x88, 0xB8, 0x87, 0x55, 0x50, 0xA2, 0x14, /* 0890 */ 0x44, 0x40, 0x56, 0xF6, 0xB4, 0x12, 0x90, 0x75, /* 0898 */ 0x82, 0x08, 0xC8, 0xFF, 0x7F }) } Device (WMI2) { Name (_HID, EisaId ("PNP0C14")) // _HID: Hardware ID Name (_UID, 0x02) // _UID: Unique ID Name (_WDG, Buffer (0x64) { /* 0000 */ 0xF1, 0x24, 0xB4, 0xFC, 0x5A, 0x07, 0x0E, 0x4E, /* 0008 */ 0xBF, 0xC4, 0x62, 0xF3, 0xE7, 0x17, 0x71, 0xFA, /* 0010 */ 0x41, 0x37, 0x01, 0x01, 0xE3, 0x5E, 0xBE, 0xE2, /* 0018 */ 0xDA, 0x42, 0xDB, 0x49, 0x83, 0x78, 0x1F, 0x52, /* 0020 */ 0x47, 0x38, 0x82, 0x02, 0x41, 0x38, 0x01, 0x02, /* 0028 */ 0x9A, 0x01, 0x30, 0x74, 0xE9, 0xDC, 0x48, 0x45, /* 0030 */ 0xBA, 0xB0, 0x9F, 0xDE, 0x09, 0x35, 0xCA, 0xFF, /* 0038 */ 0x41, 0x39, 0x0A, 0x05, 0x03, 0x70, 0xF4, 0x7F, /* 0040 */ 0x6C, 0x3B, 0x5E, 0x4E, 0xA2, 0x27, 0xE9, 0x79, /* 0048 */ 0x82, 0x4A, 0x85, 0xD1, 0x41, 0x41, 0x01, 0x06, /* 0050 */ 0x21, 0x12, 0x90, 0x05, 0x66, 0xD5, 0xD1, 0x11, /* 0058 */ 0xB2, 0xF0, 0x00, 0xA0, 0xC9, 0x06, 0x29, 0x10, /* 0060 */ 0x42, 0x42, 0x01, 0x00 }) Name (PREL, Buffer (0x08) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) Method (WQA7, 1, NotSerialized) { Acquire (\_SB.WMI1.MWMI, 0xFFFF) \WMIS (0x07, 0x00) Store (\WLS0, Index (PREL, 0x00)) Store (\WLS1, Index (PREL, 0x01)) Store (\WLS2, Index (PREL, 0x02)) Store (\WLS3, Index (PREL, 0x03)) Store (\WLS4, Index (PREL, 0x04)) Store (\WLS5, Index (PREL, 0x05)) Store (\WLS6, Index (PREL, 0x06)) Store (\WLS7, Index (PREL, 0x07)) Release (\_SB.WMI1.MWMI) Return (PREL) } Method (WMA8, 3, NotSerialized) { CreateByteField (Arg2, 0x00, PRE0) CreateByteField (Arg2, 0x01, PRE1) CreateByteField (Arg2, 0x02, PRE2) CreateByteField (Arg2, 0x03, PRE3) CreateByteField (Arg2, 0x04, PRE4) CreateByteField (Arg2, 0x05, PRE5) CreateByteField (Arg2, 0x06, PRE6) CreateByteField (Arg2, 0x07, PRE7) Acquire (\_SB.WMI1.MWMI, 0xFFFF) Store (PRE0, \WLS0) Store (PRE1, \WLS1) Store (PRE2, \WLS2) Store (PRE3, \WLS3) Store (PRE4, \WLS4) Store (PRE5, \WLS5) Store (PRE6, \WLS6) Store (PRE7, \WLS7) \WMIS (0x08, 0x00) Release (\_SB.WMI1.MWMI) } Name (ITEM, Package (0x06) { Package (0x02) { 0x00, "InhibitEnteringThinkPadSetup" }, Package (0x02) { 0x00, "MTMSerialConcatenation" }, Package (0x02) { 0x00, "SwapProductName" }, Package (0x02) { 0x00, "ComputraceMsgDisable" }, Package (0x02) { 0x00, "CpuDebugEnable" }, Package (0x02) { 0x00, "PasswordAfterBootDeviceList" } }) Name (VSEL, Package (0x02) { Package (0x02) { "Disable", "Enable" }, Package (0x02) { "Off", "On" } }) Method (WQA9, 1, NotSerialized) { Acquire (\_SB.WMI1.MWMI, 0xFFFF) If (LNotEqual (\WMIS (0x09, Arg0), 0x00)) { Release (\_SB.WMI1.MWMI) Return ("") } Store (DerefOf (Index (ITEM, \WITM)), Local0) Store (DerefOf (Index (Local0, 0x00)), Local1) Store (DerefOf (Index (Local0, 0x01)), Local2) Concatenate (Local2, ",", Local6) Store (DerefOf (Index (VSEL, Local1)), Local3) Concatenate (Local6, DerefOf (Index (Local3, \WSEL)), Local7) Release (\_SB.WMI1.MWMI) Return (Local7) } Method (WMAA, 3, NotSerialized) { Acquire (\_SB.WMI1.MWMI, 0xFFFF) If (LEqual (SizeOf (Arg2), 0x00)) { Store (0x02, Local0) } Else { Store (\_SB.WMI1.CARG (Arg2), Local0) If (LEqual (Local0, 0x00)) { Store (\_SB.WMI1.WSET (ITEM, VSEL), Local0) If (LEqual (Local0, 0x00)) { Store (\WMIS (0x0A, 0x00), Local0) } } } Release (\_SB.WMI1.MWMI) Return (DerefOf (Index (\_SB.WMI1.RETN, Local0))) } Name (WQBB, Buffer (0x0538) { /* 0000 */ 0x46, 0x4F, 0x4D, 0x42, 0x01, 0x00, 0x00, 0x00, /* 0008 */ 0x28, 0x05, 0x00, 0x00, 0xAE, 0x18, 0x00, 0x00, /* 0010 */ 0x44, 0x53, 0x00, 0x01, 0x1A, 0x7D, 0xDA, 0x54, /* 0018 */ 0x98, 0xDE, 0x8B, 0x00, 0x01, 0x06, 0x18, 0x42, /* 0020 */ 0x10, 0x0D, 0x10, 0x8A, 0x0D, 0x21, 0x02, 0x0B, /* 0028 */ 0x83, 0x50, 0x50, 0x18, 0x14, 0xA0, 0x45, 0x41, /* 0030 */ 0xC8, 0x05, 0x14, 0x95, 0x02, 0x21, 0xC3, 0x02, /* 0038 */ 0x14, 0x0B, 0x70, 0x2E, 0x40, 0xBA, 0x00, 0xE5, /* 0040 */ 0x28, 0x72, 0x0C, 0x22, 0x02, 0xF7, 0xEF, 0x0F, /* 0048 */ 0x31, 0x10, 0x88, 0x14, 0x40, 0x48, 0x28, 0x84, /* 0050 */ 0x44, 0x00, 0x53, 0x21, 0x70, 0x84, 0xA0, 0x5F, /* 0058 */ 0x01, 0x08, 0x1D, 0x0A, 0x90, 0x29, 0xC0, 0xA0, /* 0060 */ 0x00, 0xA7, 0x08, 0x22, 0x88, 0xD2, 0xB2, 0x00, /* 0068 */ 0xDD, 0x02, 0x7C, 0x0B, 0xD0, 0x0E, 0x21, 0xB4, /* 0070 */ 0xC8, 0x95, 0x0A, 0xB0, 0x08, 0x25, 0x9F, 0x80, /* 0078 */ 0x92, 0x88, 0x22, 0xD9, 0x78, 0xB2, 0x8D, 0x48, /* 0080 */ 0xE6, 0x61, 0x91, 0x83, 0x40, 0x89, 0x19, 0x04, /* 0088 */ 0x4A, 0x27, 0xAE, 0x6C, 0xE2, 0x6A, 0x10, 0x07, /* 0090 */ 0x10, 0xE5, 0x3C, 0xA2, 0x24, 0x38, 0xAA, 0x83, /* 0098 */ 0x88, 0x10, 0xBB, 0x5C, 0x01, 0x92, 0x07, 0x20, /* 00A0 */ 0xCD, 0x13, 0x93, 0xF5, 0x39, 0x68, 0x64, 0x6C, /* 00A8 */ 0x04, 0x3C, 0x98, 0x04, 0x10, 0x16, 0x65, 0x9D, /* 00B0 */ 0x8A, 0x02, 0x83, 0xF2, 0x00, 0x22, 0x39, 0x63, /* 00B8 */ 0x45, 0x01, 0xDB, 0xEB, 0x44, 0x64, 0x72, 0xA0, /* 00C0 */ 0x54, 0x12, 0x1C, 0x6A, 0x98, 0x9E, 0x5A, 0xF3, /* 00C8 */ 0x13, 0xD3, 0x44, 0x4E, 0xAD, 0xE9, 0x21, 0x0B, /* 00D0 */ 0x92, 0x49, 0x1B, 0x0A, 0x6A, 0xEC, 0x9E, 0xD6, /* 00D8 */ 0x49, 0x79, 0xA6, 0x11, 0x0F, 0xCA, 0x30, 0x09, /* 00E0 */ 0x3C, 0x0A, 0x86, 0xC6, 0x09, 0xCA, 0x82, 0x90, /* 00E8 */ 0x83, 0x81, 0xA2, 0x00, 0x4F, 0xC2, 0x73, 0x2C, /* 00F0 */ 0x5E, 0x80, 0xF0, 0x11, 0x93, 0xB3, 0x40, 0x8C, /* 00F8 */ 0x04, 0x3E, 0x13, 0x78, 0xE4, 0xC7, 0x8C, 0x1D, /* 0100 */ 0x51, 0xB8, 0x80, 0xE7, 0x73, 0x0C, 0x91, 0xE3, /* 0108 */ 0x1E, 0x6A, 0x8C, 0xA3, 0x88, 0x7C, 0x38, 0x0C, /* 0110 */ 0xED, 0x74, 0xE3, 0x1C, 0xD8, 0xE9, 0x14, 0x04, /* 0118 */ 0x2E, 0x90, 0x60, 0x3D, 0xCF, 0x59, 0x20, 0xFF, /* 0120 */ 0xFF, 0x18, 0x07, 0xC1, 0xF0, 0x8E, 0x01, 0x23, /* 0128 */ 0x03, 0x42, 0x1E, 0x05, 0x58, 0x1D, 0x96, 0x26, /* 0130 */ 0x91, 0xC0, 0xEE, 0x05, 0x68, 0xBC, 0x04, 0x48, /* 0138 */ 0xE1, 0x20, 0xA5, 0x0C, 0x42, 0x30, 0x8D, 0x09, /* 0140 */ 0xB0, 0x75, 0x68, 0x90, 0x37, 0x01, 0xD6, 0xAE, /* 0148 */ 0x02, 0x42, 0x89, 0x74, 0x02, 0x71, 0x42, 0x44, /* 0150 */ 0x89, 0x18, 0xD4, 0x40, 0x51, 0x6A, 0x43, 0x15, /* 0158 */ 0x4C, 0x67, 0xC3, 0x13, 0x66, 0xDC, 0x10, 0x31, /* 0160 */ 0x0C, 0x14, 0xB7, 0xFD, 0x41, 0x90, 0x61, 0xE3, /* 0168 */ 0xC6, 0xEF, 0x41, 0x9D, 0xD6, 0xD9, 0x1D, 0xD3, /* 0170 */ 0xAB, 0x82, 0x09, 0x3C, 0xE9, 0x37, 0x84, 0xA7, /* 0178 */ 0x83, 0xA3, 0x38, 0xDA, 0xA8, 0x31, 0x9A, 0x23, /* 0180 */ 0x65, 0xAB, 0xD6, 0xB9, 0xC2, 0x91, 0xE0, 0x51, /* 0188 */ 0xE7, 0x05, 0x9F, 0x0C, 0x3C, 0xB4, 0xC3, 0xF6, /* 0190 */ 0x60, 0xCF, 0xD2, 0x43, 0x38, 0x82, 0x67, 0x86, /* 0198 */ 0x47, 0x02, 0x8F, 0x81, 0xDD, 0x15, 0x7C, 0x08, /* 01A0 */ 0xF0, 0x19, 0x01, 0xEF, 0x1A, 0x50, 0x97, 0x83, /* 01A8 */ 0x47, 0x03, 0x36, 0xE9, 0x70, 0x98, 0xF1, 0x7A, /* 01B0 */ 0xEE, 0x9E, 0xBA, 0xCF, 0x18, 0xFC, 0xBC, 0xE1, /* 01B8 */ 0xC1, 0xE1, 0x46, 0x7A, 0x32, 0x47, 0x56, 0xAA, /* 01C0 */ 0x00, 0xB3, 0xD7, 0x00, 0x1D, 0x25, 0x7C, 0xE0, /* 01C8 */ 0x60, 0x77, 0x81, 0xA7, 0x00, 0x13, 0x58, 0xFE, /* 01D0 */ 0x20, 0x50, 0x23, 0x33, 0xB4, 0xC7, 0xFB, 0xDE, /* 01D8 */ 0x61, 0xC8, 0x27, 0x85, 0xC3, 0x62, 0x62, 0x0F, /* 01E0 */ 0x1E, 0x74, 0x3C, 0xE0, 0xBF, 0x8F, 0x3C, 0x69, /* 01E8 */ 0x78, 0xFA, 0x9E, 0xAF, 0x09, 0x06, 0x86, 0x90, /* 01F0 */ 0x95, 0xF1, 0xA0, 0x06, 0x62, 0xE8, 0x57, 0x85, /* 01F8 */ 0xC3, 0x38, 0x0D, 0x9F, 0x40, 0x7C, 0x0E, 0x08, /* 0200 */ 0x12, 0xE3, 0x98, 0x3C, 0x38, 0xFF, 0xFF, 0x09, /* 0208 */ 0x1C, 0x6B, 0xE4, 0xF4, 0x9C, 0xE2, 0xF3, 0x04, /* 0210 */ 0x3F, 0x5C, 0xF8, 0x3C, 0xC1, 0x4E, 0x0C, 0xA7, /* 0218 */ 0xF1, 0x1C, 0xE0, 0xE1, 0x9C, 0x95, 0x8F, 0x13, /* 0220 */ 0xC0, 0x02, 0xE2, 0x75, 0x82, 0x0F, 0x14, 0x3E, /* 0228 */ 0xEC, 0xA1, 0x79, 0x14, 0x2F, 0x11, 0x6F, 0x0F, /* 0230 */ 0x26, 0x88, 0xF6, 0x10, 0x03, 0xC6, 0x19, 0xE1, /* 0238 */ 0xCE, 0x1B, 0x70, 0x4E, 0x31, 0xC0, 0x03, 0xEA, /* 0240 */ 0x10, 0x30, 0x87, 0x09, 0x0F, 0x81, 0x0F, 0xE0, /* 0248 */ 0x19, 0xE4, 0x1C, 0x7D, 0xCC, 0x39, 0x33, 0xDC, /* 0250 */ 0x71, 0x07, 0x6C, 0xC3, 0xE0, 0x91, 0x2D, 0x80, /* 0258 */ 0xB0, 0x38, 0x4F, 0x02, 0x05, 0x7C, 0x1B, 0x50, /* 0260 */ 0x18, 0x1F, 0x6E, 0xC0, 0xFB, 0xFF, 0x3F, 0xDC, /* 0268 */ 0x00, 0xD7, 0xF3, 0x01, 0xEE, 0xF8, 0x00, 0xF7, /* 0270 */ 0x62, 0xC1, 0x0E, 0x0F, 0x8F, 0x37, 0xC0, 0x60, /* 0278 */ 0x48, 0x8F, 0x34, 0x6F, 0x35, 0x31, 0x5E, 0x6D, /* 0280 */ 0x42, 0x44, 0x78, 0xA8, 0x79, 0xB7, 0x31, 0x52, /* 0288 */ 0xBC, 0xC7, 0x1B, 0x76, 0x8D, 0x39, 0x8B, 0x07, /* 0290 */ 0x90, 0x28, 0xC5, 0xA1, 0xE9, 0x62, 0x13, 0x23, /* 0298 */ 0xCA, 0x9B, 0x8D, 0x61, 0xDF, 0x74, 0x0C, 0x14, /* 02A0 */ 0x2A, 0x52, 0x84, 0x30, 0x2F, 0x16, 0x21, 0x1E, /* 02A8 */ 0x6F, 0xC0, 0x2C, 0xE9, 0xA5, 0xA2, 0xCF, 0x81, /* 02B0 */ 0x8F, 0x37, 0x80, 0x97, 0xFF, 0xFF, 0xF1, 0x06, /* 02B8 */ 0xF0, 0x30, 0x0C, 0x1F, 0x53, 0xC0, 0x76, 0x73, /* 02C0 */ 0x60, 0xF7, 0x14, 0xF8, 0xE7, 0x14, 0xC0, 0x91, /* 02C8 */ 0x90, 0x47, 0x80, 0x0E, 0x1E, 0x16, 0x01, 0x22, /* 02D0 */ 0x1B, 0xCF, 0x00, 0x9F, 0x89, 0xA8, 0x40, 0x2A, /* 02D8 */ 0xCD, 0x14, 0x2C, 0xE3, 0x14, 0xAC, 0x4E, 0x88, /* 02E0 */ 0x5C, 0x06, 0x85, 0x44, 0x40, 0x68, 0x64, 0x86, /* 02E8 */ 0xF3, 0x21, 0xD1, 0x60, 0x06, 0xF1, 0xF9, 0xC0, /* 02F0 */ 0x67, 0x0A, 0x9F, 0x9C, 0xF8, 0xFF, 0xFF, 0xE4, /* 02F8 */ 0x04, 0x9E, 0x83, 0xC9, 0x43, 0x05, 0x2C, 0x44, /* 0300 */ 0x9F, 0x16, 0x38, 0x9C, 0xCF, 0x2C, 0x1C, 0xCE, /* 0308 */ 0x47, 0x12, 0x7E, 0x80, 0xE4, 0x47, 0x25, 0x70, /* 0310 */ 0x09, 0x3C, 0x34, 0x80, 0x02, 0xC8, 0xF7, 0x03, /* 0318 */ 0x9F, 0x03, 0x9E, 0x11, 0xD8, 0x1C, 0x1E, 0x09, /* 0320 */ 0x7C, 0x20, 0x60, 0xF0, 0x3C, 0xDA, 0xA8, 0xE8, /* 0328 */ 0xD1, 0xC6, 0xC3, 0xE3, 0x47, 0x06, 0xCF, 0xE7, /* 0330 */ 0x81, 0xE0, 0x28, 0x1F, 0x09, 0x70, 0x18, 0xEF, /* 0338 */ 0x17, 0x1E, 0xA2, 0x4F, 0x39, 0xB0, 0x26, 0x72, /* 0340 */ 0xD4, 0x16, 0x7D, 0x22, 0x10, 0xE8, 0x33, 0x17, /* 0348 */ 0xE6, 0x94, 0x03, 0x9C, 0x82, 0x8F, 0x1E, 0x15, /* 0350 */ 0xF5, 0x40, 0x0A, 0xDA, 0x93, 0x82, 0xCF, 0x0A, /* 0358 */ 0x3E, 0x7C, 0xC1, 0xFF, 0xFF, 0x1F, 0xBE, 0xE0, /* 0360 */ 0xCC, 0xEB, 0x65, 0xCD, 0x07, 0x8E, 0x38, 0x67, /* 0368 */ 0x71, 0xBA, 0xEF, 0x16, 0xF8, 0x13, 0x29, 0x30, /* 0370 */ 0x0B, 0x72, 0x22, 0x45, 0xC1, 0xF8, 0x44, 0x0A, /* 0378 */ 0xD8, 0xBC, 0x05, 0x60, 0xAF, 0x0B, 0x4F, 0x22, /* 0380 */ 0x30, 0xCE, 0x11, 0xCF, 0x58, 0x30, 0x0F, 0x55, /* 0388 */ 0xA7, 0xF8, 0x52, 0xF5, 0xC6, 0x10, 0xE1, 0xC9, /* 0390 */ 0xEA, 0x35, 0xEA, 0x01, 0xCB, 0x60, 0x2F, 0x02, /* 0398 */ 0x86, 0x79, 0xC5, 0xF2, 0xE9, 0x2A, 0xC4, 0x03, /* 03A0 */ 0x96, 0xCF, 0x5A, 0xD1, 0x42, 0x84, 0x8C, 0x12, /* 03A8 */ 0xEC, 0x15, 0xEB, 0x55, 0xC6, 0x47, 0x2A, 0x83, /* 03B0 */ 0x07, 0x0C, 0x1B, 0x2D, 0x52, 0x84, 0x47, 0x2C, /* 03B8 */ 0xFC, 0xFF, 0xFF, 0x88, 0x05, 0x1E, 0x09, 0x07, /* 03C0 */ 0x52, 0x80, 0x2A, 0x03, 0xC7, 0x1D, 0x48, 0x81, /* 03C8 */ 0xFD, 0x69, 0x02, 0x7F, 0xBD, 0xF0, 0x78, 0xB0, /* 03D0 */ 0xFF, 0xFF, 0x73, 0x00, 0xF8, 0x0E, 0x31, 0xC0, /* 03D8 */ 0x60, 0xC0, 0x30, 0x0E, 0x31, 0xC0, 0x43, 0xF0, /* 03E0 */ 0xC9, 0x0C, 0xF4, 0xC7, 0x1D, 0xF8, 0xE3, 0xE0, /* 03E8 */ 0x19, 0x9F, 0x1C, 0x26, 0x50, 0x98, 0x13, 0x29, /* 03F0 */ 0x0A, 0xC6, 0x27, 0x52, 0xC0, 0xD9, 0xFF, 0xFF, /* 03F8 */ 0x70, 0x05, 0x86, 0xE3, 0x0D, 0xF8, 0x6F, 0x33, /* 0400 */ 0x3E, 0x84, 0xFA, 0x7C, 0xE3, 0x0B, 0xA9, 0x21, /* 0408 */ 0x5E, 0x6C, 0xDE, 0xD4, 0x5E, 0x09, 0x5E, 0xDF, /* 0410 */ 0xD9, 0xB5, 0xE6, 0xF5, 0xDD, 0xA7, 0x82, 0x27, /* 0418 */ 0xD1, 0x08, 0x21, 0xA3, 0xBC, 0xE4, 0x18, 0x24, /* 0420 */ 0xC4, 0xEB, 0xA8, 0x01, 0x83, 0x05, 0x89, 0x78, /* 0428 */ 0x0A, 0x4F, 0x3B, 0x8F, 0x37, 0xE0, 0x15, 0x75, /* 0430 */ 0x20, 0x05, 0xE8, 0xF1, 0xFF, 0x3F, 0x90, 0x02, /* 0438 */ 0x83, 0x7B, 0x0A, 0xEC, 0x73, 0x0A, 0xE0, 0x29, /* 0440 */ 0xF9, 0x89, 0x94, 0xA6, 0x3E, 0x91, 0xA2, 0x15, /* 0448 */ 0x01, 0x69, 0xAA, 0x60, 0x21, 0x98, 0xFE, 0x44, /* 0450 */ 0x4A, 0x0F, 0x06, 0xCE, 0x4D, 0xA2, 0xE4, 0x43, /* 0458 */ 0xA3, 0x70, 0xCE, 0x7A, 0x20, 0xA1, 0x20, 0x06, /* 0460 */ 0x74, 0x90, 0x43, 0x05, 0xFA, 0xAC, 0xE2, 0x03, /* 0468 */ 0xC9, 0x81, 0x3C, 0x22, 0x7A, 0x58, 0x3E, 0x54, /* 0470 */ 0xFA, 0xAE, 0xE2, 0x73, 0x88, 0x8F, 0x14, 0x1E, /* 0478 */ 0xBF, 0x0F, 0x0B, 0xFC, 0x3F, 0xE3, 0xE3, 0x28, /* 0480 */ 0x03, 0xAF, 0xE6, 0xBC, 0x82, 0x02, 0xF3, 0x69, /* 0488 */ 0x14, 0xA3, 0xEB, 0x3E, 0x01, 0x92, 0xFF, 0xFF, /* 0490 */ 0xFC, 0xB8, 0xBE, 0xC3, 0x28, 0xC8, 0xD1, 0x79, /* 0498 */ 0xF8, 0xC9, 0xA2, 0xE2, 0x4E, 0x96, 0x82, 0x78, /* 04A0 */ 0xB2, 0x8E, 0x32, 0x59, 0xF4, 0x4C, 0x7C, 0xBB, /* 04A8 */ 0xF0, 0x8C, 0xDE, 0xBB, 0x7C, 0x83, 0x65, 0x37, /* 04B0 */ 0x59, 0x78, 0x97, 0x81, 0x90, 0x8F, 0x06, 0xBE, /* 04B8 */ 0xC9, 0xC2, 0x1D, 0x8B, 0x2F, 0x23, 0xE0, 0xBB, /* 04C0 */ 0xC9, 0x02, 0x5E, 0x47, 0xE3, 0xB3, 0x05, 0x3B, /* 04C8 */ 0x85, 0xF8, 0xBA, 0x06, 0x4B, 0xA1, 0x4D, 0x9F, /* 04D0 */ 0x1A, 0x8D, 0x5A, 0xFD, 0xFF, 0x1B, 0x94, 0xA9, /* 04D8 */ 0x51, 0xA6, 0x41, 0xAD, 0x3E, 0x95, 0x1A, 0x33, /* 04E0 */ 0x76, 0xA1, 0xB0, 0xB8, 0x0B, 0x06, 0x95, 0xB4, /* 04E8 */ 0x2C, 0x8D, 0xCB, 0x81, 0x40, 0x68, 0x80, 0x5B, /* 04F0 */ 0xA9, 0x40, 0x1C, 0xFA, 0x0B, 0xA4, 0x53, 0x02, /* 04F8 */ 0xF9, 0x6A, 0x09, 0xC8, 0x62, 0x57, 0x25, 0x10, /* 0500 */ 0xCB, 0x54, 0x01, 0xD1, 0xC8, 0xDD, 0xC2, 0x20, /* 0508 */ 0x02, 0x72, 0xBC, 0x4F, 0x8D, 0x40, 0x1D, 0x49, /* 0510 */ 0x07, 0x10, 0x13, 0xE4, 0x63, 0xAC, 0xF4, 0x25, /* 0518 */ 0x20, 0x10, 0xCB, 0xA6, 0x15, 0xA0, 0xE5, 0x3A, /* 0520 */ 0x01, 0x62, 0x61, 0x41, 0x68, 0xC0, 0x5F, 0xB5, /* 0528 */ 0x86, 0xE0, 0xB4, 0x20, 0x02, 0x72, 0x32, 0x2D, /* 0530 */ 0x40, 0x2C, 0x27, 0x88, 0x80, 0xFC, 0xFF, 0x07 }) } Device (WMI3) { Name (_HID, EisaId ("PNP0C14")) // _HID: Hardware ID Name (_UID, 0x03) // _UID: Unique ID Name (_WDG, /**** Is ResourceTemplate, but EndTag not at buffer end ****/ Buffer (0x3C) { /* 0000 */ 0x79, 0x36, 0x4D, 0x8F, 0x9E, 0x74, 0x79, 0x44, /* 0008 */ 0x9B, 0x16, 0xC6, 0x26, 0x01, 0xFD, 0x25, 0xF0, /* 0010 */ 0x41, 0x42, 0x01, 0x02, 0x69, 0xE8, 0xD2, 0x85, /* 0018 */ 0x5A, 0x36, 0xCE, 0x4A, 0xA4, 0xD3, 0xCD, 0x69, /* 0020 */ 0x2B, 0x16, 0x98, 0xA0, 0x41, 0x43, 0x01, 0x02, /* 0028 */ 0x21, 0x12, 0x90, 0x05, 0x66, 0xD5, 0xD1, 0x11, /* 0030 */ 0xB2, 0xF0, 0x00, 0xA0, 0xC9, 0x06, 0x29, 0x10, /* 0038 */ 0x42, 0x43, 0x01, 0x00 }) Method (WMAB, 3, NotSerialized) { CreateByteField (Arg2, 0x00, ASS0) CreateWordField (Arg2, 0x01, ASS1) CreateByteField (Arg2, 0x03, ASS2) Acquire (\_SB.WMI1.MWMI, 0xFFFF) Store (ASS0, \WASB) Store (ASS1, \WASI) Store (ASS2, \WASD) \WMIS (0x0B, 0x00) Store (\WASS, Local0) Release (\_SB.WMI1.MWMI) Return (Local0) } Method (WMAC, 3, NotSerialized) { CreateByteField (Arg2, 0x00, ASS0) CreateWordField (Arg2, 0x01, ASS1) Acquire (\_SB.WMI1.MWMI, 0xFFFF) Store (ASS0, \WASB) Store (ASS1, \WASI) \WMIS (0x0C, Arg1) Store (\WASS, Local0) Release (\_SB.WMI1.MWMI) Return (Local0) } Name (WQBC, Buffer (0x040A) { /* 0000 */ 0x46, 0x4F, 0x4D, 0x42, 0x01, 0x00, 0x00, 0x00, /* 0008 */ 0xFA, 0x03, 0x00, 0x00, 0x32, 0x12, 0x00, 0x00, /* 0010 */ 0x44, 0x53, 0x00, 0x01, 0x1A, 0x7D, 0xDA, 0x54, /* 0018 */ 0x98, 0xC3, 0x88, 0x00, 0x01, 0x06, 0x18, 0x42, /* 0020 */ 0x10, 0x07, 0x10, 0x8A, 0x0D, 0x21, 0x02, 0x0B, /* 0028 */ 0x83, 0x50, 0x50, 0x18, 0x14, 0xA0, 0x45, 0x41, /* 0030 */ 0xC8, 0x05, 0x14, 0x95, 0x02, 0x21, 0xC3, 0x02, /* 0038 */ 0x14, 0x0B, 0x70, 0x2E, 0x40, 0xBA, 0x00, 0xE5, /* 0040 */ 0x28, 0x72, 0x0C, 0x22, 0x02, 0xF7, 0xEF, 0x0F, /* 0048 */ 0x31, 0x10, 0x88, 0x14, 0x40, 0x48, 0x28, 0x84, /* 0050 */ 0x44, 0x00, 0x53, 0x21, 0x70, 0x84, 0xA0, 0x5F, /* 0058 */ 0x01, 0x08, 0x1D, 0x0A, 0x90, 0x29, 0xC0, 0xA0, /* 0060 */ 0x00, 0xA7, 0x08, 0x22, 0x88, 0xD2, 0xB2, 0x00, /* 0068 */ 0xDD, 0x02, 0x7C, 0x0B, 0xD0, 0x0E, 0x21, 0xB4, /* 0070 */ 0x58, 0x07, 0x11, 0x21, 0xD2, 0x31, 0x34, 0x29, /* 0078 */ 0x40, 0xA2, 0x00, 0x8B, 0x02, 0x64, 0xC3, 0xC8, /* 0080 */ 0x36, 0x22, 0x99, 0x87, 0x45, 0x0E, 0x02, 0x25, /* 0088 */ 0x66, 0x10, 0x28, 0x9D, 0xE0, 0xB2, 0x89, 0xAB, /* 0090 */ 0x41, 0x9C, 0x4C, 0x94, 0xF3, 0x88, 0x92, 0xE0, /* 0098 */ 0xA8, 0x0E, 0x22, 0x42, 0xEC, 0x72, 0x05, 0x48, /* 00A0 */ 0x1E, 0x80, 0x34, 0x4F, 0x4C, 0xD6, 0xE7, 0xA0, /* 00A8 */ 0x91, 0xB1, 0x11, 0xF0, 0x94, 0x1A, 0x40, 0x58, /* 00B0 */ 0xA0, 0x75, 0x2A, 0xE0, 0x7A, 0x0D, 0x43, 0x3D, /* 00B8 */ 0x80, 0x48, 0xCE, 0x58, 0x51, 0xC0, 0xF6, 0x3A, /* 00C0 */ 0x11, 0x8D, 0xEA, 0x40, 0x99, 0x24, 0x38, 0xD4, /* 00C8 */ 0x30, 0x3D, 0xB5, 0xE6, 0x27, 0xA6, 0x89, 0x9C, /* 00D0 */ 0x5A, 0xD3, 0x43, 0x16, 0x24, 0x93, 0x36, 0x14, /* 00D8 */ 0xD4, 0xD8, 0x3D, 0xAD, 0x93, 0xF2, 0x4C, 0x23, /* 00E0 */ 0x1E, 0x94, 0x61, 0x12, 0x78, 0x14, 0x0C, 0x8D, /* 00E8 */ 0x13, 0x94, 0x75, 0x22, 0xA0, 0x03, 0xE5, 0x80, /* 00F0 */ 0x27, 0xE1, 0x39, 0x16, 0x2F, 0x40, 0xF8, 0x88, /* 00F8 */ 0xC9, 0xB4, 0x4D, 0xE0, 0x33, 0x81, 0x87, 0x79, /* 0100 */ 0xCC, 0xD8, 0x11, 0x85, 0x0B, 0x78, 0x3E, 0xC7, /* 0108 */ 0x10, 0x39, 0xEE, 0xA1, 0xC6, 0x38, 0x8A, 0xC8, /* 0110 */ 0x47, 0x60, 0x24, 0x03, 0xC5, 0x2B, 0x08, 0x89, /* 0118 */ 0x80, 0xF8, 0x76, 0x70, 0x70, 0x91, 0xFC, 0xFF, /* 0120 */ 0x47, 0x89, 0x11, 0x2A, 0xC6, 0xDB, 0x00, 0x6E, /* 0128 */ 0x5E, 0x09, 0x8A, 0x1E, 0x07, 0x4A, 0x06, 0x84, /* 0130 */ 0x3C, 0x0A, 0xB0, 0x7A, 0x28, 0x20, 0x04, 0x16, /* 0138 */ 0x27, 0x40, 0xE3, 0x38, 0x05, 0xD3, 0x99, 0x00, /* 0140 */ 0x6D, 0x02, 0xBC, 0x09, 0x30, 0x27, 0xC0, 0x16, /* 0148 */ 0x86, 0x80, 0x82, 0x9C, 0x59, 0x94, 0x20, 0x11, /* 0150 */ 0x42, 0x31, 0x88, 0x0A, 0x05, 0x18, 0x43, 0x14, /* 0158 */ 0xCA, 0x3B, 0x41, 0x8C, 0xCA, 0x20, 0x74, 0x82, /* 0160 */ 0x08, 0x14, 0x3D, 0x78, 0x98, 0xD6, 0x40, 0x74, /* 0168 */ 0x89, 0xF0, 0xC8, 0xB1, 0x47, 0x00, 0x9F, 0x19, /* 0170 */ 0xCE, 0xE9, 0x04, 0x1F, 0x01, 0xDE, 0x16, 0x4C, /* 0178 */ 0xE0, 0x79, 0xBF, 0x24, 0x1C, 0x6A, 0xD8, 0x03, /* 0180 */ 0x8E, 0x1A, 0xE3, 0x28, 0x12, 0x58, 0xD0, 0x33, /* 0188 */ 0x42, 0x16, 0x40, 0x14, 0x09, 0x1E, 0x75, 0x64, /* 0190 */ 0xF0, 0xE1, 0xC0, 0x23, 0x3B, 0x72, 0xCF, 0xF0, /* 0198 */ 0x04, 0x82, 0x1C, 0xC2, 0x11, 0x3C, 0x36, 0x3C, /* 01A0 */ 0x15, 0x78, 0x0C, 0xEC, 0xBA, 0xE0, 0x73, 0x80, /* 01A8 */ 0x8F, 0x09, 0x78, 0xD7, 0x80, 0x9A, 0xF3, 0xD3, /* 01B0 */ 0x01, 0x9B, 0x72, 0x38, 0xCC, 0x70, 0x3D, 0xFD, /* 01B8 */ 0x70, 0x27, 0x70, 0xD2, 0x06, 0x64, 0xB3, 0xF3, /* 01C0 */ 0xE0, 0x70, 0xE3, 0x3C, 0x99, 0x23, 0x2B, 0x55, /* 01C8 */ 0x80, 0xD9, 0x13, 0x82, 0x4E, 0x13, 0x3E, 0x73, /* 01D0 */ 0xB0, 0xBB, 0xC0, 0xF9, 0xF4, 0x0C, 0x49, 0xE4, /* 01D8 */ 0x0F, 0x02, 0x35, 0x32, 0x43, 0xFB, 0x2C, 0xF0, /* 01E0 */ 0xEA, 0x61, 0xC8, 0x87, 0x85, 0xC3, 0x62, 0x62, /* 01E8 */ 0xCF, 0x1E, 0x74, 0x3C, 0xE0, 0x3F, 0x25, 0x3C, /* 01F0 */ 0x6C, 0x78, 0xFA, 0x9E, 0xAF, 0x09, 0xA2, 0x3D, /* 01F8 */ 0x8F, 0x80, 0xE1, 0xFF, 0x7F, 0x1E, 0x81, 0x39, /* 0200 */ 0x9C, 0x07, 0x84, 0x27, 0x07, 0x76, 0x80, 0xC0, /* 0208 */ 0x1C, 0x48, 0x80, 0xC9, 0xF9, 0x02, 0x77, 0x28, /* 0210 */ 0xF0, 0x10, 0xF8, 0x00, 0x1E, 0x25, 0xCE, 0xD1, /* 0218 */ 0x4A, 0x67, 0x86, 0x3C, 0xB9, 0x80, 0x2D, 0xFB, /* 0220 */ 0x1B, 0x40, 0x07, 0x0F, 0xE7, 0x06, 0x91, 0x8D, /* 0228 */ 0x57, 0x80, 0x09, 0x74, 0x38, 0xB1, 0x1E, 0x20, /* 0230 */ 0x4D, 0x14, 0x0C, 0x04, 0xD3, 0xD3, 0x6B, 0x00, /* 0238 */ 0x3E, 0x15, 0x38, 0x37, 0x89, 0x92, 0x0F, 0x8C, /* 0240 */ 0xC2, 0x39, 0xEB, 0x79, 0x84, 0x82, 0x18, 0xD0, /* 0248 */ 0x41, 0x20, 0xE4, 0xE4, 0xA0, 0x80, 0x3A, 0xAA, /* 0250 */ 0xF8, 0x3C, 0x72, 0xAA, 0x0F, 0x3D, 0x9E, 0x94, /* 0258 */ 0x47, 0xE1, 0xAB, 0x8A, 0x0F, 0x21, 0x3E, 0x4F, /* 0260 */ 0x78, 0xF4, 0x3E, 0x29, 0xF0, 0xEF, 0x8C, 0xAF, /* 0268 */ 0x0E, 0x46, 0xB7, 0x9A, 0xE3, 0x0A, 0x0A, 0xCC, /* 0270 */ 0x67, 0x11, 0x4E, 0x50, 0xD7, 0x6D, 0x01, 0xFA, /* 0278 */ 0x29, 0xE0, 0x08, 0x3C, 0x94, 0x77, 0x92, 0xC7, /* 0280 */ 0x90, 0x04, 0xF5, 0x9D, 0x16, 0x40, 0x01, 0xE4, /* 0288 */ 0x9B, 0x81, 0x4F, 0x02, 0x21, 0xFE, 0xFF, 0x4F, /* 0290 */ 0x07, 0x1E, 0xC3, 0xC3, 0x80, 0xD1, 0x8C, 0xCE, /* 0298 */ 0xC3, 0x4F, 0x16, 0x15, 0x77, 0xB2, 0x14, 0xC4, /* 02A0 */ 0x93, 0x75, 0x94, 0xC9, 0xA2, 0x67, 0xE2, 0xAB, /* 02A8 */ 0x85, 0x27, 0x74, 0x4A, 0x41, 0xCE, 0xD1, 0x13, /* 02B0 */ 0xF6, 0x55, 0x04, 0xD6, 0xF9, 0x20, 0xE4, 0x8B, /* 02B8 */ 0x81, 0xA7, 0x61, 0x38, 0x4F, 0x96, 0xC3, 0x79, /* 02C0 */ 0xB2, 0x7C, 0x2C, 0xBE, 0x6A, 0xC0, 0x1F, 0x2D, /* 02C8 */ 0x96, 0xA0, 0xC0, 0xD9, 0x82, 0x1C, 0x1E, 0x13, /* 02D0 */ 0x6F, 0x54, 0xF4, 0x46, 0xE4, 0xE1, 0xF1, 0xCB, /* 02D8 */ 0x81, 0xE7, 0xF3, 0x8C, 0x70, 0x94, 0x6F, 0x12, /* 02E0 */ 0x38, 0x8C, 0xC7, 0x12, 0x0F, 0xD1, 0x97, 0x23, /* 02E8 */ 0x58, 0x13, 0x39, 0x69, 0xDF, 0x16, 0x4E, 0x36, /* 02F0 */ 0xE8, 0x4B, 0x10, 0xBB, 0x1C, 0x01, 0xBF, 0x88, /* 02F8 */ 0x26, 0x86, 0xC1, 0x22, 0x2D, 0x45, 0x11, 0x17, /* 0300 */ 0x45, 0x61, 0x7C, 0xC5, 0x82, 0xFD, 0xFF, 0xBF, /* 0308 */ 0x62, 0x01, 0x16, 0x04, 0x0F, 0x1B, 0x34, 0x87, /* 0310 */ 0x83, 0x97, 0x1E, 0x36, 0x6B, 0x38, 0x07, 0x99, /* 0318 */ 0xD3, 0xF1, 0x48, 0x4E, 0x1B, 0xC6, 0x1D, 0x0B, /* 0320 */ 0xFE, 0x9D, 0xEA, 0xA9, 0xCA, 0xD3, 0x8A, 0xF2, /* 0328 */ 0x64, 0xF5, 0x7A, 0xE5, 0x63, 0x96, 0xA1, 0xCE, /* 0330 */ 0xE0, 0x1D, 0xCB, 0xB7, 0x3C, 0x4F, 0x21, 0x4A, /* 0338 */ 0x9C, 0x97, 0x2D, 0x76, 0xC7, 0x32, 0x48, 0x50, /* 0340 */ 0x23, 0x3F, 0x68, 0x31, 0x94, 0xE0, 0xF1, 0xDE, /* 0348 */ 0xB1, 0x00, 0x6F, 0xFF, 0xFF, 0x3B, 0x16, 0x60, /* 0350 */ 0xFC, 0x04, 0xC1, 0x09, 0x7C, 0xC7, 0x02, 0x1C, /* 0358 */ 0xC5, 0x7E, 0x37, 0xE8, 0x4A, 0x45, 0xEE, 0x58, /* 0360 */ 0x28, 0x0E, 0xAB, 0xB9, 0x63, 0x41, 0x9C, 0x28, /* 0368 */ 0xE6, 0x8A, 0x05, 0x86, 0xFF, 0xFF, 0x15, 0x0B, /* 0370 */ 0xE0, 0x75, 0xC0, 0x2B, 0x16, 0x68, 0xFE, 0xFF, /* 0378 */ 0x57, 0x2C, 0xF0, 0x5E, 0x8E, 0x80, 0xDF, 0x09, /* 0380 */ 0xD1, 0x77, 0x0D, 0x7E, 0x9A, 0xB6, 0xA2, 0xBB, /* 0388 */ 0x06, 0x94, 0x19, 0xBE, 0x07, 0xF9, 0xB0, 0x13, /* 0390 */ 0x2C, 0xD2, 0xA3, 0x8D, 0x6F, 0x49, 0xE1, 0x7C, /* 0398 */ 0xDB, 0x00, 0xD8, 0xF2, 0xFF, 0xBF, 0x6D, 0x00, /* 03A0 */ 0x4C, 0x19, 0xBF, 0x6F, 0x1B, 0xC0, 0x4F, 0xA1, /* 03A8 */ 0x4D, 0x9F, 0x1A, 0x8D, 0x5A, 0x35, 0x28, 0x53, /* 03B0 */ 0xA3, 0x4C, 0x83, 0x5A, 0x7D, 0x2A, 0x35, 0x66, /* 03B8 */ 0x4C, 0xC9, 0xC1, 0xCE, 0x77, 0x0C, 0x2A, 0x6C, /* 03C0 */ 0x65, 0x1A, 0x9A, 0x63, 0x81, 0xD0, 0x10, 0xC7, /* 03C8 */ 0x26, 0x19, 0x01, 0x51, 0x22, 0x10, 0x01, 0x59, /* 03D0 */ 0xFD, 0x6F, 0x42, 0x40, 0xCE, 0x02, 0x22, 0x20, /* 03D8 */ 0x2B, 0x58, 0x9A, 0xC0, 0x9D, 0xFF, 0xD8, 0x28, /* 03E0 */ 0x40, 0xA2, 0x02, 0x84, 0x29, 0x7D, 0x93, 0x09, /* 03E8 */ 0xD4, 0xB2, 0x41, 0x04, 0xF4, 0xFF, 0x3F, 0x42, /* 03F0 */ 0xD9, 0x00, 0x62, 0x82, 0x41, 0x04, 0x64, 0x91, /* 03F8 */ 0x3E, 0x80, 0x98, 0x62, 0x10, 0x01, 0x59, 0xDD, /* 0400 */ 0xA3, 0x40, 0x40, 0xD6, 0x0A, 0x22, 0x20, 0xFF, /* 0408 */ 0xFF, 0x01 }) } Scope (\_SB.PCI0.LPC.EC.HKEY) { Mutex (BFWM, 0x00) Method (MHCF, 1, NotSerialized) { Store (\BFWC (Arg0), Local0) Store (ShiftRight (Arg0, 0x05), \_SB.PCI0.LPC.EC.BSWR) Return (Local0) } Method (MHPF, 1, NotSerialized) { Name (RETB, Buffer (0x25){}) Acquire (BFWM, 0xFFFF) If (LLessEqual (SizeOf (Arg0), 0x25)) { Store (Arg0, \BFWB) If (\BFWP ()) { \_SB.PCI0.LPC.EC.CHKS () \BFWL () } Store (\BFWB, RETB) } Release (BFWM) Return (RETB) } Method (MHIF, 1, NotSerialized) { Name (RETB, Buffer (0x0A){}) Acquire (BFWM, 0xFFFF) \BFWG (Arg0) Store (\BFWB, RETB) Release (BFWM) Return (RETB) } Method (MHDM, 1, NotSerialized) { \BDMC (Arg0) } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (PSSG, 1, NotSerialized) { Return (\PSIF (0x00, 0x00)) } Method (PSSS, 1, NotSerialized) { Return (\PSIF (0x01, Arg0)) } Method (PSBS, 1, NotSerialized) { Return (\PSIF (0x02, Arg0)) } Method (BICG, 1, NotSerialized) { Return (\PSIF (0x03, Arg0)) } Method (BICS, 1, NotSerialized) { Return (\PSIF (0x04, Arg0)) } Method (BCTG, 1, NotSerialized) { Return (\PSIF (0x05, Arg0)) } Method (BCCS, 1, NotSerialized) { Return (\PSIF (0x06, Arg0)) } Method (BCSG, 1, NotSerialized) { Return (\PSIF (0x07, Arg0)) } Method (BCSS, 1, NotSerialized) { Return (\PSIF (0x08, Arg0)) } Method (BDSG, 1, NotSerialized) { Return (\PSIF (0x09, Arg0)) } Method (BDSS, 1, NotSerialized) { Return (\PSIF (0x0A, Arg0)) } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (GILN, 0, NotSerialized) { Return (Or (0x02, \ILNF)) } Method (SILN, 1, NotSerialized) { If (LEqual (0x01, Arg0)) { Store (0x01, \ILNF) Store (0x00, BBLS) Return (0x00) } ElseIf (LEqual (0x02, Arg0)) { Store (0x00, \ILNF) Store (0x01, BBLS) Return (0x00) } Else { Return (0x01) } } Method (GLSI, 0, NotSerialized) { If (\H8DR) { Return (Add (0x02, \_SB.PCI0.LPC.EC.HPLD)) } ElseIf (And (\RBEC (0x46), 0x04)) { Return (0x03) } Else { Return (0x02) } } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (GDLN, 0, NotSerialized) { Return (Or (0x02, \PLUX)) } Method (SDLN, 1, NotSerialized) { If (LEqual (0x01, Arg0)) { Store (0x01, \PLUX) Return (0x00) } ElseIf (LEqual (0x02, Arg0)) { Store (0x00, \PLUX) Return (0x00) } Else { Return (0x01) } } } Scope (\_SB.PCI0.LPC.EC) { Device (CINC) { Name (_HID, "PNP0C60") // _HID: Hardware ID Name (_CID, "PNP0C60") // _CID: Compatible ID Method (_STA, 0, Serialized) // _STA: Status { If (LGreaterEqual (OSYS, 0x07DD)) { Return (0x0F) } Return (0x00) } } } Device (EPC) { Name (_HID, EisaId ("INT0E0C")) // _HID: Hardware ID Name (_STR, Unicode ("Enclave Page Cache 1.0")) // _STR: Description String Name (_MLS, Package (0x01) // _MLS: Multiple Language String { Package (0x02) { "en", Unicode ("Enclave Page Cache 1.0") } }) Name (RBUF, ResourceTemplate () { QWordMemory (ResourceConsumer, PosDecode, MinNotFixed, MaxNotFixed, NonCacheable, ReadWrite, 0x0000000000000000, // Granularity 0x0000000000000000, // Range Minimum 0x0000000000000000, // Range Maximum 0x0000000000000000, // Translation Offset 0x0000000000000001, // Length ,, _Y25, AddressRangeMemory, TypeStatic) }) Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { CreateQWordField (RBUF, \_SB.EPC._Y25._MIN, EMIN) // _MIN: Minimum Base Address CreateQWordField (RBUF, \_SB.EPC._Y25._MAX, EMAX) // _MAX: Maximum Base Address CreateQWordField (RBUF, \_SB.EPC._Y25._LEN, ELEN) // _LEN: Length Store (\_PR.EMNA, EMIN) Store (\_PR.ELNG, ELEN) Subtract (Add (\_PR.EMNA, \_PR.ELNG), 0x01, EMAX) Return (RBUF) } Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { Name (BUFX, Package (0x09) { 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000 }) If (LEqual (Arg0, ToUUID ("c60fac0c-fd9e-4273-9a3f-938f2327035e"))) { If (LEqual (0x00, ToInteger (Arg1))) { Switch (ToInteger (Arg2)) { Case (0x00) { Return (Buffer (0x01) { 0x02 }) } Case (0x01) { Store (SEC0, Index (BUFX, 0x00)) Store (SEC1, Index (BUFX, 0x01)) Store (SEC2, Index (BUFX, 0x02)) Store (SEC3, Index (BUFX, 0x03)) Store (SEC4, Index (BUFX, 0x04)) Store (SEC5, Index (BUFX, 0x05)) Store (SEC6, Index (BUFX, 0x06)) Store (SEC7, Index (BUFX, 0x07)) Store (SEC8, Index (BUFX, 0x08)) Return (BUFX) } } Return (0x00) } Return (0x00) } Return (0x00) } Method (_STA, 0, NotSerialized) // _STA: Status { If (LNotEqual (\_PR.EPCS, 0x00)) { Return (0x0F) } Return (0x00) } } Device (PSM) { Name (_HID, EisaId ("INT3420")) // _HID: Hardware ID Name (_UID, 0x00) // _UID: Unique ID Name (_STR, Unicode ("Power Sharing Manager")) // _STR: Description String Method (_STA, 0, NotSerialized) // _STA: Status { If (LEqual (PSME, 0x01)) { Return (0x0F) } Else { Return (0x00) } } Name (SPLX, Package (0x03) { 0x00, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 }, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 } }) Method (SPLC, 0, Serialized) { Store (\PDT1, Index (DerefOf (Index (SPLX, 0x01)), 0x00)) Store (\PLM1, Index (DerefOf (Index (SPLX, 0x01)), 0x01)) Store (\PTW1, Index (DerefOf (Index (SPLX, 0x01)), 0x02)) Store (\PDT2, Index (DerefOf (Index (SPLX, 0x02)), 0x00)) Store (\PLM2, Index (DerefOf (Index (SPLX, 0x02)), 0x01)) Store (\PTW2, Index (DerefOf (Index (SPLX, 0x02)), 0x02)) Return (SPLX) } Name (DPLX, Package (0x03) { 0x00, Package (0x03) { 0x80000000, 0x80000000, Package (0x06) { 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000 } }, Package (0x03) { 0x80000000, 0x80000000, Package (0x06) { 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000, 0x80000000 } } }) Method (DPLC, 0, Serialized) { Store (\DDT1, Index (DerefOf (Index (DPLX, 0x01)), 0x00)) Store (\DDP1, Index (DerefOf (Index (DPLX, 0x01)), 0x01)) Store (\DLI1, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x01)), 0x02)), 0x00)) Store (\DPL1, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x01)), 0x02)), 0x01)) Store (\DTW1, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x01)), 0x02)), 0x02)) Store (\DMI1, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x01)), 0x02)), 0x03)) Store (\DMA1, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x01)), 0x02)), 0x04)) Store (\DMT1, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x01)), 0x02)), 0x05)) Store (\DDT2, Index (DerefOf (Index (DPLX, 0x02)), 0x00)) Store (\DDP2, Index (DerefOf (Index (DPLX, 0x02)), 0x01)) Store (\DLI2, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x02)), 0x02)), 0x00)) Store (\DPL2, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x02)), 0x02)), 0x01)) Store (\DTW2, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x02)), 0x02)), 0x02)) Store (\DMI2, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x02)), 0x02)), 0x03)) Store (\DMA2, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x02)), 0x02)), 0x04)) Store (\DMT2, Index (DerefOf (Index (DerefOf (Index (DPLX, 0x02)), 0x02)), 0x05)) Return (DPLX) } } } Scope (\_SB.PCI0.RP09.PXSX) { Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (PCIC (Arg0)) { Return (PCID (Arg0, Arg1, Arg2, Arg3)) } If (LEqual (Arg0, ToUUID ("1730e71d-e5dd-4a34-be57-4d76b6a2fe37"))) { If (LEqual (Arg2, Zero)) { If (LEqual (Arg1, Zero)) { Return (Buffer (0x01) { 0x03 }) } Else { Return (Buffer (0x01) { 0x00 }) } } If (LEqual (Arg2, One)) { Switch (DerefOf (Index (Arg3, 0x00))) { Case (0x01) { If (CondRefOf (\_SB.SLPB)) { Notify (\_SB.SLPB, 0x80) } } Case (0x04) { If (CondRefOf (\_SB.SLPB)) { Notify (\_SB.SLPB, 0x02) } } } } Return (0x00) } ElseIf (LEqual (Arg0, ToUUID ("7574eb17-d1a2-4cc2-9929-4a08fcc29107"))) { Switch (Arg2) { Case (0x00) { If (LEqual (Arg1, Zero)) { Return (Buffer (0x01) { 0x07 }) } Else { Return (Buffer (0x01) { 0x00 }) } } Case (0x01) { Return (\_SB.PCI0.WHIT ()) } Case (0x02) { Return (\_SB.PCI0.SELF ()) } Default { Return (Buffer (0x01) { 0x00 }) } } } Else { Return (Buffer (0x01) { 0x00 }) } } OperationRegion (RPXX, PCI_Config, 0x00, 0x10) Field (RPXX, AnyAcc, NoLock, Preserve) { VDID, 32 } OperationRegion (FLDR, PCI_Config, 0x44, 0x06) Field (FLDR, ByteAcc, NoLock, Preserve) { DCAP, 32, DCTR, 16 } Name (SPLX, Package (0x04) { 0x00, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 }, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 }, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 } }) Method (SPLC, 0, Serialized) { Store (\DOM1, Index (DerefOf (Index (SPLX, 0x01)), 0x00)) Store (\LIM1, Index (DerefOf (Index (SPLX, 0x01)), 0x01)) Store (\TIM1, Index (DerefOf (Index (SPLX, 0x01)), 0x02)) Store (\DOM2, Index (DerefOf (Index (SPLX, 0x02)), 0x00)) Store (\LIM2, Index (DerefOf (Index (SPLX, 0x02)), 0x01)) Store (\TIM2, Index (DerefOf (Index (SPLX, 0x02)), 0x02)) Store (\DOM3, Index (DerefOf (Index (SPLX, 0x03)), 0x00)) Store (\LIM3, Index (DerefOf (Index (SPLX, 0x03)), 0x01)) Store (\TIM3, Index (DerefOf (Index (SPLX, 0x03)), 0x02)) Return (SPLX) } PowerResource (WRST, 0x05, 0x0000) { Method (_STA, 0, NotSerialized) // _STA: Status { ADBG ("PXSX _STA") } Method (_ON, 0, NotSerialized) // _ON_: Power On { ADBG ("PXSX _ON") } Method (_OFF, 0, NotSerialized) // _OFF: Power Off { ADBG ("PXSX _OFF") } Method (_RST, 0, NotSerialized) // _RST: Device Reset { ADBG ("PXSX _RST") If (And (DCAP, 0x10000000)) { Store (DCTR, Local0) Or (Local0, 0x8000, Local0) Store (Local0, DCTR) } } } Name (_PRR, Package (0x01) // _PRR: Power Resource for Reset { WRST }) Name (WANX, Package (0x03) { 0x00, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 }, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 } }) Method (WAND, 0, Serialized) { Store (0x00, Index (DerefOf (Index (WANX, 0x01)), 0x00)) Store (\TRD0, Index (DerefOf (Index (WANX, 0x01)), 0x01)) Store (\TRL0, Index (DerefOf (Index (WANX, 0x01)), 0x02)) Store (0x01, Index (DerefOf (Index (WANX, 0x02)), 0x00)) Store (\TRD1, Index (DerefOf (Index (WANX, 0x02)), 0x01)) Store (\TRL1, Index (DerefOf (Index (WANX, 0x02)), 0x02)) Return (WANX) } Name (WRDX, Package (0x03) { 0x00, Package (0x02) { 0x80000000, 0x8000 }, Package (0x02) { 0x80000000, 0x8000 } }) Method (WRDD, 0, Serialized) { Store (\WDM1, Index (DerefOf (Index (WRDX, 0x01)), 0x00)) Store (\CID1, Index (DerefOf (Index (WRDX, 0x01)), 0x01)) Store (\WDM2, Index (DerefOf (Index (WRDX, 0x02)), 0x00)) Store (\CID2, Index (DerefOf (Index (WRDX, 0x02)), 0x01)) Return (WRDX) } Name (WRDY, Package (0x02) { 0x00, Package (0x0C) { 0x07, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80 } }) Method (WRDS, 0, Serialized) { Store (\STXE, Index (DerefOf (Index (WRDY, 0x01)), 0x01)) Store (\STX0, Index (DerefOf (Index (WRDY, 0x01)), 0x02)) Store (\STX1, Index (DerefOf (Index (WRDY, 0x01)), 0x03)) Store (\STX2, Index (DerefOf (Index (WRDY, 0x01)), 0x04)) Store (\STX3, Index (DerefOf (Index (WRDY, 0x01)), 0x05)) Store (\STX4, Index (DerefOf (Index (WRDY, 0x01)), 0x06)) Store (\STX5, Index (DerefOf (Index (WRDY, 0x01)), 0x07)) Store (\STX6, Index (DerefOf (Index (WRDY, 0x01)), 0x08)) Store (\STX7, Index (DerefOf (Index (WRDY, 0x01)), 0x09)) Store (\STX8, Index (DerefOf (Index (WRDY, 0x01)), 0x0A)) Store (\STX9, Index (DerefOf (Index (WRDY, 0x01)), 0x0B)) Return (WRDY) } Method (WIST, 0, Serialized) { If (CondRefOf (VDID)) { Switch (VDID) { Case (0x095A8086) { Return (0x01) } Case (0x095B8086) { Return (0x01) } Case (0x31658086) { Return (0x01) } Case (0x31668086) { Return (0x01) } Case (0x08B18086) { Return (0x01) } Case (0x08B28086) { Return (0x01) } Case (0x08B38086) { Return (0x01) } Case (0x08B48086) { Return (0x01) } Case (0x24F38086) { Return (0x01) } Case (0x24F48086) { Return (0x01) } Case (0x24F58086) { Return (0x01) } Case (0x24F68086) { Return (0x01) } Default { Return (0x00) } } } Else { Return (0x00) } } } Scope (\_SB.PCI0.EXP3.PXSX) { OperationRegion (RPXX, PCI_Config, 0x00, 0x10) Field (RPXX, AnyAcc, NoLock, Preserve) { VDID, 32 } OperationRegion (FLDR, PCI_Config, 0x44, 0x06) Field (FLDR, ByteAcc, NoLock, Preserve) { DCAP, 32, DCTR, 16 } Name (SPLX, Package (0x04) { 0x00, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 }, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 }, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 } }) Method (SPLC, 0, Serialized) { Store (\DOM1, Index (DerefOf (Index (SPLX, 0x01)), 0x00)) Store (\LIM1, Index (DerefOf (Index (SPLX, 0x01)), 0x01)) Store (\TIM1, Index (DerefOf (Index (SPLX, 0x01)), 0x02)) Store (\DOM2, Index (DerefOf (Index (SPLX, 0x02)), 0x00)) Store (\LIM2, Index (DerefOf (Index (SPLX, 0x02)), 0x01)) Store (\TIM2, Index (DerefOf (Index (SPLX, 0x02)), 0x02)) Store (\DOM3, Index (DerefOf (Index (SPLX, 0x03)), 0x00)) Store (\LIM3, Index (DerefOf (Index (SPLX, 0x03)), 0x01)) Store (\TIM3, Index (DerefOf (Index (SPLX, 0x03)), 0x02)) Return (SPLX) } PowerResource (WRST, 0x05, 0x0000) { Method (_STA, 0, NotSerialized) // _STA: Status { ADBG ("PXSX _STA") } Method (_ON, 0, NotSerialized) // _ON_: Power On { ADBG ("PXSX _ON") } Method (_OFF, 0, NotSerialized) // _OFF: Power Off { ADBG ("PXSX _OFF") } Method (_RST, 0, NotSerialized) // _RST: Device Reset { ADBG ("PXSX _RST") If (And (DCAP, 0x10000000)) { Store (DCTR, Local0) Or (Local0, 0x8000, Local0) Store (Local0, DCTR) } } } Name (_PRR, Package (0x01) // _PRR: Power Resource for Reset { WRST }) Name (WANX, Package (0x03) { 0x00, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 }, Package (0x03) { 0x80000000, 0x80000000, 0x80000000 } }) Method (WAND, 0, Serialized) { Store (0x00, Index (DerefOf (Index (WANX, 0x01)), 0x00)) Store (\TRD0, Index (DerefOf (Index (WANX, 0x01)), 0x01)) Store (\TRL0, Index (DerefOf (Index (WANX, 0x01)), 0x02)) Store (0x01, Index (DerefOf (Index (WANX, 0x02)), 0x00)) Store (\TRD1, Index (DerefOf (Index (WANX, 0x02)), 0x01)) Store (\TRL1, Index (DerefOf (Index (WANX, 0x02)), 0x02)) Return (WANX) } Name (WRDX, Package (0x03) { 0x00, Package (0x02) { 0x80000000, 0x8000 }, Package (0x02) { 0x80000000, 0x8000 } }) Method (WRDD, 0, Serialized) { Store (\WDM1, Index (DerefOf (Index (WRDX, 0x01)), 0x00)) Store (\CID1, Index (DerefOf (Index (WRDX, 0x01)), 0x01)) Store (\WDM2, Index (DerefOf (Index (WRDX, 0x02)), 0x00)) Store (\CID2, Index (DerefOf (Index (WRDX, 0x02)), 0x01)) Return (WRDX) } Name (WRDY, Package (0x02) { 0x00, Package (0x0C) { 0x07, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80 } }) Method (WRDS, 0, Serialized) { Store (\STXE, Index (DerefOf (Index (WRDY, 0x01)), 0x01)) Store (\STX0, Index (DerefOf (Index (WRDY, 0x01)), 0x02)) Store (\STX1, Index (DerefOf (Index (WRDY, 0x01)), 0x03)) Store (\STX2, Index (DerefOf (Index (WRDY, 0x01)), 0x04)) Store (\STX3, Index (DerefOf (Index (WRDY, 0x01)), 0x05)) Store (\STX4, Index (DerefOf (Index (WRDY, 0x01)), 0x06)) Store (\STX5, Index (DerefOf (Index (WRDY, 0x01)), 0x07)) Store (\STX6, Index (DerefOf (Index (WRDY, 0x01)), 0x08)) Store (\STX7, Index (DerefOf (Index (WRDY, 0x01)), 0x09)) Store (\STX8, Index (DerefOf (Index (WRDY, 0x01)), 0x0A)) Store (\STX9, Index (DerefOf (Index (WRDY, 0x01)), 0x0B)) Return (WRDY) } Method (WIST, 0, Serialized) { If (CondRefOf (VDID)) { Switch (VDID) { Case (0x095A8086) { Return (0x01) } Case (0x095B8086) { Return (0x01) } Case (0x31658086) { Return (0x01) } Case (0x31668086) { Return (0x01) } Case (0x08B18086) { Return (0x01) } Case (0x08B28086) { Return (0x01) } Case (0x08B38086) { Return (0x01) } Case (0x08B48086) { Return (0x01) } Case (0x24F38086) { Return (0x01) } Case (0x24F48086) { Return (0x01) } Case (0x24F58086) { Return (0x01) } Case (0x24F68086) { Return (0x01) } Default { Return (0x00) } } } Else { Return (0x00) } } } Scope (\_SB.PCI0) { Name (PCIG, ToUUID ("e5c937d0-3553-4d7a-9117-ea4d19c3434d") /* Device Labeling Interface */) Method (PCID, 4, Serialized) { If (LEqual (Arg0, PCIG)) { If (LGreaterEqual (Arg1, 0x03)) { If (LEqual (Arg2, 0x00)) { Return (Buffer (0x02) { 0x01, 0x03 }) } If (LEqual (Arg2, 0x08)) { Return (0x01) } If (LEqual (Arg2, 0x09)) { Return (Package (0x05) { 0xC350, Ones, Ones, 0xC350, Ones }) } } } Return (Buffer (0x01) { 0x00 }) } } Scope (\_SB.PCI0) { Method (PCIC, 1, Serialized) { If (LEqual (ECR1, 0x01)) { If (LEqual (Arg0, PCIG)) { Return (0x01) } } Return (0x00) } } Name (PNVB, 0xCFFB4C98) Name (PNVL, 0x0204) OperationRegion (PNVA, SystemMemory, PNVB, PNVL) Field (PNVA, AnyAcc, Lock, Preserve) { RCRV, 32, PCHS, 16, PCHG, 16, RPA1, 32, RPA2, 32, RPA3, 32, RPA4, 32, RPA5, 32, RPA6, 32, RPA7, 32, RPA8, 32, RPA9, 32, RPAA, 32, RPAB, 32, RPAC, 32, RPAD, 32, RPAE, 32, RPAF, 32, RPAG, 32, RPAH, 32, RPAI, 32, RPAJ, 32, RPAK, 32, NHLA, 64, NHLL, 32, ADFM, 32, SBRG, 32, GPEM, 32, G2L0, 32, G2L1, 32, G2L2, 32, G2L3, 32, G2L4, 32, G2L5, 32, G2L6, 32, G2L7, 32, G2L8, 32, G2L9, 32, PML1, 16, PML2, 16, PML3, 16, PML4, 16, PML5, 16, PML6, 16, PML7, 16, PML8, 16, PML9, 16, PMLA, 16, PMLB, 16, PMLC, 16, PMLD, 16, PMLE, 16, PMLF, 16, PMLG, 16, PMLH, 16, PMLI, 16, PMLJ, 16, PMLK, 16, PNL1, 16, PNL2, 16, PNL3, 16, PNL4, 16, PNL5, 16, PNL6, 16, PNL7, 16, PNL8, 16, PNL9, 16, PNLA, 16, PNLB, 16, PNLC, 16, PNLD, 16, PNLE, 16, PNLF, 16, PNLG, 16, PNLH, 16, PNLI, 16, PNLJ, 16, PNLK, 16, U0C0, 32, U1C0, 32, ADPM, 32, XHPC, 8, XRPC, 8, XSPC, 8, XSPA, 8, HPTB, 32, HPTE, 8, SMD0, 8, SMD1, 8, SMD2, 8, SMD3, 8, SMD4, 8, SMD5, 8, SMD6, 8, SMD7, 8, SMD8, 8, SMD9, 8, SMDA, 8, SIR0, 8, SIR1, 8, SIR2, 8, SIR3, 8, SIR4, 8, SIR5, 8, SIR6, 8, SIR7, 8, SIR8, 8, SIR9, 8, SIRA, 8, SB00, 32, SB01, 32, SB02, 32, SB03, 32, SB04, 32, SB05, 32, SB06, 32, SB07, 32, SB08, 32, SB09, 32, SB0A, 32, SB10, 32, SB11, 32, SB12, 32, SB13, 32, SB14, 32, SB15, 32, SB16, 32, SB17, 32, SB18, 32, SB19, 32, SB1A, 32, GPEN, 8, SGIR, 8, NIT1, 8, NIT2, 8, NIT3, 8, NPM1, 8, NPM2, 8, NPM3, 8, NPC1, 8, NPC2, 8, NPC3, 8, NL11, 16, NL12, 16, NL13, 16, ND21, 8, ND22, 8, ND23, 8, ND11, 32, ND12, 32, ND13, 32, NLR1, 16, NLR2, 16, NLR3, 16, NLD1, 32, NLD2, 32, NLD3, 32, NEA1, 16, NEA2, 16, NEA3, 16, NEB1, 16, NEB2, 16, NEB3, 16, NEC1, 16, NEC2, 16, NEC3, 16, NRA1, 16, NRA2, 16, NRA3, 16, NMB1, 32, NMB2, 32, NMB3, 32, NMV1, 32, NMV2, 32, NMV3, 32, NPB1, 32, NPB2, 32, NPB3, 32, NPV1, 32, NPV2, 32, NPV3, 32, Offset (0x1E6), SXRB, 32, SXRS, 32, CIOE, 8, CIOI, 8, TAEN, 8, TIRQ, 8, XWMB, 32, EMH4, 8, CSKU, 8, ITA0, 16, ITA1, 16, ITA2, 16, ITA3, 16, ITS0, 8, ITS1, 8, ITS2, 8, ITS3, 8 } Scope (\_SB) { Name (GCOM, Package (0x02) { Package (0x08) { 0x00AF0000, 0x00AF0000, 0x00AE0000, 0x00AE0000, 0x00AE0000, 0x00AC0000, 0x00AC0000, 0x00AD0000 }, Package (0x0A) { 0x00AF0000, 0x00AF0000, 0x00AE0000, 0x00AE0000, 0x00AE0000, 0x00AE0000, 0x00AE0000, 0x00AE0000, 0x00AC0000, 0x00AD0000 } }) Name (GPPG, Package (0x02) { Package (0x08) { 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x08, 0x0C }, Package (0x0A) { 0x18, 0x18, 0x18, 0x18, 0x0D, 0x18, 0x18, 0x18, 0x0B, 0x0C } }) Name (PCFG, Package (0x02) { Package (0x08) { 0x0400, 0x04C0, 0x0400, 0x04C0, 0x0580, 0x0400, 0x04C0, 0x0400 }, Package (0x0A) { 0x0400, 0x04C0, 0x0400, 0x04C0, 0x0580, 0x05E8, 0x06A8, 0x0768, 0x0400, 0x0400 } }) Name (HOWN, Package (0x02) { Package (0x08) { 0xD0, 0xD4, 0xD0, 0xD4, 0xD8, 0xD0, 0xD4, 0xD0 }, Package (0x0A) { 0xD0, 0xD4, 0xD0, 0xD4, 0xD8, 0xDC, 0xE0, 0xE4, 0xD0, 0xD0 } }) Name (POWN, Package (0x02) { Package (0x08) { 0x20, 0x30, 0x20, 0x30, 0x40, 0x20, 0x30, 0x20 }, Package (0x0A) { 0x20, 0x2C, 0x20, 0x2C, 0x38, 0x40, 0x4C, 0x58, 0x20, 0x20 } }) Name (GPEO, Package (0x02) { Package (0x08) { 0x0140, 0x0144, 0x0140, 0x0144, 0x0148, 0x0140, 0x0144, 0x0140 }, Package (0x0A) { 0x0140, 0x0144, 0x0140, 0x0144, 0x0148, 0x014C, 0x0150, 0x0154, 0x0140, 0x0140 } }) Name (GPES, Package (0x0A) { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }) Name (RXEV, Package (0x0A) { 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF, 0xFFFFFFFFFFFFFFFF }) Method (GNUM, 1, NotSerialized) { Store (GNMB (Arg0), Local1) Store (GGRP (Arg0), Local2) Return (Add (Local1, Multiply (Local2, 0x18))) } Method (INUM, 1, NotSerialized) { If (LEqual (PCHS, 0x02)) { Store (0x00, Local0) } Else { Store (0x01, Local0) } Store (GNMB (Arg0), Local1) Store (GGRP (Arg0), Local2) Store (0x00, Local3) While (LLess (Local3, Local2)) { Add (DerefOf (Index (DerefOf (Index (GPPG, Local0)), Local3)), Local1, Local1) Increment (Local3) } Return (Add (0x18, Mod (Local1, 0x60))) } Method (GGRP, 1, Serialized) { ShiftRight (And (Arg0, 0x00FF0000), 0x10, Local0) Return (Local0) } Method (GNMB, 1, Serialized) { Return (And (Arg0, 0xFFFF)) } Method (GGPE, 1, NotSerialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (And (ShiftRight (GPEM, Multiply (Local0, 0x02)), 0x03), Local2) If (LEqual (Local2, 0x00)) { Return (0x6F) } Else { Return (Add (Multiply (Subtract (Local2, 0x01), 0x20), Local1)) } } Method (GADR, 2, NotSerialized) { If (LEqual (PCHS, 0x02)) { Store (0x00, Local0) } Else { Store (0x01, Local0) } Store (Add (DerefOf (Index (DerefOf (Index (GCOM, Local0)), Arg0)), SBRG), Local1) Store (DerefOf (Index (DerefOf (Index (Arg1, Local0)), Arg0)), Local2) Return (Add (Local1, Local2)) } Method (GPC0, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { TEMP, 32 } Return (TEMP) } Method (SPC0, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { TEMP, 32 } Store (Arg1, TEMP) } Method (GPC1, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), 0x04), Local2) OperationRegion (PDW1, SystemMemory, Local2, 0x04) Field (PDW1, AnyAcc, NoLock, Preserve) { TEMP, 32 } Return (TEMP) } Method (SPC1, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), 0x04), Local2) OperationRegion (PDW1, SystemMemory, Local2, 0x04) Field (PDW1, AnyAcc, NoLock, Preserve) { TEMP, 32 } Store (Arg1, TEMP) } Method (SRXO, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 28, TEMP, 1, Offset (0x04) } Store (Arg1, TEMP) } Method (GGIV, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 1, TEMP, 1, Offset (0x04) } Return (TEMP) } Method (GGOV, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { TEMP, 1, Offset (0x04) } Return (TEMP) } Method (SGOV, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { TEMP, 1, Offset (0x04) } Store (Arg1, TEMP) } Method (GGII, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 23, TEMP, 1, Offset (0x04) } Return (TEMP) } Method (SGII, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 23, TEMP, 1, Offset (0x04) } Store (Arg1, TEMP) } Method (GPMV, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 10, TEMP, 3, Offset (0x04) } Return (TEMP) } Method (SPMV, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 10, TEMP, 3, Offset (0x04) } Store (Arg1, TEMP) } Method (GHPO, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) OperationRegion (PREG, SystemMemory, GADR (Local0, HOWN), 0x04) Field (PREG, AnyAcc, NoLock, Preserve) { TEMP, 32 } Return (And (ShiftRight (TEMP, Local1), 0x01)) } Method (SHPO, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) OperationRegion (PREG, SystemMemory, GADR (Local0, HOWN), 0x04) Field (PREG, AnyAcc, NoLock, Preserve) { TEMP, 32 } Or (And (TEMP, Not (ShiftLeft (0x01, Local1))), ShiftLeft (Arg1, Local1), TEMP) } Method (GGPO, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, POWN), Multiply (ShiftRight (Local1, 0x03), 0x04)), Local2) OperationRegion (PREG, SystemMemory, Local2, 0x04) Field (PREG, AnyAcc, NoLock, Preserve) { TEMP, 32 } Return (And (ShiftRight (TEMP, Multiply (And (Local1, 0x07), 0x04)), 0x03)) } Method (SGRA, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 20, TEMP, 1, Offset (0x04) } Store (Arg1, TEMP) } Method (SGWP, 2, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), 0x04), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 10, TEMP, 4, Offset (0x04) } Store (Arg1, TEMP) } Method (UGP1, 1, Serialized) { OperationRegion (GPPX, SystemMemory, GADR (Arg0, GPEO), 0x24) Field (GPPX, AnyAcc, NoLock, Preserve) { STSX, 32, Offset (0x20), GENX, 32 } If (LEqual (And (ShiftRight (GPEM, Multiply (Arg0, 0x02)), 0x03), 0x00)) { Store (And (STSX, GENX), Index (GPES, Arg0)) } Else { Store (0x00, Index (GPES, Arg0)) } } Method (UGPS, 0, Serialized) { If (LEqual (PCHS, 0x01)) { Store (0x0A, Local0) } Else { Store (0x08, Local0) } While (Local0) { Decrement (Local0) UGP1 (Local0) } } Method (CGP1, 2, Serialized) { If (LEqual (And (ShiftRight (GPEM, Multiply (Arg0, 0x02)), 0x03), 0x00)) { OperationRegion (GPPX, SystemMemory, GADR (Arg0, GPEO), 0x04) Field (GPPX, AnyAcc, NoLock, Preserve) { STSX, 32 } Store (Arg1, STSX) } } Method (CGPS, 0, Serialized) { If (LEqual (PCHS, 0x01)) { Store (0x0A, Local0) } Else { Store (0x08, Local0) } While (Local0) { Decrement (Local0) CGP1 (Local0, 0xFFFFFFFF) } } Method (CGLS, 0, Serialized) { If (LEqual (PCHS, 0x01)) { Store (0x0A, Local0) } Else { Store (0x08, Local0) } While (Local0) { Decrement (Local0) If (LEqual (Local0, 0x09)) { Store (G2L9, Local1) } ElseIf (LEqual (Local0, 0x08)) { Store (G2L8, Local1) } ElseIf (LEqual (Local0, 0x07)) { Store (G2L7, Local1) } ElseIf (LEqual (Local0, 0x06)) { Store (G2L6, Local1) } ElseIf (LEqual (Local0, 0x05)) { Store (G2L5, Local1) } ElseIf (LEqual (Local0, 0x04)) { Store (G2L4, Local1) } ElseIf (LEqual (Local0, 0x03)) { Store (G2L3, Local1) } ElseIf (LEqual (Local0, 0x02)) { Store (G2L2, Local1) } ElseIf (LEqual (Local0, 0x01)) { Store (G2L1, Local1) } ElseIf (LEqual (Local0, 0x00)) { Store (G2L0, Local1) } Else { Continue } CGP1 (Local0, Local1) } } Method (CAGS, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) If (LEqual (And (ShiftRight (GPEM, Multiply (Local0, 0x02)), 0x03), 0x00)) { OperationRegion (GPPX, SystemMemory, GADR (Local0, GPEO), 0x04) Field (GPPX, AnyAcc, NoLock, Preserve) { STSX, 32 } Store (STSX, Local3) ShiftLeft (0x01, Local1, Local2) Or (STSX, Local2, STSX) } } Method (ISME, 1, NotSerialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Return (And (ShiftRight (DerefOf (Index (GPES, Local0)), Local1), 0x01)) } Method (DIPI, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 9, RDIS, 1, , 15, RCFG, 2, Offset (0x04) } If (LNotEqual (RCFG, 0x02)) { Store (DerefOf (Index (RXEV, Local0)), Local3) And (Local3, Not (ShiftLeft (0x03, Multiply (Local1, 0x02))), Local3) Or (Local3, ShiftLeft (RCFG, Multiply (Local1, 0x02)), Index (RXEV, Local0)) Store (0x02, RCFG) Store (0x01, RDIS) } } Method (UIPI, 1, Serialized) { Store (GGRP (Arg0), Local0) Store (GNMB (Arg0), Local1) Store (Add (GADR (Local0, PCFG), Multiply (Local1, 0x08)), Local2) OperationRegion (PDW0, SystemMemory, Local2, 0x04) Field (PDW0, AnyAcc, NoLock, Preserve) { , 9, RDIS, 1, , 15, RCFG, 2, Offset (0x04) } Store (And (ShiftRight (DerefOf (Index (RXEV, Local0)), Multiply (Local1, 0x02)), 0x03), Local3) If (LNotEqual (Local3, 0x02)) { Store (0x00, RDIS) Store (Local3, RCFG) } } } Name (SPTH, 0x01) Name (SPTL, 0x02) Method (PCHV, 0, NotSerialized) { If (LEqual (PCHS, 0x01)) { Return (SPTH) } If (LEqual (PCHS, 0x02)) { Return (SPTL) } Return (0x00) } Scope (\_SB.PCI0) { Device (PRRE) { Name (_HID, EisaId ("PNP0C02")) // _HID: Hardware ID Name (_UID, "PCHRESV") // _UID: Unique ID Name (_STA, 0x03) // _STA: Status Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings { Name (BUF0, ResourceTemplate () { Memory32Fixed (ReadWrite, 0xFD000000, // Address Base 0x00AC0000, // Address Length ) Memory32Fixed (ReadWrite, 0xFDAD0000, // Address Base 0x00010000, // Address Length ) Memory32Fixed (ReadWrite, 0xFDB00000, // Address Base 0x00500000, // Address Length ) Memory32Fixed (ReadWrite, 0xFE000000, // Address Base 0x00020000, // Address Length ) Memory32Fixed (ReadWrite, 0xFE036000, // Address Base 0x00006000, // Address Length ) Memory32Fixed (ReadWrite, 0xFE03D000, // Address Base 0x003C3000, // Address Length ) Memory32Fixed (ReadWrite, 0xFE410000, // Address Base 0x003F0000, // Address Length ) }) Return (BUF0) } } Device (IOTR) { Name (_HID, EisaId ("PNP0C02")) // _HID: Hardware ID Name (_UID, "IoTraps") // _UID: Unique ID Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings { Store (Buffer (0x02) { 0x79, 0x00 }, Local0) Name (BUF0, ResourceTemplate () { IO (Decode16, 0x0000, // Range Minimum 0x0000, // Range Maximum 0x01, // Alignment 0xFF, // Length _Y26) }) Name (BUF1, ResourceTemplate () { IO (Decode16, 0x0000, // Range Minimum 0x0000, // Range Maximum 0x01, // Alignment 0xFF, // Length _Y27) }) Name (BUF2, ResourceTemplate () { IO (Decode16, 0x0000, // Range Minimum 0x0000, // Range Maximum 0x01, // Alignment 0xFF, // Length _Y28) }) Name (BUF3, ResourceTemplate () { IO (Decode16, 0x0000, // Range Minimum 0x0000, // Range Maximum 0x01, // Alignment 0xFF, // Length _Y29) }) CreateWordField (BUF0, \_SB.PCI0.IOTR._CRS._Y26._MIN, AMI0) // _MIN: Minimum Base Address CreateWordField (BUF0, \_SB.PCI0.IOTR._CRS._Y26._MAX, AMA0) // _MAX: Maximum Base Address CreateWordField (BUF1, \_SB.PCI0.IOTR._CRS._Y27._MIN, AMI1) // _MIN: Minimum Base Address CreateWordField (BUF1, \_SB.PCI0.IOTR._CRS._Y27._MAX, AMA1) // _MAX: Maximum Base Address CreateWordField (BUF2, \_SB.PCI0.IOTR._CRS._Y28._MIN, AMI2) // _MIN: Minimum Base Address CreateWordField (BUF2, \_SB.PCI0.IOTR._CRS._Y28._MAX, AMA2) // _MAX: Maximum Base Address CreateWordField (BUF3, \_SB.PCI0.IOTR._CRS._Y29._MIN, AMI3) // _MIN: Minimum Base Address CreateWordField (BUF3, \_SB.PCI0.IOTR._CRS._Y29._MAX, AMA3) // _MAX: Maximum Base Address Store (ITA0, AMI0) Store (ITA0, AMA0) Store (ITA1, AMI1) Store (ITA1, AMA1) Store (ITA2, AMI2) Store (ITA2, AMA2) Store (ITA3, AMI3) Store (ITA3, AMA3) If (LEqual (ITS0, 0x01)) { ConcatenateResTemplate (Local0, BUF0, Local1) Store (Local1, Local0) } If (LEqual (ITS1, 0x01)) { ConcatenateResTemplate (Local0, BUF1, Local1) Store (Local1, Local0) } If (LEqual (ITS2, 0x01)) { ConcatenateResTemplate (Local0, BUF2, Local1) Store (Local1, Local0) } If (LEqual (ITS3, 0x01)) { ConcatenateResTemplate (Local0, BUF3, Local1) Store (Local1, Local0) } Return (Local0) } } Device (PPMC) { Name (_ADR, 0x001F0002) // _ADR: Address Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method { If (PCIC (Arg0)) { Return (PCID (Arg0, Arg1, Arg2, Arg3)) } Return (0x00) } OperationRegion (PMCB, PCI_Config, 0x00, 0x0100) Field (PMCB, AnyAcc, NoLock, Preserve) { VDID, 32, Offset (0x40), Offset (0x41), ACBA, 8, Offset (0x48), , 12, PWBA, 20 } } } Scope (\) { Method (PCRR, 2, Serialized) { Add (ShiftLeft (Arg0, 0x10), Arg1, Local0) Add (SBRG, Local0, Local0) OperationRegion (PCR0, SystemMemory, Local0, 0x04) Field (PCR0, DWordAcc, Lock, Preserve) { DAT0, 32 } Return (DAT0) } Method (PCRW, 3, Serialized) { Add (ShiftLeft (Arg0, 0x10), Arg1, Local0) Add (SBRG, Local0, Local0) OperationRegion (PCR0, SystemMemory, Local0, 0x04) Field (PCR0, DWordAcc, Lock, Preserve) { DAT0, 32 } Store (Arg2, DAT0) OperationRegion (PCR1, SystemMemory, Add (SBRG, 0x00C73418), 0x04) Field (PCR1, DWordAcc, Lock, Preserve) { DAT1, 32 } Store (DAT1, Local1) } Method (PCRO, 3, Serialized) { Store (PCRR (Arg0, Arg1), Local0) Store (Or (Local0, Arg2), Local1) PCRW (Arg0, Arg1, Local1) } Method (PCRA, 3, Serialized) { Store (PCRR (Arg0, Arg1), Local0) Store (And (Local0, Arg2), Local1) PCRW (Arg0, Arg1, Local1) } Method (PCAO, 4, Serialized) { Store (PCRR (Arg0, Arg1), Local0) Store (Or (And (Local0, Arg2), Arg3), Local1) PCRW (Arg0, Arg1, Local1) } Name (PMBV, 0x00) Method (PMBS, 0, NotSerialized) { If (LEqual (PMBV, 0x00)) { Store (ShiftLeft (\_SB.PCI0.PPMC.ACBA, 0x08), PMBV) } Return (PMBV) } Name (PWRV, 0x00) Method (PWRM, 0, NotSerialized) { If (LEqual (PWRV, 0x00)) { Store (ShiftLeft (\_SB.PCI0.PPMC.PWBA, 0x0C), PWRV) } Return (PWRV) } Name (TCBV, 0x00) Method (TCBS, 0, NotSerialized) { If (LEqual (TCBV, 0x00)) { Store (ShiftLeft (\_SB.PCI0.SMBU.TCOB, 0x05), TCBV) } Return (TCBV) } OperationRegion (PMIO, SystemIO, PMBS (), 0x80) Field (PMIO, ByteAcc, NoLock, Preserve) { Offset (0x01), PBSS, 1, Offset (0x40), , 17, GPEC, 1 } OperationRegion (PMLP, SystemIO, Add (\PMBS (), 0x80), 0x20) Field (PMLP, ByteAcc, NoLock, Preserve) { Offset (0x10), Offset (0x11), GE08, 1, , 8, GE17, 1, , 17, GE35, 1, , 9, GE45, 1, Offset (0x16), GE48, 1, , 2, GE51, 1, Offset (0x20) } Field (PMLP, ByteAcc, NoLock, WriteAsZeros) { Offset (0x01), GS08, 1, , 8, GS17, 1, , 17, GS35, 1, , 9, GS45, 1, Offset (0x06), GS48, 1, , 2, GS51, 1, , 2, GS54, 1, GS55, 1, Offset (0x10) } OperationRegion (TCBA, SystemIO, TCBS (), 0x10) Field (TCBA, ByteAcc, NoLock, Preserve) { Offset (0x04), , 9, CPSC, 1 } OperationRegion (PWMR, SystemMemory, \PWRM (), 0x0800) Field (PWMR, AnyAcc, NoLock, Preserve) { Offset (0xE0), Offset (0xE2), DWLE, 1, HWLE, 1 } OperationRegion (PMST, SystemMemory, PWRV, 0x80) Field (PMST, DWordAcc, NoLock, Preserve) { Offset (0x18), , 25, USBP, 1, Offset (0x1C), Offset (0x1F), PMFS, 1, Offset (0x20), MPMC, 32, , 20, UWAB, 1 } } Scope (\_SB.PCI0) { Name (LTRN, 0x00) Name (OBFN, 0x00) Name (LMSL, 0x00) Name (LNSL, 0x00) } Name (\_S0, Package (0x04) // _S0_: S0 System State { 0x00, 0x00, 0x00, 0x00 }) Name (\_S3, Package (0x04) // _S3_: S3 System State { 0x05, 0x05, 0x00, 0x00 }) Name (\_S4, Package (0x04) // _S4_: S4 System State { 0x06, 0x06, 0x00, 0x00 }) Name (\_S5, Package (0x04) // _S5_: S5 System State { 0x07, 0x07, 0x00, 0x00 }) Method (\_PTS, 1, NotSerialized) // _PTS: Prepare To Sleep { Store (0x01, Local0) If (LEqual (Arg0, \SPS)) { Store (0x00, Local0) } If (LOr (LEqual (Arg0, 0x00), LGreaterEqual (Arg0, 0x06))) { Store (0x00, Local0) } If (Local0) { Store (Arg0, \SPS) \_SB.PCI0.LPC.EC.HKEY.MHKE (0x00) If (\_SB.PCI0.LPC.EC.KBLT) { \UCMS (0x0D) } If (LEqual (Arg0, 0x01)) { Store (\_SB.PCI0.LPC.EC.HFNI, \FNID) Store (0x00, \_SB.PCI0.LPC.EC.HFNI) Store (0x00, \_SB.PCI0.LPC.EC.HFSP) } If (LEqual (Arg0, 0x03)) { \VVPD (0x03) \TRAP () Store (\_SB.PCI0.LPC.EC.AC._PSR (), \ACST) If (LEqual (\FNWK, 0x01)) { If (\H8DR) { Store (0x00, \_SB.PCI0.LPC.EC.HWFN) } Else { \MBEC (0x32, 0xEF, 0x00) } } } If (LEqual (Arg0, 0x04)) { If (VDSP) { Store (Zero, SHA1) } \_SB.SLPB._PSW (0x00) \TRAP () \AWON (0x04) } If (LEqual (Arg0, 0x05)) { \TRAP () \AWON (0x05) } If (LGreaterEqual (Arg0, 0x04)) { Store (0x00, \_SB.PCI0.LPC.EC.HWLB) } Else { Store (0x01, \_SB.PCI0.LPC.EC.HWLB) } If (LGreaterEqual (Arg0, 0x03)) { Store (0x01, \_SB.PCI0.LPC.EC.HCMU) } If (LNotEqual (Arg0, 0x05)){} \_SB.PCI0.LPC.EC.HKEY.WGPS (Arg0) If (CondRefOf (\_SB.TPM.PTS)) { \_SB.TPM.PTS (Arg0) } } } Name (WAKI, Package (0x02) { 0x00, 0x00 }) Method (\_WAK, 1, NotSerialized) // _WAK: Wake { ADBG ("_WAK") If (LOr (LEqual (Arg0, 0x00), LGreaterEqual (Arg0, 0x05))) { Return (WAKI) } Store (0x00, \SPS) Store (0x00, \_SB.PCI0.LPC.EC.HCMU) \_SB.PCI0.LPC.EC.EVNT (0x01) \_SB.PCI0.LPC.EC.HKEY.MHKE (0x01) \_SB.PCI0.LPC.EC.FNST () \UCMS (0x0D) Store (0x00, \LIDB) Store (\_SB.PCI0.LPC.EC.CMMD, \PMMD) If (LGreaterEqual (\PMMD, 0x07)) { Store (0x00, \PMMD) } Store (\_SB.PCI0.LPC.EC.CMMD, \LVMD) If (LOr (LEqual (\LVMD, 0x00), LGreaterEqual (\LVMD, 0x07))) { Store (0x01, \LVMD) } ElseIf (LOr (LEqual (\LVMD, 0x02), LEqual (\LVMD, 0x03))) { Store (0x02, \LVMD) } Else { Store (0x03, \LVMD) } If (LEqual (Arg0, 0x01)) { Store (\_SB.PCI0.LPC.EC.HFNI, \FNID) } If (LEqual (Arg0, 0x03)) { \NVSS (0x00) Store (\_SB.PCI0.LPC.EC.AC._PSR (), \PWRS) If (\OSC4) { \PNTF (0x81) } If (LNotEqual (\ACST, \_SB.PCI0.LPC.EC.AC._PSR ())) { \_SB.PCI0.LPC.EC.ATMC () } If (\SCRM) { Store (0x07, \_SB.PCI0.LPC.EC.HFSP) } Store (0x00, \IOEN) Store (0x00, \IOST) If (LEqual (\ISWK, 0x01)) { If (\_SB.PCI0.LPC.EC.HKEY.DHKC) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6070) } } If (\VIGD) { Store (\_SB.LID._LID (), \_SB.PCI0.GFX0.CLID) If (\WVIS) { \VBTD () } } ElseIf (\WVIS) { Store (\_SB.LID._LID (), \_SB.PCI0.GFX0.CLID) \VBTD () } \VCMS (0x01, \_SB.LID._LID ()) \AWON (0x00) If (\CMPR) { Notify (\_SB.SLPB, 0x02) Store (0x00, \CMPR) } } If (LEqual (Arg0, 0x04)) { \NVSS (0x00) Store (0x00, \_SB.PCI0.LPC.EC.HSPA) Store (\_SB.PCI0.LPC.EC.AC._PSR (), \PWRS) If (\OSC4) { \PNTF (0x81) } \_SB.PCI0.LPC.EC.ATMC () If (\SCRM) { Store (0x07, \_SB.PCI0.LPC.EC.HFSP) } If (LNot (\NBCF)) { If (\VIGD) { \_SB.PCI0.LPC.EC.BRNS () } Else { \VBRC (\BRLV) } } Store (0x00, \IOEN) Store (0x00, \IOST) If (LEqual (\ISWK, 0x02)) { If (\_SB.PCI0.LPC.EC.HKEY.DHKC) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6080) } } If (\H8DR) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x60C0) } } \_SB.PCI0.LPC.EC.BATW (Arg0) \_SB.PCI0.LPC.EC.HKEY.WGWK (Arg0) Notify (\_TZ.THM0, 0x80) \VSLD (\_SB.LID._LID ()) If (\VIGD) { Store (\_SB.LID._LID (), \_SB.PCI0.GFX0.CLID) } ElseIf (\WVIS) { Store (\_SB.LID._LID (), \_SB.PCI0.GFX0.CLID) } If (LLess (Arg0, 0x04)) { If (LOr (And (\RRBF, 0x02), And (\_SB.PCI0.LPC.EC.HWAC, 0x02))) { ShiftLeft (Arg0, 0x08, Local0) Store (Or (0x2013, Local0), Local0) \_SB.PCI0.LPC.EC.HKEY.MHKQ (Local0) } } If (LEqual (Arg0, 0x04)) { Store (0x00, Local0) Store (\CSUM (0x00), Local1) If (LNotEqual (Local1, \CHKC)) { Store (0x01, Local0) Store (Local1, \CHKC) } Store (\CSUM (0x01), Local1) If (LNotEqual (Local1, \CHKE)) { Store (0x01, Local0) Store (Local1, \CHKE) } If (Local0) { Notify (\_SB, 0x00) } } If (LOr (LEqual (Arg0, 0x03), LEqual (Arg0, 0x04))) { ADBG ("_WAK0") Store (0x00, \_SB.PCI0.LPC.EC.HKEY.ANGN) If (LOr (LEqual (\_SB.LID._LID (), 0x01), LEqual (\_SB.PCI0.LPC.EC.AC._PSR (), 0x01))) { \_SB.PCI0.LPC.EC.HKEY.DYTC (0x000F4001) } Else { \_SB.PCI0.LPC.EC.HKEY.DYTC (0x000F0001) } ADBG ("_WAK1") } Store (Zero, \RRBF) Return (WAKI) } Scope (\_SI) { Method (_SST, 1, NotSerialized) // _SST: System Status { If (LEqual (Arg0, 0x00)) { \_SB.PCI0.LPC.EC.LED (0x00, 0x00) \_SB.PCI0.LPC.EC.LED (0x0A, 0x00) \_SB.PCI0.LPC.EC.LED (0x07, 0x00) } If (LEqual (Arg0, 0x01)) { If (LOr (\SPS, \WNTF)) { \_SB.PCI0.LPC.EC.BEEP (0x05) } \_SB.PCI0.LPC.EC.LED (0x00, 0x80) \_SB.PCI0.LPC.EC.LED (0x0A, 0x80) \_SB.PCI0.LPC.EC.LED (0x07, 0x00) } If (LEqual (Arg0, 0x02)) { \_SB.PCI0.LPC.EC.LED (0x00, 0xC0) \_SB.PCI0.LPC.EC.LED (0x0A, 0xC0) \_SB.PCI0.LPC.EC.LED (0x07, 0xC0) } If (LEqual (Arg0, 0x03)) { If (LGreater (\SPS, 0x03)) { \_SB.PCI0.LPC.EC.BEEP (0x07) } ElseIf (LEqual (\SPS, 0x03)) { \_SB.PCI0.LPC.EC.BEEP (0x03) } Else { \_SB.PCI0.LPC.EC.BEEP (0x04) } If (LEqual (\SPS, 0x03)){} Else { \_SB.PCI0.LPC.EC.LED (0x00, 0x80) \_SB.PCI0.LPC.EC.LED (0x0A, 0x80) } \_SB.PCI0.LPC.EC.LED (0x07, 0xC0) \_SB.PCI0.LPC.EC.LED (0x00, 0xC0) \_SB.PCI0.LPC.EC.LED (0x0A, 0xC0) } If (LEqual (Arg0, 0x04)) { \_SB.PCI0.LPC.EC.BEEP (0x03) \_SB.PCI0.LPC.EC.LED (0x07, 0xC0) \_SB.PCI0.LPC.EC.LED (0x00, 0xC0) \_SB.PCI0.LPC.EC.LED (0x0A, 0xC0) } } } Scope (\_GPE) { Method (_L17, 0, NotSerialized) // _Lxx: Level-Triggered GPE { Store (\_SB.PCI0.LPC.EC.HWAC, Local0) Store (Local0, \RRBF) Sleep (0x0A) If (And (Local0, 0x02)){} If (And (Local0, 0x04)) { Notify (\_SB.LID, 0x02) } If (And (Local0, 0x08)) { Notify (\_SB.SLPB, 0x02) } If (And (Local0, 0x10)) { Notify (\_SB.SLPB, 0x02) } If (And (Local0, 0x40)){} If (And (Local0, 0x80)) { Notify (\_SB.SLPB, 0x02) } } Method (_L69, 0, NotSerialized) // _Lxx: Level-Triggered GPE { If (\_SB.PCI0.EXP1.PSPX) { Store (0x01, \_SB.PCI0.EXP1.PSPX) Store (0x01, \_SB.PCI0.EXP1.PMSX) Notify (\_SB.PCI0.EXP1, 0x02) } If (\_SB.PCI0.EXP2.PSPX) { Store (0x01, \_SB.PCI0.EXP2.PSPX) Store (0x01, \_SB.PCI0.EXP2.PMSX) Notify (\_SB.PCI0.EXP2, 0x02) } If (\_SB.PCI0.EXP3.PSPX) { Store (0x01, \_SB.PCI0.EXP3.PSPX) Store (0x01, \_SB.PCI0.EXP3.PMSX) Notify (\_SB.PCI0.EXP3, 0x02) } If (\_SB.PCI0.EXP5.PSPX) { Store (0x01, \_SB.PCI0.EXP5.PSPX) Store (0x01, \_SB.PCI0.EXP5.PMSX) Notify (\_SB.PCI0.EXP5, 0x02) } If (\_SB.PCI0.RP09.PSPX) { Store (0x01, \_SB.PCI0.RP09.PSPX) Store (0x01, \_SB.PCI0.RP09.PMSX) Notify (\_SB.PCI0.RP09, 0x02) } } Method (_L61, 0, NotSerialized) // _Lxx: Level-Triggered GPE { } Method (_L62, 0, NotSerialized) // _Lxx: Level-Triggered GPE { Store (0x00, \_SB.PCI0.LPC.SWGE) } Method (_L66, 0, NotSerialized) // _Lxx: Level-Triggered GPE { If (\_SB.PCI0.GFX0.GSSE) { \_SB.PCI0.GFX0.GSCI () } Else { Store (0x01, \_SB.PCI0.SMBU.CPSC) } } Name (GPFG, 0x00) Method (_L34, 0, NotSerialized) // _Lxx: Level-Triggered GPE { If (LAnd (GPFG, \_SB.PCI0.LPC.NFCI)) { Store (0x00, GPFG) Notify (\_SB.PCI0.SMBU.NFC, 0xC0) } } } Scope (\_SB.PCI0.LPC.EC.HKEY) { Method (MHQT, 1, NotSerialized) { If (LAnd (\WNTF, \TATC)) { If (LEqual (Arg0, 0x00)) { Store (\TATC, Local0) Return (Local0) } ElseIf (LEqual (Arg0, 0x01)) { Store (\TDFA, Local0) Add (Local0, ShiftLeft (\TDTA, 0x04), Local0) Add (Local0, ShiftLeft (\TDFD, 0x08), Local0) Add (Local0, ShiftLeft (\TDTD, 0x0C), Local0) Add (Local0, ShiftLeft (\TNFT, 0x10), Local0) Add (Local0, ShiftLeft (\TNTT, 0x14), Local0) Return (Local0) } ElseIf (LEqual (Arg0, 0x02)) { Store (\TCFA, Local0) Add (Local0, ShiftLeft (\TCTA, 0x04), Local0) Add (Local0, ShiftLeft (\TCFD, 0x08), Local0) Add (Local0, ShiftLeft (\TCTD, 0x0C), Local0) Return (Local0) } ElseIf (LEqual (Arg0, 0x03)){} ElseIf (LEqual (Arg0, 0x04)) { Store (\TATW, Local0) Return (Local0) } Else { Noop } } Return (0x00) } Method (MHAT, 1, NotSerialized) { If (LAnd (\WNTF, \TATC)) { Store (And (Arg0, 0xFF), Local0) If (LNot (ATMV (Local0))) { Return (0x00) } Store (And (ShiftRight (Arg0, 0x08), 0xFF), Local0) If (LNot (ATMV (Local0))) { Return (0x00) } Store (And (Arg0, 0x0F), \TCFA) Store (And (ShiftRight (Arg0, 0x04), 0x0F), \TCTA) Store (And (ShiftRight (Arg0, 0x08), 0x0F), \TCFD) Store (And (ShiftRight (Arg0, 0x0C), 0x0F), \TCTD) ATMC () If (And (\_PR.CFGD, 0x0100)) { Store (\FTPS, Local1) If (And (Arg0, 0x00010000)) { If (\_PR.CLVL) { Store (\CTPR, \FTPS) Increment (\FTPS) } Else { Store (0x01, \FTPS) } } ElseIf (\_PR.CLVL) { Store (\CTPR, \FTPS) } Else { Store (0x00, \FTPS) } If (XOr (\FTPS, Local1)) { If (LOr (\OSPX, \CPPX)) { \PNTF (0x80) } } } Store (\SCRM, Local2) If (And (Arg0, 0x00040000)) { Store (0x01, \SCRM) Store (0x07, \_SB.PCI0.LPC.EC.HFSP) } Else { Store (0x00, \SCRM) Store (0x80, \_SB.PCI0.LPC.EC.HFSP) } Store (\ETAU, Local3) If (And (Arg0, 0x00020000)) { Store (0x01, \ETAU) } Else { Store (0x00, \ETAU) } Return (0x01) } Return (0x00) } Method (MHGT, 1, NotSerialized) { If (LAnd (\WNTF, \TATC)) { Store (0x01000000, Local0) If (And (\_PR.CFGD, 0x0100)) { Or (Local0, 0x08000000, Local0) } If (\SCRM) { Or (Local0, 0x10000000, Local0) } If (\ETAU) { Or (Local0, 0x04000000, Local0) } If (LLess (\CTPR, \FTPS)) { Or (Local0, 0x02000000, Local0) } Add (Local0, ShiftLeft (\TSFT, 0x10), Local0) Add (Local0, ShiftLeft (\TSTT, 0x14), Local0) Store (And (Arg0, 0xFF), Local1) If (LNot (ATMV (Local1))) { Or (Local0, 0xFFFF, Local0) Return (Local0) } Store (And (Arg0, 0x0F), Local1) If (LEqual (Local1, 0x00)) { Add (Local0, \TIF0, Local0) } ElseIf (LEqual (Local1, 0x01)) { Add (Local0, \TIF1, Local0) } ElseIf (LEqual (Local1, 0x02)) { Add (Local0, \TIF2, Local0) } Else { Add (Local0, 0xFF, Local0) } Store (And (ShiftRight (Arg0, 0x04), 0x0F), Local1) If (LEqual (Local1, 0x00)) { Add (Local0, ShiftLeft (\TIT0, 0x08), Local0) } ElseIf (LEqual (Local1, 0x01)) { Add (Local0, ShiftLeft (\TIT1, 0x08), Local0) } ElseIf (LEqual (Local1, 0x02)) { Add (Local0, ShiftLeft (\TIT2, 0x08), Local0) } Else { Add (Local0, ShiftLeft (0xFF, 0x08), Local0) } Return (Local0) } Return (0x00) } Method (ATMV, 1, NotSerialized) { Store (And (Arg0, 0x0F), Local1) Store (\TNFT, Local0) If (LGreaterEqual (Local1, Local0)) { Return (0x00) } Store (And (ShiftRight (Arg0, 0x04), 0x0F), Local2) Store (\TNTT, Local0) If (LGreaterEqual (Local2, Local0)) { Return (0x00) } If (\TATL) { If (XOr (Local1, Local2)) { Return (0x00) } } Return (0x01) } Method (MHCT, 1, NotSerialized) { Store (0x00, Local0) If (\SPEN) { Store (\LWST, Local0) Increment (Local0) ShiftLeft (Local0, 0x08, Local0) } Store (0x08, Local1) ShiftLeft (Local1, 0x08, Local1) If (LEqual (Arg0, 0xFFFFFFFF)) { Or (Local1, \TPCR, Local1) If (\SPEN) { Or (Local0, \PPCR, Local0) If (LNot (LAnd (\_PR.CFGD, 0x02000000))) { Or (Local1, 0x80, Local1) } If (LNot (LAnd (\_PR.CFGD, 0x08000000))) { Or (Local1, 0x40, Local1) } } Else { Or (Local1, 0xC0, Local1) } } Else { If (LAnd (LOr (\OSPX, \CPPX), \SPEN)) { And (Arg0, 0x00FF0000, Local2) ShiftRight (Local2, 0x10, Local2) Or (Local0, Local2, Local0) If (XOr (Local2, \PPCR)) { Store (Local2, \PPCA) \PNTF (0x80) } } If (\WVIS) { And (Arg0, 0x1F, Local2) Or (Local1, Local2, Local1) If (XOr (Local2, \TPCR)) { Store (Local2, \TPCA) \PNTF (0x82) } } } ShiftLeft (Local0, 0x10, Local0) Or (Local0, Local1, Local0) Return (Local0) } Method (DYTC, 1, Serialized) { Store (Arg0, Local0) Store (0x00, Local1) ADBG (Concatenate ("DYTC STT=", ToHexString (Local0))) If (LAnd (\WNTF, \TATC)) { Switch (ToInteger (And (Local0, 0x01FF))) { Case (0x00) { Store (ShiftLeft (0x01, 0x08), Local1) Or (Local1, ShiftLeft (0x03, 0x1C), Local1) Or (Local1, 0x01, Local1) } Case (0x01) { And (ShiftRight (Local0, 0x0C), 0x0F, Local2) And (ShiftRight (Local0, 0x10), 0x0F, Local3) And (ShiftRight (Local0, 0x14), 0x01, Local4) Switch (Local2) { Case (0x01) { If (LNotEqual (Local3, 0x0F)) { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } If (LEqual (Local4, 0x00)) { Store (0x00, \VCQL) } Else { Store (0x01, \VCQL) } } Case (0x03) { Switch (Local3) { Case (0x00) { If (LNotEqual (Local4, 0x01)) { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } } Case (0x01) { If (LNotEqual (Local4, 0x01)) { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } } Case (0x01) { If (LNotEqual (Local4, 0x01)) { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } } Case (0x0F) { If (LNotEqual (Local4, 0x00)) { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } } Default { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } } If (LEqual (Local4, 0x00)) { Store (0x00, \VMYH) } Else { Store (0x01, \VMYH) } } Case (0x04) { If (LNotEqual (Local3, 0x0F)) { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } If (LEqual (Local4, 0x00)) { Store (0x00, \VSTP) } Else { Store (0x01, \VSTP) } } Case (0x05) { If (LNotEqual (Local3, 0x0F)) { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } If (LEqual (Local4, 0x00)) { Store (0x00, \VCQH) } Else { Store (0x01, \VCQH) } } Case (0x00) { If (LNotEqual (Local3, 0x0F)) { ShiftLeft (0x05, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } } Default { ShiftLeft (0x01, 0x01, Local1) ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } } If (LEqual (\VSTP, 0x01)) { Store (0x04, \CICF) If (LGreater (\_PR.CLVL, 0x01)) { \_SB.PCI0.PL1S (0x44) } \FLPF (0x01) NVST (0x36) } ElseIf (LEqual (\VMYH, 0x01)) { Store (0x03, \CICF) If (LEqual (Local3, 0x00)) { Store (0x00, \CICM) If (LGreater (\_PR.CLVL, 0x01)) { \_SB.PCI0.PL1S (0x50) } \FLPF (0x00) } ElseIf (LEqual (Local3, 0x01)) { Store (0x01, \CICM) If (LGreater (\_PR.CLVL, 0x01)) { \_SB.PCI0.PL1S (0x50) } \FLPF (0x00) } ElseIf (LEqual (Local3, 0x02)) { Store (0x02, \CICM) If (LGreater (\_PR.CLVL, 0x01)) { \_SB.PCI0.PL1S (0x70) } \FLPF (0x00) } } ElseIf (LEqual (\VCQL, 0x01)) { Store (0x01, \CICF) If (LGreater (\_PR.CLVL, 0x01)) { \_SB.PCI0.PL1S (0x50) } \FLPF (0x00) NVST (0x3C) } ElseIf (LEqual (\VCQH, 0x01)) { Store (0x05, \CICF) If (LGreater (\_PR.CLVL, 0x01)) { \_SB.PCI0.PL1S (0x78) } \FLPF (0x00) } Else { Store (0x00, \CICF) If (LGreater (\_PR.CLVL, 0x01)) { \_SB.PCI0.PL1S (0x70) } \FLPF (0x00) NVST (0x3C) } Store (\VSTD, Local5) Or (ShiftLeft (\VCQL, 0x01), Local5, Local5) Or (ShiftLeft (\VTIO, 0x02), Local5, Local5) Or (ShiftLeft (\VMYH, 0x03), Local5, Local5) Or (ShiftLeft (\VSTP, 0x04), Local5, Local5) Or (ShiftLeft (\VCQH, 0x05), Local5, Local5) Or (ShiftLeft (\VDCC, 0x06), Local5, Local5) Or (ShiftLeft (\VSFN, 0x07), Local5, Local5) Or (ShiftLeft (\VDMC, 0x08), Local5, Local5) Store (ShiftLeft (\CICF, 0x08), Local1) If (LNotEqual (\CICF, 0x03)) { Store (0x0F, \CICM) } Or (ShiftLeft (\CICM, 0x0C), Local1, Local1) Or (ShiftLeft (Local5, 0x10), Local1, Local1) Or (Local1, 0x01, Local1) } Case (0x02) { Store (\VSTD, Local5) Or (ShiftLeft (\VCQL, 0x01), Local5, Local5) Or (ShiftLeft (\VTIO, 0x02), Local5, Local5) Or (ShiftLeft (\VMYH, 0x03), Local5, Local5) Or (ShiftLeft (\VSTP, 0x04), Local5, Local5) Or (ShiftLeft (\VCQH, 0x05), Local5, Local5) Or (ShiftLeft (\VDCC, 0x06), Local5, Local5) Or (ShiftLeft (\VSFN, 0x07), Local5, Local5) Or (ShiftLeft (\VDMC, 0x08), Local5, Local5) Store (ShiftLeft (\CICF, 0x08), Local1) If (LNotEqual (\CICF, 0x03)) { Store (0x0F, \CICM) } Or (ShiftLeft (\CICM, 0x0C), Local1, Local1) Or (ShiftLeft (Local5, 0x10), Local1, Local1) Or (Local1, 0x01, Local1) } Case (0x03) { Store (ShiftLeft (FCAP, 0x10), Local1) Or (Local1, 0x01, Local1) } Case (0x04) { Store (ShiftLeft (MCAP, 0x10), Local1) Or (Local1, 0x01, Local1) } Case (0x0100) { Store (ShiftLeft (0x1001, 0x10), Local1) Or (Local1, 0x01, Local1) } Case (0x01FF) { Store (0x00, \VCQL) Store (0x00, \VTIO) Store (0x00, \VMYH) Store (0x00, \VSTP) Store (0x00, \VCQH) Store (0x00, \VDCC) Store (0x00, \VSFN) Store (0x00, \VDMC) Store (0x00, \CICF) If (LGreater (\_PR.CLVL, 0x01)) { \_SB.PCI0.PL1S (0x70) } \FLPF (0x00) NVST (0x3C) Store (0x0F, \CICM) Store (\VSTD, Local5) Or (ShiftLeft (\VCQL, 0x01), Local5, Local5) Or (ShiftLeft (\VTIO, 0x02), Local5, Local5) Or (ShiftLeft (\VMYH, 0x03), Local5, Local5) Or (ShiftLeft (\VSTP, 0x04), Local5, Local5) Or (ShiftLeft (\VCQH, 0x05), Local5, Local5) Or (ShiftLeft (\VDCC, 0x06), Local5, Local5) Or (ShiftLeft (\VSFN, 0x07), Local5, Local5) Or (ShiftLeft (\VDMC, 0x08), Local5, Local5) Store (ShiftLeft (\CICF, 0x08), Local1) Or (ShiftLeft (\CICM, 0x0C), Local1, Local1) Or (ShiftLeft (Local5, 0x10), Local1, Local1) Or (Local1, 0x01, Local1) } Default { ShiftLeft (0x02, 0x01, Local1) } } } Else { ShiftLeft (0x04, 0x01, Local1) } ADBG (Concatenate ("DYTC END=", ToHexString (Local1))) Return (Local1) } Name (GPTL, 0x3C) Name (ANGN, 0x00) Method (NVST, 1, NotSerialized) { Store (Arg0, \_SB.PCI0.LPC.EC.HKEY.GPTL) If (LAnd (ANGN, LNotEqual (\_SB.PCI0.LPC.EC.VPON, 0x00))) { If (CondRefOf (\_SB.PCI0.RP09.PEGP.CPPC)) { \_SB.PCI0.RP09.PEGP.NVST () } } } } Scope (\_SB.PCI0) { Method (PL1S, 1, NotSerialized) { ADBG (Concatenate ("PL1S Value=", ToHexString (Arg0))) ADBG (Concatenate ("PL1S PTDP =", ToHexString (\_SB.PCI0.PTDP))) ADBG (Concatenate ("PL1S CTNL =", ToHexString (\_SB.PCI0.CTNL))) If (LEqual (\_SB.PCI0.PTDP, Arg0)) { \_SB.PCI0.CTCN () } ElseIf (LGreater (\_SB.PCI0.PTDP, Arg0)) { If (LGreater (\_PR.CLVL, 0x01)) { If (LGreaterEqual (\_SB.PCI0.CTNL, 0x01)) { Store (Arg0, \PT1D) \_SB.PCI0.CTCD () } } } ElseIf (LLess (\_SB.PCI0.PTDP, Arg0)) { If (LGreater (\_PR.CLVL, 0x02)) { If (LGreaterEqual (\_SB.PCI0.CTNL, 0x02)) { Store (Arg0, \PT2D) \_SB.PCI0.CTCU () } } } } } Scope (\_SB.PCI0.LPC.EC) { Method (ATMC, 0, NotSerialized) { If (LAnd (\WNTF, \TATC)) { If (HPAC) { Store (\TCFA, Local0) Store (\TCTA, Local1) Store (Or (ShiftLeft (Local1, 0x04), Local0), Local2) XOr (Local2, ATMX, Local3) Store (Local2, ATMX) If (LEqual (\TCTA, 0x00)) { Store (\TCR0, \TCRT) Store (\TPS0, \TPSV) } ElseIf (LEqual (\TCTA, 0x01)) { Store (\TCR1, \TCRT) Store (\TPS1, \TPSV) } Else { } } Else { Store (\TCFD, Local0) Store (\TCTD, Local1) Store (Or (ShiftLeft (Local1, 0x04), Local0), Local2) XOr (Local2, ATMX, Local3) Store (Local2, ATMX) If (LEqual (\TCTD, 0x00)) { Store (\TCR0, \TCRT) Store (\TPS0, \TPSV) } ElseIf (LEqual (\TCTD, 0x01)) { Store (\TCR1, \TCRT) Store (\TPS1, \TPSV) } Else { } } If (Local3) { If (\_SB.PCI0.LPC.EC.HKEY.DHKC) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6030) } } Notify (\_TZ.THM0, 0x81) } } } Scope (\_TZ) { ThermalZone (THM0) { Method (_CRT, 0, NotSerialized) // _CRT: Critical Temperature { Return (\TCRT) } Method (_TMP, 0, NotSerialized) // _TMP: Temperature { If (\H8DR) { Store (\_SB.PCI0.LPC.EC.TMP0, Local0) Store (\_SB.PCI0.LPC.EC.TSL2, Local1) Store (\_SB.PCI0.LPC.EC.TSL3, Local2) } Else { Store (\RBEC (0x78), Local0) Store (And (\RBEC (0x8A), 0x7F), Local1) Store (And (\RBEC (0x8B), 0x7F), Local2) } If (LEqual (Local0, 0x80)) { Store (0x30, Local0) } If (Local2) { \TSDL () Return (\TCRT) } If (LNot (\_SB.PCI0.LPC.EC.HKEY.DHKC)) { If (Local1) { \TSDL () Return (\TCRT) } } Return (C2K (Local0)) } } Method (C2K, 1, NotSerialized) { Add (Multiply (Arg0, 0x0A), 0x0AAC, Local0) If (LLessEqual (Local0, 0x0AAC)) { Store (0x0BB8, Local0) } If (LGreater (Local0, 0x0FAC)) { Store (0x0BB8, Local0) } Return (Local0) } } Scope (\_SB.PCI0.LPC.EC) { Method (_Q40, 0, NotSerialized) // _Qxx: EC Query { Notify (\_TZ.THM0, 0x80) If (\H8DR) { Store (\_SB.PCI0.LPC.EC.TSL2, Local1) } Else { Store (And (\RBEC (0x8A), 0x7F), Local1) } If (\_SB.PCI0.LPC.EC.HKEY.DHKC) { If (Local1) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6022) } } If (VIGD) { Noop } Else { \VTHR () } If (And (\_PR.CFGD, 0x01)) { If (LOr (\OSPX, \CPPX)) { \PNTF (0x80) } Else { Store (And (\_SB.PCI0.LPC.EC.TSL0, 0x77), Local2) If (Local2) { \STEP (0x09) } Else { \STEP (0x0A) } } } } } Method (_PIC, 1, NotSerialized) // _PIC: Interrupt Model { Store (Arg0, \GPIC) } OperationRegion (SMI0, SystemIO, 0xB2, 0x01) Field (SMI0, ByteAcc, NoLock, Preserve) { APMC, 8 } Field (MNVS, AnyAcc, NoLock, Preserve) { Offset (0xFC0), CMD, 8, ERR, 32, PAR0, 32, PAR1, 32, PAR2, 32, PAR3, 32 } Mutex (MSMI, 0x00) Method (SMI, 5, Serialized) { Acquire (MSMI, 0xFFFF) Store (Arg0, CMD) Store (0x01, ERR) Store (Arg1, PAR0) Store (Arg2, PAR1) Store (Arg3, PAR2) Store (Arg4, PAR3) Store (0xF5, APMC) While (LEqual (ERR, 0x01)) { Sleep (0x01) Store (0xF5, APMC) } Store (PAR0, Local0) Release (MSMI) Return (Local0) } Method (RPCI, 1, NotSerialized) { Return (SMI (0x00, 0x00, Arg0, 0x00, 0x00)) } Method (WPCI, 2, NotSerialized) { SMI (0x00, 0x01, Arg0, Arg1, 0x00) } Method (MPCI, 3, NotSerialized) { SMI (0x00, 0x02, Arg0, Arg1, Arg2) } Method (RBEC, 1, NotSerialized) { Return (SMI (0x00, 0x03, Arg0, 0x00, 0x00)) } Method (WBEC, 2, NotSerialized) { SMI (0x00, 0x04, Arg0, Arg1, 0x00) } Method (MBEC, 3, NotSerialized) { SMI (0x00, 0x05, Arg0, Arg1, Arg2) } Method (RISA, 1, NotSerialized) { Return (SMI (0x00, 0x06, Arg0, 0x00, 0x00)) } Method (WISA, 2, NotSerialized) { SMI (0x00, 0x07, Arg0, Arg1, 0x00) } Method (MISA, 3, NotSerialized) { SMI (0x00, 0x08, Arg0, Arg1, Arg2) } Method (VEXP, 0, NotSerialized) { SMI (0x01, 0x00, 0x00, 0x00, 0x00) } Method (VUPS, 1, NotSerialized) { SMI (0x01, 0x01, Arg0, 0x00, 0x00) } Method (VSDS, 2, NotSerialized) { SMI (0x01, 0x02, Arg0, Arg1, 0x00) } Method (VDDC, 0, NotSerialized) { SMI (0x01, 0x03, 0x00, 0x00, 0x00) } Method (VVPD, 1, NotSerialized) { SMI (0x01, 0x04, Arg0, 0x00, 0x00) } Method (VNRS, 1, NotSerialized) { SMI (0x01, 0x05, Arg0, 0x00, 0x00) } Method (GLPW, 0, NotSerialized) { Return (SMI (0x01, 0x06, 0x00, 0x00, 0x00)) } Method (VSLD, 1, NotSerialized) { SMI (0x01, 0x07, Arg0, 0x00, 0x00) } Method (VEVT, 1, NotSerialized) { Return (SMI (0x01, 0x08, Arg0, 0x00, 0x00)) } Method (VTHR, 0, NotSerialized) { Return (SMI (0x01, 0x09, 0x00, 0x00, 0x00)) } Method (VBRC, 1, NotSerialized) { SMI (0x01, 0x0A, Arg0, 0x00, 0x00) } Method (VBRG, 0, NotSerialized) { Return (SMI (0x01, 0x0E, 0x00, 0x00, 0x00)) } Method (VCMS, 2, NotSerialized) { Return (SMI (0x01, 0x0B, Arg0, Arg1, 0x00)) } Method (VBTD, 0, NotSerialized) { Return (SMI (0x01, 0x0F, 0x00, 0x00, 0x00)) } Method (VHYB, 2, NotSerialized) { Return (SMI (0x01, 0x10, Arg0, Arg1, 0x00)) } Method (VDYN, 2, NotSerialized) { Return (SMI (0x01, 0x11, Arg0, Arg1, 0x00)) } Method (UCMS, 1, NotSerialized) { Return (SMI (0x02, Arg0, 0x00, 0x00, 0x00)) } Method (BHDP, 2, NotSerialized) { Return (SMI (0x03, 0x00, Arg0, Arg1, 0x00)) } Method (STEP, 1, NotSerialized) { SMI (0x04, Arg0, 0x00, 0x00, 0x00) } Method (TRAP, 0, NotSerialized) { SMI (0x05, 0x00, 0x00, 0x00, 0x00) } Method (CBRI, 0, NotSerialized) { SMI (0x05, 0x01, 0x00, 0x00, 0x00) } Method (BCHK, 0, NotSerialized) { Return (SMI (0x05, 0x04, 0x00, 0x00, 0x00)) } Method (BYRS, 0, NotSerialized) { SMI (0x05, 0x05, 0x00, 0x00, 0x00) } Method (LCHK, 1, NotSerialized) { Return (SMI (0x05, 0x06, Arg0, 0x00, 0x00)) } Method (BLTH, 1, NotSerialized) { Return (SMI (0x06, Arg0, 0x00, 0x00, 0x00)) } Method (PRSM, 2, NotSerialized) { Return (SMI (0x07, 0x00, Arg0, Arg1, 0x00)) } Method (ISOC, 1, NotSerialized) { Return (SMI (0x07, 0x03, Arg0, 0x00, 0x00)) } Method (EZRC, 1, NotSerialized) { Return (SMI (0x07, 0x04, Arg0, 0x00, 0x00)) } Method (WGSV, 1, NotSerialized) { Return (SMI (0x09, Arg0, 0x00, 0x00, 0x00)) } Method (SWTT, 1, NotSerialized) { If (SMI (0x0A, 0x02, Arg0, 0x00, 0x00)) { If (\_SB.PCI0.LPC.EC.HKEY.DHKC) { \_SB.PCI0.LPC.EC.HKEY.MHKQ (0x6030) } } } Method (TSDL, 0, NotSerialized) { Return (SMI (0x0A, 0x03, 0x00, 0x00, 0x00)) } Method (FLPF, 1, NotSerialized) { Return (SMI (0x0A, 0x04, Arg0, 0x00, 0x00)) } Method (CSUM, 1, NotSerialized) { Return (SMI (0x0E, Arg0, 0x00, 0x00, 0x00)) } Method (NVSS, 1, NotSerialized) { Return (SMI (0x0F, Arg0, 0x00, 0x00, 0x00)) } Method (WMIS, 2, NotSerialized) { Return (SMI (0x10, Arg0, Arg1, 0x00, 0x00)) } Method (AWON, 1, NotSerialized) { Return (SMI (0x12, Arg0, 0x00, 0x00, 0x00)) } Method (PMON, 2, NotSerialized) { Store (SizeOf (Arg0), Local0) Name (TSTR, Buffer (Local0){}) Store (Arg0, TSTR) Store (TSTR, \DBGB) SMI (0x11, Arg1, 0x00, 0x00, 0x00) } Method (UAWS, 1, NotSerialized) { Return (SMI (0x13, Arg0, 0x00, 0x00, 0x00)) } Method (BFWC, 1, NotSerialized) { Return (SMI (0x14, 0x00, Arg0, 0x00, 0x00)) } Method (BFWP, 0, NotSerialized) { Return (SMI (0x14, 0x01, 0x00, 0x00, 0x00)) } Method (BFWL, 0, NotSerialized) { SMI (0x14, 0x02, 0x00, 0x00, 0x00) } Method (BFWG, 1, NotSerialized) { SMI (0x14, 0x03, Arg0, 0x00, 0x00) } Method (BDMC, 1, NotSerialized) { SMI (0x14, 0x04, Arg0, 0x00, 0x00) } Method (PSIF, 2, NotSerialized) { Return (SMI (0x14, 0x05, Arg0, Arg1, 0x00)) } Method (FNSC, 2, NotSerialized) { Return (SMI (0x14, 0x06, Arg0, Arg1, 0x00)) } Method (AUDC, 2, NotSerialized) { Return (SMI (0x14, 0x07, Arg0, Arg1, 0x00)) } Method (SYBC, 2, NotSerialized) { Return (SMI (0x14, 0x08, Arg0, Arg1, 0x00)) } Method (KBLS, 2, NotSerialized) { Return (SMI (0x14, 0x09, Arg0, Arg1, 0x00)) } Method (UBIS, 1, NotSerialized) { Return (SMI (0x15, 0x00, Arg0, 0x00, 0x00)) } Method (DIEH, 1, NotSerialized) { Return (SMI (0x16, 0x00, Arg0, 0x00, 0x00)) } Method (OUTP, 2, NotSerialized) { SMI (0x17, Arg0, Arg1, 0x00, 0x00) } Method (SCMP, 2, NotSerialized) { Store (SizeOf (Arg0), Local0) If (LNotEqual (Local0, SizeOf (Arg1))) { Return (One) } Increment (Local0) Name (STR1, Buffer (Local0){}) Name (STR2, Buffer (Local0){}) Store (Arg0, STR1) Store (Arg1, STR2) Store (Zero, Local1) While (LLess (Local1, Local0)) { Store (DerefOf (Index (STR1, Local1)), Local2) Store (DerefOf (Index (STR2, Local1)), Local3) If (LNotEqual (Local2, Local3)) { Return (One) } Increment (Local1) } Return (Zero) } Name (SPS, 0x00) Name (OSIF, 0x00) Name (WNTF, 0x00) Name (WXPF, 0x00) Name (WVIS, 0x00) Name (WIN7, 0x00) Name (WIN8, 0x00) Name (WSPV, 0x00) Name (LNUX, 0x00) Name (H8DR, 0x00) Name (MEMX, 0x00) Name (ACST, 0x00) Name (FMBL, 0x01) Name (FDTP, 0x02) Name (FUPS, 0x03) Name (FNID, 0x00) Name (RRBF, 0x00) Name (NBCF, 0x00) Scope (\_SB.PCI0.XHCI) { Name (UPWR, 0x00) Name (USPP, 0x00) } Scope (\_SB.PCI0.XHCI.URTH) { Method (PS0X, 0, Serialized) { Store (0x00, \_SB.PCI0.XHCI.USPP) } Method (PS2X, 0, Serialized) { OperationRegion (XHCM, SystemMemory, And (ToInteger (MEMB), 0xFFFFFFFFFFFF0000), 0x0600) Field (XHCM, DWordAcc, NoLock, Preserve) { Offset (0x02), XHCV, 16, Offset (0x480), HP01, 1, Offset (0x490), HP02, 1, Offset (0x530), SP00, 1, Offset (0x540), SP01, 1 } If (LEqual (XHCV, 0xFFFF)) { Return (Zero) } If (LAnd (LEqual (HP01, 0x00), LEqual (SP00, 0x00))) { Or (\_SB.PCI0.XHCI.USPP, 0x02, \_SB.PCI0.XHCI.USPP) } If (LAnd (LEqual (HP02, 0x00), LEqual (SP01, 0x00))) { Or (\_SB.PCI0.XHCI.USPP, 0x04, \_SB.PCI0.XHCI.USPP) } } Method (PS3X, 0, Serialized) { } } }