Skip to content

Instantly share code, notes, and snippets.

@jschmidt-1
Created September 2, 2019 18:10
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save jschmidt-1/d08ae4c001c6a425be11f59711d8856c to your computer and use it in GitHub Desktop.
Save jschmidt-1/d08ae4c001c6a425be11f59711d8856c to your computer and use it in GitHub Desktop.
This file has been truncated, but you can view the full file.
/*
* Intel ACPI Component Architecture
* AML/ASL+ Disassembler version 20190816 (64-bit version)
* Copyright (c) 2000 - 2019 Intel Corporation
*
* Disassembling to symbolic ASL+ operators
*
* Disassembly of dsdt.dat, Mon Sep 2 19:41:14 2019
*
* Original Table Header:
* Signature "DSDT"
* Length 0x0002A2B6 (172726)
* Revision 0x02
* Checksum 0x1E
* OEM ID "LENOVO"
* OEM Table ID "SKL "
* OEM Revision 0x00000000 (0)
* Compiler ID "INTL"
* Compiler Version 0x20160527 (538314023)
*/
DefinitionBlock ("", "DSDT", 2, "LENOVO", "SKL ", 0x00000000)
{
External (_PR_.BGIA, UnknownObj)
External (_PR_.BGMA, UnknownObj)
External (_PR_.BGMS, UnknownObj)
External (_PR_.CFGD, UnknownObj)
External (_PR_.CLVL, UnknownObj)
External (_PR_.CPPC, IntObj)
External (_PR_.DSAE, UnknownObj)
External (_PR_.DTS1, UnknownObj)
External (_PR_.DTS2, UnknownObj)
External (_PR_.DTS3, UnknownObj)
External (_PR_.DTS4, UnknownObj)
External (_PR_.DTSE, UnknownObj)
External (_PR_.DTSF, UnknownObj)
External (_PR_.ELNG, UnknownObj)
External (_PR_.EMNA, UnknownObj)
External (_PR_.EPCS, UnknownObj)
External (_PR_.PDTS, UnknownObj)
External (_PR_.PKGA, UnknownObj)
External (_PR_.POWS, UnknownObj)
External (_PR_.PR00, DeviceObj)
External (_PR_.PR00.LPSS, PkgObj)
External (_PR_.PR00.TPSS, PkgObj)
External (_PR_.TRPD, UnknownObj)
External (_PR_.TRPF, UnknownObj)
External (_SB_.IETM, DeviceObj)
External (_SB_.IETM.DPTE, UnknownObj)
External (_SB_.PCI0.B0D4.CPNU, MethodObj) // 2 Arguments
External (_SB_.PCI0.B0D4.NPCC, PkgObj)
External (_SB_.PCI0.GFX0, DeviceObj)
External (_SB_.PCI0.GFX0.AINT, MethodObj) // 2 Arguments
External (_SB_.PCI0.GFX0.ALSI, UnknownObj)
External (_SB_.PCI0.GFX0.CBLV, UnknownObj)
External (_SB_.PCI0.GFX0.CDCK, UnknownObj)
External (_SB_.PCI0.GFX0.CLID, UnknownObj)
External (_SB_.PCI0.GFX0.DD1F, DeviceObj)
External (_SB_.PCI0.GFX0.DRDY, UnknownObj)
External (_SB_.PCI0.GFX0.GSCI, MethodObj) // 0 Arguments
External (_SB_.PCI0.GFX0.GSSE, UnknownObj)
External (_SB_.PCI0.GFX0.IUEH, MethodObj) // 1 Arguments
External (_SB_.PCI0.GFX0.STAT, UnknownObj)
External (_SB_.PCI0.GFX0.TCHE, UnknownObj)
External (_SB_.PCI0.GFX0.VLOC, MethodObj) // 1 Arguments
External (_SB_.PCI0.HDAS.PPMS, MethodObj) // 1 Arguments
External (_SB_.PCI0.HDAS.PS0X, MethodObj) // 0 Arguments
External (_SB_.PCI0.HDAS.PS3X, MethodObj) // 0 Arguments
External (_SB_.PCI0.LPCB.EC__.CHRG, DeviceObj)
External (_SB_.PCI0.LPCB.EC__.HIDS, UnknownObj)
External (_SB_.PCI0.LPCB.EC__.SSD0, DeviceObj)
External (_SB_.PCI0.LPCB.EC__.VBEN, UnknownObj)
External (_SB_.PCI0.LPCB.H_EC.XDAT, MethodObj) // 0 Arguments
External (_SB_.PCI0.PAUD.PUAM, MethodObj) // 0 Arguments
External (_SB_.PCI0.PEG0, DeviceObj)
External (_SB_.PCI0.PEG0.PEGP, DeviceObj)
External (_SB_.PCI0.PEG1, DeviceObj)
External (_SB_.PCI0.PEG2, DeviceObj)
External (_SB_.PCI0.PTDP, UnknownObj)
External (_SB_.PCI0.RP05.PWRG, UnknownObj)
External (_SB_.PCI0.RP05.RSTG, UnknownObj)
External (_SB_.PCI0.RP05.SCLK, UnknownObj)
External (_SB_.PCI0.RP09.PEGP.NVST, MethodObj) // 0 Arguments
External (_SB_.PCI0.RP09.PWRG, UnknownObj)
External (_SB_.PCI0.RP09.RSTG, UnknownObj)
External (_SB_.PCI0.RP09.SCLK, UnknownObj)
External (_SB_.PCI0.RP13.PWRG, UnknownObj)
External (_SB_.PCI0.RP13.RSTG, UnknownObj)
External (_SB_.PCI0.RP13.SCLK, UnknownObj)
External (_SB_.PCI0.RP17.PWRG, UnknownObj)
External (_SB_.PCI0.RP17.RSTG, UnknownObj)
External (_SB_.PCI0.RP17.SCLK, UnknownObj)
External (_SB_.PCI0.SAT0.NVM1.VLPM, UnknownObj)
External (_SB_.PCI0.SAT0.NVM2.VLPM, UnknownObj)
External (_SB_.PCI0.SAT0.NVM3.VLPM, UnknownObj)
External (_SB_.PCI0.SAT0.PRIM, DeviceObj)
External (_SB_.PCI0.SAT0.PRIM.GTME, IntObj)
External (_SB_.PCI0.SAT0.SCND, DeviceObj)
External (_SB_.PCI0.SAT0.SCND.GTME, IntObj)
External (_SB_.PCI0.SAT0.SCND.MSTR, DeviceObj)
External (_SB_.PCI0.SAT0.SDSM, MethodObj) // 4 Arguments
External (_SB_.PCI0.VID_.IUEH, MethodObj) // 1 Arguments
External (_SB_.PCI0.XHC_.DUAM, MethodObj) // 0 Arguments
External (_SB_.PCI0.XHC_.PS0X, MethodObj) // 0 Arguments
External (_SB_.PCI0.XHC_.PS3X, MethodObj) // 0 Arguments
External (_SB_.PCI0.XHC_.RHUB.HS07.PRT0, DeviceObj)
External (_SB_.PCI0.XHC_.RHUB.INIR, MethodObj) // 0 Arguments
External (_SB_.PCI0.XHC_.RHUB.PS0X, MethodObj) // 0 Arguments
External (_SB_.PCI0.XHC_.RHUB.PS2X, MethodObj) // 0 Arguments
External (_SB_.PCI0.XHC_.RHUB.PS3X, MethodObj) // 0 Arguments
External (_SB_.PCI0.XHC_.RHUB.SS05.PRT0, DeviceObj)
External (_SB_.TBFP, MethodObj) // 1 Arguments
External (_SB_.TPM_.PTS_, MethodObj) // 1 Arguments
External (_SB_.UBTC, DeviceObj)
External (_SB_.UBTC.DSMR, MethodObj) // 0 Arguments
External (_TZ_.ETMD, IntObj)
External (_TZ_.TZ00, DeviceObj)
External (_TZ_.TZ01, DeviceObj)
External (ALSE, UnknownObj)
External (BNUM, UnknownObj)
External (BRTL, UnknownObj)
External (CFGD, UnknownObj)
External (DIDX, UnknownObj)
External (FFTB, MethodObj) // 1 Arguments
External (GSMI, UnknownObj)
External (IGDS, UnknownObj)
External (LHIH, UnknownObj)
External (LIDS, UnknownObj)
External (LLOW, UnknownObj)
External (M32B, UnknownObj)
External (M32L, UnknownObj)
External (M64B, UnknownObj)
External (M64L, UnknownObj)
External (MMRP, MethodObj) // 1 Arguments
External (MMTB, MethodObj) // 1 Arguments
External (PC00, IntObj)
External (PC01, UnknownObj)
External (PC02, UnknownObj)
External (PC03, UnknownObj)
External (PC04, UnknownObj)
External (PC05, UnknownObj)
External (PC06, UnknownObj)
External (PC07, UnknownObj)
External (PC08, UnknownObj)
External (PC09, UnknownObj)
External (PC10, UnknownObj)
External (PC11, UnknownObj)
External (PC12, UnknownObj)
External (PC13, UnknownObj)
External (PC14, UnknownObj)
External (PC15, UnknownObj)
External (PTTB, UnknownObj)
External (SGMD, UnknownObj)
External (TBTD, MethodObj) // 1 Arguments
External (TBTF, MethodObj) // 1 Arguments
External (XBAS, UnknownObj)
Name (SS1, 0x00)
Name (SS2, 0x00)
Name (SS3, One)
One
Name (SS4, One)
One
OperationRegion (GNVS, SystemMemory, 0xBFF4E000, 0x072C)
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),
BNUM, 8,
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,
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,
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,
LTRL, 8,
LTRM, 8,
LTRN, 8,
LTRO, 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,
OBFL, 8,
OBFM, 8,
OBFN, 8,
OBFO, 8,
XTUB, 32,
XTUS, 32,
XMPB, 32,
DDRF, 8,
RTD3, 8,
PEP0, 8,
PEP3, 8,
DPTF, 8,
DCFE, 16,
SADE, 8,
SACR, 8,
SAHT, 8,
CPUS, 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,
Offset (0x1FC),
PPPR, 16,
PBPE, 8,
VSPE, 8,
Offset (0x203),
XHPR, 8,
RIC0, 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,
RCG1, 16,
ECDB, 8,
P2ME, 8,
P2MK, 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,
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,
PEAT, 8,
PEPV, 8,
PECR, 8,
PEC3, 8,
PEHT, 8,
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,
STGE, 8,
STAT, 8,
STPT, 8,
STCT, 8,
STC3, 8,
STHT, 8,
VSP1, 8,
V1AT, 8,
V1PV, 8,
V1CR, 8,
V1C3, 8,
V1HT, 8,
VSP2, 8,
V2AT, 8,
V2PV, 8,
V2CR, 8,
V2C3, 8,
V2HT, 8,
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,
ICAE, 8,
PSME, 8,
PDT1, 8,
PLM1, 32,
PTW1, 32,
PDT2, 8,
PLM2, 32,
PTW2, 32,
DDT1, 8,
DDP1, 8,
DLI1, 16,
DPL1, 16,
DTW1, 32,
DMI1, 16,
DMA1, 16,
DMT1, 16,
DDT2, 8,
DDP2, 8,
DLI2, 16,
DPL2, 16,
DTW2, 32,
DMI2, 16,
DMA2, 16,
DMT2, 16,
WIFE, 8,
DOM1, 8,
LIM1, 16,
TIM1, 32,
DOM2, 8,
LIM2, 16,
TIM2, 32,
DOM3, 8,
LIM3, 16,
TIM3, 32,
TRD0, 8,
TRL0, 8,
TRD1, 8,
TRL1, 8,
WDM1, 8,
CID1, 16,
WDM2, 8,
CID2, 16,
Offset (0x378),
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,
TBWS, 8,
AICS, 8,
TARS, 8,
FPAT, 8,
FPEN, 8,
FPGN, 32,
FPLV, 8,
CPAD, 16,
CPAB, 8,
TNAT, 8,
CPGN, 32,
CF2T, 8,
TDGS, 8,
DCSC, 8,
DCKE, 8,
UDCK, 8,
SUDK, 8,
OHPN, 8,
GHPN, 8,
EGPC, 32,
EGPV, 8,
TBDT, 32,
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,
IVDF, 8,
IFWG, 64,
IVWS, 8,
IVPR, 8,
DIVO, 16,
DIVF, 16,
IVAD, 8,
IVRS, 8,
IVDG, 64,
DSPR, 8,
DDSO, 16,
DDSF, 16,
DSAD, 8,
DSRS, 8,
DVDG, 64,
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 (0x60E),
I2SC, 8,
ODV0, 8,
ODV1, 8,
ODV2, 8,
ODV3, 8,
ODV4, 8,
ODV5, 8,
UBCB, 32,
EMOD, 8,
WIFC, 8,
Offset (0x622),
TPLS, 8,
TPDB, 8,
TPDH, 16,
TPDS, 8,
ADPM, 32,
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,
RTVM, 8,
USTC, 8,
BATP, 8,
TSDB, 8,
DEPC, 8,
PDFC, 8,
IVCM, 8,
HEB1, 32,
RBY1, 8,
RBY2, 8,
SCSS, 8,
HAID, 8,
NCTC, 8,
NCTI, 8,
NCTH, 8,
HSIO, 8,
TPPT, 8,
SHAP, 8,
EIAP, 8,
ZPOD, 8,
SRSP, 32,
CEDS, 8,
EHK3, 8,
EHK4, 8,
EHK5, 8,
EHK6, 8,
EHK7, 8,
EHK8, 8,
VBVP, 8,
VBVD, 8,
VBHB, 8,
VBRL, 8,
SMSS, 8,
VBST, 8,
ADAS, 8,
PPBG, 32,
AEAB, 8,
AHDB, 8,
PBSD, 8,
DPLL, 8,
DPHL, 8,
PWIG, 8,
MESE, 8,
ICAT, 8,
ICPV, 8,
ICCR, 8,
ICC3, 8,
ICHT, 8,
XSMI, 32,
PAPE, 32,
PSTW, 32,
MWLR, 32,
UP8P, 32,
MS2R, 32,
MS2P, 32,
UCSI, 8,
UCG1, 32,
UCG2, 32,
WGUR, 32,
WRFE, 8,
WRC1, 8,
WRC2, 8,
WRC3, 8,
WRC4, 8,
AWVI, 32,
Offset (0x6E0),
WTSP, 8,
WGWS, 8,
PIDE, 8,
C0VE, 8,
C0W0, 8,
C0W1, 8,
C0W2, 8,
C0W3, 8,
C0W4, 8,
C0W5, 8,
C1VE, 8,
C1W0, 8,
C1W1, 8,
C1W2, 8,
C1W3, 8,
C1W4, 8,
C1W5, 8,
C2VE, 8,
C2W0, 8,
C2W1, 8,
C2W2, 8,
C2W3, 8,
C2W4, 8,
C2W5, 8,
C3VE, 8,
C3W0, 8,
C3W1, 8,
C3W2, 8,
C3W3, 8,
C3W4, 8,
C3W5, 8,
L0LE, 8,
L0PP, 8,
L0VR, 8,
L1LE, 8,
L1PP, 8,
L1VR, 8,
L2LE, 8,
L2PP, 8,
L2VR, 8,
L3LE, 8,
L3PP, 8,
L3VR, 8,
WLRP, 8,
SSRP, 8,
WIPR, 8,
TBS1, 8,
TBMP, 8,
FPA1, 8,
FPE1, 8,
FPG1, 32,
FP1L, 8,
CPD1, 16,
CPB1, 8,
CPG1, 32,
UTCM, 8,
USME, 8,
UPT1, 8,
UPT2, 8,
TWIN, 8,
TRWA, 8,
PWMG, 32,
PWRG, 32
}
Scope (\_SB)
{
Name (PR00, Package (0x21)
{
Package (0x04)
{
0x001FFFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x001FFFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0x001FFFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0x001FFFFF,
0x03,
LNKD,
0x00
},
Package (0x04)
{
0x001DFFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x001DFFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0x001DFFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0x001DFFFF,
0x03,
LNKD,
0x00
},
Package (0x04)
{
0x001CFFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x001CFFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0x001CFFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0x001CFFFF,
0x03,
LNKD,
0x00
},
Package (0x04)
{
0x001BFFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x001BFFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0x001BFFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0x001BFFFF,
0x03,
LNKD,
0x00
},
Package (0x04)
{
0x0017FFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x0016FFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x0016FFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0x0016FFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0x0016FFFF,
0x03,
LNKD,
0x00
},
Package (0x04)
{
0x0014FFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x0014FFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0x0014FFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0x0014FFFF,
0x03,
LNKD,
0x00
},
Package (0x04)
{
0x0001FFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x0001FFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0x0001FFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0x0001FFFF,
0x03,
LNKD,
0x00
},
Package (0x04)
{
0x0002FFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x0004FFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x0005FFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0x0008FFFF,
0x00,
LNKA,
0x00
}
})
Name (AR00, Package (0x2D)
{
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)
{
0x001EFFFF,
0x00,
0x00,
0x14
},
Package (0x04)
{
0x001EFFFF,
0x01,
0x00,
0x15
},
Package (0x04)
{
0x001EFFFF,
0x02,
0x00,
0x16
},
Package (0x04)
{
0x001EFFFF,
0x03,
0x00,
0x17
},
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)
{
0x001CFFFF,
0x00,
0x00,
0x10
},
Package (0x04)
{
0x001CFFFF,
0x01,
0x00,
0x11
},
Package (0x04)
{
0x001CFFFF,
0x02,
0x00,
0x12
},
Package (0x04)
{
0x001CFFFF,
0x03,
0x00,
0x13
},
Package (0x04)
{
0x001BFFFF,
0x00,
0x00,
0x10
},
Package (0x04)
{
0x001BFFFF,
0x01,
0x00,
0x11
},
Package (0x04)
{
0x001BFFFF,
0x02,
0x00,
0x12
},
Package (0x04)
{
0x001BFFFF,
0x03,
0x00,
0x13
},
Package (0x04)
{
0x0019FFFF,
0x00,
0x00,
0x20
},
Package (0x04)
{
0x0019FFFF,
0x01,
0x00,
0x21
},
Package (0x04)
{
0x0019FFFF,
0x02,
0x00,
0x22
},
Package (0x04)
{
0x0017FFFF,
0x00,
0x00,
0x10
},
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)
{
0x0015FFFF,
0x00,
0x00,
0x10
},
Package (0x04)
{
0x0015FFFF,
0x01,
0x00,
0x11
},
Package (0x04)
{
0x0015FFFF,
0x02,
0x00,
0x12
},
Package (0x04)
{
0x0015FFFF,
0x03,
0x00,
0x13
},
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)
{
0x0013FFFF,
0x00,
0x00,
0x14
},
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
}
})
Name (PR04, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKD,
0x00
}
})
Name (AR04, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x10
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x11
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x13
}
})
Name (PR05, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKB,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKD,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKA,
0x00
}
})
Name (AR05, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x11
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x13
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x10
}
})
Name (PR06, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKD,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKA,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKB,
0x00
}
})
Name (AR06, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x13
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x10
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x11
}
})
Name (PR07, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKD,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKA,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKB,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKC,
0x00
}
})
Name (AR07, 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
}
})
Name (PR08, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKD,
0x00
}
})
Name (AR08, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x10
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x11
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x13
}
})
Name (PR09, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKB,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKD,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKA,
0x00
}
})
Name (AR09, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x11
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x13
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x10
}
})
Name (PR0E, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKD,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKA,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKB,
0x00
}
})
Name (AR0E, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x13
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x10
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x11
}
})
Name (PR0F, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKD,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKA,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKB,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKC,
0x00
}
})
Name (AR0F, 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
}
})
Name (PR02, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKA,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKB,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKD,
0x00
}
})
Name (AR02, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x10
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x11
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x13
}
})
Name (PR0A, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKB,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKD,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKA,
0x00
}
})
Name (AR0A, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x11
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x13
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x10
}
})
Name (PR0B, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
LNKC,
0x00
},
Package (0x04)
{
0xFFFF,
0x01,
LNKD,
0x00
},
Package (0x04)
{
0xFFFF,
0x02,
LNKA,
0x00
},
Package (0x04)
{
0xFFFF,
0x03,
LNKB,
0x00
}
})
Name (AR0B, Package (0x04)
{
Package (0x04)
{
0xFFFF,
0x00,
0x00,
0x12
},
Package (0x04)
{
0xFFFF,
0x01,
0x00,
0x13
},
Package (0x04)
{
0xFFFF,
0x02,
0x00,
0x10
},
Package (0x04)
{
0xFFFF,
0x03,
0x00,
0x11
}
})
Name (PRSA, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, )
{3,4,5,6,10,11,12,14,15}
})
Alias (PRSA, PRSB)
Alias (PRSA, PRSC)
Alias (PRSA, PRSD)
Alias (PRSA, PRSE)
Alias (PRSA, PRSF)
Alias (PRSA, PRSG)
Alias (PRSA, PRSH)
Device (PCI0)
{
Name (_HID, EisaId ("PNP0A08") /* PCI Express Bus */) // _HID: Hardware ID
Name (_CID, EisaId ("PNP0A03") /* PCI Bus */) // _CID: Compatible ID
Name (_ADR, 0x00) // _ADR: Address
Method (^BN00, 0, NotSerialized)
{
Return (0x00)
}
Method (_BBN, 0, NotSerialized) // _BBN: BIOS Bus Number
{
Return (BN00 ())
}
Name (_UID, 0x00) // _UID: Unique ID
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR00 ())
}
Return (PR00 ())
}
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 (0x54),
D0EN, 1,
D1F2, 1,
D1F1, 1,
D1F0, 1,
Offset (0x60),
PXEN, 1,
PXSZ, 2,
, 23,
PXBR, 6,
Offset (0x68),
DIEN, 1,
, 11,
DIBR, 20,
Offset (0x70),
, 20,
MEBR, 12,
Offset (0x80),
PMLK, 1,
, 3,
PM0H, 2,
Offset (0x81),
PM1L, 2,
, 2,
PM1H, 2,
Offset (0x82),
PM2L, 2,
, 2,
PM2H, 2,
Offset (0x83),
PM3L, 2,
, 2,
PM3H, 2,
Offset (0x84),
PM4L, 2,
, 2,
PM4H, 2,
Offset (0x85),
PM5L, 2,
, 2,
PM5H, 2,
Offset (0x86),
PM6L, 2,
, 2,
PM6H, 2,
Offset (0x87),
Offset (0xA8),
, 20,
TUUD, 19,
Offset (0xBC),
, 20,
TLUD, 12,
Offset (0xC8),
, 7,
HTSE, 1
}
Name (BUF0, ResourceTemplate ()
{
WordBusNumber (ResourceProducer, MinFixed, MaxFixed, PosDecode,
0x0000, // Granularity
0x0000, // Range Minimum
0x00FF, // Range Maximum
0x0000, // Translation Offset
0x0100, // Length
,, _Y00)
DWordIO (ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange,
0x00000000, // Granularity
0x00000000, // Range Minimum
0x00000CF7, // Range Maximum
0x00000000, // Translation Offset
0x00000CF8, // Length
,, , TypeStatic, DenseTranslation)
IO (Decode16,
0x0CF8, // Range Minimum
0x0CF8, // Range Maximum
0x01, // Alignment
0x08, // Length
)
DWordIO (ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange,
0x00000000, // Granularity
0x00000D00, // Range Minimum
0x0000FFFF, // Range Maximum
0x00000000, // Translation Offset
0x0000F300, // 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
,, _Y01, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000C4000, // Range Minimum
0x000C7FFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y02, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000C8000, // Range Minimum
0x000CBFFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y03, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000CC000, // Range Minimum
0x000CFFFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y04, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000D0000, // Range Minimum
0x000D3FFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y05, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000D4000, // Range Minimum
0x000D7FFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y06, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000D8000, // Range Minimum
0x000DBFFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y07, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000DC000, // Range Minimum
0x000DFFFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y08, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000E0000, // Range Minimum
0x000E3FFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y09, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000E4000, // Range Minimum
0x000E7FFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y0A, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000E8000, // Range Minimum
0x000EBFFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y0B, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000EC000, // Range Minimum
0x000EFFFF, // Range Maximum
0x00000000, // Translation Offset
0x00004000, // Length
,, _Y0C, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
0x00000000, // Granularity
0x000F0000, // Range Minimum
0x000FFFFF, // Range Maximum
0x00000000, // Translation Offset
0x00010000, // Length
,, _Y0D, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, NonCacheable, ReadWrite,
0x00000000, // Granularity
0x00000000, // Range Minimum
0xDFFFFFFF, // Range Maximum
0x00000000, // Translation Offset
0xE0000000, // Length
,, _Y0E, AddressRangeMemory, TypeStatic)
QWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, NonCacheable, ReadWrite,
0x0000000000000000, // Granularity
0x0000000000010000, // Range Minimum
0x000000000001FFFF, // Range Maximum
0x0000000000000000, // Translation Offset
0x0000000000010000, // Length
,, _Y0F, AddressRangeMemory, TypeStatic)
DWordMemory (ResourceProducer, PosDecode, MinFixed, MaxFixed, NonCacheable, ReadWrite,
0x00000000, // Granularity
0xFD000000, // Range Minimum
0xFE7FFFFF, // Range Maximum
0x00000000, // Translation Offset
0x01800000, // Length
,, , AddressRangeMemory, TypeStatic)
})
If ((TLUD >= 0x0404))
{
Device (SRRE)
{
Name (_HID, EisaId ("PNP0C02") /* PNP Motherboard Resources */) // _HID: Hardware ID
Name (_UID, "SARESV") // _UID: Unique ID
Name (_STA, 0x03) // _STA: Status
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (BUF0, ResourceTemplate ()
{
Memory32Fixed (ReadOnly,
0x40000000, // Address Base
0x00400000, // Address Length
)
})
Return (BUF0) /* \_SB_.PCI0.SRRE._CRS.BUF0 */
}
}
}
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 ((EP_B == 0x00))
{
EP_B = (\_SB.PCI0.EPBR << 0x0C)
}
Return (EP_B) /* \_SB_.PCI0.EP_B */
}
Method (GMHB, 0, Serialized)
{
If ((MH_B == 0x00))
{
MH_B = (\_SB.PCI0.MHBR << 0x0F)
}
Return (MH_B) /* \_SB_.PCI0.MH_B */
}
Method (GPCB, 0, Serialized)
{
If ((PC_B == 0x00))
{
PC_B = (\_SB.PCI0.PXBR << 0x1A)
}
Return (PC_B) /* \_SB_.PCI0.PC_B */
}
Method (GPCL, 0, Serialized)
{
If ((PC_L == 0x00))
{
PC_L = (0x10000000 >> \_SB.PCI0.PXSZ)
}
Return (PC_L) /* \_SB_.PCI0.PC_L */
}
Method (GDMB, 0, Serialized)
{
If ((DM_B == 0x00))
{
DM_B = (\_SB.PCI0.DIBR << 0x0C)
}
Return (DM_B) /* \_SB_.PCI0.DM_B */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Local0 = \_SB.PCI0.GPCL ()
CreateWordField (BUF0, \_SB.PCI0._Y00._MAX, PBMX) // _MAX: Maximum Base Address
PBMX = ((Local0 >> 0x14) - 0x02)
CreateWordField (BUF0, \_SB.PCI0._Y00._LEN, PBLN) // _LEN: Length
PBLN = ((Local0 >> 0x14) - 0x01)
If (PM1L)
{
CreateDWordField (BUF0, \_SB.PCI0._Y01._LEN, C0LN) // _LEN: Length
C0LN = Zero
}
If ((PM1L == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y01._RW, C0RW) // _RW_: Read-Write Status
C0RW = Zero
}
If (PM1H)
{
CreateDWordField (BUF0, \_SB.PCI0._Y02._LEN, C4LN) // _LEN: Length
C4LN = Zero
}
If ((PM1H == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y02._RW, C4RW) // _RW_: Read-Write Status
C4RW = Zero
}
If (PM2L)
{
CreateDWordField (BUF0, \_SB.PCI0._Y03._LEN, C8LN) // _LEN: Length
C8LN = Zero
}
If ((PM2L == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y03._RW, C8RW) // _RW_: Read-Write Status
C8RW = Zero
}
If (PM2H)
{
CreateDWordField (BUF0, \_SB.PCI0._Y04._LEN, CCLN) // _LEN: Length
CCLN = Zero
}
If ((PM2H == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y04._RW, CCRW) // _RW_: Read-Write Status
CCRW = Zero
}
If (PM3L)
{
CreateDWordField (BUF0, \_SB.PCI0._Y05._LEN, D0LN) // _LEN: Length
D0LN = Zero
}
If ((PM3L == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y05._RW, D0RW) // _RW_: Read-Write Status
D0RW = Zero
}
If (PM3H)
{
CreateDWordField (BUF0, \_SB.PCI0._Y06._LEN, D4LN) // _LEN: Length
D4LN = Zero
}
If ((PM3H == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y06._RW, D4RW) // _RW_: Read-Write Status
D4RW = Zero
}
If (PM4L)
{
CreateDWordField (BUF0, \_SB.PCI0._Y07._LEN, D8LN) // _LEN: Length
D8LN = Zero
}
If ((PM4L == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y07._RW, D8RW) // _RW_: Read-Write Status
D8RW = Zero
}
If (PM4H)
{
CreateDWordField (BUF0, \_SB.PCI0._Y08._LEN, DCLN) // _LEN: Length
DCLN = Zero
}
If ((PM4H == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y08._RW, DCRW) // _RW_: Read-Write Status
DCRW = Zero
}
If (PM5L)
{
CreateDWordField (BUF0, \_SB.PCI0._Y09._LEN, E0LN) // _LEN: Length
E0LN = Zero
}
If ((PM5L == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y09._RW, E0RW) // _RW_: Read-Write Status
E0RW = Zero
}
If (PM5H)
{
CreateDWordField (BUF0, \_SB.PCI0._Y0A._LEN, E4LN) // _LEN: Length
E4LN = Zero
}
If ((PM5H == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y0A._RW, E4RW) // _RW_: Read-Write Status
E4RW = Zero
}
If (PM6L)
{
CreateDWordField (BUF0, \_SB.PCI0._Y0B._LEN, E8LN) // _LEN: Length
E8LN = Zero
}
If ((PM6L == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y0B._RW, E8RW) // _RW_: Read-Write Status
E8RW = Zero
}
If (PM6H)
{
CreateDWordField (BUF0, \_SB.PCI0._Y0C._LEN, ECLN) // _LEN: Length
ECLN = Zero
}
If ((PM6H == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y0C._RW, ECRW) // _RW_: Read-Write Status
ECRW = Zero
}
If (PM0H)
{
CreateDWordField (BUF0, \_SB.PCI0._Y0D._LEN, F0LN) // _LEN: Length
F0LN = Zero
}
If ((PM0H == 0x01))
{
CreateBitField (BUF0, \_SB.PCI0._Y0D._RW, F0RW) // _RW_: Read-Write Status
F0RW = Zero
}
CreateDWordField (BUF0, \_SB.PCI0._Y0E._MIN, M1MN) // _MIN: Minimum Base Address
CreateDWordField (BUF0, \_SB.PCI0._Y0E._MAX, M1MX) // _MAX: Maximum Base Address
CreateDWordField (BUF0, \_SB.PCI0._Y0E._LEN, M1LN) // _LEN: Length
M1LN = M32L /* External reference */
M1MN = M32B /* External reference */
M1MX = ((M1MN + M1LN) - 0x01)
If ((M64L == 0x00))
{
CreateQWordField (BUF0, \_SB.PCI0._Y0F._LEN, MSLN) // _LEN: Length
MSLN = 0x00
}
Else
{
CreateQWordField (BUF0, \_SB.PCI0._Y0F._LEN, M2LN) // _LEN: Length
CreateQWordField (BUF0, \_SB.PCI0._Y0F._MIN, M2MN) // _MIN: Minimum Base Address
CreateQWordField (BUF0, \_SB.PCI0._Y0F._MAX, M2MX) // _MAX: Maximum Base Address
M2LN = M64L /* External reference */
M2MN = M64B /* External reference */
M2MX = ((M2MN + M2LN) - 0x01)
}
Return (BUF0) /* \_SB_.PCI0.BUF0 */
}
Name (GUID, ToUUID ("33db4d5b-1ff7-401c-9657-7441c03dd766") /* PCI Host Bridge Device */)
Name (SUPP, 0x00)
Name (CTRL, 0x00)
Name (XCNT, 0x00)
Method (_OSC, 4, Serialized) // _OSC: Operating System Capabilities
{
Local0 = Arg3
CreateDWordField (Local0, 0x00, CDW1)
CreateDWordField (Local0, 0x04, CDW2)
CreateDWordField (Local0, 0x08, CDW3)
If ((Arg0 == GUID))
{
SUPP = CDW2 /* \_SB_.PCI0._OSC.CDW2 */
CTRL = CDW3 /* \_SB_.PCI0._OSC.CDW3 */
If ((NEXP == 0x00))
{
CTRL &= 0xFFFFFFE0
}
ElseIf ((TBTS == 0x01))
{
CTRL &= 0xFFFFFFF7
}
If (~(CDW1 & 0x01))
{
If ((CTRL & 0x01))
{
NHPG ()
}
If ((CTRL & 0x04))
{
NPME ()
}
}
If ((Arg1 != One))
{
CDW1 |= 0x08
}
If ((CDW3 != CTRL))
{
CDW1 |= 0x10
}
CDW3 = CTRL /* \_SB_.PCI0.CTRL */
OSCC = CTRL /* \_SB_.PCI0.CTRL */
Return (Local0)
}
Else
{
CDW1 |= 0x04
Return (Local0)
}
}
Scope (\_SB.PCI0)
{
Method (AR00, 0, NotSerialized)
{
Return (\_SB.AR00)
}
Method (PR00, 0, NotSerialized)
{
Return (\_SB.PR00)
}
Method (AR02, 0, NotSerialized)
{
Return (\_SB.AR02)
}
Method (PR02, 0, NotSerialized)
{
Return (\_SB.PR02)
}
Method (AR04, 0, NotSerialized)
{
Return (\_SB.AR04)
}
Method (PR04, 0, NotSerialized)
{
Return (\_SB.PR04)
}
Method (AR05, 0, NotSerialized)
{
Return (\_SB.AR05)
}
Method (PR05, 0, NotSerialized)
{
Return (\_SB.PR05)
}
Method (AR06, 0, NotSerialized)
{
Return (\_SB.AR06)
}
Method (PR06, 0, NotSerialized)
{
Return (\_SB.PR06)
}
Method (AR07, 0, NotSerialized)
{
Return (\_SB.AR07)
}
Method (PR07, 0, NotSerialized)
{
Return (\_SB.PR07)
}
Method (AR08, 0, NotSerialized)
{
Return (\_SB.AR08)
}
Method (PR08, 0, NotSerialized)
{
Return (\_SB.PR08)
}
Method (AR09, 0, NotSerialized)
{
Return (\_SB.AR09)
}
Method (PR09, 0, NotSerialized)
{
Return (\_SB.PR09)
}
Method (AR0A, 0, NotSerialized)
{
Return (\_SB.AR0A)
}
Method (PR0A, 0, NotSerialized)
{
Return (\_SB.PR0A)
}
Method (AR0B, 0, NotSerialized)
{
Return (\_SB.AR0B)
}
Method (PR0B, 0, NotSerialized)
{
Return (\_SB.PR0B)
}
Device (PEG0)
{
Name (_ADR, 0x00010000) // _ADR: Address
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
}
Device (B0D4)
{
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Name (_ADR, 0x00040000) // _ADR: Address
}
Device (ISP0)
{
Name (_ADR, 0x00050000) // _ADR: Address
}
}
}
}
If ((ECR1 == 0x01))
{
Scope (\_SB.PCI0)
{
Name (PCIG, ToUUID ("e5c937d0-3553-4d7a-9117-ea4d19c3434d") /* Device Labeling Interface */)
Method (PCID, 4, Serialized)
{
If ((Arg0 == PCIG))
{
If ((Arg1 >= 0x03))
{
If ((Arg2 == 0x00))
{
Return (Buffer (0x02)
{
0x01, 0x03 // ..
})
}
If ((Arg2 == 0x08))
{
Return (0x01)
}
If ((Arg2 == 0x09))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
Scope (\_SB.PCI0)
{
Method (PCIC, 1, Serialized)
{
If ((ECR1 == 0x01))
{
If ((Arg0 == PCIG))
{
Return (0x01)
}
}
Return (0x00)
}
}
Name (PNVB, 0xBFF5F018)
Name (PNVL, 0x0287)
OperationRegion (PNVA, SystemMemory, PNVB, PNVL)
Field (PNVA, AnyAcc, Lock, Preserve)
{
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,
RPAL, 32,
RPAM, 32,
RPAN, 32,
RPAO, 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,
PMLL, 16,
PMLM, 16,
PMLN, 16,
PMLO, 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,
PNLL, 16,
PNLM, 16,
PNLN, 16,
PNLO, 16,
U0C0, 32,
U1C0, 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, 64,
SB01, 64,
SB02, 64,
SB03, 64,
SB04, 64,
SB05, 64,
SB06, 64,
SB07, 64,
SB08, 64,
SB09, 64,
SB0A, 64,
SB10, 64,
SB11, 64,
SB12, 64,
SB13, 64,
SB14, 64,
SB15, 64,
SB16, 64,
SB17, 64,
SB18, 64,
SB19, 64,
SB1A, 64,
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,
NRP1, 32,
NRP2, 32,
NRP3, 32,
Offset (0x262),
SXRB, 32,
SXRS, 32,
CIOE, 8,
CIOI, 8,
TAEN, 8,
TIRQ, 8,
XWMB, 32,
EMH4, 8,
EMDS, 8,
CSKU, 8,
ITA0, 16,
ITA1, 16,
ITA2, 16,
ITA3, 16,
ITS0, 8,
ITS1, 8,
ITS2, 8,
ITS3, 8,
PMBS, 16,
PWRM, 32
}
Scope (\_SB)
{
Name (GPCL, Package (0x08)
{
Package (0x06)
{
0x00AF0000,
0x18,
0x0400,
0xD0,
0x20,
0x0140
},
Package (0x06)
{
0x00AF0000,
0x18,
0x04C0,
0xD4,
0x30,
0x0144
},
Package (0x06)
{
0x00AE0000,
0x18,
0x0400,
0xD0,
0x20,
0x0140
},
Package (0x06)
{
0x00AE0000,
0x18,
0x04C0,
0xD4,
0x30,
0x0144
},
Package (0x06)
{
0x00AE0000,
0x18,
0x0580,
0xD8,
0x40,
0x0148
},
Package (0x06)
{
0x00AC0000,
0x18,
0x0400,
0xD0,
0x20,
0x0140
},
Package (0x06)
{
0x00AC0000,
0x08,
0x04C0,
0xD4,
0x30,
0x0144
},
Package (0x06)
{
0x00AD0000,
0x0C,
0x0400,
0xD0,
0x20,
0x0140
}
})
Name (GPCH, Package (0x0A)
{
Package (0x06)
{
0x00AF0000,
0x18,
0x0400,
0xD0,
0x20,
0x0140
},
Package (0x06)
{
0x00AF0000,
0x18,
0x04C0,
0xD4,
0x2C,
0x0144
},
Package (0x06)
{
0x00AE0000,
0x18,
0x0400,
0xD0,
0x20,
0x0140
},
Package (0x06)
{
0x00AE0000,
0x18,
0x04C0,
0xD4,
0x2C,
0x0144
},
Package (0x06)
{
0x00AE0000,
0x0D,
0x0580,
0xD8,
0x38,
0x0148
},
Package (0x06)
{
0x00AE0000,
0x18,
0x05E8,
0xDC,
0x40,
0x014C
},
Package (0x06)
{
0x00AE0000,
0x18,
0x06A8,
0xE0,
0x4C,
0x0150
},
Package (0x06)
{
0x00AE0000,
0x18,
0x0768,
0xE4,
0x58,
0x0154
},
Package (0x06)
{
0x00AC0000,
0x0B,
0x0400,
0xD0,
0x20,
0x0140
},
Package (0x06)
{
0x00AD0000,
0x0C,
0x0400,
0xD0,
0x20,
0x0140
}
})
Name (RXEV, Package (0x0A)
{
Buffer (0x18){},
Buffer (0x18){},
Buffer (0x18){},
Buffer (0x18){},
Buffer (0x18){},
Buffer (0x18){},
Buffer (0x18){},
Buffer (0x18){},
Buffer (0x0B){},
Buffer (0x0C){}
})
}
Scope (\_SB)
{
Method (GINF, 2, NotSerialized)
{
If ((PCHS == SPTL))
{
Return (DerefOf (DerefOf (GPCL [Arg0]) [Arg1]))
}
Else
{
Return (DerefOf (DerefOf (GPCH [Arg0]) [Arg1]))
}
}
Method (GMXG, 0, NotSerialized)
{
If ((PCHS == SPTL))
{
Return (0x08)
}
Else
{
Return (0x0A)
}
}
Method (GADR, 2, NotSerialized)
{
Local0 = (GINF (Arg0, 0x00) + SBRG)
Local1 = GINF (Arg0, Arg1)
Return ((Local0 + Local1))
}
Method (GNUM, 1, NotSerialized)
{
Local0 = GNMB (Arg0)
Local1 = GGRP (Arg0)
Return ((Local0 + (Local1 * 0x18)))
}
Method (INUM, 1, NotSerialized)
{
Local1 = GNMB (Arg0)
Local2 = GGRP (Arg0)
Local3 = 0x00
While ((Local3 < Local2))
{
Local1 += GINF (Local3, 0x01)
Local3++
}
Return ((0x18 + (Local1 % 0x60)))
}
Method (GGRP, 1, Serialized)
{
Local0 = ((Arg0 & 0x00FF0000) >> 0x10)
Return (Local0)
}
Method (GNMB, 1, Serialized)
{
Return ((Arg0 & 0xFFFF))
}
Method (GGPE, 1, NotSerialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
If ((((GPEM >> (Local0 * 0x02)) & 0x03) ==
0x00))
{
Return (0x6F)
}
Else
{
Local2 = ((GPEM >> (Local0 * 0x02)) & 0x03)
Return ((((Local2 - 0x01) * 0x20) + Local1))
}
}
Method (GPC0, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
TEMP, 32
}
Return (TEMP) /* \_SB_.GPC0.TEMP */
}
Method (SPC0, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
TEMP, 32
}
TEMP = Arg1
}
Method (GPC1, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = ((GADR (Local0, 0x02) + (Local1 * 0x08)) +
0x04)
OperationRegion (PDW1, SystemMemory, Local2, 0x04)
Field (PDW1, AnyAcc, NoLock, Preserve)
{
TEMP, 32
}
Return (TEMP) /* \_SB_.GPC1.TEMP */
}
Method (SPC1, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = ((GADR (Local0, 0x02) + (Local1 * 0x08)) +
0x04)
OperationRegion (PDW1, SystemMemory, Local2, 0x04)
Field (PDW1, AnyAcc, NoLock, Preserve)
{
TEMP, 32
}
TEMP = Arg1
}
Method (SRXO, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 28,
TEMP, 1,
Offset (0x04)
}
TEMP = Arg1
}
Method (GGIV, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 1,
TEMP, 1,
Offset (0x04)
}
Return (TEMP) /* \_SB_.GGIV.TEMP */
}
Method (GGOV, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
TEMP, 1,
Offset (0x04)
}
Return (TEMP) /* \_SB_.GGOV.TEMP */
}
Method (SGOV, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
TEMP, 1,
Offset (0x04)
}
TEMP = Arg1
}
Method (GGII, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 23,
TEMP, 1,
Offset (0x04)
}
Return (TEMP) /* \_SB_.GGII.TEMP */
}
Method (SGII, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 23,
TEMP, 1,
Offset (0x04)
}
TEMP = Arg1
}
Method (GPMV, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 10,
TEMP, 3,
Offset (0x04)
}
Return (TEMP) /* \_SB_.GPMV.TEMP */
}
Method (SPMV, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 10,
TEMP, 3,
Offset (0x04)
}
TEMP = Arg1
}
Method (GHPO, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local3 = (GADR (Local0, 0x03) + ((Local1 >> 0x05) * 0x04))
Local4 = (Local1 & 0x1F)
OperationRegion (PREG, SystemMemory, Local3, 0x04)
Field (PREG, AnyAcc, NoLock, Preserve)
{
TEMP, 32
}
Return (((TEMP >> Local4) & 0x01))
}
Method (SHPO, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local3 = (GADR (Local0, 0x03) + ((Local1 >> 0x05) * 0x04))
Local4 = (Local1 & 0x1F)
OperationRegion (PREG, SystemMemory, Local3, 0x04)
Field (PREG, AnyAcc, NoLock, Preserve)
{
TEMP, 32
}
If (Arg1)
{
TEMP |= (0x01 << Local4)
}
Else
{
TEMP &= ~(0x01 << Local4)
}
}
Method (GGPO, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x04) + ((Local1 >> 0x03) * 0x04
))
OperationRegion (PREG, SystemMemory, Local2, 0x04)
Field (PREG, AnyAcc, NoLock, Preserve)
{
TEMP, 32
}
Return (((TEMP >> ((Local1 & 0x07) * 0x04)) &
0x03))
}
Method (SGRA, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 20,
TEMP, 1,
Offset (0x04)
}
TEMP = Arg1
}
Method (SGWP, 2, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = ((GADR (Local0, 0x02) + (Local1 * 0x08)) +
0x04)
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 10,
TEMP, 4,
Offset (0x04)
}
TEMP = Arg1
}
Method (UGPS, 0, Serialized)
{
}
Method (CGPS, 0, Serialized)
{
}
Method (CGLS, 0, Serialized)
{
}
Method (CAGS, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local4 = ((Local1 >> 0x05) * 0x04)
If ((((GPEM >> (Local0 * 0x02)) & 0x03) ==
0x00))
{
OperationRegion (GPPX, SystemMemory, (GADR (Local0, 0x05) + Local4), 0x04)
Field (GPPX, AnyAcc, NoLock, Preserve)
{
STSX, 32
}
Local2 = (0x01 << (Local1 % 0x20))
STSX = Local2
}
}
Method (ISME, 1, NotSerialized)
{
If ((((GPEM >> (Arg0 * 0x02)) & 0x03
) != 0x00))
{
Return (0x00)
}
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x05) + ((Local1 >> 0x05) * 0x04))
Local3 = (Local1 & 0x1F)
OperationRegion (GPPX, SystemMemory, Local2, 0x24)
Field (GPPX, AnyAcc, NoLock, Preserve)
{
STSX, 32,
Offset (0x20),
GENX, 32
}
Return ((((STSX & GENX) >> Local3) & 0x01))
}
Method (DIPI, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 9,
RDIS, 1,
, 15,
RCFG, 2,
Offset (0x04)
}
If ((RCFG != 0x02))
{
DerefOf (RXEV [Local0]) [Local1] = RCFG /* \_SB_.DIPI.RCFG */
RCFG = 0x02
RDIS = 0x01
}
}
Method (UIPI, 1, Serialized)
{
Local0 = GGRP (Arg0)
Local1 = GNMB (Arg0)
Local2 = (GADR (Local0, 0x02) + (Local1 * 0x08))
OperationRegion (PDW0, SystemMemory, Local2, 0x04)
Field (PDW0, AnyAcc, NoLock, Preserve)
{
, 9,
RDIS, 1,
, 15,
RCFG, 2,
Offset (0x04)
}
Local3 = DerefOf (DerefOf (RXEV [Local0]) [Local1])
If ((Local3 != 0x02))
{
RDIS = 0x00
RCFG = Local3
}
}
}
Scope (\)
{
Method (THEN, 0, Serialized)
{
OperationRegion (THBA, SystemMemory, 0xFE200000, 0x10)
Field (THBA, DWordAcc, NoLock, Preserve)
{
DO00, 32
}
Return ((DO00 != 0xFFFFFFFF))
}
Method (THDA, 2, Serialized)
{
Local0 = 0xFE200000
Local0 += (0x40 * (0x80 * (Arg0 - 0x20)))
Local0 += (0x40 * Arg1)
Return (Local0)
}
Method (STRD, 3, Serialized)
{
If (((Arg1 + Arg2) > SizeOf (Arg0)))
{
Return (0x00)
}
ToBuffer (Arg0, Local3)
Local0 = 0x00
Local1 = 0x00
While ((Local1 < Arg2))
{
Local2 = DerefOf (Local3 [(Arg1 + Local1)])
Local0 += (Local2 << (0x08 * Local1))
Local1++
}
Return (Local0)
}
Method (THDS, 1, Serialized)
{
If (!THEN ())
{
Return (Zero)
}
Concatenate (Arg0, "\n", Local2)
Local0 = SizeOf (Local2)
Local1 = THDA (0x20, 0x16)
OperationRegion (THBA, SystemMemory, Local1, 0x40)
Field (THBA, QWordAcc, NoLock, Preserve)
{
QO00, 64
}
Field (THBA, DWordAcc, NoLock, Preserve)
{
DO00, 32,
Offset (0x10),
DO10, 32,
Offset (0x30),
DO30, 32
}
Field (THBA, WordAcc, NoLock, Preserve)
{
WO00, 16
}
Field (THBA, ByteAcc, NoLock, Preserve)
{
BO00, 8
}
DO10 = 0x01000242
WO00 = Local0
Local6 = 0x00
Local7 = Local0
While ((Local7 >= 0x08))
{
QO00 = STRD (Local2, Local6, 0x08)
Local6 += 0x08
Local7 -= 0x08
}
If ((Local7 >= 0x04))
{
DO00 = STRD (Local2, Local6, 0x04)
Local6 += 0x04
Local7 -= 0x04
}
If ((Local7 >= 0x02))
{
WO00 = STRD (Local2, Local6, 0x02)
Local6 += 0x02
Local7 -= 0x02
}
If ((Local7 >= 0x01))
{
BO00 = STRD (Local2, Local6, 0x01)
Local6 += 0x01
Local7 -= 0x01
}
DO30 = 0x00
}
Method (THDH, 1, Serialized)
{
THDS (ToHexString (Arg0))
}
Method (THDD, 1, Serialized)
{
THDS (ToDecimalString (Arg0))
}
}
Name (SPTH, 0x01)
Name (SPTL, 0x02)
Method (PCHV, 0, NotSerialized)
{
If ((PCHS == 0x01))
{
Return (SPTH) /* \SPTH */
}
If ((PCHS == 0x02))
{
Return (SPTL) /* \SPTL */
}
Return (0x00)
}
Scope (\_GPE)
{
Method (_L6D, 0, Serialized) // _Lxx: Level-Triggered GPE, xx=0x00-0xFF
{
\_SB.PCI0.XHC.GPEH ()
\_SB.PCI0.HDAS.GPEH ()
\_SB.PCI0.GLAN.GPEH ()
\_SB.PCI0.XDCI.GPEH ()
}
}
Scope (\_SB.PCI0)
{
Name (TEMP, 0x00)
Device (PRRE)
{
Name (_HID, EisaId ("PNP0C02") /* PNP Motherboard Resources */) // _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) /* \_SB_.PCI0.PRRE._CRS.BUF0 */
}
}
Device (IOTR)
{
Name (_HID, EisaId ("PNP0C02") /* PNP Motherboard Resources */) // _HID: Hardware ID
Name (_UID, "IoTraps") // _UID: Unique ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
Name (BUF0, ResourceTemplate ()
{
IO (Decode16,
0x0000, // Range Minimum
0x0000, // Range Maximum
0x01, // Alignment
0xFF, // Length
_Y10)
})
Name (BUF1, ResourceTemplate ()
{
IO (Decode16,
0x0000, // Range Minimum
0x0000, // Range Maximum
0x01, // Alignment
0xFF, // Length
_Y11)
})
Name (BUF2, ResourceTemplate ()
{
IO (Decode16,
0x0000, // Range Minimum
0x0000, // Range Maximum
0x01, // Alignment
0xFF, // Length
_Y12)
})
Name (BUF3, ResourceTemplate ()
{
IO (Decode16,
0x0000, // Range Minimum
0x0000, // Range Maximum
0x01, // Alignment
0xFF, // Length
_Y13)
})
CreateWordField (BUF0, \_SB.PCI0.IOTR._CRS._Y10._MIN, AMI0) // _MIN: Minimum Base Address
CreateWordField (BUF0, \_SB.PCI0.IOTR._CRS._Y10._MAX, AMA0) // _MAX: Maximum Base Address
CreateWordField (BUF1, \_SB.PCI0.IOTR._CRS._Y11._MIN, AMI1) // _MIN: Minimum Base Address
CreateWordField (BUF1, \_SB.PCI0.IOTR._CRS._Y11._MAX, AMA1) // _MAX: Maximum Base Address
CreateWordField (BUF2, \_SB.PCI0.IOTR._CRS._Y12._MIN, AMI2) // _MIN: Minimum Base Address
CreateWordField (BUF2, \_SB.PCI0.IOTR._CRS._Y12._MAX, AMA2) // _MAX: Maximum Base Address
CreateWordField (BUF3, \_SB.PCI0.IOTR._CRS._Y13._MIN, AMI3) // _MIN: Minimum Base Address
CreateWordField (BUF3, \_SB.PCI0.IOTR._CRS._Y13._MAX, AMA3) // _MAX: Maximum Base Address
AMI0 = ITA0 /* \ITA0 */
AMA0 = ITA0 /* \ITA0 */
AMI1 = ITA1 /* \ITA1 */
AMA1 = ITA1 /* \ITA1 */
AMI2 = ITA2 /* \ITA2 */
AMA2 = ITA2 /* \ITA2 */
AMI3 = ITA3 /* \ITA3 */
AMA3 = ITA3 /* \ITA3 */
If ((ITS0 == 0x01))
{
ConcatenateResTemplate (Local0, BUF0, Local1)
Local0 = Local1
}
If ((ITS1 == 0x01))
{
ConcatenateResTemplate (Local0, BUF1, Local1)
Local0 = Local1
}
If ((ITS2 == 0x01))
{
ConcatenateResTemplate (Local0, BUF2, Local1)
Local0 = Local1
}
If ((ITS3 == 0x01))
{
ConcatenateResTemplate (Local0, BUF3, Local1)
Local0 = Local1
}
Return (Local0)
}
}
Device (LPCB)
{
Name (_ADR, 0x001F0000) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
OperationRegion (LPC, PCI_Config, 0x00, 0x0100)
Field (LPC, AnyAcc, NoLock, Preserve)
{
Offset (0x02),
CDID, 16,
Offset (0x08),
CRID, 8,
Offset (0x80),
IOD0, 8,
IOD1, 8,
Offset (0xA0),
, 9,
PRBL, 1,
Offset (0xDC),
, 2,
ESPI, 1
}
}
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 (Buffer (0x01)
{
0x00 // .
})
}
}
Device (SBUS)
{
Name (_ADR, 0x001F0004) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
Scope (\_SB)
{
Device (LNKA)
{
Name (_HID, EisaId ("PNP0C0F") /* PCI Interrupt Link Device */) // _HID: Hardware ID
Name (_UID, 0x01) // _UID: Unique ID
Method (_DIS, 0, Serialized) // _DIS: Disable Device
{
\_SB.PARC |= 0x80
}
Method (_PRS, 0, Serialized) // _PRS: Possible Resource Settings
{
Return (PRSA) /* \_SB_.PRSA */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (RTLA, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, _Y14)
{}
})
CreateWordField (RTLA, \_SB.LNKA._CRS._Y14._INT, IRQ0) // _INT: Interrupts
IRQ0 = Zero
IRQ0 = (0x01 << (\_SB.PARC & 0x0F))
Return (RTLA) /* \_SB_.LNKA._CRS.RTLA */
}
Method (_SRS, 1, Serialized) // _SRS: Set Resource Settings
{
CreateWordField (Arg0, 0x01, IRQ0)
FindSetRightBit (IRQ0, Local0)
Local0--
\_SB.PARC = Local0
}
Method (_STA, 0, Serialized) // _STA: Status
{
If ((\_SB.PARC & 0x80))
{
Return (0x09)
}
Else
{
Return (0x0B)
}
}
}
Device (LNKB)
{
Name (_HID, EisaId ("PNP0C0F") /* PCI Interrupt Link Device */) // _HID: Hardware ID
Name (_UID, 0x02) // _UID: Unique ID
Method (_DIS, 0, Serialized) // _DIS: Disable Device
{
\_SB.PBRC |= 0x80
}
Method (_PRS, 0, Serialized) // _PRS: Possible Resource Settings
{
Return (PRSB) /* \_SB_.PRSB */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (RTLB, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, _Y15)
{}
})
CreateWordField (RTLB, \_SB.LNKB._CRS._Y15._INT, IRQ0) // _INT: Interrupts
IRQ0 = Zero
IRQ0 = (0x01 << (\_SB.PBRC & 0x0F))
Return (RTLB) /* \_SB_.LNKB._CRS.RTLB */
}
Method (_SRS, 1, Serialized) // _SRS: Set Resource Settings
{
CreateWordField (Arg0, 0x01, IRQ0)
FindSetRightBit (IRQ0, Local0)
Local0--
\_SB.PBRC = Local0
}
Method (_STA, 0, Serialized) // _STA: Status
{
If ((\_SB.PBRC & 0x80))
{
Return (0x09)
}
Else
{
Return (0x0B)
}
}
}
Device (LNKC)
{
Name (_HID, EisaId ("PNP0C0F") /* PCI Interrupt Link Device */) // _HID: Hardware ID
Name (_UID, 0x03) // _UID: Unique ID
Method (_DIS, 0, Serialized) // _DIS: Disable Device
{
\_SB.PCRC |= 0x80
}
Method (_PRS, 0, Serialized) // _PRS: Possible Resource Settings
{
Return (PRSC) /* \_SB_.PRSC */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (RTLC, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, _Y16)
{}
})
CreateWordField (RTLC, \_SB.LNKC._CRS._Y16._INT, IRQ0) // _INT: Interrupts
IRQ0 = Zero
IRQ0 = (0x01 << (\_SB.PCRC & 0x0F))
Return (RTLC) /* \_SB_.LNKC._CRS.RTLC */
}
Method (_SRS, 1, Serialized) // _SRS: Set Resource Settings
{
CreateWordField (Arg0, 0x01, IRQ0)
FindSetRightBit (IRQ0, Local0)
Local0--
\_SB.PCRC = Local0
}
Method (_STA, 0, Serialized) // _STA: Status
{
If ((\_SB.PCRC & 0x80))
{
Return (0x09)
}
Else
{
Return (0x0B)
}
}
}
Device (LNKD)
{
Name (_HID, EisaId ("PNP0C0F") /* PCI Interrupt Link Device */) // _HID: Hardware ID
Name (_UID, 0x04) // _UID: Unique ID
Method (_DIS, 0, Serialized) // _DIS: Disable Device
{
\_SB.PDRC |= 0x80
}
Method (_PRS, 0, Serialized) // _PRS: Possible Resource Settings
{
Return (PRSD) /* \_SB_.PRSD */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (RTLD, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, _Y17)
{}
})
CreateWordField (RTLD, \_SB.LNKD._CRS._Y17._INT, IRQ0) // _INT: Interrupts
IRQ0 = Zero
IRQ0 = (0x01 << (\_SB.PDRC & 0x0F))
Return (RTLD) /* \_SB_.LNKD._CRS.RTLD */
}
Method (_SRS, 1, Serialized) // _SRS: Set Resource Settings
{
CreateWordField (Arg0, 0x01, IRQ0)
FindSetRightBit (IRQ0, Local0)
Local0--
\_SB.PDRC = Local0
}
Method (_STA, 0, Serialized) // _STA: Status
{
If ((\_SB.PDRC & 0x80))
{
Return (0x09)
}
Else
{
Return (0x0B)
}
}
}
Device (LNKE)
{
Name (_HID, EisaId ("PNP0C0F") /* PCI Interrupt Link Device */) // _HID: Hardware ID
Name (_UID, 0x05) // _UID: Unique ID
Method (_DIS, 0, Serialized) // _DIS: Disable Device
{
\_SB.PERC |= 0x80
}
Method (_PRS, 0, Serialized) // _PRS: Possible Resource Settings
{
Return (PRSE) /* \_SB_.PRSE */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (RTLE, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, _Y18)
{}
})
CreateWordField (RTLE, \_SB.LNKE._CRS._Y18._INT, IRQ0) // _INT: Interrupts
IRQ0 = Zero
IRQ0 = (0x01 << (\_SB.PERC & 0x0F))
Return (RTLE) /* \_SB_.LNKE._CRS.RTLE */
}
Method (_SRS, 1, Serialized) // _SRS: Set Resource Settings
{
CreateWordField (Arg0, 0x01, IRQ0)
FindSetRightBit (IRQ0, Local0)
Local0--
\_SB.PERC = Local0
}
Method (_STA, 0, Serialized) // _STA: Status
{
If ((\_SB.PERC & 0x80))
{
Return (0x09)
}
Else
{
Return (0x0B)
}
}
}
Device (LNKF)
{
Name (_HID, EisaId ("PNP0C0F") /* PCI Interrupt Link Device */) // _HID: Hardware ID
Name (_UID, 0x06) // _UID: Unique ID
Method (_DIS, 0, Serialized) // _DIS: Disable Device
{
\_SB.PFRC |= 0x80
}
Method (_PRS, 0, Serialized) // _PRS: Possible Resource Settings
{
Return (PRSF) /* \_SB_.PRSF */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (RTLF, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, _Y19)
{}
})
CreateWordField (RTLF, \_SB.LNKF._CRS._Y19._INT, IRQ0) // _INT: Interrupts
IRQ0 = Zero
IRQ0 = (0x01 << (\_SB.PFRC & 0x0F))
Return (RTLF) /* \_SB_.LNKF._CRS.RTLF */
}
Method (_SRS, 1, Serialized) // _SRS: Set Resource Settings
{
CreateWordField (Arg0, 0x01, IRQ0)
FindSetRightBit (IRQ0, Local0)
Local0--
\_SB.PFRC = Local0
}
Method (_STA, 0, Serialized) // _STA: Status
{
If ((\_SB.PFRC & 0x80))
{
Return (0x09)
}
Else
{
Return (0x0B)
}
}
}
Device (LNKG)
{
Name (_HID, EisaId ("PNP0C0F") /* PCI Interrupt Link Device */) // _HID: Hardware ID
Name (_UID, 0x07) // _UID: Unique ID
Method (_DIS, 0, Serialized) // _DIS: Disable Device
{
\_SB.PGRC |= 0x80
}
Method (_PRS, 0, Serialized) // _PRS: Possible Resource Settings
{
Return (PRSG) /* \_SB_.PRSG */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (RTLG, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, _Y1A)
{}
})
CreateWordField (RTLG, \_SB.LNKG._CRS._Y1A._INT, IRQ0) // _INT: Interrupts
IRQ0 = Zero
IRQ0 = (0x01 << (\_SB.PGRC & 0x0F))
Return (RTLG) /* \_SB_.LNKG._CRS.RTLG */
}
Method (_SRS, 1, Serialized) // _SRS: Set Resource Settings
{
CreateWordField (Arg0, 0x01, IRQ0)
FindSetRightBit (IRQ0, Local0)
Local0--
\_SB.PGRC = Local0
}
Method (_STA, 0, Serialized) // _STA: Status
{
If ((\_SB.PGRC & 0x80))
{
Return (0x09)
}
Else
{
Return (0x0B)
}
}
}
Device (LNKH)
{
Name (_HID, EisaId ("PNP0C0F") /* PCI Interrupt Link Device */) // _HID: Hardware ID
Name (_UID, 0x08) // _UID: Unique ID
Method (_DIS, 0, Serialized) // _DIS: Disable Device
{
\_SB.PHRC |= 0x80
}
Method (_PRS, 0, Serialized) // _PRS: Possible Resource Settings
{
Return (PRSH) /* \_SB_.PRSH */
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (RTLH, ResourceTemplate ()
{
IRQ (Level, ActiveLow, Shared, _Y1B)
{}
})
CreateWordField (RTLH, \_SB.LNKH._CRS._Y1B._INT, IRQ0) // _INT: Interrupts
IRQ0 = Zero
IRQ0 = (0x01 << (\_SB.PHRC & 0x0F))
Return (RTLH) /* \_SB_.LNKH._CRS.RTLH */
}
Method (_SRS, 1, Serialized) // _SRS: Set Resource Settings
{
CreateWordField (Arg0, 0x01, IRQ0)
FindSetRightBit (IRQ0, Local0)
Local0--
\_SB.PHRC = Local0
}
Method (_STA, 0, Serialized) // _STA: Status
{
If ((\_SB.PHRC & 0x80))
{
Return (0x09)
}
Else
{
Return (0x0B)
}
}
}
}
Scope (\)
{
Method (PCRR, 2, Serialized)
{
Local0 = ((Arg0 << 0x10) + Arg1)
Local0 += SBRG
OperationRegion (PCR0, SystemMemory, Local0, 0x04)
Field (PCR0, DWordAcc, Lock, Preserve)
{
DAT0, 32
}
Return (DAT0) /* \PCRR.DAT0 */
}
Method (PCRW, 3, Serialized)
{
Local0 = ((Arg0 << 0x10) + Arg1)
Local0 += SBRG
OperationRegion (PCR0, SystemMemory, Local0, 0x04)
Field (PCR0, DWordAcc, Lock, Preserve)
{
DAT0, 32
}
DAT0 = Arg2
Local0 = PCRR (0xC7, 0x3418)
}
Method (PCRO, 3, Serialized)
{
Local0 = PCRR (Arg0, Arg1)
Local1 = (Local0 | Arg2)
PCRW (Arg0, Arg1, Local1)
}
Method (PCRA, 3, Serialized)
{
Local0 = PCRR (Arg0, Arg1)
Local1 = (Local0 & Arg2)
PCRW (Arg0, Arg1, Local1)
}
Method (PCAO, 4, Serialized)
{
Local0 = PCRR (Arg0, Arg1)
Local1 = ((Local0 & Arg2) | Arg3)
PCRW (Arg0, Arg1, Local1)
}
Name (TCBV, 0x00)
Method (TCBS, 0, NotSerialized)
{
If ((TCBV == 0x00))
{
Local0 = PCRR (0xEF, 0x2778)
TCBV = (Local0 & 0xFFE0)
}
Return (TCBV) /* \TCBV */
}
OperationRegion (PMIO, SystemIO, PMBS, 0x60)
Field (PMIO, ByteAcc, NoLock, Preserve)
{
Offset (0x01),
PBSS, 1,
Offset (0x40),
, 17,
GPEC, 1
}
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)
{
ACWA, 32,
DCWA, 32,
ACET, 32,
DCET, 32,
Offset (0xE0),
Offset (0xE2),
DWLE, 1,
HWLE, 1,
Offset (0x31C),
, 13,
SLS0, 1,
, 8,
XSQD, 1
}
OperationRegion (PMST, SystemMemory, PWRM, 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)
{
Device (GLAN)
{
Name (_ADR, 0x001F0006) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
OperationRegion (GLBA, PCI_Config, 0x00, 0x0100)
Field (GLBA, AnyAcc, NoLock, Preserve)
{
DVID, 16
}
Field (GLBA, ByteAcc, NoLock, Preserve)
{
Offset (0xCC),
Offset (0xCD),
PMEE, 1,
, 6,
PMES, 1
}
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x6D, 0x04))
}
Method (_DSW, 3, NotSerialized) // _DSW: Device Sleep Wake
{
PMEE = Arg0
}
Method (GPEH, 0, NotSerialized)
{
If ((DVID == 0xFFFF))
{
Return (Zero)
}
If ((PMEE && PMES))
{
PMES = 0x01
Notify (GLAN, 0x02) // Device Wake
}
}
}
}
Scope (\_SB.PCI0)
{
Device (XHC)
{
Name (_ADR, 0x00140000) // _ADR: Address
OperationRegion (XPRT, PCI_Config, 0x00, 0x0100)
Field (XPRT, AnyAcc, NoLock, Preserve)
{
DVID, 16,
Offset (0x10),
XADL, 32,
XADH, 32,
Offset (0x50),
, 2,
STGE, 1,
Offset (0xA2),
, 2,
D3HE, 1
}
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")
Local0 = (XADH << 0x20)
Local0 |= XADL /* \_SB_.PCI0.XHC_.XADL */
Local0 &= 0xFFFFFFFFFFFFFFF0
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 ((Arg0 == ToUUID ("ac340cb7-e901-45bf-b7e6-2b34ec931e23")))
{
If ((Arg1 == 0x03))
{
XFLT = Arg1
}
If (((PRTM > 0x00) && ((Arg1 == 0x05) || (Arg1 == 0x06))))
{
ADBG ("SSIC")
If ((((PCCS == 0x00) || (PTPP == 0x00)) || ((
PPLS >= 0x04) && (PPLS <= 0x0F))))
{
If ((PPLS == 0x08))
{
D3HE = One
}
Else
{
D3HE = Zero
}
}
Else
{
D3HE = One
}
}
}
Return (Buffer (0x01)
{
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 ((XFLT == Zero))
{
Return (0x00)
}
Else
{
Return (0x03)
}
}
Name (_PR0, Package (0x01) // _PR0: Power Resources for D0
{
\_SB.PCI0.LPCB.EC.PUBS
})
Name (_PR1, Package (0x01) // _PR1: Power Resources for D1
{
\_SB.PCI0.LPCB.EC.PUBS
})
Name (_PR2, Package (0x01) // _PR2: Power Resources for D2
{
\_SB.PCI0.LPCB.EC.PUBS
})
Name (_PRW, Package (0x03) // _PRW: Power Resources for Wake
{
0x6D,
0x03,
\_SB.PCI0.LPCB.EC.PUBS
})
Method (_DSW, 3, NotSerialized) // _DSW: Device Sleep Wake
{
PMEE = Arg0
}
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
If (CondRefOf (\_SB.PCI0.XHC.RHUB.INIR))
{
\_SB.PCI0.XHC.RHUB.INIR ()
}
}
Method (GPEH, 0, NotSerialized)
{
If ((DVID == 0xFFFF))
{
Return (Zero)
}
Local0 = PMES /* \_SB_.PCI0.XHC_.PMES */
PMES = 0x01
If ((PMEE && Local0))
{
Notify (XHC, 0x02) // Device Wake
}
}
OperationRegion (XHCP, SystemMemory, (\_SB.PCI0.GPCB () + 0x000A0000), 0x0100)
Field (XHCP, AnyAcc, Lock, Preserve)
{
Offset (0x04),
PDBM, 16,
Offset (0x10),
MEMB, 64
}
Method (USRA, 0, Serialized)
{
If ((PCHV () == SPTH))
{
Return (0x0F)
}
Else
{
Return (0x0B)
}
}
Method (SSPA, 0, Serialized)
{
If ((PCHV () == SPTH))
{
Return (0x11)
}
Else
{
Return (0x0D)
}
}
Name (XRST, Zero)
Method (_PS0, 0, Serialized) // _PS0: Power State 0
{
If ((^DVID == 0xFFFF))
{
Return (Zero)
}
Local2 = ^MEMB /* \_SB_.PCI0.XHC_.MEMB */
Local1 = ^PDBM /* \_SB_.PCI0.XHC_.PDBM */
^PDBM &= ~0x06
D3HE = 0x00
STGE = 0x00
^D0D3 = 0x00
^MEMB = \XWMB
^PDBM = (Local1 | 0x02)
OperationRegion (MC11, SystemMemory, \XWMB, 0x9000)
Field (MC11, DWordAcc, Lock, Preserve)
{
Offset (0x81C4),
, 2,
UPSW, 2
}
UPSW = 0x00
^PDBM &= ~0x02
^MEMB = Local2
^PDBM = Local1
If (CondRefOf (\_SB.PCI0.XHC.PS0X))
{
\_SB.PCI0.XHC.PS0X ()
}
If ((UWAB && ((D0D3 == 0x00) || (\_SB.PCI0.XDCI.D0I3 == 0x00))))
{
MPMC = 0x01
While (PMFS)
{
Sleep (0x0A)
}
}
}
Method (_PS3, 0, Serialized) // _PS3: Power State 3
{
If ((^DVID == 0xFFFF))
{
Return (Zero)
}
Local2 = ^MEMB /* \_SB_.PCI0.XHC_.MEMB */
Local1 = ^PDBM /* \_SB_.PCI0.XHC_.PDBM */
^PDBM &= ~0x06
^D0D3 = 0x00
^MEMB = \XWMB
^PDBM = (Local1 | 0x02)
OperationRegion (MC11, SystemMemory, \XWMB, 0x9000)
Field (MC11, DWordAcc, Lock, Preserve)
{
Offset (0x81A0),
LFU3, 6,
Offset (0x81C4),
, 2,
UPSW, 2
}
Name (U3PS, Zero)
If ((PCHV () == SPTL))
{
U3PS = 0x0540
}
Else
{
U3PS = 0x0580
}
OperationRegion (UPSC, SystemMemory, (\XWMB + U3PS), 0x0100)
Field (UPSC, DWordAcc, Lock, Preserve)
{
, 5,
PLS1, 4,
, 13,
PLC1, 1,
Offset (0x03),
CAS1, 1,
Offset (0x10),
, 5,
PLS2, 4,
, 13,
PLC2, 1,
Offset (0x13),
CAS2, 1,
Offset (0x20),
, 5,
PLS3, 4,
, 13,
PLC3, 1,
Offset (0x23),
CAS3, 1,
Offset (0x30),
, 5,
PLS4, 4,
, 13,
PLC4, 1,
Offset (0x33),
CAS4, 1,
Offset (0x40),
, 5,
PLS5, 4,
, 13,
PLC5, 1,
Offset (0x43),
CAS5, 1,
Offset (0x50),
, 5,
PLS6, 4,
, 13,
PLC6, 1,
Offset (0x53),
CAS6, 1,
Offset (0x60),
Offset (0x63),
CAS7, 1,
Offset (0x70),
Offset (0x73),
CAS8, 1,
Offset (0x80),
Offset (0x83),
CAS9, 1,
Offset (0x90),
Offset (0x93),
CASA, 1
}
Field (UPSC, DWordAcc, Lock, Preserve)
{
PSC1, 32,
Offset (0x10),
PSC2, 32,
Offset (0x20),
PSC3, 32,
Offset (0x30),
PSC4, 32,
Offset (0x40),
PSC5, 32,
Offset (0x50),
PSC6, 32
}
UPSW = 0x03
STGE = 0x01
LFU3 = 0x3F
Name (PSCO, 0xFFFFFFFF)
Sleep (0x01)
If (((PLS1 == 0x03) && PLC1))
{
PSCO = (0xFFFFFFFD & PSC1) /* \_SB_.PCI0.XHC_._PS3.PSC1 */
PSCO |= 0x00400000 /* \_SB_.PCI0.XHC_._PS3.PSCO */
PSC1 = PSCO /* \_SB_.PCI0.XHC_._PS3.PSCO */
}
If (((PLS2 == 0x03) && PLC2))
{
PSCO = (0xFFFFFFFD & PSC2) /* \_SB_.PCI0.XHC_._PS3.PSC2 */
PSCO |= 0x00400000 /* \_SB_.PCI0.XHC_._PS3.PSCO */
PSC2 = PSCO /* \_SB_.PCI0.XHC_._PS3.PSCO */
}
If (((PLS3 == 0x03) && PLC3))
{
PSCO = (0xFFFFFFFD & PSC3) /* \_SB_.PCI0.XHC_._PS3.PSC3 */
PSCO |= 0x00400000 /* \_SB_.PCI0.XHC_._PS3.PSCO */
PSC3 = PSCO /* \_SB_.PCI0.XHC_._PS3.PSCO */
}
If (((PLS4 == 0x03) && PLC4))
{
PSCO = (0xFFFFFFFD & PSC4) /* \_SB_.PCI0.XHC_._PS3.PSC4 */
PSCO |= 0x00400000 /* \_SB_.PCI0.XHC_._PS3.PSCO */
PSC4 = PSCO /* \_SB_.PCI0.XHC_._PS3.PSCO */
}
If (((PLS5 == 0x03) && PLC5))
{
PSCO = (0xFFFFFFFD & PSC5) /* \_SB_.PCI0.XHC_._PS3.PSC5 */
PSCO |= 0x00400000 /* \_SB_.PCI0.XHC_._PS3.PSCO */
PSC5 = PSCO /* \_SB_.PCI0.XHC_._PS3.PSCO */
}
If (((PLS6 == 0x03) && PLC6))
{
PSCO = (0xFFFFFFFD & PSC6) /* \_SB_.PCI0.XHC_._PS3.PSC6 */
PSCO |= 0x00400000 /* \_SB_.PCI0.XHC_._PS3.PSCO */
PSC6 = PSCO /* \_SB_.PCI0.XHC_._PS3.PSCO */
}
STGE = 0x01
If (((((((CAS1 || CAS2) || CAS3) || CAS4) || CAS5) ||
CAS6) || ((PCHV () == SPTH) && (((CAS7 || CAS8) || CAS9) || CASA))))
{
D3HE = 0x00
Sleep (0x01)
}
Else
{
D3HE = 0x01
}
LFU3 = 0x00
^PDBM &= ~0x02
^D0D3 = 0x03
^MEMB = Local2
^PDBM = Local1
If (CondRefOf (\_SB.PCI0.XHC.PS3X))
{
\_SB.PCI0.XHC.PS3X ()
}
If ((UWAB && ((D0D3 == 0x03) && ((\_SB.PCI0.XDCI.D0I3 == 0x03) || (
\_SB.PCI0.XDCI.DVID == 0xFFFF)))))
{
MPMC = 0x03
While (PMFS)
{
Sleep (0x0A)
}
}
}
Method (CUID, 1, Serialized)
{
If ((Arg0 == ToUUID ("7c9512a9-1705-4cb4-af7d-506a2423ab71")))
{
Return (0x01)
}
Return (0x00)
}
Device (RHUB)
{
Name (_ADR, Zero) // _ADR: Address
Method (_PS0, 0, Serialized) // _PS0: Power State 0
{
If ((\_SB.PCI0.XHC.DVID == 0xFFFF))
{
Return (Zero)
}
If (CondRefOf (\_SB.PCI0.XHC.RHUB.PS0X))
{
\_SB.PCI0.XHC.RHUB.PS0X ()
}
}
Method (_PS2, 0, Serialized) // _PS2: Power State 2
{
If ((\_SB.PCI0.XHC.DVID == 0xFFFF))
{
Return (Zero)
}
If (CondRefOf (\_SB.PCI0.XHC.RHUB.PS2X))
{
\_SB.PCI0.XHC.RHUB.PS2X ()
}
}
Method (_PS3, 0, Serialized) // _PS3: Power State 3
{
If ((\_SB.PCI0.XHC.DVID == 0xFFFF))
{
Return (Zero)
}
If (CondRefOf (\_SB.PCI0.XHC.RHUB.PS3X))
{
\_SB.PCI0.XHC.RHUB.PS3X ()
}
}
Device (HS01)
{
Name (_ADR, 0x01) // _ADR: Address
}
Device (HS02)
{
Name (_ADR, 0x02) // _ADR: Address
}
Device (HS03)
{
Name (_ADR, 0x03) // _ADR: Address
}
Device (HS04)
{
Name (_ADR, 0x04) // _ADR: Address
}
Device (HS05)
{
Name (_ADR, 0x05) // _ADR: Address
}
Device (HS06)
{
Name (_ADR, 0x06) // _ADR: Address
}
Device (HS07)
{
Name (_ADR, 0x07) // _ADR: Address
}
Device (HS08)
{
Name (_ADR, 0x08) // _ADR: Address
}
Device (HS09)
{
Name (_ADR, 0x09) // _ADR: Address
}
Device (HS10)
{
Name (_ADR, 0x0A) // _ADR: Address
}
Device (USR1)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((USRA () + 0x00))
}
}
Device (USR2)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((USRA () + 0x01))
}
}
Device (SS01)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x00))
}
}
Device (SS02)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x01))
}
}
Device (SS03)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x02))
}
}
Device (SS04)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x03))
}
}
Device (SS05)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x04))
}
}
Device (SS06)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x05))
}
}
}
}
}
If ((PCHV () == SPTH))
{
Scope (\_SB.PCI0.XHC.RHUB)
{
Device (HS11)
{
Name (_ADR, 0x0B) // _ADR: Address
}
Device (HS12)
{
Name (_ADR, 0x0C) // _ADR: Address
}
Device (HS13)
{
Name (_ADR, 0x0D) // _ADR: Address
}
Device (HS14)
{
Name (_ADR, 0x0E) // _ADR: Address
}
Device (SS07)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x06))
}
}
Device (SS08)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x07))
}
}
Device (SS09)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x08))
}
}
Device (SS10)
{
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
Return ((SSPA () + 0x09))
}
}
}
}
Scope (\_SB.PCI0)
{
Device (XDCI)
{
Name (_ADR, 0x00140001) // _ADR: Address
OperationRegion (OTGD, PCI_Config, 0x00, 0x0100)
Field (OTGD, DWordAcc, NoLock, Preserve)
{
DVID, 16,
Offset (0x10),
XDCB, 64
}
Field (OTGD, ByteAcc, NoLock, Preserve)
{
Offset (0x84),
D0I3, 2,
Offset (0x85),
PMEE, 1,
, 6,
PMES, 1
}
Method (XDBA, 0, NotSerialized)
{
Return ((^XDCB & 0xFFFFFFFFFFFFFF00))
}
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
If ((Arg0 == ToUUID ("732b85d5-b7a7-4a1b-9ba0-4bbd00ffd511")))
{
If ((Arg1 == 0x01))
{
Method (SPPS, 2, Serialized)
{
OperationRegion (XDBW, SystemMemory, XDBA (), 0x00110000)
Field (XDBW, WordAcc, NoLock, Preserve)
{
Offset (0x10F810),
Offset (0x10F811),
U2CP, 2,
U3CP, 2,
Offset (0x10F818),
PUPS, 2,
, 1,
PURC, 1,
Offset (0x10F81A),
Offset (0x10F81C),
, 3,
UXPE, 2,
Offset (0x10F81E)
}
Local1 = Arg0
Local2 = Arg1
If ((Local1 == 0x00))
{
UXPE = 0x00
Local0 = 0x00
While ((Local0 < 0x0A))
{
Stall (0x64)
Local0++
}
PUPS = 0x00
Local0 = 0x00
While ((Local0 < 0x07D0))
{
Stall (0x64)
If (((U2CP == 0x00) && (U3CP == 0x00)))
{
Break
}
Local0++
}
If ((U2CP != 0x00)){}
If ((U3CP != 0x00)){}
Return (0x00)
}
If ((Local1 == 0x03))
{
If ((U2CP != 0x00)){}
If ((U3CP != 0x00)){}
PUPS = 0x03
Local0 = 0x00
While ((Local0 < 0x07D0))
{
Stall (0x64)
If (((U2CP == 0x03) && (U3CP == 0x03)))
{
Break
}
Local0++
}
If ((U2CP != 0x03)){}
If ((U3CP != 0x03)){}
UXPE = Local2
Return (0x00)
}
Return (0x00)
}
Switch (ToInteger (Arg2))
{
Case (0x00)
{
Return (Buffer (0x01)
{
0xF3 // .
})
}
Case (0x01)
{
Return (0x01)
}
Case (0x04)
{
Local1 = DerefOf (Arg3 [0x00])
SPPS (Local1, 0x00)
}
Case (0x05)
{
If (CondRefOf (\_SB.PCI0.LPCB.H_EC.XDAT))
{
If ((\_SB.PCI0.LPCB.H_EC.XDAT () == 0x01))
{
Notify (\_SB.PCI0.XDCI, 0x80) // Status Change
}
Else
{
Notify (\_SB.PCI0.XDCI, 0x81) // Information Change
}
}
Return (0x00)
}
Case (0x06)
{
OperationRegion (XDBD, SystemMemory, XDBA (), 0x00110000)
Field (XDBD, DWordAcc, NoLock, Preserve)
{
Offset (0xC704),
, 30,
CSFR, 1,
Offset (0xC708)
}
OperationRegion (XDW2, SystemMemory, XDBA (), 0x00110000)
Field (XDW2, WordAcc, NoLock, Preserve)
{
Offset (0x10F820),
, 13,
OTHC, 1
}
If ((OTHC == 0x00))
{
CSFR = 0x01
Local0 = 0x00
While ((Local0 < 0x64))
{
If ((CSFR == 0x00))
{
Break
}
Sleep (0x01)
}
}
Return (0x00)
}
Case (0x07)
{
OperationRegion (XD22, SystemMemory, XDBA (), 0x00110000)
Field (XD22, WordAcc, NoLock, Preserve)
{
Offset (0x10F818),
P2PS, 2,
Offset (0x10F81A)
}
Local0 = P2PS /* \_SB_.PCI0.XDCI._DSM.P2PS */
Return (Local0)
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Name (_DDN, "SPT XHCI controller") // _DDN: DOS Device Name
Name (_STR, Unicode ("SPT XHCI controller")) // _STR: Description String
Method (_S0W, 0, NotSerialized) // _S0W: S0 Device Wake State
{
Return (0x03)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((DVID != 0xFFFFFFFF))
{
Return (0x0F)
}
Else
{
Return (0x00)
}
}
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x6D, 0x04))
}
Method (_DSW, 3, NotSerialized) // _DSW: Device Sleep Wake
{
PMEE = Arg0
}
Method (GPEH, 0, NotSerialized)
{
If ((DVID == 0xFFFF))
{
Return (Zero)
}
Local0 = PMES /* \_SB_.PCI0.XDCI.PMES */
PMES = 0x01
If ((PMEE && Local0))
{
Notify (XDCI, 0x02) // Device Wake
}
}
}
}
Scope (\_SB.PCI0)
{
Device (HDAS)
{
Name (_ADR, 0x001F0003) // _ADR: Address
OperationRegion (HDAR, PCI_Config, 0x00, 0x0100)
Field (HDAR, WordAcc, NoLock, Preserve)
{
VDID, 32
}
Field (HDAR, ByteAcc, NoLock, Preserve)
{
Offset (0x54),
Offset (0x55),
PMEE, 1,
, 6,
PMES, 1
}
Name (_S0W, 0x03) // _S0W: S0 Device Wake State
Method (_DSW, 3, NotSerialized) // _DSW: Device Sleep Wake
{
PMEE = Arg0
}
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x6D, 0x04))
}
Method (GPEH, 0, NotSerialized)
{
If ((VDID == 0xFFFFFFFF))
{
Return (Zero)
}
If ((PMEE && PMES))
{
ADBG ("HDAS GPEH")
PMES = 0x01
Notify (HDAS, 0x02) // Device Wake
}
}
Method (_PS0, 0, Serialized) // _PS0: Power State 0
{
If ((VDID != 0xFFFFFFFF))
{
\_SB.VMMH (0x00, 0x01)
}
If (CondRefOf (\_SB.PCI0.HDAS.PS0X))
{
\_SB.PCI0.HDAS.PS0X ()
}
}
Method (_PS3, 0, Serialized) // _PS3: Power State 3
{
If ((VDID != 0xFFFFFFFF))
{
\_SB.VMMH (0x00, 0x00)
}
If (CondRefOf (\_SB.PCI0.HDAS.PS3X))
{
\_SB.PCI0.HDAS.PS3X ()
}
}
Name (NBUF, ResourceTemplate ()
{
QWordMemory (ResourceConsumer, PosDecode, MinNotFixed, MaxNotFixed, NonCacheable, ReadOnly,
0x0000000000000001, // Granularity
0x0000000000000000, // Range Minimum
0x0000000000000000, // Range Maximum
0x0000000000000000, // Translation Offset
0x0000000000000000, // Length
,, _Y1C, AddressRangeACPI, TypeStatic)
})
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
ADBG ("HDAS _INI")
CreateQWordField (NBUF, \_SB.PCI0.HDAS._Y1C._MIN, NBAS) // _MIN: Minimum Base Address
CreateQWordField (NBUF, \_SB.PCI0.HDAS._Y1C._MAX, NMAS) // _MAX: Maximum Base Address
CreateQWordField (NBUF, \_SB.PCI0.HDAS._Y1C._LEN, NLEN) // _LEN: Length
NBAS = NHLA /* \NHLA */
NMAS = (NHLA + (NHLL - 0x01))
NLEN = NHLL /* \NHLL */
If ((VDID != 0xFFFFFFFF))
{
\_SB.VMMH (0x00, 0x01)
}
}
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
ADBG ("HDAS _DSM")
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
If ((Arg0 == ToUUID ("a69f886e-6ceb-4594-a41f-7b5dce24c553")))
{
Switch (ToInteger (Arg2))
{
Case (0x00)
{
Return (Buffer (One)
{
0x0F // .
})
}
Case (0x01)
{
ADBG ("_DSM Fun 1 NHLT")
Return (NBUF) /* \_SB_.PCI0.HDAS.NBUF */
}
Case (0x02)
{
ADBG ("_DSM Fun 2 FMSK")
Return (ADFM) /* \ADFM */
}
Case (0x03)
{
ADBG ("_DSM Fun 3 PPMS")
If (CondRefOf (\_SB.PCI0.HDAS.PPMS))
{
Return (\_SB.PCI0.HDAS.PPMS (Arg3))
}
Return (0x00)
}
Default
{
ADBG ("_DSM Fun NOK")
Return (Buffer (One)
{
0x00 // .
})
}
}
}
ADBG ("_DSM UUID NOK")
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (RP01)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA1 != 0x00))
{
Return (RPA1) /* \RPA1 */
}
Else
{
Return (0x001C0000)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR1 /* \LTR1 */
LMSL = PML1 /* \PML1 */
LNSL = PNL1 /* \PNL1 */
OBFZ = OBF1 /* \OBF1 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP01._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP01.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR04 ())
}
Return (PR04 ())
}
}
Device (RP02)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA2 != 0x00))
{
Return (RPA2) /* \RPA2 */
}
Else
{
Return (0x001C0001)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR2 /* \LTR2 */
LMSL = PML2 /* \PML2 */
LNSL = PNL2 /* \PNL2 */
OBFZ = OBF2 /* \OBF2 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP02._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP02.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR05 ())
}
Return (PR05 ())
}
}
Device (RP03)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA3 != 0x00))
{
Return (RPA3) /* \RPA3 */
}
Else
{
Return (0x001C0002)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR3 /* \LTR3 */
LMSL = PML3 /* \PML3 */
LNSL = PNL3 /* \PNL3 */
OBFZ = OBF3 /* \OBF3 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP03._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP03.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR06 ())
}
Return (PR06 ())
}
}
Device (RP04)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA4 != 0x00))
{
Return (RPA4) /* \RPA4 */
}
Else
{
Return (0x001C0003)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR4 /* \LTR4 */
LMSL = PML4 /* \PML4 */
LNSL = PNL4 /* \PNL4 */
OBFZ = OBF4 /* \OBF4 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP04._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP04.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR07 ())
}
Return (PR07 ())
}
}
Device (RP05)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA5 != 0x00))
{
Return (RPA5) /* \RPA5 */
}
Else
{
Return (0x001C0004)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR5 /* \LTR5 */
LMSL = PML5 /* \PML5 */
LNSL = PNL5 /* \PNL5 */
OBFZ = OBF5 /* \OBF5 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP05._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP05.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR04 ())
}
Return (PR04 ())
}
}
Device (RP06)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA6 != 0x00))
{
Return (RPA6) /* \RPA6 */
}
Else
{
Return (0x001C0005)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR6 /* \LTR6 */
LMSL = PML6 /* \PML6 */
LNSL = PNL6 /* \PNL6 */
OBFZ = OBF6 /* \OBF6 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP06._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP06.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR05 ())
}
Return (PR05 ())
}
}
Device (RP07)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA7 != 0x00))
{
Return (RPA7) /* \RPA7 */
}
Else
{
Return (0x001C0006)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR7 /* \LTR7 */
LMSL = PML7 /* \PML7 */
LNSL = PNL7 /* \PNL7 */
OBFZ = OBF7 /* \OBF7 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP07._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP07.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR06 ())
}
Return (PR06 ())
}
}
Device (RP08)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA8 != 0x00))
{
Return (RPA8) /* \RPA8 */
}
Else
{
Return (0x001C0007)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR8 /* \LTR8 */
LMSL = PML8 /* \PML8 */
LNSL = PNL8 /* \PNL8 */
OBFZ = OBF8 /* \OBF8 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP08._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP08.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR07 ())
}
Return (PR07 ())
}
}
Device (RP09)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPA9 != 0x00))
{
Return (RPA9) /* \RPA9 */
}
Else
{
Return (0x001D0000)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTR9 /* \LTR9 */
LMSL = PML9 /* \PML9 */
LNSL = PNL9 /* \PNL9 */
OBFZ = OBF9 /* \OBF9 */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP09._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP09.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR04 ())
}
Return (PR04 ())
}
}
Device (RP10)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAA != 0x00))
{
Return (RPAA) /* \RPAA */
}
Else
{
Return (0x001D0001)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRA /* \LTRA */
LMSL = PMLA /* \PMLA */
LNSL = PNLA /* \PNLA */
OBFZ = OBFA /* \OBFA */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP10._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP10.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR05 ())
}
Return (PR05 ())
}
}
Device (RP11)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAB != 0x00))
{
Return (RPAB) /* \RPAB */
}
Else
{
Return (0x001D0002)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRB /* \LTRB */
LMSL = PMLB /* \PMLB */
LNSL = PNLB /* \PNLB */
OBFZ = OBFB /* \OBFB */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP11._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP11.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR06 ())
}
Return (PR06 ())
}
}
Device (RP12)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAC != 0x00))
{
Return (RPAC) /* \RPAC */
}
Else
{
Return (0x001D0003)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRC /* \LTRC */
LMSL = PMLC /* \PMLC */
LNSL = PNLC /* \PNLC */
OBFZ = OBFC /* \OBFC */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP12._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP12.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR07 ())
}
Return (PR07 ())
}
}
Device (RP13)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAD != 0x00))
{
Return (RPAD) /* \RPAD */
}
Else
{
Return (0x001D0004)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRD /* \LTRD */
LMSL = PMLD /* \PMLD */
LNSL = PNLD /* \PNLD */
OBFZ = OBFD /* \OBFD */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP13._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP13.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR04 ())
}
Return (PR04 ())
}
}
Device (RP14)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAE != 0x00))
{
Return (RPAE) /* \RPAE */
}
Else
{
Return (0x001D0005)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRE /* \LTRE */
LMSL = PMLE /* \PMLE */
LNSL = PNLE /* \PNLE */
OBFZ = OBFE /* \OBFE */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP14._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP14.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR05 ())
}
Return (PR05 ())
}
}
Device (RP15)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAF != 0x00))
{
Return (RPAF) /* \RPAF */
}
Else
{
Return (0x001D0006)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRF /* \LTRF */
LMSL = PMLF /* \PMLF */
LNSL = PNLF /* \PNLF */
OBFZ = OBFF /* \OBFF */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP15._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP15.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR06 ())
}
Return (PR06 ())
}
}
Device (RP16)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAG != 0x00))
{
Return (RPAG) /* \RPAG */
}
Else
{
Return (0x001D0007)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRG /* \LTRG */
LMSL = PMLG /* \PMLG */
LNSL = PNLG /* \PNLG */
OBFZ = OBFG /* \OBFG */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP16._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP16.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR07 ())
}
Return (PR07 ())
}
}
Device (RP17)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAH != 0x00))
{
Return (RPAH) /* \RPAH */
}
Else
{
Return (0x001B0000)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRH /* \LTRH */
LMSL = PMLH /* \PMLH */
LNSL = PNLH /* \PNLH */
OBFZ = OBFH /* \OBFH */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP17._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP17.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR04 ())
}
Return (PR04 ())
}
}
Device (RP18)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAI != 0x00))
{
Return (RPAI) /* \RPAI */
}
Else
{
Return (0x001B0001)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRI /* \LTRI */
LMSL = PMLI /* \PMLI */
LNSL = PNLI /* \PNLI */
OBFZ = OBFI /* \OBFI */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP18._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP18.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR05 ())
}
Return (PR05 ())
}
}
Device (RP19)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAJ != 0x00))
{
Return (RPAJ) /* \RPAJ */
}
Else
{
Return (0x001B0002)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRJ /* \LTRJ */
LMSL = PMLJ /* \PMLJ */
LNSL = PNLJ /* \PNLJ */
OBFZ = OBFJ /* \OBFJ */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP19._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP19.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR06 ())
}
Return (PR06 ())
}
}
Device (RP20)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAK != 0x00))
{
Return (RPAK) /* \RPAK */
}
Else
{
Return (0x001B0003)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRK /* \LTRK */
LMSL = PMLK /* \_SB_.PCI0.PMLK */
LNSL = PNLK /* \PNLK */
OBFZ = OBFK /* \OBFK */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP20._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP20.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR07 ())
}
Return (PR07 ())
}
}
Device (RP21)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAL != 0x00))
{
Return (RPAL) /* \RPAL */
}
Else
{
Return (0x001B0004)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRL /* \LTRL */
LMSL = PMLL /* \PMLL */
LNSL = PNLL /* \PNLL */
OBFZ = OBFL /* \OBFL */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP21._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP21.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR04 ())
}
Return (PR04 ())
}
}
Device (RP22)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAM != 0x00))
{
Return (RPAM) /* \RPAM */
}
Else
{
Return (0x001B0005)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRM /* \LTRM */
LMSL = PMLM /* \PMLM */
LNSL = PNLM /* \PNLM */
OBFZ = OBFM /* \OBFM */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP22._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP22.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR05 ())
}
Return (PR05 ())
}
}
Device (RP23)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAN != 0x00))
{
Return (RPAN) /* \RPAN */
}
Else
{
Return (0x001B0006)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRN /* \LTRN */
LMSL = PMLN /* \PMLN */
LNSL = PNLN /* \PNLN */
OBFZ = OBFN /* \OBFN */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP23._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP23.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR06 ())
}
Return (PR06 ())
}
}
Device (RP24)
{
Name (RID, 0x00)
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
Method (_ADR, 0, NotSerialized) // _ADR: Address
{
If ((RPAO != 0x00))
{
Return (RPAO) /* \RPAO */
}
Else
{
Return (0x001B0007)
}
}
Name (LTRZ, 0x00)
Name (OBFZ, 0x00)
Name (LMSL, 0x00)
Name (LNSL, 0x00)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
LTRZ = LTRO /* \LTRO */
LMSL = PMLO /* \PMLO */
LNSL = PNLO /* \PNLO */
OBFZ = OBFO /* \OBFO */
}
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 ((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 ((Arg1 >= 0x02))
{
FUN0 = 0x01
If (LTRZ)
{
FUN6 = 0x01
}
If (OBFZ)
{
FUN4 = 0x01
}
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
FUN8 = 0x01
FUN9 = 0x01
}
}
}
Return (OPTS) /* \_SB_.PCI0.RP24._DSM.OPTS */
}
Case (0x04)
{
If ((Arg1 >= 0x02))
{
If (OBFZ)
{
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 (0x05)
{
If ((Arg1 == 0x01))
{
Return (0x01)
}
}
Case (0x06)
{
If ((Arg1 >= 0x02))
{
If (LTRZ)
{
If (((LMSL == 0x00) || (LNSL == 0x00)))
{
If ((PCHS == SPTH))
{
LMSL = 0x0846
LNSL = 0x0846
}
ElseIf ((PCHS == SPTL))
{
LMSL = 0x1003
LNSL = 0x1003
}
}
LTRV [0x00] = ((LMSL >> 0x0A) & 0x07)
LTRV [0x01] = (LMSL & 0x03FF)
LTRV [0x02] = ((LNSL >> 0x0A) & 0x07)
LTRV [0x03] = (LNSL & 0x03FF)
Return (LTRV) /* \_SB_.PCI0.RP24.LTRV */
}
Else
{
Return (0x00)
}
}
}
Case (0x08)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (0x01)
}
}
}
Case (0x09)
{
If ((ECR1 == 0x01))
{
If ((Arg1 >= 0x03))
{
Return (Package (0x05)
{
0xC350,
Ones,
Ones,
0xC350,
Ones
})
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PXSX)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_PRW, 0, NotSerialized) // _PRW: Power Resources for Wake
{
Return (GPRW (0x69, 0x04))
}
}
Method (HPME, 0, Serialized)
{
If (((VDID != 0xFFFFFFFF) && (PMSX == 0x01)))
{
Notify (PXSX, 0x02) // Device Wake
PMSX = 0x01
PSPX = 0x01
}
}
Method (_PRT, 0, NotSerialized) // _PRT: PCI Routing Table
{
If (PICM)
{
Return (AR07 ())
}
Return (PR07 ())
}
}
Device (SAT0)
{
Name (_ADR, 0x00170000) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
If (CondRefOf (\_SB.PCI0.SAT0.SDSM))
{
Return (\_SB.PCI0.SAT0.SDSM (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (PRT0)
{
Name (_ADR, 0xFFFF) // _ADR: Address
}
Device (PRT1)
{
Name (_ADR, 0x0001FFFF) // _ADR: Address
}
Device (PRT2)
{
Name (_ADR, 0x0002FFFF) // _ADR: Address
}
Device (PRT3)
{
Name (_ADR, 0x0003FFFF) // _ADR: Address
}
Device (PRT4)
{
Name (_ADR, 0x0004FFFF) // _ADR: Address
}
Device (PRT5)
{
Name (_ADR, 0x0005FFFF) // _ADR: Address
}
Device (VOL0)
{
Name (_ADR, 0x0080FFFF) // _ADR: Address
}
Device (VOL1)
{
Name (_ADR, 0x0081FFFF) // _ADR: Address
}
Device (VOL2)
{
Name (_ADR, 0x0082FFFF) // _ADR: Address
}
Method (RDCA, 5, Serialized)
{
OperationRegion (RPAL, SystemMemory, (\_SB.PCI0.GPCB () + ((0x000B8000 + 0x0100) + Arg1)), 0x04)
Field (RPAL, DWordAcc, Lock, Preserve)
{
RPCD, 32
}
OperationRegion (EPAC, SystemMemory, (\_SB.PCI0.GPCB () + (0x000B8000 + 0x0308)), 0x08)
Field (EPAC, DWordAcc, Lock, Preserve)
{
CAIR, 32,
CADR, 32
}
OperationRegion (NCRG, SystemMemory, (\_SB.PCI0.GPCB () + (0x000B8000 + 0x0FC0)), 0x04)
Field (NCRG, DWordAcc, Lock, Preserve)
{
CRGC, 32
}
If ((Arg0 > 0x02))
{
Return (0x00)
}
Else
{
CRGC = Arg0
}
Switch (ToInteger (Arg4))
{
Case (0x00)
{
Return (RPCD) /* \_SB_.PCI0.SAT0.RDCA.RPCD */
}
Case (0x02)
{
CAIR = Arg1
Return (CADR) /* \_SB_.PCI0.SAT0.RDCA.CADR */
}
Case (0x01)
{
Local0 = (Arg2 & RPCD) /* \_SB_.PCI0.SAT0.RDCA.RPCD */
Local0 |= Arg3
RPCD = Local0
}
Case (0x03)
{
CAIR = Arg1
Local0 = (Arg2 & CADR) /* \_SB_.PCI0.SAT0.RDCA.CADR */
Local0 |= Arg3
CADR = Local0
}
Default
{
Return (0x00)
}
}
Return (0x00)
}
Method (ARPC, 4, Serialized)
{
ADBG (Concatenate ("NRPN: ", ToHexString (Arg0)))
Switch (ToInteger (Arg0))
{
Case (0x04)
{
If (CondRefOf (\_SB.PCI0.RP05.PWRG))
{
CopyObject (\_SB.PCI0.RP05.PWRG, Arg1)
}
If (CondRefOf (\_SB.PCI0.RP05.RSTG))
{
CopyObject (\_SB.PCI0.RP05.RSTG, Arg2)
}
If (CondRefOf (\_SB.PCI0.RP05.SCLK))
{
CopyObject (\_SB.PCI0.RP05.SCLK, Arg3)
}
}
Case (0x08)
{
If (CondRefOf (\_SB.PCI0.RP09.PWRG))
{
CopyObject (\_SB.PCI0.RP09.PWRG, Arg1)
}
If (CondRefOf (\_SB.PCI0.RP09.RSTG))
{
CopyObject (\_SB.PCI0.RP09.RSTG, Arg2)
}
If (CondRefOf (\_SB.PCI0.RP09.SCLK))
{
CopyObject (\_SB.PCI0.RP09.SCLK, Arg3)
}
}
Case (0x0C)
{
If (CondRefOf (\_SB.PCI0.RP13.PWRG))
{
CopyObject (\_SB.PCI0.RP13.PWRG, Arg1)
}
If (CondRefOf (\_SB.PCI0.RP13.RSTG))
{
CopyObject (\_SB.PCI0.RP13.RSTG, Arg2)
}
If (CondRefOf (\_SB.PCI0.RP13.SCLK))
{
CopyObject (\_SB.PCI0.RP13.SCLK, Arg3)
}
}
Case (0x10)
{
If (CondRefOf (\_SB.PCI0.RP17.PWRG))
{
CopyObject (\_SB.PCI0.RP17.PWRG, Arg1)
}
If (CondRefOf (\_SB.PCI0.RP17.RSTG))
{
CopyObject (\_SB.PCI0.RP17.RSTG, Arg2)
}
If (CondRefOf (\_SB.PCI0.RP17.SCLK))
{
CopyObject (\_SB.PCI0.RP17.SCLK, Arg3)
}
}
Default
{
ADBG (Concatenate ("ERR!NRPN: ", ToHexString (Arg0)))
}
}
}
Device (NVM1)
{
Name (_ADR, 0x00C1FFFF) // _ADR: Address
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
NITV = NIT1 /* \NIT1 */
NPMV = NPM1 /* \NPM1 */
NPCV = NPC1 /* \NPC1 */
NL1V = NL11 /* \NL11 */
ND2V = ND21 /* \ND21 */
ND1V = ND11 /* \ND11 */
NLRV = NLR1 /* \NLR1 */
NLDV = NLD1 /* \NLD1 */
NEAV = NEA1 /* \NEA1 */
NEBV = NEB1 /* \NEB1 */
NECV = NEC1 /* \NEC1 */
NRAV = NRA1 /* \NRA1 */
NMBV = NMB1 /* \NMB1 */
NMVV = NMV1 /* \NMV1 */
NPBV = NPB1 /* \NPB1 */
NPVV = NPV1 /* \NPV1 */
NRPN = NRP1 /* \NRP1 */
NCRN = 0x00
ARPC (NRPN, RefOf (PWRG), RefOf (RSTG), RefOf (SCLK))
}
Name (PRBI, 0x00)
Name (PRBD, 0x00)
Name (PCMD, 0x00)
Name (RSTG, Package (0x04)
{
0x00,
0x00,
0x00,
0x00
})
Name (PWRG, Package (0x04)
{
0x00,
0x00,
0x00,
0x00
})
Name (SCLK, Package (0x03)
{
0x00,
0x00,
0x00
})
Name (NCRN, 0x00)
Name (NITV, 0x00)
Name (NPMV, 0x00)
Name (NPCV, 0x00)
Name (NL1V, 0x00)
Name (ND2V, 0x00)
Name (ND1V, 0x00)
Name (NLRV, 0x00)
Name (NLDV, 0x00)
Name (NEAV, 0x00)
Name (NEBV, 0x00)
Name (NECV, 0x00)
Name (NRAV, 0x00)
Name (NMBV, 0x00)
Name (NMVV, 0x00)
Name (NPBV, 0x00)
Name (NPVV, 0x00)
Name (NRPN, 0x00)
Name (MXIE, 0x00)
Name (ISD3, 0x00)
Method (RPPC, 1, Serialized)
{
If ((Arg0 == 0x00))
{
RPOF ()
}
Else
{
RPON ()
}
}
Method (RPON, 0, Serialized)
{
If ((ISD3 == 0x00))
{
Return (Zero)
}
ISD3 = 0x00
ADBG (Concatenate ("RPONs: ", ToHexString (NRPN)))
\_SB.PCI0.SAT0.PON (PWRG)
If ((DerefOf (SCLK [0x00]) != 0x00))
{
PCRA (0xDC, 0x100C, ~DerefOf (SCLK [0x01]))
Sleep (0x10)
}
\_SB.PCI0.SAT0.PON (RSTG)
RDCA (NCRN, 0x0420, 0xBFFFFFFF, 0x00, 0x01)
RDCA (NCRN, 0xE2, 0xFFFFFFFF, 0x08, 0x01)
Sleep (0x10)
Local0 = 0x00
While ((RDCA (NCRN, 0xE2, 0x00, 0x00, 0x00) & 0x08))
{
If ((Local0 > 0x04))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0420, 0xFFFFFFFF, 0x40000000, 0x01)
Local0 = 0x00
While (((RDCA (NCRN, 0x52, 0x00, 0x00, 0x00) & 0x2000) == 0x00))
{
If ((Local0 > 0x08))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0324, 0xFFFFFFF7, 0x00, 0x01)
Sleep (0x07D0)
NVD0 ()
ADBG (Concatenate ("RPONe: ", ToHexString (NRPN)))
}
Method (RPOF, 0, Serialized)
{
If ((NVD3 () == 0x00))
{
Return (Zero)
}
ADBG (Concatenate ("POFF NRPN: ", ToHexString (NRPN)))
RDCA (NCRN, 0xE2, 0xFFFFFFFF, 0x04, 0x01)
Sleep (0x10)
Local0 = 0x00
While ((RDCA (NCRN, 0xE2, 0x00, 0x00, 0x00) & 0x04))
{
If ((Local0 > 0x04))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0324, 0xFFFFFFFF, 0x08, 0x01)
\_SB.PCI0.SAT0.POFF (RSTG)
If ((DerefOf (SCLK [0x00]) != 0x00))
{
PCRO (0xDC, 0x100C, DerefOf (SCLK [0x01]))
Sleep (0x10)
}
\_SB.PCI0.SAT0.POFF (PWRG)
RDCA (NCRN, 0x50, 0xFFFFFFFF, 0x10, 0x01)
RDCA (NCRN, 0x50, 0xFFFFFFEF, 0x00, 0x01)
ISD3 = 0x03
}
Method (NVD3, 0, Serialized)
{
If ((NITV == 0x00))
{
Return (0x00)
}
PCMD = RDCA (NCRN, 0x04, 0x00, 0x00, 0x02)
If ((NITV == 0x01))
{
PRBI = 0x24
PRBD = RDCA (NCRN, 0x24, 0x00, 0x00, 0x02)
}
ElseIf ((NITV == 0x02))
{
PRBI = 0x10
PRBD = RDCA (NCRN, 0x10, 0x00, 0x00, 0x02)
OperationRegion (MCRC, SystemMemory, (\_SB.PCI0.GPCB () + (0x000B8000 + 0x033C)), 0x04)
Field (MCRC, AnyAcc, NoLock, Preserve)
{
SCSO, 8,
Offset (0x02),
TCSO, 8,
, 7,
RE, 1
}
MXIE = RDCA (NCRN, TCSO, 0x00, 0x00, 0x02)
}
RDCA (NCRN, (NPMV + 0x04), 0xFFFFFFFC, 0x03, 0x03)
RDCA (NCRN, 0xA4, 0xFFFFFFFC, 0x03, 0x01)
Return (0x01)
}
Method (NVD0, 0, Serialized)
{
If ((NITV == 0x00))
{
Return (0x00)
}
RDCA (NCRN, 0xA4, 0xFFFFFFFC, 0x00, 0x01)
RDCA (NCRN, (NPMV + 0x04), 0xFFFFFFFC, 0x00, 0x03)
CNRS ()
If ((NITV == 0x02))
{
OperationRegion (MCRC, SystemMemory, (\_SB.PCI0.GPCB () + (0x000B8000 + 0x033C)), 0x04)
Field (MCRC, AnyAcc, NoLock, Preserve)
{
SCSO, 8,
Offset (0x02),
TCSO, 8,
, 7,
RE, 1
}
RDCA (NCRN, TCSO, 0xFFFFFFFF, (MXIE & 0x80000000), 0x03)
ADBG ("NVD0: MSIXe")
}
Else
{
}
Return (0x01)
}
Method (CNRS, 0, Serialized)
{
Debug = "[ACPI RST] Restore Remapped Device and Hidden RP context |start"
ADBG (Concatenate ("CNRSs ", ToDecimalString (Timer)))
If ((NITV == 0x00))
{
Return (Zero)
}
RDCA (NCRN, 0x10, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x14, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x18, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x1C, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x20, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x24, 0x00, 0x00, 0x03)
RDCA (NCRN, PRBI, 0x00, PRBD, 0x03)
RDCA (NCRN, 0x04, 0xFFFFFFF8, PCMD, 0x03)
If ((NL1V != 0x00))
{
RDCA (NCRN, (NL1V + 0x0C), 0xFFFFFF00, ND2V, 0x03)
RDCA (NCRN, (NL1V + 0x08), 0x0F, (ND1V & 0xFFFFFFF0), 0x03)
RDCA (NCRN, (NL1V + 0x08), 0xFFFFFFFF, ND1V, 0x03)
}
If ((NLRV != 0x00))
{
RDCA (NCRN, (NLRV + 0x04), 0xFFFFFFFF, NLDV, 0x03)
}
RDCA (NCRN, (NPCV + 0x10), 0xFFFFFEBF, (NEAV & 0xFFFC), 0x03)
RDCA (NCRN, (NPCV + 0x28), 0xFFFFFBFF, NECV, 0x03)
RDCA (NCRN, (NPCV + 0x08), 0xFFFFFF1F, NEBV, 0x03)
RDCA (NCRN, 0x68, 0xFFFFFBFF, NRAV, 0x01)
If (((NEAV & 0x40) == 0x40))
{
RDCA (NCRN, 0x50, 0xFFFFFFDF, 0x20, 0x01)
ADBG (Concatenate ("CNRSw ", ToDecimalString (Timer)))
While (((RDCA (NCRN, 0x52, 0x00, 0x00, 0x00) & 0x2000) == 0x00))
{
Stall (0x0A)
}
}
ADBG (Concatenate ("CNRSx ", ToDecimalString (Timer)))
RDCA (NCRN, (NPCV + 0x10), 0xFFFFFFFC, (NEAV & 0x03), 0x03)
If ((NMVV != 0x00))
{
RDCA (NCRN, NMBV, 0x00, NMVV, 0x03)
}
If ((NPVV != 0x00))
{
RDCA (NCRN, NPBV, 0x00, NPVV, 0x03)
}
ADBG (Concatenate ("CNRSe ", ToDecimalString (Timer)))
Debug = "[ACPI RST] Restore Remapped Device and Hidden RP context |complete"
}
}
Device (NVM2)
{
Name (_ADR, 0x00C2FFFF) // _ADR: Address
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
NITV = NIT2 /* \NIT2 */
NPMV = NPM2 /* \NPM2 */
NPCV = NPC2 /* \NPC2 */
NL1V = NL12 /* \NL12 */
ND2V = ND22 /* \ND22 */
ND1V = ND12 /* \ND12 */
NLRV = NLR2 /* \NLR2 */
NLDV = NLD2 /* \NLD2 */
NEAV = NEA2 /* \NEA2 */
NEBV = NEB2 /* \NEB2 */
NECV = NEC2 /* \NEC2 */
NRAV = NRA2 /* \NRA2 */
NMBV = NMB2 /* \NMB2 */
NMVV = NMV2 /* \NMV2 */
NPBV = NPB2 /* \NPB2 */
NPVV = NPV2 /* \NPV2 */
NRPN = NRP2 /* \NRP2 */
NCRN = 0x01
ARPC (NRPN, RefOf (PWRG), RefOf (RSTG), RefOf (SCLK))
}
Name (PRBI, 0x00)
Name (PRBD, 0x00)
Name (PCMD, 0x00)
Name (RSTG, Package (0x04)
{
0x00,
0x00,
0x00,
0x00
})
Name (PWRG, Package (0x04)
{
0x00,
0x00,
0x00,
0x00
})
Name (SCLK, Package (0x03)
{
0x00,
0x00,
0x00
})
Name (NCRN, 0x00)
Name (NITV, 0x00)
Name (NPMV, 0x00)
Name (NPCV, 0x00)
Name (NL1V, 0x00)
Name (ND2V, 0x00)
Name (ND1V, 0x00)
Name (NLRV, 0x00)
Name (NLDV, 0x00)
Name (NEAV, 0x00)
Name (NEBV, 0x00)
Name (NECV, 0x00)
Name (NRAV, 0x00)
Name (NMBV, 0x00)
Name (NMVV, 0x00)
Name (NPBV, 0x00)
Name (NPVV, 0x00)
Name (NRPN, 0x00)
Name (MXIE, 0x00)
Name (ISD3, 0x00)
Method (RPPC, 1, Serialized)
{
If ((Arg0 == 0x00))
{
RPOF ()
}
Else
{
RPON ()
}
}
Method (RPON, 0, Serialized)
{
If ((ISD3 == 0x00))
{
Return (Zero)
}
ISD3 = 0x00
ADBG (Concatenate ("RPONs: ", ToHexString (NRPN)))
\_SB.PCI0.SAT0.PON (PWRG)
If ((DerefOf (SCLK [0x00]) != 0x00))
{
PCRA (0xDC, 0x100C, ~DerefOf (SCLK [0x01]))
Sleep (0x10)
}
\_SB.PCI0.SAT0.PON (RSTG)
RDCA (NCRN, 0x0420, 0xBFFFFFFF, 0x00, 0x01)
RDCA (NCRN, 0xE2, 0xFFFFFFFF, 0x08, 0x01)
Sleep (0x10)
Local0 = 0x00
While ((RDCA (NCRN, 0xE2, 0x00, 0x00, 0x00) & 0x08))
{
If ((Local0 > 0x04))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0420, 0xFFFFFFFF, 0x40000000, 0x01)
Local0 = 0x00
While (((RDCA (NCRN, 0x52, 0x00, 0x00, 0x00) & 0x2000) == 0x00))
{
If ((Local0 > 0x08))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0324, 0xFFFFFFF7, 0x00, 0x01)
Sleep (0x07D0)
NVD0 ()
ADBG (Concatenate ("RPONe: ", ToHexString (NRPN)))
}
Method (RPOF, 0, Serialized)
{
If ((NVD3 () == 0x00))
{
Return (Zero)
}
ADBG (Concatenate ("POFF NRPN: ", ToHexString (NRPN)))
RDCA (NCRN, 0xE2, 0xFFFFFFFF, 0x04, 0x01)
Sleep (0x10)
Local0 = 0x00
While ((RDCA (NCRN, 0xE2, 0x00, 0x00, 0x00) & 0x04))
{
If ((Local0 > 0x04))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0324, 0xFFFFFFFF, 0x08, 0x01)
\_SB.PCI0.SAT0.POFF (RSTG)
If ((DerefOf (SCLK [0x00]) != 0x00))
{
PCRO (0xDC, 0x100C, DerefOf (SCLK [0x01]))
Sleep (0x10)
}
\_SB.PCI0.SAT0.POFF (PWRG)
RDCA (NCRN, 0x50, 0xFFFFFFFF, 0x10, 0x01)
RDCA (NCRN, 0x50, 0xFFFFFFEF, 0x00, 0x01)
ISD3 = 0x03
}
Method (NVD3, 0, Serialized)
{
If ((NITV == 0x00))
{
Return (0x00)
}
PCMD = RDCA (NCRN, 0x04, 0x00, 0x00, 0x02)
If ((NITV == 0x01))
{
PRBI = 0x24
PRBD = RDCA (NCRN, 0x24, 0x00, 0x00, 0x02)
}
ElseIf ((NITV == 0x02))
{
PRBI = 0x10
PRBD = RDCA (NCRN, 0x10, 0x00, 0x00, 0x02)
OperationRegion (MCRC, SystemMemory, (\_SB.PCI0.GPCB () + (0x000B8000 + 0x033C)), 0x04)
Field (MCRC, AnyAcc, NoLock, Preserve)
{
SCSO, 8,
Offset (0x02),
TCSO, 8,
, 7,
RE, 1
}
MXIE = RDCA (NCRN, TCSO, 0x00, 0x00, 0x02)
}
RDCA (NCRN, (NPMV + 0x04), 0xFFFFFFFC, 0x03, 0x03)
RDCA (NCRN, 0xA4, 0xFFFFFFFC, 0x03, 0x01)
Return (0x01)
}
Method (NVD0, 0, Serialized)
{
If ((NITV == 0x00))
{
Return (0x00)
}
RDCA (NCRN, 0xA4, 0xFFFFFFFC, 0x00, 0x01)
RDCA (NCRN, (NPMV + 0x04), 0xFFFFFFFC, 0x00, 0x03)
CNRS ()
If ((NITV == 0x02))
{
OperationRegion (MCRC, SystemMemory, (\_SB.PCI0.GPCB () + (0x000B8000 + 0x033C)), 0x04)
Field (MCRC, AnyAcc, NoLock, Preserve)
{
SCSO, 8,
Offset (0x02),
TCSO, 8,
, 7,
RE, 1
}
RDCA (NCRN, TCSO, 0xFFFFFFFF, (MXIE & 0x80000000), 0x03)
ADBG ("NVD0: MSIXe")
}
Else
{
}
Return (0x01)
}
Method (CNRS, 0, Serialized)
{
Debug = "[ACPI RST] Restore Remapped Device and Hidden RP context |start"
ADBG (Concatenate ("CNRSs ", ToDecimalString (Timer)))
If ((NITV == 0x00))
{
Return (Zero)
}
RDCA (NCRN, 0x10, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x14, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x18, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x1C, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x20, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x24, 0x00, 0x00, 0x03)
RDCA (NCRN, PRBI, 0x00, PRBD, 0x03)
RDCA (NCRN, 0x04, 0xFFFFFFF8, PCMD, 0x03)
If ((NL1V != 0x00))
{
RDCA (NCRN, (NL1V + 0x0C), 0xFFFFFF00, ND2V, 0x03)
RDCA (NCRN, (NL1V + 0x08), 0x0F, (ND1V & 0xFFFFFFF0), 0x03)
RDCA (NCRN, (NL1V + 0x08), 0xFFFFFFFF, ND1V, 0x03)
}
If ((NLRV != 0x00))
{
RDCA (NCRN, (NLRV + 0x04), 0xFFFFFFFF, NLDV, 0x03)
}
RDCA (NCRN, (NPCV + 0x10), 0xFFFFFEBF, (NEAV & 0xFFFC), 0x03)
RDCA (NCRN, (NPCV + 0x28), 0xFFFFFBFF, NECV, 0x03)
RDCA (NCRN, (NPCV + 0x08), 0xFFFFFF1F, NEBV, 0x03)
RDCA (NCRN, 0x68, 0xFFFFFBFF, NRAV, 0x01)
If (((NEAV & 0x40) == 0x40))
{
RDCA (NCRN, 0x50, 0xFFFFFFDF, 0x20, 0x01)
ADBG (Concatenate ("CNRSw ", ToDecimalString (Timer)))
While (((RDCA (NCRN, 0x52, 0x00, 0x00, 0x00) & 0x2000) == 0x00))
{
Stall (0x0A)
}
}
ADBG (Concatenate ("CNRSx ", ToDecimalString (Timer)))
RDCA (NCRN, (NPCV + 0x10), 0xFFFFFFFC, (NEAV & 0x03), 0x03)
If ((NMVV != 0x00))
{
RDCA (NCRN, NMBV, 0x00, NMVV, 0x03)
}
If ((NPVV != 0x00))
{
RDCA (NCRN, NPBV, 0x00, NPVV, 0x03)
}
ADBG (Concatenate ("CNRSe ", ToDecimalString (Timer)))
Debug = "[ACPI RST] Restore Remapped Device and Hidden RP context |complete"
}
}
Device (NVM3)
{
Name (_ADR, 0x00C3FFFF) // _ADR: Address
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
NITV = NIT3 /* \NIT3 */
NPMV = NPM3 /* \NPM3 */
NPCV = NPC3 /* \NPC3 */
NL1V = NL13 /* \NL13 */
ND2V = ND23 /* \ND23 */
ND1V = ND13 /* \ND13 */
NLRV = NLR3 /* \NLR3 */
NLDV = NLD3 /* \NLD3 */
NEAV = NEA3 /* \NEA3 */
NEBV = NEB3 /* \NEB3 */
NECV = NEC3 /* \NEC3 */
NRAV = NRA3 /* \NRA3 */
NMBV = NMB3 /* \NMB3 */
NMVV = NMV3 /* \NMV3 */
NPBV = NPB3 /* \NPB3 */
NPVV = NPV3 /* \NPV3 */
NRPN = NRP3 /* \NRP3 */
NCRN = 0x02
ARPC (NRPN, RefOf (PWRG), RefOf (RSTG), RefOf (SCLK))
}
Name (PRBI, 0x00)
Name (PRBD, 0x00)
Name (PCMD, 0x00)
Name (RSTG, Package (0x04)
{
0x00,
0x00,
0x00,
0x00
})
Name (PWRG, Package (0x04)
{
0x00,
0x00,
0x00,
0x00
})
Name (SCLK, Package (0x03)
{
0x00,
0x00,
0x00
})
Name (NCRN, 0x00)
Name (NITV, 0x00)
Name (NPMV, 0x00)
Name (NPCV, 0x00)
Name (NL1V, 0x00)
Name (ND2V, 0x00)
Name (ND1V, 0x00)
Name (NLRV, 0x00)
Name (NLDV, 0x00)
Name (NEAV, 0x00)
Name (NEBV, 0x00)
Name (NECV, 0x00)
Name (NRAV, 0x00)
Name (NMBV, 0x00)
Name (NMVV, 0x00)
Name (NPBV, 0x00)
Name (NPVV, 0x00)
Name (NRPN, 0x00)
Name (MXIE, 0x00)
Name (ISD3, 0x00)
Method (RPPC, 1, Serialized)
{
If ((Arg0 == 0x00))
{
RPOF ()
}
Else
{
RPON ()
}
}
Method (RPON, 0, Serialized)
{
If ((ISD3 == 0x00))
{
Return (Zero)
}
ISD3 = 0x00
ADBG (Concatenate ("RPONs: ", ToHexString (NRPN)))
\_SB.PCI0.SAT0.PON (PWRG)
If ((DerefOf (SCLK [0x00]) != 0x00))
{
PCRA (0xDC, 0x100C, ~DerefOf (SCLK [0x01]))
Sleep (0x10)
}
\_SB.PCI0.SAT0.PON (RSTG)
RDCA (NCRN, 0x0420, 0xBFFFFFFF, 0x00, 0x01)
RDCA (NCRN, 0xE2, 0xFFFFFFFF, 0x08, 0x01)
Sleep (0x10)
Local0 = 0x00
While ((RDCA (NCRN, 0xE2, 0x00, 0x00, 0x00) & 0x08))
{
If ((Local0 > 0x04))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0420, 0xFFFFFFFF, 0x40000000, 0x01)
Local0 = 0x00
While (((RDCA (NCRN, 0x52, 0x00, 0x00, 0x00) & 0x2000) == 0x00))
{
If ((Local0 > 0x08))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0324, 0xFFFFFFF7, 0x00, 0x01)
Sleep (0x07D0)
NVD0 ()
ADBG (Concatenate ("RPONe: ", ToHexString (NRPN)))
}
Method (RPOF, 0, Serialized)
{
If ((NVD3 () == 0x00))
{
Return (Zero)
}
ADBG (Concatenate ("POFF NRPN: ", ToHexString (NRPN)))
RDCA (NCRN, 0xE2, 0xFFFFFFFF, 0x04, 0x01)
Sleep (0x10)
Local0 = 0x00
While ((RDCA (NCRN, 0xE2, 0x00, 0x00, 0x00) & 0x04))
{
If ((Local0 > 0x04))
{
Break
}
Sleep (0x10)
Local0++
}
RDCA (NCRN, 0x0324, 0xFFFFFFFF, 0x08, 0x01)
\_SB.PCI0.SAT0.POFF (RSTG)
If ((DerefOf (SCLK [0x00]) != 0x00))
{
PCRO (0xDC, 0x100C, DerefOf (SCLK [0x01]))
Sleep (0x10)
}
\_SB.PCI0.SAT0.POFF (PWRG)
RDCA (NCRN, 0x50, 0xFFFFFFFF, 0x10, 0x01)
RDCA (NCRN, 0x50, 0xFFFFFFEF, 0x00, 0x01)
ISD3 = 0x03
}
Method (NVD3, 0, Serialized)
{
If ((NITV == 0x00))
{
Return (0x00)
}
PCMD = RDCA (NCRN, 0x04, 0x00, 0x00, 0x02)
If ((NITV == 0x01))
{
PRBI = 0x24
PRBD = RDCA (NCRN, 0x24, 0x00, 0x00, 0x02)
}
ElseIf ((NITV == 0x02))
{
PRBI = 0x10
PRBD = RDCA (NCRN, 0x10, 0x00, 0x00, 0x02)
OperationRegion (MCRC, SystemMemory, (\_SB.PCI0.GPCB () + (0x000B8000 + 0x033C)), 0x04)
Field (MCRC, AnyAcc, NoLock, Preserve)
{
SCSO, 8,
Offset (0x02),
TCSO, 8,
, 7,
RE, 1
}
MXIE = RDCA (NCRN, TCSO, 0x00, 0x00, 0x02)
}
RDCA (NCRN, (NPMV + 0x04), 0xFFFFFFFC, 0x03, 0x03)
RDCA (NCRN, 0xA4, 0xFFFFFFFC, 0x03, 0x01)
Return (0x01)
}
Method (NVD0, 0, Serialized)
{
If ((NITV == 0x00))
{
Return (0x00)
}
RDCA (NCRN, 0xA4, 0xFFFFFFFC, 0x00, 0x01)
RDCA (NCRN, (NPMV + 0x04), 0xFFFFFFFC, 0x00, 0x03)
CNRS ()
If ((NITV == 0x02))
{
OperationRegion (MCRC, SystemMemory, (\_SB.PCI0.GPCB () + (0x000B8000 + 0x033C)), 0x04)
Field (MCRC, AnyAcc, NoLock, Preserve)
{
SCSO, 8,
Offset (0x02),
TCSO, 8,
, 7,
RE, 1
}
RDCA (NCRN, TCSO, 0xFFFFFFFF, (MXIE & 0x80000000), 0x03)
ADBG ("NVD0: MSIXe")
}
Else
{
}
Return (0x01)
}
Method (CNRS, 0, Serialized)
{
Debug = "[ACPI RST] Restore Remapped Device and Hidden RP context |start"
ADBG (Concatenate ("CNRSs ", ToDecimalString (Timer)))
If ((NITV == 0x00))
{
Return (Zero)
}
RDCA (NCRN, 0x10, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x14, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x18, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x1C, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x20, 0x00, 0x00, 0x03)
RDCA (NCRN, 0x24, 0x00, 0x00, 0x03)
RDCA (NCRN, PRBI, 0x00, PRBD, 0x03)
RDCA (NCRN, 0x04, 0xFFFFFFF8, PCMD, 0x03)
If ((NL1V != 0x00))
{
RDCA (NCRN, (NL1V + 0x0C), 0xFFFFFF00, ND2V, 0x03)
RDCA (NCRN, (NL1V + 0x08), 0x0F, (ND1V & 0xFFFFFFF0), 0x03)
RDCA (NCRN, (NL1V + 0x08), 0xFFFFFFFF, ND1V, 0x03)
}
If ((NLRV != 0x00))
{
RDCA (NCRN, (NLRV + 0x04), 0xFFFFFFFF, NLDV, 0x03)
}
RDCA (NCRN, (NPCV + 0x10), 0xFFFFFEBF, (NEAV & 0xFFFC), 0x03)
RDCA (NCRN, (NPCV + 0x28), 0xFFFFFBFF, NECV, 0x03)
RDCA (NCRN, (NPCV + 0x08), 0xFFFFFF1F, NEBV, 0x03)
RDCA (NCRN, 0x68, 0xFFFFFBFF, NRAV, 0x01)
If (((NEAV & 0x40) == 0x40))
{
RDCA (NCRN, 0x50, 0xFFFFFFDF, 0x20, 0x01)
ADBG (Concatenate ("CNRSw ", ToDecimalString (Timer)))
While (((RDCA (NCRN, 0x52, 0x00, 0x00, 0x00) & 0x2000) == 0x00))
{
Stall (0x0A)
}
}
ADBG (Concatenate ("CNRSx ", ToDecimalString (Timer)))
RDCA (NCRN, (NPCV + 0x10), 0xFFFFFFFC, (NEAV & 0x03), 0x03)
If ((NMVV != 0x00))
{
RDCA (NCRN, NMBV, 0x00, NMVV, 0x03)
}
If ((NPVV != 0x00))
{
RDCA (NCRN, NPBV, 0x00, NPVV, 0x03)
}
ADBG (Concatenate ("CNRSe ", ToDecimalString (Timer)))
Debug = "[ACPI RST] Restore Remapped Device and Hidden RP context |complete"
}
}
Method (PSTA, 1, Serialized)
{
If ((DerefOf (Arg0 [0x00]) == 0x00))
{
Return (0x01)
}
If ((DerefOf (Arg0 [0x00]) == 0x01))
{
If ((\_SB.GGOV (DerefOf (Arg0 [0x02])) == DerefOf (Arg0 [0x03]
)))
{
Return (0x01)
}
Return (0x00)
}
If ((DerefOf (Arg0 [0x00]) == 0x02))
{
If ((\_SB.PCI0.GEXP.GEPS (DerefOf (Arg0 [0x01]), DerefOf (Arg0 [0x02]
)) == DerefOf (Arg0 [0x03])))
{
Return (0x01)
}
Return (0x00)
}
Return (0x00)
}
Method (PON, 1, Serialized)
{
If ((DerefOf (Arg0 [0x00]) != 0x00))
{
If ((DerefOf (Arg0 [0x00]) == 0x01))
{
ADBG (Concatenate ("PON GPIO=", ToHexString (DerefOf (Arg0 [0x02]))))
\_SB.SGOV (DerefOf (Arg0 [0x02]), DerefOf (Arg0 [0x03]))
}
If ((DerefOf (Arg0 [0x00]) == 0x02))
{
ADBG (Concatenate ("PON IOEX=", ToHexString (DerefOf (Arg0 [0x02]))))
\_SB.PCI0.GEXP.SGEP (DerefOf (Arg0 [0x01]), DerefOf (Arg0 [0x02]), DerefOf (
Arg0 [0x03]))
}
}
}
Method (POFF, 1, Serialized)
{
If ((DerefOf (Arg0 [0x00]) != 0x00))
{
If ((DerefOf (Arg0 [0x00]) == 0x01))
{
ADBG (Concatenate ("POFF GPIO=", ToHexString (DerefOf (Arg0 [0x02]))))
\_SB.SGOV (DerefOf (Arg0 [0x02]), (DerefOf (Arg0 [0x03]) ^
0x01))
}
If ((DerefOf (Arg0 [0x00]) == 0x02))
{
ADBG (Concatenate ("POFF IOEX=", ToHexString (DerefOf (Arg0 [0x02]))))
\_SB.PCI0.GEXP.SGEP (DerefOf (Arg0 [0x01]), DerefOf (Arg0 [0x02]), (
DerefOf (Arg0 [0x03]) ^ 0x01))
}
}
}
}
Device (CIO2)
{
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (0x0F)
}
If ((CIOE == 0x01))
{
Name (_HID, "INT343E") // _HID: Hardware ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Name (CBUF, ResourceTemplate ()
{
Interrupt (ResourceConsumer, Level, ActiveLow, Shared, ,, _Y1D)
{
0x00000010,
}
Memory32Fixed (ReadWrite,
0xFE400000, // Address Base
0x00010000, // Address Length
)
})
CreateDWordField (CBUF, \_SB.PCI0.CIO2._CRS._Y1D._INT, CIOV) // _INT: Interrupts
CIOV = CIOI /* \CIOI */
Return (CBUF) /* \_SB_.PCI0.CIO2._CRS.CBUF */
}
}
Else
{
Name (_ADR, 0x00140003) // _ADR: Address
}
}
}
Scope (\_SB)
{
Name (HDAA, 0x00)
Name (DISA, 0x01)
Method (DION, 0, NotSerialized)
{
VMMH (0x01, 0x01)
}
Method (DIOF, 0, NotSerialized)
{
VMMH (0x01, 0x00)
}
Method (VMMH, 2, Serialized)
{
If ((!CondRefOf (\_SB.VMON) || !CondRefOf (\_SB.VMOF)))
{
Return (Zero)
}
Switch (ToInteger (Arg0))
{
Case (0x00)
{
HDAA = Arg1
}
Case (0x01)
{
DISA = Arg1
}
Default
{
Return (Zero)
}
}
If ((!DISA && !HDAA))
{
XSQD = 0x00
SLS0 = 0x01
\_SB.VMON ()
}
Else
{
XSQD = 0x01
SLS0 = 0x00
\_SB.VMOF ()
}
}
}
Scope (\_SB.PCI0)
{
Method (LPD3, 1, Serialized)
{
OperationRegion (ICB1, SystemMemory, (Arg0 + 0x84), 0x04)
Field (ICB1, DWordAcc, NoLock, Preserve)
{
PMEC, 32
}
PMEC = 0x03
TEMP = PMEC /* \_SB_.PCI0.LPD3.PMEC */
}
Method (LPD0, 1, Serialized)
{
OperationRegion (ICB1, SystemMemory, (Arg0 + 0x84), 0x04)
Field (ICB1, DWordAcc, NoLock, Preserve)
{
PMEC, 32
}
PMEC &= 0xFFFF7FFC
TEMP = PMEC /* \_SB_.PCI0.LPD0.PMEC */
}
Method (LHRV, 1, Serialized)
{
OperationRegion (ICB1, SystemMemory, (Arg0 + 0x08), 0x04)
Field (ICB1, DWordAcc, NoLock, Preserve)
{
HRV, 8
}
Return (HRV) /* \_SB_.PCI0.LHRV.HRV_ */
}
Method (GETD, 1, Serialized)
{
OperationRegion (ICB1, SystemMemory, (Arg0 + 0x84), 0x04)
Field (ICB1, DWordAcc, NoLock, Preserve)
{
PMEC, 32
}
Return ((PMEC & 0x03))
}
Method (LCRS, 3, Serialized)
{
Name (RBUF, ResourceTemplate ()
{
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00001000, // Address Length
_Y1E)
Interrupt (ResourceConsumer, Level, ActiveLow, Shared, ,, _Y1F)
{
0x00000014,
}
})
CreateDWordField (RBUF, \_SB.PCI0.LCRS._Y1E._BAS, BVAL) // _BAS: Base Address
CreateDWordField (RBUF, \_SB.PCI0.LCRS._Y1E._LEN, BLEN) // _LEN: Length
CreateDWordField (RBUF, \_SB.PCI0.LCRS._Y1F._INT, IRQN) // _INT: Interrupts
BVAL = Arg1
IRQN = Arg2
If ((Arg0 == 0x04))
{
BLEN = 0x08
}
Return (RBUF) /* \_SB_.PCI0.LCRS.RBUF */
}
Method (LSTA, 1, Serialized)
{
If (((Arg0 == 0x00) || (Arg0 == 0x03)))
{
Return (0x00)
}
If ((OSYS < 0x07DC))
{
Return (0x00)
}
Return (0x0F)
}
Method (GIRQ, 1, Serialized)
{
Return ((0x18 + (Arg0 % 0x60)))
}
}
Scope (\_SB.PCI0)
{
Device (SIRC)
{
Name (_HID, EisaId ("PNP0C02") /* PNP Motherboard Resources */) // _HID: Hardware ID
Name (_STA, 0x03) // _STA: Status
Name (_UID, 0x05) // _UID: Unique ID
Method (ADDB, 3, Serialized)
{
Name (BUFF, ResourceTemplate ()
{
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00001000, // Address Length
_Y20)
})
CreateDWordField (BUFF, \_SB.PCI0.SIRC.ADDB._Y20._BAS, ADDR) // _BAS: Base Address
CreateDWordField (BUFF, \_SB.PCI0.SIRC.ADDB._Y20._LEN, LENG) // _LEN: Length
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((((Arg0 == 0x01) || (Arg0 == 0x03)) || (Arg0 == 0x04)))
{
ADDR = Arg2
ConcatenateResTemplate (Local0, BUFF, Local1)
Local0 = Local1
}
If ((Arg0 == 0x03))
{
ADDR = Arg1
ConcatenateResTemplate (Local0, BUFF, Local1)
Local0 = Local1
}
If ((Arg0 == 0x04))
{
ADDR = (0x08 + Arg1)
LENG = 0x0FF8
ConcatenateResTemplate (Local0, BUFF, Local1)
Local0 = Local1
}
Return (Local0)
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
ConcatenateResTemplate (Local0, ADDB (SMD0, SB00, SB10), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD1, SB01, SB11), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD2, SB02, SB12), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD3, SB03, SB13), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD4, SB04, SB14), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD5, SB05, SB15), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD6, SB06, SB16), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD7, SB07, SB17), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD8, SB08, SB18), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMD9, SB09, SB19), Local1)
Local0 = Local1
ConcatenateResTemplate (Local0, ADDB (SMDA, SB0A, SB1A), Local1)
Local0 = Local1
If ((\_SB.PCI0.GPI0._STA () == 0x00))
{
ConcatenateResTemplate (Local0, \_SB.PCI0.GPI0._CRS (), Local1)
Local0 = Local1
}
Return (Local0)
}
}
Device (GPI0)
{
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
If ((PCHV () == SPTH))
{
If ((PCHG == 0x02))
{
Return ("INT3451")
}
Return ("INT345D")
}
Return ("INT344B")
}
Name (LINK, "\\_SB.PCI0.GPI0")
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Name (RBUF, ResourceTemplate ()
{
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00010000, // Address Length
_Y21)
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00010000, // Address Length
_Y22)
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00010000, // Address Length
_Y24)
Interrupt (ResourceConsumer, Level, ActiveLow, Shared, ,, _Y23)
{
0x0000000E,
}
})
CreateDWordField (RBUF, \_SB.PCI0.GPI0._CRS._Y21._BAS, COM0) // _BAS: Base Address
CreateDWordField (RBUF, \_SB.PCI0.GPI0._CRS._Y22._BAS, COM1) // _BAS: Base Address
CreateDWordField (RBUF, \_SB.PCI0.GPI0._CRS._Y23._INT, IRQN) // _INT: Interrupts
COM0 = (SBRG + 0x00AF0000)
COM1 = (SBRG + 0x00AE0000)
CreateDWordField (RBUF, \_SB.PCI0.GPI0._CRS._Y24._BAS, COM3) // _BAS: Base Address
COM3 = (SBRG + 0x00AC0000)
IRQN = SGIR /* \SGIR */
Return (RBUF) /* \_SB_.PCI0.GPI0._CRS.RBUF */
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((SBRG == 0x00))
{
Return (0x00)
}
If ((GPEN == 0x00))
{
Return (0x00)
}
Return (0x0F)
}
}
}
Scope (\_SB.PCI0)
{
Device (I2C0)
{
Name (LINK, "\\_SB.PCI0.I2C0")
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB10))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB10)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB10)
}
If ((SMD0 != 0x02))
{
Name (_HID, "INT3442") // _HID: Hardware ID
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB10))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD0, SB00, SIR0))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD0))
}
}
If ((SMD0 == 0x02))
{
Name (_ADR, 0x00150000) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
}
Scope (\_SB.PCI0)
{
Device (I2C1)
{
Name (LINK, "\\_SB.PCI0.I2C1")
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB11))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB11)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB11)
}
If ((SMD1 != 0x02))
{
Name (_HID, "INT3443") // _HID: Hardware ID
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB11))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD1, SB01, SIR1))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD1))
}
}
If ((SMD1 == 0x02))
{
Name (_ADR, 0x00150001) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
}
Scope (\_SB.PCI0)
{
Device (I2C2)
{
Name (LINK, "\\_SB.PCI0.I2C2")
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB12))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB12)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB12)
}
If ((SMD2 != 0x02))
{
Name (_HID, "INT3444") // _HID: Hardware ID
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB12))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD2, SB02, SIR2))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD2))
}
}
If ((SMD2 == 0x02))
{
Name (_ADR, 0x00150002) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
}
Scope (\_SB.PCI0)
{
Device (I2C3)
{
Name (LINK, "\\_SB.PCI0.I2C3")
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB13))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB13)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB13)
}
If ((SMD3 != 0x02))
{
Name (_HID, "INT3445") // _HID: Hardware ID
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB13))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD3, SB03, SIR3))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD3))
}
}
If ((SMD3 == 0x02))
{
Name (_ADR, 0x00150003) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
}
Scope (\_SB.PCI0)
{
Device (I2C4)
{
Name (LINK, "\\_SB.PCI0.I2C4")
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB14))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB14)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB14)
}
If ((SMD4 != 0x02))
{
Name (_HID, "INT3446") // _HID: Hardware ID
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB14))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD4, SB04, SIR4))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD4))
}
}
If ((SMD4 == 0x02))
{
Name (_ADR, 0x00190002) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
}
Scope (\_SB.PCI0)
{
Device (I2C5)
{
Name (LINK, "\\_SB.PCI0.I2C5")
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB15))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB15)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB15)
}
If ((SMD5 != 0x02))
{
Name (_HID, "INT3447") // _HID: Hardware ID
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB15))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD5, SB05, SIR5))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD5))
}
}
If ((SMD5 == 0x02))
{
Name (_ADR, 0x00190001) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
}
Scope (\_SB.PCI0)
{
Device (SPI0)
{
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB16))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB16)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB16)
}
If ((SMD6 != 0x02))
{
Name (_HID, "INT3440") // _HID: Hardware ID
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB16))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD6, SB06, SIR6))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD6))
}
}
If ((SMD6 == 0x02))
{
Name (_ADR, 0x001E0002) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
}
Scope (\_SB.PCI0)
{
Device (SPI1)
{
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB17))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB17)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB17)
}
If ((SMD7 != 0x02))
{
Name (_HID, "INT3441") // _HID: Hardware ID
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB17))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD7, SB07, SIR7))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD7))
}
}
If ((SMD7 == 0x02))
{
Name (_ADR, 0x001E0003) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
}
Scope (\_SB.PCI0)
{
Device (UA00)
{
If ((SMD8 != 0x02))
{
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
If ((SMD8 == 0x04))
{
Return (0x020CD041)
}
Else
{
Return ("INT3448")
}
}
Name (_UID, "SerialIoUart0") // _UID: Unique ID
Name (_DDN, "SerialIoUart0") // _DDN: DOS Device Name
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB18))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD8, SB08, SIR8))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD8))
}
}
If ((SMD8 == 0x02))
{
Name (_ADR, 0x001E0000) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
If ((SMD8 != 0x04))
{
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB18))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB18)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB18)
}
}
}
}
Scope (\_SB.PCI0)
{
Device (UA01)
{
If ((SMD9 != 0x02))
{
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
If ((SMD9 == 0x04))
{
Return (0x020CD041)
}
Else
{
Return ("INT3449")
}
}
Name (_UID, "SerialIoUart1") // _UID: Unique ID
Name (_DDN, "SerialIoUart1") // _DDN: DOS Device Name
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB19))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMD9, SB09, SIR9))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMD9))
}
}
If ((SMD9 == 0x02))
{
Name (_ADR, 0x001E0001) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
If ((SMD9 != 0x04))
{
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB19))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB19)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB19)
}
}
}
}
Scope (\_SB.PCI0)
{
Device (UA02)
{
If ((SMDA != 0x02))
{
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
If ((SMDA == 0x04))
{
Return (0x020CD041)
}
Else
{
Return ("INT344A")
}
}
Name (_UID, "SerialIoUart2") // _UID: Unique ID
Name (_DDN, "SerialIoUart2") // _DDN: DOS Device Name
Method (_HRV, 0, NotSerialized) // _HRV: Hardware Revision
{
Return (LHRV (SB1A))
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Return (LCRS (SMDA, SB0A, SIRA))
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (LSTA (SMDA))
}
}
If ((SMDA == 0x02))
{
Name (_ADR, 0x00190000) // _ADR: Address
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
If ((SMDA != 0x04))
{
Method (_PSC, 0, NotSerialized) // _PSC: Power State Current
{
Return (GETD (SB1A))
}
Method (_PS0, 0, NotSerialized) // _PS0: Power State 0
{
LPD0 (SB1A)
}
Method (_PS3, 0, NotSerialized) // _PS3: Power State 3
{
LPD3 (SB1A)
}
}
}
}
Scope (\_SB.PCI0)
{
Name (HIDG, ToUUID ("3cdff6f7-4267-4555-ad05-b30a3d8938de") /* HID I2C Device */)
Name (TP7G, ToUUID ("ef87eb82-f951-46da-84ec-14871ac6f84b"))
Method (HIDD, 5, Serialized)
{
If ((Arg0 == HIDG))
{
If ((Arg2 == Zero))
{
If ((Arg1 == One))
{
Return (Buffer (One)
{
0x03 // .
})
}
}
If ((Arg2 == One))
{
Return (Arg4)
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Method (TP7D, 6, Serialized)
{
If ((Arg0 == TP7G))
{
If ((Arg2 == Zero))
{
If ((Arg1 == One))
{
Return (Buffer (One)
{
0x03 // .
})
}
}
If ((Arg2 == One))
{
Return (ConcatenateResTemplate (Arg4, Arg5))
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Scope (\_SB.PCI0.I2C0)
{
Device (TPL0)
{
Name (HID2, 0x00)
Name (MDE0, 0x01)
Name (SBFB, ResourceTemplate ()
{
I2cSerialBusV2 (0x000A, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C0",
0x00, ResourceConsumer, _Y25, Exclusive,
)
})
Name (SBFG, ResourceTemplate ()
{
GpioInt (Level, ActiveLow, Exclusive, PullDefault, 0x0000,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
})
Name (SBFI, ResourceTemplate ()
{
Interrupt (ResourceConsumer, Level, ActiveLow, Exclusive, ,, _Y26)
{
0x00000000,
}
})
CreateWordField (SBFB, \_SB.PCI0.I2C0.TPL0._Y25._ADR, BADR) // _ADR: Address
CreateDWordField (SBFB, \_SB.PCI0.I2C0.TPL0._Y25._SPE, SPED) // _SPE: Speed
CreateDWordField (SBFI, \_SB.PCI0.I2C0.TPL0._Y26._INT, INT2) // _INT: Interrupts
CreateWordField (SBFG, 0x17, INT1)
Method (_INI, 0, Serialized) // _INI: Initialize
{
If ((OSYS < 0x07DC))
{
SRXO (GPLI, 0x01)
}
INT1 = GNUM (GPLI)
INT2 = INUM (GPLI)
If ((MDE0 == 0x00))
{
SHPO (GPLI, 0x01)
}
Switch (ToInteger (\WPID))
{
Case (0x01)
{
_HID = "WCOM5115"
HID2 = 0x01
BADR = 0x0A
SPED = 0x00061A80
}
Case (0x02)
{
_HID = "WCOM5116"
HID2 = 0x01
BADR = 0x0A
SPED = 0x00061A80
}
Case (0x03)
{
_HID = "WCOM5117"
HID2 = 0x01
BADR = 0x0A
SPED = 0x00061A80
}
Case (0x04)
{
_HID = "WCOM5118"
HID2 = 0x01
BADR = 0x0A
SPED = 0x00061A80
}
Default
{
_HID = "WCOM5115"
HID2 = 0x01
BADR = 0x0A
SPED = 0x00061A80
}
}
}
Name (_HID, "XXXX0000") // _HID: Hardware ID
Name (_CID, "PNP0C50" /* HID Protocol Device (I2C bus) */) // _CID: Compatible ID
Name (_S0W, 0x04) // _S0W: S0 Device Wake State
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If ((Arg0 == HIDG))
{
Return (HIDD (Arg0, Arg1, Arg2, Arg3, HID2))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (0x0F)
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
If ((MDE0 == 0x00))
{
Return (ConcatenateResTemplate (SBFB, SBFG))
}
Return (ConcatenateResTemplate (SBFB, SBFI))
}
}
}
Scope (\_SB.PCI0.I2C1)
{
Device (TPL1)
{
Name (HID2, 0x00)
Name (SBFB, ResourceTemplate ()
{
I2cSerialBusV2 (0x004C, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C1",
0x00, ResourceConsumer, _Y27, Exclusive,
)
})
Name (SBFG, ResourceTemplate ()
{
GpioInt (Level, ActiveLow, Exclusive, PullDefault, 0x0000,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
})
Name (SBFI, ResourceTemplate ()
{
Interrupt (ResourceConsumer, Level, ActiveLow, Exclusive, ,, _Y28)
{
0x00000000,
}
})
CreateWordField (SBFB, \_SB.PCI0.I2C1.TPL1._Y27._ADR, BADR) // _ADR: Address
CreateDWordField (SBFB, \_SB.PCI0.I2C1.TPL1._Y27._SPE, SPED) // _SPE: Speed
CreateDWordField (SBFI, \_SB.PCI0.I2C1.TPL1._Y28._INT, INT2) // _INT: Interrupts
CreateWordField (SBFG, 0x17, INT1)
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
If ((OSYS < 0x07DC))
{
SRXO (GPLI, 0x01)
}
INT1 = GNUM (GPLI)
INT2 = INUM (GPLI)
If ((SDM1 == 0x00))
{
SHPO (GPLI, 0x01)
}
If ((SDS1 == 0x01))
{
_HID = "ATML3432"
HID2 = 0x00
BADR = 0x4C
SPED = 0x00061A80
Return (Zero)
}
If ((SDS1 == 0x02))
{
_HID = "ATML2952"
HID2 = 0x00
BADR = 0x4A
SPED = 0x00061A80
Return (Zero)
}
If ((SDS1 == 0x03))
{
_HID = "ELAN2097"
HID2 = 0x01
BADR = 0x10
SPED = 0x00061A80
Return (Zero)
}
If ((SDS1 == 0x04))
{
_HID = "NTRG0001"
HID2 = 0x01
BADR = 0x07
SPED = 0x00061A80
Return (Zero)
}
If ((SDS1 == 0x05))
{
_HID = "NTRG0002"
HID2 = 0x01
BADR = 0x64
SPED = 0x00061A80
Return (Zero)
}
If ((SDS1 == 0x06))
{
_HID = "WCOM508E"
HID2 = 0x01
BADR = 0x0A
If ((TPLS == 0x00))
{
SPED = 0x00061A80
}
If ((TPLS == 0x01))
{
SPED = 0x000F4240
}
Return (Zero)
}
If ((SDS1 == 0x07))
{
_HID = "CUST0000"
HID2 = TPLH /* \TPLH */
BADR = TPLB /* \TPLB */
If ((TPLS == 0x00))
{
SPED = 0x000186A0
}
If ((TPLS == 0x01))
{
SPED = 0x00061A80
}
If ((TPLS == 0x02))
{
SPED = 0x000F4240
}
Return (Zero)
}
}
Name (_HID, "XXXX0000") // _HID: Hardware ID
Name (_CID, "PNP0C50" /* HID Protocol Device (I2C bus) */) // _CID: Compatible ID
Name (_S0W, 0x04) // _S0W: S0 Device Wake State
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If ((Arg0 == HIDG))
{
Return (HIDD (Arg0, Arg1, Arg2, Arg3, HID2))
}
If ((Arg0 == TP7G))
{
Return (TP7D (Arg0, Arg1, Arg2, Arg3, SBFB, SBFG))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((SDS1 != 0x00))
{
Return (0x0F)
}
Return (0x00)
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
If ((OSYS < 0x07DC))
{
Return (SBFI) /* \_SB_.PCI0.I2C1.TPL1.SBFI */
}
If ((SDM1 == 0x00))
{
Return (ConcatenateResTemplate (SBFB, SBFG))
}
Return (ConcatenateResTemplate (SBFB, SBFI))
}
}
Device (IMP3)
{
Name (_ADR, Zero) // _ADR: Address
Name (_HID, "IMPJ0003") // _HID: Hardware ID
Name (_CID, "IMPJ0003") // _CID: Compatible ID
Name (_UID, One) // _UID: Unique ID
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((HAID == 0x01))
{
Return (0x0F)
}
Return (0x00)
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Name (SBUF, ResourceTemplate ()
{
I2cSerialBusV2 (0x006E, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C1",
0x00, ResourceConsumer, , Exclusive,
)
})
Return (SBUF) /* \_SB_.PCI0.I2C1.IMP3._CRS.SBUF */
}
}
}
Scope (\_SB.PCI0.SPI0)
{
Device (FPNT)
{
Name (_ADR, Zero) // _ADR: Address
Name (_HID, "SYNA8001") // _HID: Hardware ID
Name (_DDN, "Synaptics Fingerprint Sensor SYNA8001") // _DDN: DOS Device Name
Name (_UID, One) // _UID: Unique ID
Name (SFPI, 0x02010015)
Name (SFPS, 0x02010016)
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (\_SB.PCI0.LPCB.FPRD)
{
Return (0x00)
}
Else
{
Return (0x0F)
}
}
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
SHPO (SFPI, 0x01)
SHPO (SFPS, 0x01)
}
Name (BBUF, ResourceTemplate ()
{
SpiSerialBusV2 (0x0001, PolarityLow, FourWireMode, 0x08,
ControllerInitiated, 0x007A1200, ClockPolarityLow,
ClockPhaseFirst, "\\_SB.PCI0.SPI0",
0x00, ResourceConsumer, , Exclusive,
)
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionInputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
})
Name (IBUF, ResourceTemplate ()
{
Interrupt (ResourceConsumer, Edge, ActiveHigh, Exclusive, ,, _Y29)
{
0x00000000,
}
})
CreateWordField (BBUF, 0x3B, SPIN)
CreateWordField (BBUF, 0x63, SINP)
CreateDWordField (IBUF, \_SB.PCI0.SPI0.FPNT._Y29._INT, IPIN) // _INT: Interrupts
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
SPIN = GNUM (SFPS)
SINP = GNUM (SFPI)
IPIN = INUM (SFPI)
Return (ConcatenateResTemplate (BBUF, IBUF))
}
Method (_PS0, 0, Serialized) // _PS0: Power State 0
{
\_SB.SGOV (0x02010016, 0x01)
}
Method (_PS3, 0, Serialized) // _PS3: Power State 3
{
\_SB.SGOV (0x02010016, 0x00)
}
}
}
Scope (\_SB.PCI0.SPI1)
{
Device (FPNT)
{
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
If ((SDS7 == 0x01))
{
Return ("FPC1011")
}
If ((SDS7 == 0x02))
{
Return ("FPC1020")
}
If ((SDS7 == 0x03))
{
Return ("VFSI6101")
}
If ((SDS7 == 0x04))
{
Return ("VFSI7500")
}
If ((SDS7 == 0x05))
{
Return ("EGIS0300")
}
If ((SDS7 == 0x06))
{
Return ("FPC1021")
}
Return ("FPNT_DIS")
}
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
SHPO (GFPI, 0x01)
SHPO (GFPS, 0x01)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((SDS7 != 0x00))
{
Return (0x0F)
}
Return (0x00)
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
Name (BBUF, ResourceTemplate ()
{
SpiSerialBusV2 (0x0000, PolarityLow, FourWireMode, 0x08,
ControllerInitiated, 0x00989680, ClockPolarityLow,
ClockPhaseFirst, "\\_SB.PCI0.SPI1",
0x00, ResourceConsumer, _Y2A, Exclusive,
)
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0008
}
})
Name (IBUF, ResourceTemplate ()
{
Interrupt (ResourceConsumer, Level, ActiveLow, ExclusiveAndWake, ,, _Y2B)
{
0x00000000,
}
})
Name (GBUF, ResourceTemplate ()
{
GpioInt (Level, ActiveLow, ExclusiveAndWake, PullDefault, 0x0000,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, _Y2C,
)
{ // Pin list
0x0000
}
})
Name (UBUF, ResourceTemplate ()
{
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionInputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
})
CreateDWordField (BBUF, \_SB.PCI0.SPI1.FPNT._CRS._Y2A._SPE, SPEX) // _SPE: Speed
CreateByteField (BBUF, \_SB.PCI0.SPI1.FPNT._CRS._Y2A._PHA, PHAX) // _PHA: Clock Phase
CreateWordField (BBUF, 0x3B, SPIN)
CreateWordField (GBUF, 0x17, GPIN)
CreateDWordField (IBUF, \_SB.PCI0.SPI1.FPNT._CRS._Y2B._INT, IPIN) // _INT: Interrupts
CreateBitField (IBUF, \_SB.PCI0.SPI1.FPNT._CRS._Y2B._LL, ILVL) // _LL_: Low Level
CreateBitField (IBUF, \_SB.PCI0.SPI1.FPNT._CRS._Y2B._HE, ITRG) // _HE_: High-Edge
CreateField (GBUF, \_SB.PCI0.SPI1.FPNT._CRS._Y2C._POL, 0x02, GLVL) // _POL: Polarity
CreateBitField (GBUF, \_SB.PCI0.SPI1.FPNT._CRS._Y2C._MOD, GTRG) // _MOD: Mode
CreateBitField (BBUF, \_SB.PCI0.SPI1.FPNT._CRS._Y2A._DPL, SCSP) // _DPL: Device Selection Polarity
CreateWordField (UBUF, 0x17, UPIN)
SPIN = GNUM (GFPS)
GPIN = GNUM (GFPI)
IPIN = INUM (GFPI)
UPIN = GNUM (GFPI)
If (((SDS7 == 0x02) || (SDS7 == 0x06)))
{
ILVL = 0x00
ITRG = 0x01
GLVL = 0x00
GTRG = 0x01
}
If ((SDS7 == 0x04))
{
ILVL = 0x00
ITRG = 0x01
}
Switch (ToInteger (SDS7))
{
Case (0x01)
{
SPEX = 0x00989680
PHAX = 0x00
}
Case (0x02)
{
SPEX = 0x002DC6C0
PHAX = 0x00
}
Case (0x03)
{
SPEX = 0x007A1200
PHAX = 0x01
}
Case (0x04)
{
SPEX = 0x007A1200
PHAX = 0x00
}
Case (0x05)
{
SPEX = 0x00F42400
PHAX = 0x00
}
Case (0x06)
{
SPEX = 0x002DC6C0
PHAX = 0x00
}
Default
{
}
}
If ((SDS7 == 0x01))
{
Return (BBUF) /* \_SB_.PCI0.SPI1.FPNT._CRS.BBUF */
}
If (((SDS7 == 0x04) && (SDM7 == 0x00)))
{
Return (ConcatenateResTemplate (BBUF, ConcatenateResTemplate (UBUF, GBUF)))
}
If (((SDS7 == 0x04) && (SDM7 != 0x00)))
{
Return (ConcatenateResTemplate (BBUF, ConcatenateResTemplate (UBUF, IBUF)))
}
If ((SDM7 == 0x00))
{
Return (ConcatenateResTemplate (BBUF, GBUF))
}
Return (ConcatenateResTemplate (BBUF, IBUF))
}
}
}
Scope (\_SB.PCI0.UA00)
{
Device (BTH0)
{
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
If ((SDS8 == 0x01))
{
Return ("INT33E1")
}
If ((SDS8 == 0x02))
{
Return ("BCM2E40")
}
Return ("INT33E1")
}
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
SHPO (GBTI, 0x01)
SHPO (GBTW, 0x01)
SHPO (GBTK, 0x01)
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Name (SBFG, ResourceTemplate ()
{
UartSerialBusV2 (0x0001C200, DataBitsEight, StopBitsOne,
0xC0, LittleEndian, ParityTypeNone, FlowControlHardware,
0x0020, 0x0020, "\\_SB.PCI0.UA00",
0x00, ResourceConsumer, , Exclusive,
)
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
GpioInt (Edge, ActiveLow, ExclusiveAndWake, PullDefault, 0x0000,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
})
CreateWordField (SBFG, 0x8C, INT3)
CreateWordField (SBFG, 0x3C, WAK3)
CreateWordField (SBFG, 0x64, KIL3)
INT3 = GNUM (GBTI)
WAK3 = GNUM (GBTW)
KIL3 = GNUM (GBTK)
Name (SBFI, ResourceTemplate ()
{
UartSerialBusV2 (0x0001C200, DataBitsEight, StopBitsOne,
0xC0, LittleEndian, ParityTypeNone, FlowControlHardware,
0x0020, 0x0020, "\\_SB.PCI0.UA00",
0x00, ResourceConsumer, , Exclusive,
)
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
Interrupt (ResourceConsumer, Edge, ActiveLow, ExclusiveAndWake, ,, _Y2D)
{
0x00000000,
}
})
CreateDWordField (SBFI, \_SB.PCI0.UA00.BTH0._CRS._Y2D._INT, INT4) // _INT: Interrupts
CreateWordField (SBFI, 0x3C, WAK4)
CreateWordField (SBFI, 0x64, KIL4)
INT4 = INUM (GBTI)
WAK4 = GNUM (GBTW)
KIL4 = GNUM (GBTK)
If ((SDM8 == 0x00))
{
Return (SBFG) /* \_SB_.PCI0.UA00.BTH0._CRS.SBFG */
}
Else
{
Return (SBFI) /* \_SB_.PCI0.UA00.BTH0._CRS.SBFI */
}
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((SDS8 != 0x00))
{
Return (0x0F)
}
Return (0x00)
}
Name (_S0W, 0x02) // _S0W: S0 Device Wake State
}
}
Scope (\_SB.PCI0)
{
Device (GNSS)
{
Name (_HID, "INT33A2") // _HID: Hardware ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Name (BUF1, ResourceTemplate ()
{
UartSerialBusV2 (0x0001C200, DataBitsEight, StopBitsOne,
0xC0, LittleEndian, ParityTypeNone, FlowControlHardware,
0x0040, 0x0040, "\\_SB.PCI0.UA01",
0x00, ResourceConsumer, , Exclusive,
)
})
Name (BUF2, ResourceTemplate ()
{
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0x0000
}
})
CreateWordField (BUF2, 0x17, RPIN)
RPIN = GNUM (GGNR)
If ((GNSC == 0x01))
{
Return (ConcatenateResTemplate (BUF1, BUF2))
}
Else
{
Return (BUF2) /* \_SB_.PCI0.GNSS._CRS.BUF2 */
}
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((GNSC == 0x00))
{
Return (0x00)
}
Return (0x0F)
}
}
}
Scope (\_SB.PCI0)
{
Device (GEXP)
{
Name (_ADR, 0x01) // _ADR: Address
Name (_STA, 0x0B) // _STA: Status
OperationRegion (BAR0, SystemMemory, SB04, 0x0208)
Field (BAR0, DWordAcc, NoLock, Preserve)
{
ICON, 32,
TAR, 32,
Offset (0x10),
DATA, 32,
HCNT, 32,
LCNT, 32,
Offset (0x2C),
, 5,
ABRT, 1,
Offset (0x40),
RBCK, 32,
Offset (0x54),
CLR, 32,
Offset (0x6C),
ENB, 1,
Offset (0x70),
ACTV, 1,
TFNF, 1,
, 1,
RFNE, 1,
Offset (0x7C),
HOLD, 32,
Offset (0x9C),
ENSB, 1,
Offset (0x204),
RST, 32
}
Method (SGEP, 3, Serialized)
{
CSER (GEXN, Arg0, Arg1, Arg2, 0x00)
}
Method (SGED, 3, Serialized)
{
CSER (GEXN, Arg0, Arg1, Arg2, 0x01)
}
Method (GEPS, 2, Serialized)
{
Return (CSER (GEXN, Arg0, Arg1, 0x00, 0x02))
}
Method (SGEI, 3, Serialized)
{
CSER (GEXN, Arg0, Arg1, Arg2, 0x03)
}
Method (INVC, 0, NotSerialized)
{
Local0 = 0x00
While ((Local0 < 0x10))
{
If ((R3DC (0x00, Local0, 0x00) == 0x02))
{
W3DC (0x00, Local0, 0x00, 0x01)
}
If ((R3DC (0x01, Local0, 0x00) == 0x02))
{
W3DC (0x01, Local0, 0x00, 0x01)
}
Local0 += 0x01
}
}
Name (PPR, 0x08)
Name (INR, Package (0x03)
{
0x00,
0x01,
0x02
})
Name (OUTR, Package (0x03)
{
0x04,
0x05,
0x06
})
Name (CFGR, Package (0x03)
{
0x0C,
0x0D,
0x0E
})
Name (POLR, Package (0x03)
{
0x08,
0x09,
0x0A
})
Name (EXPA, 0x22)
Name (UCCH, 0x01)
Name (END, 0x0200)
Name (READ, 0x0100)
Name (TEMP, 0x00)
Name (CACH, Package (0x02)
{
Package (0x10)
{
Package (0x02)
{
0x00,
0x00
},
Package (0x02)
{
0x00,
0x00
},
Package (0x02)
{
0x00,
0x00
},
Package (0x02)
{
0x03,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x03,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x03,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x03,
0x00
}
},
Package (0x10)
{
Package (0x02)
{
0x00,
0x00
},
Package (0x02)
{
0x00,
0x00
},
Package (0x02)
{
0x00,
0x00
},
Package (0x02)
{
0x03,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x03,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x03,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x01,
0x00
},
Package (0x02)
{
0x03,
0x00
}
}
})
Method (W3DC, 4, NotSerialized)
{
DerefOf (DerefOf (CACH [Arg0]) [Arg1]) [Arg2]
= Arg3
}
Method (R3DC, 3, NotSerialized)
{
Return (DerefOf (DerefOf (DerefOf (CACH [Arg0]) [Arg1]) [
Arg2]))
}
Method (WREG, 4, Serialized)
{
Local1 = (Timer + 0xC350)
RST = 0x07
ENB = 0x00
TEMP = RBCK /* \_SB_.PCI0.GEXP.RBCK */
TEMP = CLR /* \_SB_.PCI0.GEXP.CLR_ */
HOLD = 0x001C001C
HCNT = 0x0210
LCNT = 0x0280
TAR = (EXPA + Arg1)
ICON = 0x65
ENB = 0x01
While ((ENSB != 0x01))
{
If ((Timer > Local1))
{
Return (0x00)
}
}
DATA = Arg2
DATA = (END + Arg3)
While ((ACTV != 0x00))
{
If ((Timer > Local1))
{
Return (0x00)
}
}
ENB = 0x00
While ((ENSB != 0x00))
{
If ((Timer > Local1))
{
Return (0x00)
}
}
W3DC (Arg1, Arg2, 0x01, Arg3)
If ((R3DC (Arg1, Arg2, 0x00) == 0x01))
{
W3DC (Arg1, Arg2, 0x00, 0x02)
}
Return (0x00)
}
Method (RREG, 3, Serialized)
{
If ((UCCH == 0x01))
{
If ((R3DC (Arg1, Arg2, 0x00) == 0x02))
{
Return (R3DC (Arg1, Arg2, 0x01))
}
}
Local1 = (Timer + 0xC350)
RST = 0x07
ENB = 0x00
TEMP = RBCK /* \_SB_.PCI0.GEXP.RBCK */
TEMP = CLR /* \_SB_.PCI0.GEXP.CLR_ */
HOLD = 0x001C001C
HCNT = 0x0210
LCNT = 0x0280
TAR = (EXPA + Arg1)
ICON = 0x65
ENB = 0x01
While ((ENSB != 0x01))
{
If ((Timer > Local1))
{
Return (0x00)
}
}
DATA = Arg2
DATA = (END + READ)
While ((ACTV != 0x00))
{
If ((Timer > Local1))
{
Return (0x00)
}
}
Local0 = DATA /* \_SB_.PCI0.GEXP.DATA */
ENB = 0x00
While ((ENSB != 0x00))
{
If ((Timer > Local1))
{
Return (0x00)
}
}
Return (Local0)
}
Method (PS0, 1, Serialized)
{
OperationRegion (BAR1, SystemMemory, Arg0, 0x88)
Field (BAR1, DWordAcc, NoLock, Preserve)
{
Offset (0x84),
D0D3, 2
}
D0D3 = 0x00
TEMP = D0D3 /* \_SB_.PCI0.GEXP.PS0_.D0D3 */
}
Method (PS3, 1, Serialized)
{
OperationRegion (BAR1, SystemMemory, Arg0, 0x88)
Field (BAR1, DWordAcc, NoLock, Preserve)
{
Offset (0x84),
D0D3, 2
}
D0D3 = 0x03
TEMP = D0D3 /* \_SB_.PCI0.GEXP.PS3_.D0D3 */
}
Method (CSER, 5, Serialized)
{
Name (SB1X, 0x00)
Name (SB0X, 0x00)
Name (SMDX, 0x00)
Name (PINN, 0x00)
Name (REGN, 0x00)
Name (REGA, 0x00)
Name (OLDV, 0x00)
Name (NEWV, 0x00)
Name (RETV, 0x00)
If ((Arg0 > 0x05))
{
Return (0x00)
}
If ((Arg0 == 0x00))
{
SB1X = SB10 /* \SB10 */
SB0X = SB00 /* \SB00 */
SMDX = SMD0 /* \SMD0 */
}
If ((Arg0 == 0x01))
{
SB1X = SB11 /* \SB11 */
SB0X = SB01 /* \SB01 */
SMDX = SMD1 /* \SMD1 */
}
If ((Arg0 == 0x02))
{
SB1X = SB12 /* \SB12 */
SB0X = SB02 /* \SB02 */
SMDX = SMD2 /* \SMD2 */
}
If ((Arg0 == 0x03))
{
SB1X = SB13 /* \SB13 */
SB0X = SB03 /* \SB03 */
SMDX = SMD3 /* \SMD3 */
}
If ((Arg0 == 0x04))
{
SB1X = SB14 /* \SB14 */
SB0X = SB04 /* \SB04 */
SMDX = SMD4 /* \SMD4 */
}
If ((Arg0 == 0x05))
{
SB1X = SB15 /* \SB15 */
SB0X = SB05 /* \SB05 */
SMDX = SMD5 /* \SMD5 */
}
If ((Arg0 > 0x05))
{
Return (0x00)
}
If ((Arg1 > 0x01))
{
Return (0x00)
}
If ((Arg2 > 0x17))
{
Return (0x00)
}
If ((Arg3 > 0x01))
{
Return (0x00)
}
If ((Arg4 > 0x02))
{
Return (0x00)
}
If ((SMDX != 0x03))
{
Return (0x00)
}
If ((Arg4 == 0x00))
{
Local0 = OUTR /* \_SB_.PCI0.GEXP.OUTR */
}
If ((Arg4 == 0x01))
{
Local0 = CFGR /* \_SB_.PCI0.GEXP.CFGR */
}
If ((Arg4 == 0x02))
{
Local0 = INR /* \_SB_.PCI0.GEXP.INR_ */
}
If ((Arg4 == 0x03))
{
Local0 = POLR /* \_SB_.PCI0.GEXP.POLR */
}
PS0 (SB1X)
Divide (Arg2, PPR, PINN, REGN) /* \_SB_.PCI0.GEXP.CSER.REGN */
REGA = DerefOf (Local0 [REGN])
OLDV = RREG (SB0X, Arg1, REGA)
If ((Arg4 == 0x02))
{
RETV = (0x01 & (OLDV >> PINN))
}
Else
{
NEWV = (OLDV & ~(0x01 << PINN))
NEWV |= (Arg3 << PINN) /* \_SB_.PCI0.GEXP.CSER.NEWV */
If ((NEWV != OLDV))
{
WREG (SB0X, Arg1, REGA, NEWV)
}
}
PS3 (SB1X)
Return (RETV) /* \_SB_.PCI0.GEXP.CSER.RETV */
}
}
}
If ((PCHV () == SPTL))
{
Scope (\_SB.PCI0)
{
Method (DLLR, 5, Serialized)
{
ADBG ("SD DLL restore flow")
Name (TEMP, 0x00)
Name (EMPB, 0x00)
EMPB = \XBAS /* External reference */
EMPB |= (Arg0 << 0x14)
EMPB |= (Arg1 << 0x0F)
EMPB |= (Arg2 << 0x0C)
OperationRegion (EMPC, SystemMemory, EMPB, 0x0100)
Field (EMPC, DWordAcc, NoLock, Preserve)
{
Offset (0x04),
, 1,
MSE, 1,
Offset (0x10),
BAR0, 64,
Offset (0x84),
PSTA, 32
}
Name (OPST, 0x00)
OPST = PSTA /* \_SB_.PCI0.DLLR.PSTA */
PSTA &= 0xFFFFFFFC
TEMP = PSTA /* \_SB_.PCI0.DLLR.PSTA */
Name (OMSE, 0x00)
OMSE = MSE /* \_SB_.PCI0.DLLR.MSE_ */
MSE = 0x00
Name (OBAR, 0x00)
OBAR = BAR0 /* \_SB_.PCI0.DLLR.BAR0 */
BAR0 = Arg3
TEMP = BAR0 /* \_SB_.PCI0.DLLR.BAR0 */
MSE = 0x01
OperationRegion (EMMI, SystemMemory, Arg3, Arg4)
Field (EMMI, DWordAcc, NoLock, Preserve)
{
Offset (0x834),
FDLL, 8,
Offset (0x840),
ADLL, 8
}
Name (FDLV, 0x00)
Name (ADLV, 0x00)
FDLV = FDLL /* \_SB_.PCI0.DLLR.FDLL */
ADLV = ADLL /* \_SB_.PCI0.DLLR.ADLL */
ADBG (Concatenate ("Fixed DLL value ", ToHexString (FDLV)))
ADBG (Concatenate ("Auto DLL Value ", ToHexString (ADLV)))
If ((ADLV != 0x00))
{
ADBG ("Auto tuning executed, restoring values")
ADLV *= 0x02
FDLL = ADLV /* \_SB_.PCI0.DLLR.ADLV */
}
MSE = 0x00
BAR0 = OBAR /* \_SB_.PCI0.DLLR.OBAR */
MSE = OMSE /* \_SB_.PCI0.DLLR.OMSE */
PSTA = OPST /* \_SB_.PCI0.DLLR.OPST */
TEMP = PSTA /* \_SB_.PCI0.DLLR.PSTA */
}
Device (PEMC)
{
Name (_ADR, 0x001E0004) // _ADR: Address
OperationRegion (SCSR, PCI_Config, 0x00, 0x0100)
Field (SCSR, WordAcc, NoLock, Preserve)
{
Offset (0x84),
PSTA, 32,
Offset (0xA2),
, 2,
PGEN, 1
}
Method (_PS0, 0, Serialized) // _PS0: Power State 0
{
PGEN = 0x00
PCRA (0xC0, 0x0600, 0x7FFFFFBA)
Sleep (0x02)
PCRO (0xC0, 0x0600, 0x80000045)
PSTA &= 0xFFFFFFFC
TEMP = PSTA /* \_SB_.PCI0.PEMC.PSTA */
}
Method (_PS3, 0, Serialized) // _PS3: Power State 3
{
DLLR (0x00, 0x1E, 0x04, 0xFE0B0000, 0x00010000)
PGEN = 0x01
PSTA |= 0x03
TEMP = PSTA /* \_SB_.PCI0.PEMC.PSTA */
}
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
ADBG (Concatenate ("EMH4=", ToDecimalString (EMH4)))
If ((Arg0 == ToUUID ("f6c13ea5-65cd-461f-ab7a-29f7e8d5bd61")))
{
If ((Arg1 >= Zero))
{
Switch (ToInteger (Arg2))
{
Case (0x00)
{
If ((EMH4 == 0x01))
{
Return (Buffer (0x02)
{
0x61, 0x02 // a.
})
}
Return (Buffer (0x02)
{
0x21, 0x02 // !.
})
}
Case (0x05)
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Case (0x06)
{
Return (Buffer (0x01)
{
0x05 // .
})
}
Case (0x09)
{
Switch (EMDS)
{
Case (0x00)
{
Return (Buffer (0x01)
{
0x00 // .
})
}
Case (0x01)
{
Return (Buffer (0x01)
{
0x01 // .
})
}
Case (0x04)
{
Return (Buffer (0x01)
{
0x04 // .
})
}
}
}
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Device (CARD)
{
Name (_ADR, 0x08) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (0x00)
}
}
}
}
}
Scope (\_SB.PCI0)
{
Device (ISHD)
{
Name (_ADR, 0x00130000) // _ADR: Address
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
Scope (\_SB.PCI0)
{
Device (HECI)
{
Name (_ADR, 0x00160000) // _ADR: Address
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
Scope (\_SB.PCI0.RP02.PXSX)
{
Name (_S0W, 0x03) // _S0W: S0 Device Wake State
}
Scope (\_SB.PCI0.LPCB)
{
Device (EC)
{
Name (_HID, EisaId ("PNP0C09") /* Embedded Controller Device */) // _HID: Hardware ID
Name (_UID, 0x00) // _UID: Unique ID
Name (_GPE, 0x16) // _GPE: General Purpose Events
Method (_REG, 2, NotSerialized) // _REG: Region Availability
{
If ((Arg0 == 0x03))
{
\H8DR = Arg1
SYSC (0x50)
}
}
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,
PSST, 1,
Offset (0x47),
HPBU, 1,
, 1,
HBID, 1,
, 3,
HBCS, 1,
PODK, 1,
, 1,
POAC, 1,
, 2,
HLBU, 1,
DOCD, 1,
HCBL, 1,
Offset (0x49),
SLUL, 1,
, 1,
ACAT, 1,
, 4,
ELNK, 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,
GPUT, 1,
Offset (0x8D),
HDAA, 3,
HDAB, 3,
HDAC, 2,
Offset (0xA0),
SIA0, 8,
SIA1, 8,
SIA2, 8,
SIA3, 8,
SIA4, 8,
SIA5, 8,
SIA6, 8,
SIA7, 8,
SIA8, 8,
SIA9, 8,
SIAA, 8,
SIAB, 8,
SIAC, 8,
SIAD, 8,
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 (0xD4),
GDID, 8,
, 5,
FKBS, 1,
Offset (0xE0),
TSI, 8,
TSHT, 8,
HYST, 8,
TSSR, 8,
VBKY, 8,
Offset (0xE6),
ELSS, 8,
Offset (0xED),
, 4,
HDDD, 1,
Offset (0xFE),
B10E, 1,
RSDE, 1,
, 5,
ESLP, 1,
INOS, 1,
LEDC, 1,
, 1,
HIDS, 1,
VBEN, 1,
, 2,
ECCM, 1
}
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
ADBG ("H8 _INI")
If (\H8DR)
{
HSPA = 0x00
}
Else
{
\MBEC (0x05, 0xFE, 0x00)
}
\_SB.PCI0.LPCB.EC.HKEY.WGIN ()
If ((\WLAC == 0x02)){}
ElseIf ((ELNK && (\WLAC == 0x01)))
{
DCWL = 0x00
}
Else
{
DCWL = 0x01
}
If (\H8DR)
{
If ((\_SB.PCI0.LPCB.EC.HPLD && \_SB.PCI0.LPCB.EC.FKBS))
{
\_SB.PCI0.LPCB.EC.FLIP = 0x01
}
Else
{
\_SB.PCI0.LPCB.EC.FLIP = 0x00
}
}
}
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)
{
Local0 = (Arg0 | Arg1)
If (\H8DR)
{
HLCL = Local0
}
Else
{
\WBEC (0x0C, Local0)
}
}
Name (BAON, 0x00)
Name (WBON, 0x00)
Method (BEEP, 1, NotSerialized)
{
If ((Arg0 == 0x05))
{
WBON = 0x00
}
Local2 = WBON /* \_SB_.PCI0.LPCB.EC__.WBON */
If (BAON)
{
If ((Arg0 == 0x00))
{
BAON = 0x00
If (WBON)
{
Local0 = 0x03
Local1 = 0x08
}
Else
{
Local0 = 0x00
Local1 = 0x00
}
}
Else
{
Local0 = 0xFF
Local1 = 0xFF
If ((Arg0 == 0x11))
{
WBON = 0x00
}
If ((Arg0 == 0x10))
{
WBON = 0x01
}
}
}
Else
{
Local0 = Arg0
Local1 = 0xFF
If ((Arg0 == 0x0F))
{
Local0 = Arg0
Local1 = 0x08
BAON = 0x01
}
If ((Arg0 == 0x11))
{
Local0 = 0x00
Local1 = 0x00
WBON = 0x00
}
If ((Arg0 == 0x10))
{
Local0 = 0x03
Local1 = 0x08
WBON = 0x01
}
}
If ((Arg0 == 0x03))
{
WBON = 0x00
If (Local2)
{
Local0 = 0x07
If (((\SPS == 0x03) || (\SPS == 0x04)))
{
Local2 = 0x00
Local0 = 0xFF
Local1 = 0xFF
}
}
}
If ((Arg0 == 0x07))
{
If (Local2)
{
Local2 = 0x00
Local0 = 0xFF
Local1 = 0xFF
}
}
If (\H8DR)
{
If ((Local2 && !WBON))
{
HSRP = 0x00
HSUN = 0x00
Sleep (0x64)
}
If ((Local1 != 0xFF))
{
HSRP = Local1
}
If ((Local0 != 0xFF))
{
HSUN = Local0
}
}
Else
{
If ((Local2 && !WBON))
{
\WBEC (0x07, 0x00)
\WBEC (0x06, 0x00)
Sleep (0x64)
}
If ((Local1 != 0xFF))
{
\WBEC (0x07, Local1)
}
If ((Local0 != 0xFF))
{
\WBEC (0x06, Local0)
}
}
If ((Arg0 == 0x03)){}
If ((Arg0 == 0x07))
{
Sleep (0x01F4)
}
}
Method (EVNT, 1, NotSerialized)
{
If (\H8DR)
{
If (Arg0)
{
HAM5 |= 0x04
}
Else
{
HAM5 &= 0xFB
}
}
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)
{
Local0 = HUBS /* \_SB_.PCI0.LPCB.EC__.HUBS */
}
Else
{
Local0 = (\RBEC (0x3B) & 0x10)
}
If (Local0)
{
Return (0x01)
}
Else
{
Return (0x00)
}
}
Method (_ON, 0, NotSerialized) // _ON_: Power On
{
Local0 = 0x64
While ((USPS && Local0))
{
Sleep (0x01)
Local0--
}
If (\H8DR)
{
HUBS = 0x01
}
Else
{
\MBEC (0x3B, 0xFF, 0x10)
}
}
Method (_OFF, 0, NotSerialized) // _OFF: Power Off
{
USPS = 0x01
If (\H8DR)
{
HUBS = 0x00
}
Else
{
\MBEC (0x3B, 0xEF, 0x00)
}
Sleep (0x14)
USPS = 0x00
}
}
Method (CHKS, 0, NotSerialized)
{
Local0 = 0x03E8
While (HMPR)
{
Sleep (0x01)
Local0--
If (!Local0)
{
Return (0x8080)
}
}
If (HMDN)
{
Return (Zero)
}
Return (0x8081)
}
Method (LPMD, 0, NotSerialized)
{
Local0 = 0x00
Local1 = 0x00
Local2 = 0x00
If (\H8DR)
{
If (HPAC)
{
If (HPLO)
{
Local0 = \LPST
}
ElseIf ((HWAT < 0x5A))
{
If (HB0A)
{
If (((HB0S & 0x10) || ((HB0S & 0x07) < 0x02)))
{
Local1 = 0x01
}
}
Else
{
Local1 = 0x01
}
If (HB1A)
{
If (((HB1S & 0x10) || ((HB1S & 0x07) < 0x02)))
{
Local2 = 0x01
}
}
Else
{
Local2 = 0x01
}
If ((Local1 && Local2))
{
Local0 = \LPST
}
}
}
}
ElseIf ((\RBEC (0x46) & 0x10))
{
If ((\RBEC (0x34) & 0x80))
{
Local0 = \LPST
}
ElseIf ((\RBEC (0xC9) < 0x5A))
{
Local3 = \RBEC (0x38)
If ((Local3 & 0x80))
{
If (((Local3 & 0x10) || ((Local3 & 0x07) < 0x02)))
{
Local1 = 0x01
}
}
Else
{
Local2 = 0x01
}
Local3 = \RBEC (0x39)
If ((Local3 & 0x80))
{
If (((Local3 & 0x10) || ((Local3 & 0x07) < 0x02)))
{
Local1 = 0x01
}
}
Else
{
Local2 = 0x01
}
If ((Local1 && Local2))
{
Local0 = \LPST
}
}
}
Return (Local0)
}
Method (CLPM, 0, NotSerialized)
{
If ((\_PR.CFGD & 0x01))
{
If ((\OSPX || \CPPX))
{
\PNTF (0x80)
}
Else
{
Local0 = LPMD ()
If (Local0)
{
\STEP (0x04)
}
Else
{
\STEP (0x05)
}
}
}
}
Method (ECNT, 1, Serialized)
{
Switch (ToInteger (Arg0))
{
Case (0x00)
{
P8XH (0x00, 0xC5)
P8XH (0x01, 0xAB)
ADBG ("EC Exit CS")
If ((ECNO == 0x01))
{
ADBG ("EC Notify")
Local0 = Acquire (\EHLD, 0xFFFF)
If ((Local0 == Zero))
{
\_SB.SGOV (0x02030009, 0x01)
Sleep (0x0A)
If ((ECLP == 0x01))
{
\ECUP = One
}
Release (\EHLD)
}
If ((ECDB == 0x01))
{
ADBG ("EC Debug")
LED (0x0A, 0x80)
LEDC = 0x00
}
}
\_SB.PCI0.LPCB.EC.VBEN = 0x00
Return (0x00)
}
Case (0x01)
{
P8XH (0x00, 0xC5)
P8XH (0x01, 0x00)
ADBG ("EC Enter CS")
If ((ECNO == 0x01))
{
ADBG ("EC Notify")
If ((ECDB == 0x01))
{
ADBG ("EC Debug")
LED (0x0A, 0x00)
LEDC = 0x01
}
If ((ECLP == 0x01))
{
\ECUP = Zero
}
}
Return (0x00)
}
Case (0x02)
{
ADBG ("Resiliency Exit")
If ((ECNO == 0x01))
{
ADBG ("EC Notify")
}
Return (0x00)
}
Case (0x03)
{
P8XH (0x00, 0xC6)
P8XH (0x01, 0x00)
ADBG ("Resiliency Entry")
If ((ECNO == 0x01))
{
ADBG ("EC Notify")
ESLP = 0x01
\_SB.SGOV (0x02030009, 0x00)
}
Return (0x00)
}
Default
{
Return (0xFF)
}
}
}
Device (HKEY)
{
Name (_HID, EisaId ("LEN0268")) // _HID: Hardware ID
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (0x0F)
}
Method (_INI, 0, NotSerialized) // _INI: Initialize
{
ADBG ("HKEY _INI")
ADBG ("_INI0")
\_SB.PCI0.LPCB.EC.HKEY.ANGN = 0x00
\_SB.PCI0.LPCB.EC.HKEY.DYTC (0x000F0001)
ADBG ("_INI1")
}
Method (MHKV, 0, NotSerialized)
{
Return (0x0200)
}
Name (DHKC, 0x00)
Name (DHKB, 0x01)
Name (DHKH, 0x00)
Name (DHKW, 0x00)
Name (DHKS, 0x00)
Name (DHKD, 0x00)
Name (DHKN, 0x0808)
Name (DHKE, 0x00)
Name (DHKF, 0x001F0000)
Name (DHKT, 0x00)
Name (DHWW, 0x00)
Mutex (XDHK, 0x00)
Method (MHKA, 1, NotSerialized)
{
If ((Arg0 == 0x00))
{
Return (0x03)
}
ElseIf ((Arg0 == 0x01))
{
Return (0xFFFFFFFB)
}
ElseIf ((Arg0 == 0x02))
{
Return (0x00)
}
ElseIf ((Arg0 == 0x03))
{
Return (0x001F0000)
}
Else
{
Return (0x00)
}
}
Method (MHKN, 1, NotSerialized)
{
If ((Arg0 == 0x00))
{
Return (0x03)
}
ElseIf ((Arg0 == 0x01))
{
Return (DHKN) /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKN */
}
ElseIf ((Arg0 == 0x02))
{
Return (DHKE) /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKE */
}
ElseIf ((Arg0 == 0x03))
{
Return (DHKF) /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKF */
}
Else
{
Return (0x00)
}
}
Method (MHKK, 2, NotSerialized)
{
If ((Arg0 == 0x00))
{
Return (0x03)
}
ElseIf (DHKC)
{
If ((Arg0 == 0x01))
{
Return ((DHKN & Arg1))
}
ElseIf ((Arg0 == 0x02))
{
Return ((DHKE & Arg1))
}
ElseIf ((Arg0 == 0x03))
{
Return ((DHKF & Arg1))
}
Else
{
Return (0x00)
}
}
Else
{
Return (Zero)
}
}
Method (MHKM, 2, NotSerialized)
{
Acquire (XDHK, 0xFFFF)
If ((Arg0 > 0x60))
{
Noop
}
ElseIf ((Arg0 <= 0x20))
{
Local0 = (One << Arg0--)
If ((Local0 & 0xFFFFFFFB))
{
If (Arg1)
{
DHKN |= Local0 /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKN */
}
Else
{
DHKN &= (Local0 ^ 0xFFFFFFFF)
}
}
Else
{
Noop
}
}
ElseIf ((Arg0 <= 0x40))
{
Noop
}
ElseIf ((Arg0 <= 0x60))
{
Arg0 -= 0x40
Local0 = (One << Arg0--)
If ((Local0 & 0x001F0000))
{
If (Arg1)
{
DHKF |= Local0 /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKF */
}
Else
{
DHKF &= (Local0 ^ 0xFFFFFFFF)
}
}
Else
{
Noop
}
}
Release (XDHK)
}
Method (MHKS, 0, NotSerialized)
{
Notify (\_SB.SLPB, 0x80) // Status Change
}
Method (MHKC, 1, NotSerialized)
{
DHKC = Arg0
}
Method (MHKP, 0, NotSerialized)
{
Acquire (XDHK, 0xFFFF)
If (DHWW)
{
Local1 = DHWW /* \_SB_.PCI0.LPCB.EC__.HKEY.DHWW */
DHWW = Zero
}
ElseIf (DHKW)
{
Local1 = DHKW /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKW */
DHKW = Zero
}
ElseIf (DHKD)
{
Local1 = DHKD /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKD */
DHKD = Zero
}
ElseIf (DHKS)
{
Local1 = DHKS /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKS */
DHKS = Zero
}
ElseIf (DHKT)
{
Local1 = DHKT /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKT */
DHKT = Zero
}
Else
{
Local1 = DHKH /* \_SB_.PCI0.LPCB.EC__.HKEY.DHKH */
DHKH = Zero
}
Release (XDHK)
Return (Local1)
}
Method (MHKE, 1, Serialized)
{
DHKB = Arg0
Acquire (XDHK, 0xFFFF)
DHKH = Zero
DHKW = Zero
DHKS = Zero
DHKD = Zero
DHKT = Zero
DHWW = Zero
Release (XDHK)
}
Method (MHKQ, 1, Serialized)
{
If (DHKB)
{
If (DHKC)
{
Acquire (XDHK, 0xFFFF)
If ((Arg0 < 0x1000)){}
ElseIf ((Arg0 < 0x2000))
{
DHKH = Arg0
}
ElseIf ((Arg0 < 0x3000))
{
DHKW = Arg0
}
ElseIf ((Arg0 < 0x4000))
{
DHKS = Arg0
}
ElseIf ((Arg0 < 0x5000))
{
DHKD = Arg0
}
ElseIf ((Arg0 < 0x6000))
{
DHKH = Arg0
}
ElseIf ((Arg0 < 0x7000))
{
DHKT = Arg0
}
ElseIf ((Arg0 < 0x8000))
{
DHWW = Arg0
}
Else
{
}
Release (XDHK)
Notify (HKEY, 0x80) // Status Change
}
ElseIf ((Arg0 == 0x1004))
{
Notify (\_SB.SLPB, 0x80) // Status Change
}
}
}
Method (MHKB, 1, NotSerialized)
{
If ((Arg0 == 0x00))
{
\_SB.PCI0.LPCB.EC.BEEP (0x11)
\LIDB = 0x00
}
ElseIf ((Arg0 == 0x01))
{
\_SB.PCI0.LPCB.EC.BEEP (0x10)
\LIDB = 0x01
}
Else
{
}
}
Method (MHKD, 0, NotSerialized)
{
If ((\PLUX == 0x00))
{
If (VIGD)
{
\_SB.PCI0.GFX0.VLOC (0x00)
}
}
}
Method (MHQC, 1, NotSerialized)
{
If (\WNTF)
{
If ((Arg0 == 0x00))
{
Return (\CWAC)
}
ElseIf ((Arg0 == 0x01))
{
Return (\CWAP)
}
ElseIf ((Arg0 == 0x02))
{
Return (\CWAT)
}
Else
{
Noop
}
}
Else
{
Noop
}
Return (0x00)
}
Method (MHGC, 0, NotSerialized)
{
If (\WNTF)
{
Acquire (XDHK, 0xFFFF)
If (CKC4 (0x00))
{
Local0 = 0x03
}
Else
{
Local0 = 0x04
}
Release (XDHK)
Return (Local0)
}
Else
{
Noop
}
Return (0x00)
}
Method (MHSC, 1, NotSerialized)
{
If ((\CWAC && \WNTF))
{
Acquire (XDHK, 0xFFFF)
If (\OSC4)
{
If ((Arg0 == 0x03))
{
If (!\CWAS)
{
\PNTF (0x81)
\CWAS = 0x01
}
}
ElseIf ((Arg0 == 0x04))
{
If (\CWAS)
{
\PNTF (0x81)
\CWAS = 0x00
}
}
Else
{
Noop
}
}
Release (XDHK)
}
Else
{
Noop
}
}
Method (CKC4, 1, NotSerialized)
{
Local0 = 0x00
If (\C4WR)
{
If (!\C4AC)
{
Local0 |= 0x01
}
}
If (\C4NA)
{
Local0 |= 0x02
}
If ((\CWAC && \CWAS))
{
Local0 |= 0x04
}
Local0 &= ~Arg0
Return (Local0)
}
Method (MHQE, 0, NotSerialized)
{
Return (\C4WR)
}
Method (MHGE, 0, NotSerialized)
{
If ((\C4WR && \C4AC))
{
Return (0x04)
}
Return (0x03)
}
Method (MHSE, 1, NotSerialized)
{
If (\C4WR)
{
Local0 = \C4AC
If ((Arg0 == 0x03))
{
\C4AC = 0x00
If ((Local0 ^ \C4AC))
{
If (\OSC4)
{
\PNTF (0x81)
}
}
}
ElseIf ((Arg0 == 0x04))
{
\C4AC = 0x01
If ((Local0 ^ \C4AC))
{
If (\OSC4)
{
\PNTF (0x81)
}
}
}
}
}
Method (UAWO, 1, NotSerialized)
{
Return (0x00)
}
Method (MLCS, 1, NotSerialized)
{
Local0 = \KBLS (0x01, Arg0)
If (!(Local0 & 0x80000000))
{
If ((Arg0 & 0x00010000))
{
\_SB.PCI0.LPCB.EC.HKEY.MHKQ (0x6001)
}
ElseIf (\_SB.PCI0.LPCB.EC.HKEY.MHKK (0x01, 0x00020000))
{
\_SB.PCI0.LPCB.EC.HKEY.MHKQ (0x1012)
}
}
Return (Local0)
}
Method (DSSG, 1, NotSerialized)
{
Local0 = (0x0400 | \PDCI)
Return (Local0)
}
Method (DSSS, 1, NotSerialized)
{
\PDCI |= Arg0
}
Method (SBSG, 1, NotSerialized)
{
Return (\SYBC (0x00, 0x00))
}
Method (SBSS, 1, NotSerialized)
{
Return (\SYBC (0x01, Arg0))
}
Method (PBLG, 1, NotSerialized)
{
Local0 = \BRLV
Local1 = (Local0 | 0x0F00)
Return (Local1)
}
Method (PBLS, 1, NotSerialized)
{
\BRLV = Arg0
If (\VIGD)
{
\_SB.PCI0.LPCB.EC.BRNS ()
}
Else
{
\VBRC (\BRLV)
}
If (!\NBCF)
{
\_SB.PCI0.LPCB.EC.HKEY.MHKQ (0x6050)
}
Return (0x00)
}
Method (PMSG, 1, NotSerialized)
{
Local0 = \PRSM (0x00, 0x00)
Local0 &= 0xFFFFEFFF
Return (Local0)
}
Method (PMSS, 1, NotSerialized)
{
\PRSM (0x01, Arg0)
Return (0x00)
}
Method (ISSG, 1, NotSerialized)
{
Local0 = \ISSP
If (\ISSP)
{
Local0 |= 0x01000000
Local0 |= (\ISFS << 0x19)
}
Local0 |= (\ISCG & 0x30)
Return (Local0)
}
Method (ISSS, 1, NotSerialized)
{
\ISCG = Arg0
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, (Arg0 & 0x00010001)))
}
Method (GSKL, 1, NotSerialized)
{
Return (\FNSC (0x04, (Arg0 & 0x0F000000)))
}
Method (SSKL, 1, NotSerialized)
{
Return (\FNSC (0x05, (Arg0 & 0x0F00FFFF)))
}
Method (INSG, 1, NotSerialized)
{
Local0 = \IOEN
Local0 |= (\IOST << 0x07)
Local0 |= (\IOCP << 0x08)
Local0 |= 0x10000000
Return (Local0)
}
Method (INSS, 1, NotSerialized)
{
If ((Arg0 & 0x10000000))
{
If (\IOCP)
{
Local0 = ((Arg0 & 0x80) >> 0x07)
If (!\EZRC (Local0))
{
\IOST = Local0
}
}
Return (0x00)
}
If ((\IOCP && (Arg0 & 0x01)))
{
\IOEN = 0x01
}
Else
{
\IOEN = 0x00
If (\IOST)
{
If (!\ISOC (0x00))
{
\IOST = 0x00
}
}
}
Return (0x00)
}
Method (SSPI, 1, NotSerialized)
{
If ((Arg0 == 0x00))
{
Local0 = 0x0100
Return (Local0)
}
ElseIf ((Arg0 == 0x0100))
{
Local0 = 0x01
Return (Local0)
}
}
Method (GTCS, 1, NotSerialized)
{
If ((Arg0 == 0x00))
{
Local0 = 0x0100
Return (Local0)
}
ElseIf ((Arg0 == 0x0100))
{
If ((\_SB.GGOV (0x02030017) == 0x00))
{
Return (0x00)
}
Else
{
Return (0x01)
}
}
}
Method (STCS, 1, NotSerialized)
{
If ((Arg0 == 0x00))
{
Local0 = 0x0100
Return (Local0)
}
ElseIf ((Arg0 == 0x0100))
{
\_SB.SGOV (0x02030017, 0x00)
Return (0x00)
}
ElseIf ((Arg0 == 0x0101))
{
If (\_SB.PCI0.LPCB.EC.HPLD)
{
\_SB.SGOV (0x02030017, 0x01)
}
Return (0x00)
}
}
Method (VOPP, 1, NotSerialized)
{
If (((Arg0 & 0x00F00000) == 0x00100000))
{
If ((((Arg0 & 0x03E3) == 0x00) || (Arg0 & 0x1C)))
{
\SDPS (0x01, (Arg0 & 0x1C))
Local0 = 0x00
Local0 |= \SDPS (0x00, 0x00)
Local0 |= 0x7000
Return (Local0)
}
Else
{
Return (0x00100000)
}
}
ElseIf (((Arg0 & 0x00F00000) == 0x00200000))
{
Local0 = 0x00
Local0 |= \SDPS (0x00, 0x00)
Local0 |= 0x7000
Return (Local0)
}
Else
{
Return (0x00100000)
}
Return (0x00)
}
Method (GTOP, 1, Serialized)
{
Local0 = Arg0
Local1 = 0x00
Local2 = 0x00
If ((\WNTF && \TATC))
{
Local1 = (Local0 & 0x0FFF)
Switch (ToInteger (Local1))
{
Case (0x00)
{
Local2 |= 0x0103
}
Case (0x0100)
{
Local2 |= 0x04
}
Case (0x0200)
{
If (DOCD)
{
Local2 |= 0x01
}
Switch (GDID)
{
Case (0x02)
{
Local2 |= 0x02
}
Case (0x03)
{
Local2 |= 0x04
}
Case (0x04)
{
Local2 |= 0x10
}
}
If (FKBS)
{
Sleep (0x012C)
If (HPLD)
{
Local2 |= 0x00010000
}
}
ElseIf (HPLD)
{
Sleep (0x012C)
If (FKBS)
{
Local2 |= 0x00010000
}
}
}
Default
{
}
}
Return (Local2)
}
}
Method (STOP, 1, NotSerialized)
{
Return (0x00)
}
}
Device (AC)
{
Name (_HID, "ACPI0003" /* Power Source Device */) // _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) /* \_SB_.PCI0.LPCB.EC__.HPAC */
}
ElseIf ((\RBEC (0x46) & 0x10))
{
Return (0x01)
}
Else
{
Return (0x00)
}
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (0x0F)
}
}
Method (_Q22, 0, NotSerialized) // _Qxx: EC Query, xx=0x00-0xFF
{
CLPM ()
If (HB0A)
{
Notify (BAT0, 0x80) // Status Change
}
If (HB1A)
{
Notify (BAT1, 0x80) // Status Change
}
}
Method (_Q4A, 0, NotSerialized) // _Qxx: EC Query, xx=0x00-0xFF
{
CLPM ()
Notify (BAT0, 0x81) // Information Change
}
Method (_Q4B, 0, NotSerialized) // _Qxx: EC Query, xx=0x00-0xFF
{
CLPM ()
Notify (BAT0, 0x80) // Status Change
}
Method (_Q4D, 0, NotSerialized) // _Qxx: EC Query, xx=0x00-0xFF
{
CLPM ()
If (\BT2T)
{
If ((^BAT1.SBLI == 0x01))
{
Sleep (0x0A)
If ((HB1A && (SLUL == 0x00)))
{
^BAT1.XB1S = 0x01
Notify (\_SB.PCI0.LPCB.EC.BAT1, 0x01) // Device Check
}
}
ElseIf ((SLUL == 0x01))
{
^BAT1.XB1S = 0x00
Notify (\_SB.PCI0.LPCB.EC.BAT1, 0x03) // Eject Request
}
}
If ((^BAT1.B1ST & ^BAT1.XB1S))
{
Notify (BAT1, 0x80) // Status Change
}
}
Method (_Q24, 0, NotSerialized) // _Qxx: EC Query, xx=0x00-0xFF
{
CLPM ()
Notify (BAT0, 0x80) // Status Change
}
Method (_Q25, 0, NotSerialized) // _Qxx: EC Query, xx=0x00-0xFF
{
If ((^BAT1.B1ST & ^BAT1.XB1S))
{
CLPM ()
Notify (BAT1, 0x80) // Status Change
}
}
Method (BFCC, 0, NotSerialized)
{
If (\_SB.PCI0.LPCB.EC.BAT0.B0ST)
{
Notify (BAT0, 0x81) // Information Change
}
If (\_SB.PCI0.LPCB.EC.BAT1.B1ST)
{
Notify (BAT1, 0x81) // Information Change
}
}
Method (BATW, 1, NotSerialized)
{
If (\BT2T)
{
Local0 = \_SB.PCI0.LPCB.EC.BAT1.XB1S
If ((HB1A && !SLUL))
{
Local1 = 0x01
}
Else
{
Local1 = 0x00
}
If ((Local0 ^ Local1))
{
\_SB.PCI0.LPCB.EC.BAT1.XB1S = Local1
Notify (\_SB.PCI0.LPCB.EC.BAT1, 0x01) // Device Check
}
}
}
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)
{
HIID = (Arg0 | 0x01)
Local7 = SBBM /* \_SB_.PCI0.LPCB.EC__.SBBM */
Local7 >>= 0x0F
Arg1 [0x00] = (Local7 ^ 0x01)
HIID = Arg0
If (Local7)
{
Local1 = (SBFC * 0x0A)
}
Else
{
Local1 = SBFC /* \_SB_.PCI0.LPCB.EC__.SBFC */
}
Arg1 [0x02] = Local1
HIID = (Arg0 | 0x02)
If (Local7)
{
Local0 = (SBDC * 0x0A)
}
Else
{
Local0 = SBDC /* \_SB_.PCI0.LPCB.EC__.SBDC */
}
Arg1 [0x01] = Local0
Divide (Local1, 0x14, Local2, Arg1 [0x05])
If (Local7)
{
Arg1 [0x06] = 0xC8
}
ElseIf (SBDV)
{
Divide (0x00030D40, SBDV, Local2, Arg1 [0x06])
}
Else
{
Arg1 [0x06] = 0x00
}
Arg1 [0x04] = SBDV /* \_SB_.PCI0.LPCB.EC__.SBDV */
Local0 = SBSN /* \_SB_.PCI0.LPCB.EC__.SBSN */
Name (SERN, Buffer (0x06)
{
" "
})
Local2 = 0x04
While (Local0)
{
Divide (Local0, 0x0A, Local1, Local0)
SERN [Local2] = (Local1 + 0x30)
Local2--
}
Arg1 [0x0A] = SERN /* \_SB_.PCI0.LPCB.EC__.GBIF.SERN */
HIID = (Arg0 | 0x06)
Arg1 [0x09] = SBDN /* \_SB_.PCI0.LPCB.EC__.SBDN */
HIID = (Arg0 | 0x04)
Name (BTYP, Buffer (0x05)
{
0x00, 0x00, 0x00, 0x00, 0x00 // .....
})
BTYP = SBCH /* \_SB_.PCI0.LPCB.EC__.SBCH */
Arg1 [0x0B] = BTYP /* \_SB_.PCI0.LPCB.EC__.GBIF.BTYP */
HIID = (Arg0 | 0x05)
Arg1 [0x0C] = SBMN /* \_SB_.PCI0.LPCB.EC__.SBMN */
}
Else
{
Arg1 [0x01] = 0xFFFFFFFF
Arg1 [0x05] = 0x00
Arg1 [0x06] = 0x00
Arg1 [0x02] = 0xFFFFFFFF
}
Release (BATM)
Return (Arg1)
}
Method (GBIX, 3, NotSerialized)
{
Acquire (BATM, 0xFFFF)
If (Arg2)
{
HIID = (Arg0 | 0x01)
Local7 = SBCC /* \_SB_.PCI0.LPCB.EC__.SBCC */
Arg1 [0x08] = Local7
Local7 = SBBM /* \_SB_.PCI0.LPCB.EC__.SBBM */
Local7 >>= 0x0F
Arg1 [0x01] = (Local7 ^ 0x01)
HIID = Arg0
If (Local7)
{
Local1 = (SBFC * 0x0A)
}
Else
{
Local1 = SBFC /* \_SB_.PCI0.LPCB.EC__.SBFC */
}
Arg1 [0x03] = Local1
HIID = (Arg0 | 0x02)
If (Local7)
{
Local0 = (SBDC * 0x0A)
}
Else
{
Local0 = SBDC /* \_SB_.PCI0.LPCB.EC__.SBDC */
}
Arg1 [0x02] = Local0
Divide (Local1, 0x14, Local2, Arg1 [0x06])
If (Local7)
{
Arg1 [0x07] = 0xC8
}
ElseIf (SBDV)
{
Divide (0x00030D40, SBDV, Local2, Arg1 [0x07])
}
Else
{
Arg1 [0x07] = 0x00
}
Arg1 [0x05] = SBDV /* \_SB_.PCI0.LPCB.EC__.SBDV */
Local0 = SBSN /* \_SB_.PCI0.LPCB.EC__.SBSN */
Name (SERN, Buffer (0x06)
{
" "
})
Local2 = 0x04
While (Local0)
{
Divide (Local0, 0x0A, Local1, Local0)
SERN [Local2] = (Local1 + 0x30)
Local2--
}
Arg1 [0x11] = SERN /* \_SB_.PCI0.LPCB.EC__.GBIX.SERN */
HIID = (Arg0 | 0x06)
Arg1 [0x10] = SBDN /* \_SB_.PCI0.LPCB.EC__.SBDN */
HIID = (Arg0 | 0x04)
Name (BTYP, Buffer (0x05)
{
0x00, 0x00, 0x00, 0x00, 0x00 // .....
})
BTYP = SBCH /* \_SB_.PCI0.LPCB.EC__.SBCH */
Arg1 [0x12] = BTYP /* \_SB_.PCI0.LPCB.EC__.GBIX.BTYP */
HIID = (Arg0 | 0x05)
Arg1 [0x13] = SBMN /* \_SB_.PCI0.LPCB.EC__.SBMN */
}
Else
{
Arg1 [0x02] = 0xFFFFFFFF
Arg1 [0x06] = 0x00
Arg1 [0x07] = 0x00
Arg1 [0x03] = 0xFFFFFFFF
}
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 ((Arg1 & 0x20))
{
Local0 = 0x02
}
ElseIf ((Arg1 & 0x40))
{
Local0 = 0x01
}
Else
{
Local0 = 0x00
}
If ((Arg1 & 0x07)){}
Else
{
Local0 |= 0x04
}
If (((Arg1 & 0x07) == 0x07))
{
Local0 = 0x04
Local1 = 0x00
Local2 = 0x00
Local3 = 0x00
}
Else
{
HIID = Arg0
Local3 = SBVO /* \_SB_.PCI0.LPCB.EC__.SBVO */
If (Arg2)
{
Local2 = (SBRC * 0x0A)
}
Else
{
Local2 = SBRC /* \_SB_.PCI0.LPCB.EC__.SBRC */
}
Local1 = SBAC /* \_SB_.PCI0.LPCB.EC__.SBAC */
If ((Local1 >= 0x8000))
{
If ((Local0 & 0x01))
{
Local1 = (0x00010000 - Local1)
}
Else
{
Local1 = 0x00
}
}
ElseIf (!(Local0 & 0x02))
{
Local1 = 0x00
}
If (Arg2)
{
Local1 *= Local3
Divide (Local1, 0x03E8, Local7, Local1)
}
}
Local5 = (0x01 << (Arg0 >> 0x04))
BSWA |= BSWR /* \_SB_.PCI0.LPCB.EC__.BSWR */
If (((BSWA & Local5) == 0x00))
{
Arg3 [0x00] = Local0
Arg3 [0x01] = Local1
Arg3 [0x02] = Local2
Arg3 [0x03] = Local3
If ((Arg0 == 0x00))
{
B0I0 = Local0
B0I1 = Local1
B0I2 = Local2
B0I3 = Local3
}
Else
{
B1I0 = Local0
B1I1 = Local1
B1I2 = Local2
B1I3 = Local3
}
}
Else
{
If (\_SB.PCI0.LPCB.EC.AC._PSR ())
{
If ((Arg0 == 0x00))
{
Arg3 [0x00] = B0I0 /* \_SB_.PCI0.LPCB.EC__.B0I0 */
Arg3 [0x01] = B0I1 /* \_SB_.PCI0.LPCB.EC__.B0I1 */
Arg3 [0x02] = B0I2 /* \_SB_.PCI0.LPCB.EC__.B0I2 */
Arg3 [0x03] = B0I3 /* \_SB_.PCI0.LPCB.EC__.B0I3 */
}
Else
{
Arg3 [0x00] = B1I0 /* \_SB_.PCI0.LPCB.EC__.B1I0 */
Arg3 [0x01] = B1I1 /* \_SB_.PCI0.LPCB.EC__.B1I1 */
Arg3 [0x02] = B1I2 /* \_SB_.PCI0.LPCB.EC__.B1I2 */
Arg3 [0x03] = B1I3 /* \_SB_.PCI0.LPCB.EC__.B1I3 */
}
}
Else
{
Arg3 [0x00] = Local0
Arg3 [0x01] = Local1
Arg3 [0x02] = Local2
Arg3 [0x03] = Local3
}
If ((((Local0 & 0x04) == 0x00) && ((Local2 > 0x00) &&
(Local3 > 0x00))))
{
BSWA &= ~Local5
Arg3 [0x00] = Local0
Arg3 [0x01] = Local1
Arg3 [0x02] = Local2
Arg3 [0x03] = Local3
}
}
Release (BATM)
Return (Arg3)
}
Name (BSWR, 0x00)
Name (BSWA, 0x00)
Device (BAT0)
{
Name (_HID, EisaId ("PNP0C0A") /* Control Method Battery */) // _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 (BX0I, Package (0x15)
{
0x01,
0x00,
0xFFFFFFFF,
0xFFFFFFFF,
0x01,
0xFFFFFFFF,
0x00,
0x00,
0xFFFFFFFF,
0x00017318,
0xFFFFFFFF,
0xFFFFFFFF,
0x03E8,
0x01F4,
0xFFFFFFFF,
0xFFFFFFFF,
"",
"",
"",
"",
0x00
})
Name (BT0P, Package (0x04){})
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (\H8DR)
{
B0ST = HB0A /* \_SB_.PCI0.LPCB.EC__.HB0A */
}
ElseIf ((\RBEC (0x38) & 0x80))
{
B0ST = 0x01
}
Else
{
B0ST = 0x00
}
If (B0ST)
{
Return (0x1F)
}
Else
{
Return (0x0F)
}
}
Method (_BIF, 0, NotSerialized) // _BIF: Battery Information
{
Local7 = 0x00
Local6 = 0x0A
While ((!Local7 && Local6))
{
If (HB0A)
{
If (((HB0S & 0x07) == 0x07))
{
Sleep (0x03E8)
Local6--
}
Else
{
Local7 = 0x01
}
}
Else
{
Local6 = 0x00
}
}
GBIX (0x00, BX0I, Local7)
BT0I [0x00] = DerefOf (BX0I [0x01])
BT0I [0x01] = DerefOf (BX0I [0x02])
BT0I [0x02] = DerefOf (BX0I [0x03])
BT0I [0x03] = DerefOf (BX0I [0x04])
BT0I [0x04] = DerefOf (BX0I [0x05])
BT0I [0x05] = DerefOf (BX0I [0x06])
BT0I [0x06] = DerefOf (BX0I [0x07])
BT0I [0x07] = DerefOf (BX0I [0x0E])
BT0I [0x08] = DerefOf (BX0I [0x0F])
BT0I [0x09] = DerefOf (BX0I [0x10])
BT0I [0x0A] = DerefOf (BX0I [0x11])
BT0I [0x0B] = DerefOf (BX0I [0x12])
BT0I [0x0C] = DerefOf (BX0I [0x13])
Return (BT0I) /* \_SB_.PCI0.LPCB.EC__.BAT0.BT0I */
}
Method (_BIX, 0, NotSerialized) // _BIX: Battery Information Extended
{
Local7 = 0x00
Local6 = 0x0A
While ((!Local7 && Local6))
{
If (HB0A)
{
If (((HB0S & 0x07) == 0x07))
{
Sleep (0x03E8)
Local6--
}
Else
{
Local7 = 0x01
}
}
Else
{
Local6 = 0x00
}
}
Return (GBIX (0x00, BX0I, Local7))
}
Method (_BST, 0, NotSerialized) // _BST: Battery Status
{
Local0 = (DerefOf (BX0I [0x01]) ^ 0x01)
Return (GBST (0x00, HB0S, Local0, BT0P))
}
Method (_BTP, 1, NotSerialized) // _BTP: Battery Trip Point
{
HAM4 &= 0xEF
If (Arg0)
{
Local1 = Arg0
If (!DerefOf (BX0I [0x01]))
{
Divide (Local1, 0x0A, Local0, Local1)
}
HT0L = (Local1 & 0xFF)
HT0H = ((Local1 >> 0x08) & 0xFF)
HAM4 |= 0x10
}
}
}
Device (BAT1)
{
Name (_HID, EisaId ("PNP0C0A") /* Control Method Battery */) // _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 (BX1I, Package (0x15)
{
0x00,
0x00,
0xFFFFFFFF,
0xFFFFFFFF,
0x01,
0xFFFFFFFF,
0x00,
0x00,
0xFFFFFFFF,
0x00017318,
0xFFFFFFFF,
0xFFFFFFFF,
0x03E8,
0x01F4,
0xFFFFFFFF,
0xFFFFFFFF,
"",
"",
"",
"",
0x00
})
Name (BT1P, Package (0x04){})
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (\H8DR)
{
If (HB1A)
{
B1ST = 0x01
If (\BT2T)
{
If (SLUL)
{
SBLI = 0x01
XB1S = 0x00
}
Else
{
SBLI = 0x00
XB1S = 0x01
}
}
Else
{
XB1S = 0x01
}
}
Else
{
B1ST = 0x00
If (\BT2T)
{
SBLI = 0x01
XB1S = 0x00
}
Else
{
XB1S = 0x00
}
}
}
ElseIf ((\RBEC (0x39) & 0x80))
{
B1ST = 0x01
If (\BT2T)
{
If ((\RBEC (0x49) & 0x01))
{
SBLI = 0x01
XB1S = 0x00
}
Else
{
SBLI = 0x00
XB1S = 0x01
}
}
Else
{
XB1S = 0x01
}
}
Else
{
B1ST = 0x00
If (\BT2T)
{
SBLI = 0x01
XB1S = 0x00
}
Else
{
XB1S = 0x00
}
}
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
{
Local7 = 0x00
Local6 = 0x0A
While ((!Local7 && Local6))
{
If (HB1A)
{
If (((HB1S & 0x07) == 0x07))
{
Sleep (0x03E8)
Local6--
}
Else
{
Local7 = 0x01
}
}
Else
{
Local6 = 0x00
}
}
GBIX (0x10, BX1I, Local7)
BT1I [0x00] = DerefOf (BX1I [0x01])
BT1I [0x01] = DerefOf (BX1I [0x02])
BT1I [0x02] = DerefOf (BX1I [0x03])
BT1I [0x03] = DerefOf (BX1I [0x04])
BT1I [0x04] = DerefOf (BX1I [0x05])
BT1I [0x05] = DerefOf (BX1I [0x06])
BT1I [0x06] = DerefOf (BX1I [0x07])
BT1I [0x07] = DerefOf (BX1I [0x0E])
BT1I [0x08] = DerefOf (BX1I [0x0F])
BT1I [0x09] = DerefOf (BX1I [0x10])
BT1I [0x0A] = DerefOf (BX1I [0x11])
BT1I [0x0B] = DerefOf (BX1I [0x12])
BT1I [0x0C] = DerefOf (BX1I [0x13])
Return (BT1I) /* \_SB_.PCI0.LPCB.EC__.BAT1.BT1I */
}
Method (_BIX, 0, NotSerialized) // _BIX: Battery Information Extended
{
Local7 = 0x00
Local6 = 0x0A
While ((!Local7 && Local6))
{
If (HB1A)
{
If (((HB1S & 0x07) == 0x07))
{
Sleep (0x03E8)
Local6--
}
Else
{
Local7 = 0x01
}
}
Else
{
Local6 = 0x00
}
}
Return (GBIX (0x10, BX1I, Local7))
}
Method (_BST, 0, NotSerialized) // _BST: Battery Status
{
Local0 = (DerefOf (BX1I [0x01]) ^ 0x01)
GBST (0x10, HB1S, Local0, BT1P)
BTPL (BT1P, BT1I)
Return (BT1P) /* \_SB_.PCI0.LPCB.EC__.BAT1.BT1P */
}
Method (_BTP, 1, NotSerialized) // _BTP: Battery Trip Point
{
HAM4 &= 0xDF
If (Arg0)
{
Local1 = Arg0
If (!DerefOf (BX1I [0x01]))
{
Divide (Local1, 0x0A, Local0, Local1)
}
HT1L = (Local1 & 0xFF)
HT1H = ((Local1 >> 0x08) & 0xFF)
HAM4 |= 0x20
}
}
}
Method (BTPL, 2, Serialized)
{
Name (PL4N, 0x00)
Local0 = DerefOf (Arg0 [0x00])
If ((Local0 & 0x01))
{
Local0 = DerefOf (Arg0 [0x02])
Local1 = DerefOf (Arg1 [0x02])
If (((Local1 != 0x00) && (Local1 != 0xFFFFFFFF)))
{
If ((Local0 != 0xFFFFFFFF))
{
Local0 *= 0x64
Divide (Local0, Local1, Local2, Local0)
If ((Local0 < 0x0A))
{
PL4N = 0x01
}
}
}
}
If ((PL4N != \PL4S))
{
\PL4S = PL4N /* \_SB_.PCI0.LPCB.EC__.BTPL.PL4N */
If (PL4N)
{
\PLOV (0x01, \PL4O)
}
Else
{
\PLOV (0x01, \PL4D)
}
}
Return (Zero)
}
Scope (HKEY)
{
Method (SCRQ, 1, Serialized)
{
Name (SCRS, 0x00)
Local0 = Arg0
Local1 = 0x00
ADBG (Concatenate ("SCRQ =", ToHexString (Local0)))
If (((Local0 & 0x80000000) == 0x00))
{
Switch ((Local0 & 0xFFFF))
{
Case (0x00)
{
Local2 = 0x01000000
}
Case (0x0100)
{
Return (0x01)
}
Case (0x0101)
{
Return (0x01)
}
Case (0x0102)
{
Return (0x01)
}
Case (0x0200)
{
Return (0x01)
}
Case (0x0210)
{
Return (0x01)
}
Case (0x0211)
{
Return (0x01)
}
Case (0x0212)
{
Return (0x01)
}
Case (0x0300)
{
Return (0x01)
}
Case (0x0301)
{
Return (0x01)
}
Case (0x0302)
{
Return (0x01)
}
Default
{
Return (0x00)
}
}
Return (Local2)
}
Else
{
Local2 = (0x00 + 0x40000000)
Switch ((Local0 & 0xFFFF))
{
Case (0x00)
{
Local2 = 0x01000000
}
Case (0x0100)
{
Local2 = 0x01000000
}
Case (0x0101)
{
\SREQ (0x01, 0x00, 0x00)
}
Case (0x0102)
{
\SREQ (0x01, 0x01, 0x00)
}
Case (0x0200)
{
Local2 = 0x01000000
}
Case (0x0210)
{
\SREQ (0x02, 0x00, 0x00)
}
Case (0x0211)
{
\SREQ (0x02, 0x01, 0x00)
}
Case (0x0212)
{
\SREQ (0x02, 0x02, 0x00)
}
Case (0x0300)
{
Local2 = 0x01000000
}
Case (0x0301)
{
If ((\TBTS == 0x01))
{
\_SB.TBFP (0x01)
}
Else
{
Local2 = (0x02 + 0x80000000)
}
}
Case (0x0302)
{
If ((\TBTS == 0x01))
{
\_SB.TBFP (0x00)
}
Else
{
Local2 = (0x02 + 0x80000000)
}
}
Default
{
Local2 = (0x01 + 0x80000000)
}
}
Return (Local2)
}
}
}
Method (SYSC, 1, NotSerialized)
{
If (\H8DR)
{
ELSS = Arg0
}
Else
{
}
}
Method (GTMP, 1, Serialized)
{
Acquire (BATM, 0xFFFF)
If ((\_SB.PCI0.LPCB.EC.HIID != 0x60))
{
\_SB.PCI0.LPCB.EC.HIID = 0x60
Sleep (0x1E)
}
Local0 = 0x00
Switch (ToInteger (Arg0))
{
Case (0x00)
{
Local0 = \_SB.PCI0.LPCB.EC.SIA0
}
Case (0x08)
{
Local0 = \_SB.PCI0.LPCB.EC.SIA8
}
Case (0x0D)
{
Local0 = \_SB.PCI0.LPCB.EC.SIAD
}
Case (0x09)
{
Local0 = \_SB.PCI0.LPCB.EC.SIA9
}
Case (0x0A)
{
Local0 = \_SB.PCI0.LPCB.EC.SIAA
}
Case (0x0C)
{
Local0 = \_SB.PCI0.LPCB.EC.SIAC
}
Case (0x02)
{
Local0 = \_SB.PCI0.LPCB.EC.SIA2
}
}
If ((Local0 & 0x80))
{
Local0 = 0x00
}
Release (BATM)
Return (Local0)
}
}
Device (FWHD)
{
Name (_HID, EisaId ("INT0800") /* Intel 82802 Firmware Hub Device */) // _HID: Hardware ID
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
{
Memory32Fixed (ReadOnly,
0xFF000000, // Address Base
0x01000000, // Address Length
)
})
}
Device (HPET)
{
Name (_HID, EisaId ("PNP0103") /* HPET System Timer */) // _HID: Hardware ID
Name (_UID, 0x00) // _UID: Unique ID
Name (BUF0, ResourceTemplate ()
{
Memory32Fixed (ReadWrite,
0xFED00000, // Address Base
0x00000400, // Address Length
_Y2E)
})
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (HPTE)
{
Return (0x0F)
}
Return (0x00)
}
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
If (HPTE)
{
CreateDWordField (BUF0, \_SB.PCI0.LPCB.HPET._Y2E._BAS, HPT0) // _BAS: Base Address
HPT0 = HPTB /* \HPTB */
}
Return (BUF0) /* \_SB_.PCI0.LPCB.HPET.BUF0 */
}
}
Device (IPIC)
{
Name (_HID, EisaId ("PNP0000") /* 8259-compatible Programmable Interrupt Controller */) // _HID: Hardware ID
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
{
IO (Decode16,
0x0020, // Range Minimum
0x0020, // Range Maximum
0x01, // Alignment
0x02, // 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,
0x00A0, // Range Minimum
0x00A0, // 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
0x02, // Length
)
IO (Decode16,
0x00B4, // Range Minimum
0x00B4, // Range Maximum
0x01, // Alignment
0x02, // 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,
0x04D0, // Range Minimum
0x04D0, // Range Maximum
0x01, // Alignment
0x02, // Length
)
IRQNoFlags ()
{2}
})
}
Device (MATH)
{
Name (_HID, EisaId ("PNP0C04") /* x87-compatible Floating Point Processing Unit */) // _HID: Hardware ID
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
{
IO (Decode16,
0x00F0, // Range Minimum
0x00F0, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IRQNoFlags ()
{13}
})
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((PCHV () == SPTH))
{
Return (0x1F)
}
Else
{
Return (0x00)
}
}
}
Device (LDRC)
{
Name (_HID, EisaId ("PNP0C02") /* PNP Motherboard Resources */) // _HID: Hardware ID
Name (_UID, 0x02) // _UID: Unique ID
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
{
IO (Decode16,
0x002E, // Range Minimum
0x002E, // Range Maximum
0x01, // Alignment
0x02, // Length
)
IO (Decode16,
0x004E, // Range Minimum
0x004E, // Range Maximum
0x01, // Alignment
0x02, // Length
)
IO (Decode16,
0x0061, // Range Minimum
0x0061, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0x0063, // Range Minimum
0x0063, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0x0065, // Range Minimum
0x0065, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0x0067, // Range Minimum
0x0067, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0x0070, // Range Minimum
0x0070, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0x0080, // Range Minimum
0x0080, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0x0092, // Range Minimum
0x0092, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0x00B2, // Range Minimum
0x00B2, // Range Maximum
0x01, // Alignment
0x02, // Length
)
IO (Decode16,
0x0680, // Range Minimum
0x0680, // Range Maximum
0x01, // Alignment
0x20, // Length
)
IO (Decode16,
0xFFFF, // Range Minimum
0xFFFF, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0xFFFF, // Range Minimum
0xFFFF, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0xFFFF, // Range Minimum
0xFFFF, // Range Maximum
0x01, // Alignment
0x01, // Length
)
IO (Decode16,
0x1800, // Range Minimum
0x1800, // Range Maximum
0x01, // Alignment
0xFF, // Length
)
IO (Decode16,
0x164E, // Range Minimum
0x164E, // Range Maximum
0x01, // Alignment
0x02, // Length
)
})
}
Device (LDR2)
{
Name (_HID, EisaId ("PNP0C02") /* PNP Motherboard Resources */) // _HID: Hardware ID
Name (_UID, "LPC_DEV") // _UID: Unique ID
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
{
IO (Decode16,
0x0800, // Range Minimum
0x0800, // Range Maximum
0x01, // Alignment
0x80, // Length
)
})
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((PCHV () == SPTH))
{
Return (0x0F)
}
Else
{
Return (0x00)
}
}
}
Device (RTC)
{
Name (_HID, EisaId ("PNP0B00") /* AT Real-Time Clock */) // _HID: Hardware ID
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
{
IO (Decode16,
0x0070, // Range Minimum
0x0070, // Range Maximum
0x01, // Alignment
0x08, // Length
)
IRQNoFlags ()
{8}
})
}
Device (TIMR)
{
Name (_HID, EisaId ("PNP0100") /* PC-class System Timer */) // _HID: Hardware ID
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
{
IO (Decode16,
0x0040, // Range Minimum
0x0040, // Range Maximum
0x01, // Alignment
0x04, // Length
)
IO (Decode16,
0x0050, // Range Minimum
0x0050, // Range Maximum
0x10, // Alignment
0x04, // Length
)
IRQNoFlags ()
{0}
})
}
Device (CWDT)
{
Name (_HID, EisaId ("INT3F0D") /* ACPI Motherboard Resources */) // _HID: Hardware ID
Name (_CID, EisaId ("PNP0C02") /* PNP Motherboard Resources */) // _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) /* \_SB_.PCI0.LPCB.CWDT.BUF0 */
}
}
Device (SPKR)
{
Name (_HID, EisaId ("PNP0800") /* Microsoft Sound System Compatible Device */) // _HID: Hardware ID
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
{
IO (Decode16,
0x0061, // Range Minimum
0x0061, // Range Maximum
0x01, // Alignment
0x01, // Length
)
})
}
Device (KBD)
{
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
If (\WIN8)
{
Return (0x7100AE30)
}
Return (0x0303D041)
}
Name (_CID, EisaId ("PNP0303") /* IBM Enhanced Keyboard (101/102-key, PS/2 Mouse) */) // _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}
})
}
}
Name (ECUP, 0x01)
Mutex (EHLD, 0x00)
Method (TBTD, 1, Serialized)
{
ADBG ("TBTD")
Switch (ToInteger (Arg0))
{
Case (Package (0x08)
{
0x01,
0x02,
0x03,
0x04,
0x05,
0x06,
0x07,
0x08
}
)
{
Local0 = 0x1C
}
Case (Package (0x08)
{
0x09,
0x0A,
0x0B,
0x0C,
0x0D,
0x0E,
0x0F,
0x10
}
)
{
Local0 = 0x1D
}
Case (Package (0x04)
{
0x11,
0x12,
0x13,
0x14
}
)
{
Local0 = 0x1B
}
Case (Package (0x03)
{
0x15,
0x16,
0x17
}
)
{
Local0 = 0x01
}
}
ADBG ("Device no")
ADBG (Local0)
Return (Local0)
}
Method (TBTF, 1, Serialized)
{
ADBG ("TBTF")
Switch (ToInteger (Arg0))
{
Case (0x01)
{
Local0 = (\RPA1 & 0x0F)
}
Case (0x02)
{
Local0 = (\RPA2 & 0x0F)
}
Case (0x03)
{
Local0 = (\RPA3 & 0x0F)
}
Case (0x04)
{
Local0 = (\RPA4 & 0x0F)
}
Case (0x05)
{
Local0 = (\RPA5 & 0x0F)
}
Case (0x06)
{
Local0 = (\RPA6 & 0x0F)
}
Case (0x07)
{
Local0 = (\RPA7 & 0x0F)
}
Case (0x08)
{
Local0 = (\RPA8 & 0x0F)
}
Case (0x09)
{
Local0 = (\RPA9 & 0x0F)
}
Case (0x0A)
{
Local0 = (\RPAA & 0x0F)
}
Case (0x0B)
{
Local0 = (\RPAB & 0x0F)
}
Case (0x0C)
{
Local0 = (\RPAC & 0x0F)
}
Case (0x0D)
{
Local0 = (\RPAD & 0x0F)
}
Case (0x0E)
{
Local0 = (\RPAE & 0x0F)
}
Case (0x0F)
{
Local0 = (\RPAF & 0x0F)
}
Case (0x10)
{
Local0 = (\RPAG & 0x0F)
}
Case (0x11)
{
Local0 = (\RPAH & 0x0F)
}
Case (0x12)
{
Local0 = (\RPAI & 0x0F)
}
Case (0x13)
{
Local0 = (\RPAJ & 0x0F)
}
Case (0x14)
{
Local0 = (\RPAK & 0x0F)
}
Case (0x15)
{
Local0 = 0x00
}
Case (0x16)
{
Local0 = 0x01
}
Case (0x17)
{
Local0 = 0x02
}
}
ADBG ("Function no")
ADBG (Local0)
Return (Local0)
}
Method (MMRP, 1, Serialized)
{
Local0 = \_SB.PCI0.GPCB ()
Local0 += (TBTD (Arg0) << 0x0F)
Local0 += (TBTF (Arg0) << 0x0C)
Return (Local0)
}
Method (MMTB, 1, Serialized)
{
ADBG ("MMTB")
Local0 = \_SB.PCI0.GPCB ()
Local0 += (TBTD (Arg0) << 0x0F)
Local0 += (TBTF (Arg0) << 0x0C)
OperationRegion (MMMM, SystemMemory, Local0, 0x1A)
Field (MMMM, AnyAcc, NoLock, Preserve)
{
Offset (0x19),
SBUS, 8
}
Local2 = SBUS /* \MMTB.SBUS */
Local0 = \_SB.PCI0.GPCB ()
Local2 *= 0x00100000
Local0 += Local2
ADBG ("TBT-US-ADR")
ADBG (Local0)
Return (Local0)
}
Method (FFTB, 1, Serialized)
{
ADBG ("FFTB")
Local0 = (MMTB (Arg0) + 0x0548)
OperationRegion (PXVD, SystemMemory, Local0, 0x08)
Field (PXVD, DWordAcc, NoLock, Preserve)
{
TB2P, 32,
P2TB, 32
}
Local1 = TB2P /* \FFTB.TB2P */
If ((Local1 == 0xFFFFFFFF))
{
ADBG ("FFTb 1")
Return (0x01)
}
Else
{
ADBG ("FFTb 0")
Return (0x00)
}
}
Scope (\_SB)
{
OperationRegion (ITSS, SystemMemory, 0xFDC43100, 0x0208)
Field (ITSS, ByteAcc, NoLock, Preserve)
{
PARC, 8,
PBRC, 8,
PCRC, 8,
PDRC, 8,
PERC, 8,
PFRC, 8,
PGRC, 8,
PHRC, 8,
Offset (0x200),
, 1,
, 1,
SCGE, 1
}
}
Mutex (MUTX, 0x00)
Mutex (OSUM, 0x00)
Event (WFEV)
OperationRegion (PRT0, SystemIO, 0x80, 0x04)
Field (PRT0, DWordAcc, Lock, Preserve)
{
P80H, 32
}
OperationRegion (PXVD, SystemMemory, 0xF0500544, 0x08)
Field (PXVD, DWordAcc, NoLock, Preserve)
{
HPFI, 1,
Offset (0x04),
TB2P, 32
}
Field (PRT0, ByteAcc, NoLock, Preserve)
{
P80P, 8
}
Method (D8XH, 2, Serialized)
{
If ((Arg0 == 0x00))
{
P80D = ((P80D & 0xFFFFFF00) | Arg1)
}
If ((Arg0 == 0x01))
{
P80D = ((P80D & 0xFFFF00FF) | (Arg1 << 0x08))
}
If ((Arg0 == 0x02))
{
P80D = ((P80D & 0xFF00FFFF) | (Arg1 << 0x10))
}
If ((Arg0 == 0x03))
{
P80D = ((P80D & 0x00FFFFFF) | (Arg1 << 0x18))
}
P80H = P80D /* \P80D */
}
Method (P8XH, 2, Serialized)
{
If (CondRefOf (MDBG))
{
D8XH (Arg0, Arg1)
}
}
Method (ADBG, 1, Serialized)
{
Return (0x00)
}
OperationRegion (SPRT, SystemIO, 0xB2, 0x02)
Field (SPRT, ByteAcc, Lock, Preserve)
{
SSMP, 8
}
Method (\_PIC, 1, NotSerialized) // _PIC: Interrupt Model
{
GPIC = Arg0
PICM = Arg0
}
Method (OPTS, 1, NotSerialized)
{
P80D = 0x00
P8XH (0x00, Arg0)
ADBG (Concatenate ("OPTS=", ToHexString (Arg0)))
Local0 = 0x01
If ((Arg0 == \SPS))
{
Local0 = 0x00
}
If (((Arg0 == 0x00) || (Arg0 >= 0x06)))
{
Local0 = 0x00
}
If (Local0)
{
\SPS = Arg0
\_SB.PCI0.LPCB.EC.HKEY.MHKE (0x00)
If (\_SB.PCI0.LPCB.EC.KBLT)
{
\UCMS (0x0D)
}
If ((Arg0 == 0x01))
{
\FNID = \_SB.PCI0.LPCB.EC.HFNI
\_SB.PCI0.LPCB.EC.HFNI = 0x00
\_SB.PCI0.LPCB.EC.HFSP = 0x00
}
If ((Arg0 == 0x03))
{
\_SB.PCI0.LPCB.EC.SYSC (0x03)
\VVPD (0x03)
\_SB.PCI0.LPCB.EC.INOS = 0x00
\SLTP ()
\ACST = \_SB.PCI0.LPCB.EC.AC._PSR ()
If ((\FNWK == 0x01))
{
If (\H8DR)
{
\_SB.PCI0.LPCB.EC.HWFN = 0x00
}
Else
{
\MBEC (0x32, 0xEF, 0x00)
}
}
}
If ((Arg0 == 0x04))
{
\_SB.PCI0.LPCB.EC.SYSC (0x04)
\_SB.PCI0.LPCB.EC.INOS = 0x00
If (VDSP)
{
SHA1 = Zero
}
\_SB.SLPB._PSW (0x00)
\SLTP ()
\AWON (0x04)
}
If ((Arg0 == 0x05))
{
\_SB.PCI0.LPCB.EC.SYSC (0x05)
\SLTP ()
\_SB.PCI0.LPCB.EC.INOS = 0x00
\AWON (0x05)
}
If ((Arg0 >= 0x04))
{
\_SB.PCI0.LPCB.EC.HWLB = 0x00
}
Else
{
\_SB.PCI0.LPCB.EC.HWLB = 0x01
}
If ((Arg0 >= 0x04))
{
\_SB.SGOV (0x0203000F, 0x00)
}
If ((Arg0 >= 0x03))
{
\_SB.PCI0.LPCB.EC.HCMU = 0x01
}
If ((Arg0 != 0x05)){}
\_SB.PCI0.LPCB.EC.HKEY.WGPS (Arg0)
}
ADBG ("OPTS END")
}
Method (_PTS, 1, NotSerialized) // _PTS: Prepare To Sleep
{
P80D = 0x00
D8XH (0x00, Arg0)
ADBG (Concatenate ("_PTS=", ToHexString (Arg0)))
If ((TBTS == 0x01))
{
TRD3 = 0x01
Reset (WFEV)
}
If ((Arg0 == 0x03))
{
If (CondRefOf (\_PR.DTSE))
{
If ((\_PR.DTSE && (TCNT > 0x01)))
{
TRAP (0x02, 0x1E)
}
}
}
If (CondRefOf (\_SB.TPM.PTS))
{
\_SB.TPM.PTS (Arg0)
}
If ((((Arg0 == 0x03) || (Arg0 == 0x04)) || (Arg0 == 0x05)))
{
If ((PFLV == 0x02))
{
\_SB.SGOV (0x02010003, 0x01)
}
}
OPTS (Arg0)
}
Name (WAKI, Package (0x02)
{
0x00,
0x00
})
Method (OWAK, 1, NotSerialized)
{
ADBG ("OWAK")
If (((Arg0 == 0x00) || (Arg0 >= 0x05)))
{
Return (WAKI) /* \WAKI */
}
\SPS = 0x00
\_SB.PCI0.LPCB.EC.HCMU = 0x00
\_SB.PCI0.LPCB.EC.EVNT (0x01)
\_SB.PCI0.LPCB.EC.HKEY.MHKE (0x01)
\_SB.PCI0.LPCB.EC.FNST ()
\UCMS (0x0D)
\LIDB = 0x00
\PMMD = \_SB.PCI0.LPCB.EC.CMMD
If ((\PMMD >= 0x07))
{
\PMMD = 0x00
}
\LVMD = \_SB.PCI0.LPCB.EC.CMMD
If (((\LVMD == 0x00) || (\LVMD >= 0x07)))
{
\LVMD = 0x01
}
ElseIf (((\LVMD == 0x02) || (\LVMD == 0x03)))
{
\LVMD = 0x02
}
Else
{
\LVMD = 0x03
}
If ((\PMMD >= 0x04))
{
\_SB.PCI0.LPCB.EC.VGBI.STPR = 0x01
}
Else
{
\_SB.PCI0.LPCB.EC.VGBI.STPR = 0x00
}
If ((\_SB.PCI0.LPCB.EC.HPLD && \_SB.PCI0.LPCB.EC.FKBS))
{
\_SB.PCI0.LPCB.EC.FLIP = 0x01
}
Else
{
\_SB.PCI0.LPCB.EC.FLIP = 0x00
}
If ((Arg0 == 0x01))
{
\FNID = \_SB.PCI0.LPCB.EC.HFNI
}
If ((Arg0 == 0x03))
{
\_SB.PCI0.LPCB.EC.SYSC (0x30)
\NVSS (0x00)
\_SB.PCI0.LPCB.EC.INOS = 0x01
\PWRS = \_SB.PCI0.LPCB.EC.AC._PSR ()
If (\OSC4)
{
\PNTF (0x81)
}
If ((\ACST != \_SB.PCI0.LPCB.EC.AC._PSR ()))
{
\_SB.PCI0.LPCB.EC.ATMC ()
}
If (\SCRM)
{
\_SB.PCI0.LPCB.EC.HFSP = 0x07
}
\IOEN = 0x00
\IOST = 0x00
If ((\ISWK == 0x01))
{
If (\_SB.PCI0.LPCB.EC.HKEY.DHKC)
{
\_SB.PCI0.LPCB.EC.HKEY.MHKQ (0x6070)
}
}
If (\VIGD)
{
\_SB.PCI0.GFX0.CLID = \_SB.LID._LID ()
If (\WVIS)
{
\VBTD ()
}
}
ElseIf (\WVIS)
{
\_SB.PCI0.GFX0.CLID = \_SB.LID._LID ()
\VBTD ()
}
\VCMS (0x01, \_SB.LID._LID ())
\AWON (0x00)
If (\CMPR)
{
Notify (\_SB.SLPB, 0x02) // Device Wake
\CMPR = 0x00
}
If ((\WLAC == 0x02)){}
ElseIf ((\_SB.PCI0.LPCB.EC.ELNK && (\WLAC == 0x01)))
{
\_SB.PCI0.LPCB.EC.DCWL = 0x00
}
Else
{
\_SB.PCI0.LPCB.EC.DCWL = 0x01
}
}
If ((Arg0 >= 0x04))
{
\_SB.PCI0.LPCB.EC.SYSC (0x40)
\_SB.SGOV (0x0203000F, 0x01)
}
If (\_SB.PCI0.LPCB.EC.HPLD)
{
\_SB.SGOV (0x02030017, 0x01)
}
Else
{
\_SB.SGOV (0x02030017, 0x00)
}
If ((Arg0 >= 0x04))
{
If ((\LCME >= 0x01))
{
\_SB.PCI0.LPCB.EC.ECCM = 0x01
}
Else
{
\_SB.PCI0.LPCB.EC.ECCM = 0x00
}
}
If ((Arg0 == 0x04))
{
\NVSS (0x00)
\_SB.PCI0.LPCB.EC.INOS = 0x01
\_SB.PCI0.LPCB.EC.HSPA = 0x00
\PWRS = \_SB.PCI0.LPCB.EC.AC._PSR ()
If (\OSC4)
{
\PNTF (0x81)
}
\_SB.PCI0.LPCB.EC.ATMC ()
If (\SCRM)
{
\_SB.PCI0.LPCB.EC.HFSP = 0x07
}
If (!\NBCF)
{
If (\VIGD)
{
\_SB.PCI0.LPCB.EC.BRNS ()
}
Else
{
\VBRC (\BRLV)
}
}
\IOEN = 0x00
\IOST = 0x00
If ((\ISWK == 0x02))
{
If (\_SB.PCI0.LPCB.EC.HKEY.DHKC)
{
\_SB.PCI0.LPCB.EC.HKEY.MHKQ (0x6080)
}
}
If ((\WLAC == 0x02)){}
ElseIf ((\_SB.PCI0.LPCB.EC.ELNK && (\WLAC == 0x01)))
{
\_SB.PCI0.LPCB.EC.DCWL = 0x00
}
Else
{
\_SB.PCI0.LPCB.EC.DCWL = 0x01
}
}
\_SB.PCI0.LPCB.EC.BATW (Arg0)
\_SB.PCI0.LPCB.EC.HKEY.WGWK (Arg0)
Notify (\_TZ.THM0, 0x80) // Thermal Status Change
\VSLD (\_SB.LID._LID ())
If (\VIGD)
{
\_SB.PCI0.GFX0.CLID = \_SB.LID._LID ()
}
ElseIf (\WVIS)
{
\_SB.PCI0.GFX0.CLID = \_SB.LID._LID ()
}
If ((Arg0 < 0x04))
{
If (((\RRBF & 0x02) || (\_SB.PCI0.LPCB.EC.HWAC & 0x02)))
{
Local0 = (Arg0 << 0x08)
Local0 = (0x2013 | Local0)
\_SB.PCI0.LPCB.EC.HKEY.MHKQ (Local0)
}
}
If ((Arg0 == 0x04))
{
Local0 = 0x00
Local1 = \CSUM (0x00)
If ((Local1 != \CHKC))
{
Local0 = 0x01
\CHKC = Local1
}
Local1 = \CSUM (0x01)
If ((Local1 != \CHKE))
{
Local0 = 0x01
\CHKE = Local1
}
If (Local0)
{
Notify (\_SB, 0x00) // Bus Check
}
}
If (((Arg0 == 0x03) || (Arg0 == 0x04)))
{
ADBG ("_WAK0")
\_SB.PCI0.LPCB.EC.HKEY.ANGN = 0x00
If (\H8DR)
{
Local1 = \_SB.PCI0.LPCB.EC.TSL2
Local2 = \_SB.PCI0.LPCB.EC.TSL1
}
Else
{
Local1 = (\RBEC (0x8A) & 0x7F)
Local2 = (\RBEC (0x89) & 0x7F)
}
If ((Local2 & 0x76))
{
\_SB.PCI0.LPCB.EC.HKEY.DYTC (0x001F4001)
}
Else
{
\_SB.PCI0.LPCB.EC.HKEY.DYTC (0x000F4001)
}
\_SB.PCI0.LPCB.EC.HKEY.DYTC (0x000F0001)
ADBG ("_WAK1")
}
If (((Arg0 == 0x03) || (Arg0 == 0x04)))
{
If ((GBSX & 0x40))
{
\_SB.PCI0.VID.IUEH (0x06)
PB1E ^= 0x08
}
If ((GBSX & 0x80))
{
\_SB.PCI0.VID.IUEH (0x07)
PB1E ^= 0x10
}
}
If ((Arg0 >= 0x04))
{
\_SB.PCI0.LPCB.EC.HATR = 0x45
}
\RRBF = Zero
ADBG ("OWAK END")
Return (WAKI) /* \WAKI */
}
Method (_WAK, 1, Serialized) // _WAK: Wake
{
D8XH (0x01, 0xAB)
ADBG ("_WAK")
If ((TBTS == 0x01))
{
TRD3 = 0x00
}
\_SB.PCI0.GEXP.INVC ()
If ((S0ID == One))
{
\_SB.SCGE = 0x01
}
If (NEXP)
{
If ((OSCC & 0x02))
{
\_SB.PCI0.NHPG ()
}
If ((OSCC & 0x04))
{
\_SB.PCI0.NPME ()
}
}
If (((Arg0 == 0x03) || (Arg0 == 0x04)))
{
If ((GBSX & 0x40))
{
\_SB.PCI0.GFX0.IUEH (0x06)
PB1E ^= 0x08
}
If ((GBSX & 0x80))
{
\_SB.PCI0.GFX0.IUEH (0x07)
PB1E ^= 0x10
}
If (CondRefOf (\_PR.DTSE))
{
If ((\_PR.DTSE && (TCNT > 0x01)))
{
TRAP (0x02, 0x14)
}
}
If ((TBTS == 0x01))
{
Acquire (OSUM, 0xFFFF)
Local0 = \_GPE.TINI (TBSE)
If ((TBMP == 0x01))
{
\_GPE.TINI (TBS1)
}
Release (OSUM)
If ((Local0 == 0x01))
{
Local1 = 0xC8
ADBG ("Out of While")
While ((Local1 > 0x00))
{
ADBG ("In While _WAK")
Local2 = HPFI /* \HPFI */
If ((Local2 == 0x01))
{
ADBG ("STBT Again")
\_GPE.STBT (TBSE, CPGN)
ADBG ("STBT Again End")
Break
}
Local1 = (Local1 - 0x01)
Sleep (0x32)
}
}
}
If ((\_SB.PCI0.RP01.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP01, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP02.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP02, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP03.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP03, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP04.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP04, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP05.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP05, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP06.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP06, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP07.VDID != 0xFFFFFFFF))
{
If ((\DSTS == 0x00))
{
Notify (\_SB.PCI0.RP07, 0x00) // Bus Check
}
}
If ((\_SB.PCI0.RP08.VDID != 0xFFFFFFFF))
{
If ((\DSTS == 0x00))
{
Notify (\_SB.PCI0.RP08, 0x00) // Bus Check
}
}
If ((\_SB.PCI0.RP09.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP09, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP10.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP10, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP11.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP11, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP12.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP12, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP13.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP13, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP14.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP14, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP15.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP15, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP16.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP16, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP17.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP17, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP18.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP18, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP19.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP19, 0x00) // Bus Check
}
If ((\_SB.PCI0.RP20.VDID != 0xFFFFFFFF))
{
Notify (\_SB.PCI0.RP20, 0x00) // Bus Check
}
If (CondRefOf (\_SB.VMEN))
{
\_SB.VMEN = 0xFF
}
}
OWAK (Arg0)
If ((TBTS == 0x01))
{
Signal (WFEV)
}
Return (Package (0x02)
{
0x00,
0x00
})
}
Method (GETB, 3, Serialized)
{
Local0 = (Arg0 * 0x08)
Local1 = (Arg1 * 0x08)
CreateField (Arg2, Local0, Local1, TBF3)
Return (TBF3) /* \GETB.TBF3 */
}
Method (PNOT, 0, Serialized)
{
If ((TCNT > 0x01))
{
If ((\PC00 & 0x08))
{
Notify (\_PR.PR00, 0x80) // Performance Capability Change
}
If ((\PC01 & 0x08))
{
Notify (\_PR.PR01, 0x80) // Performance Capability Change
}
If ((\PC02 & 0x08))
{
Notify (\_PR.PR02, 0x80) // Performance Capability Change
}
If ((\PC03 & 0x08))
{
Notify (\_PR.PR03, 0x80) // Performance Capability Change
}
If ((\PC04 & 0x08))
{
Notify (\_PR.PR04, 0x80) // Performance Capability Change
}
If ((\PC05 & 0x08))
{
Notify (\_PR.PR05, 0x80) // Performance Capability Change
}
If ((\PC06 & 0x08))
{
Notify (\_PR.PR06, 0x80) // Performance Capability Change
}
If ((\PC07 & 0x08))
{
Notify (\_PR.PR07, 0x80) // Performance Capability Change
}
If ((\PC08 & 0x08))
{
Notify (\_PR.PR08, 0x80) // Performance Capability Change
}
If ((\PC09 & 0x08))
{
Notify (\_PR.PR09, 0x80) // Performance Capability Change
}
If ((\PC10 & 0x08))
{
Notify (\_PR.PR10, 0x80) // Performance Capability Change
}
If ((\PC11 & 0x08))
{
Notify (\_PR.PR11, 0x80) // Performance Capability Change
}
If ((\PC12 & 0x08))
{
Notify (\_PR.PR12, 0x80) // Performance Capability Change
}
If ((\PC13 & 0x08))
{
Notify (\_PR.PR13, 0x80) // Performance Capability Change
}
If ((\PC14 & 0x08))
{
Notify (\_PR.PR14, 0x80) // Performance Capability Change
}
If ((\PC15 & 0x08))
{
Notify (\_PR.PR15, 0x80) // Performance Capability Change
}
}
Else
{
Notify (\_PR.PR00, 0x80) // Performance Capability Change
}
If ((TCNT > 0x01))
{
If (((\PC00 & 0x08) && (\PC00 & 0x10)))
{
Notify (\_PR.PR00, 0x81) // C-State Change
}
If (((\PC01 & 0x08) && (\PC01 & 0x10)))
{
Notify (\_PR.PR01, 0x81) // C-State Change
}
If (((\PC02 & 0x08) && (\PC02 & 0x10)))
{
Notify (\_PR.PR02, 0x81) // C-State Change
}
If (((\PC03 & 0x08) && (\PC03 & 0x10)))
{
Notify (\_PR.PR03, 0x81) // C-State Change
}
If (((\PC04 & 0x08) && (\PC04 & 0x10)))
{
Notify (\_PR.PR04, 0x81) // C-State Change
}
If (((\PC05 & 0x08) && (\PC05 & 0x10)))
{
Notify (\_PR.PR05, 0x81) // C-State Change
}
If (((\PC06 & 0x08) && (\PC06 & 0x10)))
{
Notify (\_PR.PR06, 0x81) // C-State Change
}
If (((\PC07 & 0x08) && (\PC07 & 0x10)))
{
Notify (\_PR.PR07, 0x81) // C-State Change
}
If (((\PC08 & 0x08) && (\PC08 & 0x10)))
{
Notify (\_PR.PR08, 0x81) // C-State Change
}
If (((\PC09 & 0x08) && (\PC09 & 0x10)))
{
Notify (\_PR.PR09, 0x81) // C-State Change
}
If (((\PC10 & 0x08) && (\PC10 & 0x10)))
{
Notify (\_PR.PR10, 0x81) // C-State Change
}
If (((\PC11 & 0x08) && (\PC11 & 0x10)))
{
Notify (\_PR.PR11, 0x81) // C-State Change
}
If (((\PC12 & 0x08) && (\PC12 & 0x10)))
{
Notify (\_PR.PR12, 0x81) // C-State Change
}
If (((\PC13 & 0x08) && (\PC13 & 0x10)))
{
Notify (\_PR.PR13, 0x81) // C-State Change
}
If (((\PC14 & 0x08) && (\PC14 & 0x10)))
{
Notify (\_PR.PR14, 0x81) // C-State Change
}
If (((\PC15 & 0x08) && (\PC15 & 0x10)))
{
Notify (\_PR.PR15, 0x81) // C-State Change
}
}
Else
{
Notify (\_PR.PR00, 0x81) // C-State Change
}
If ((DPTF == 0x01))
{
Notify (\_SB.IETM, 0x86) // Device-Specific
If ((CHGE == 0x01)){}
}
}
OperationRegion (MBAR, SystemMemory, (\_SB.PCI0.GMHB () + 0x5000), 0x1000)
Field (MBAR, ByteAcc, NoLock, Preserve)
{
Offset (0x938),
PWRU, 4,
Offset (0x9A0),
PPL1, 15,
PL1E, 1,
CLP1, 1
}
Name (CLMP, 0x00)
Name (PLEN, 0x00)
Name (PLSV, 0x8000)
Name (CSEM, 0x00)
Method (SPL1, 0, Serialized)
{
Name (PPUU, 0x00)
If ((CSEM == 0x01))
{
Return (Zero)
}
CSEM = 0x01
PLSV = PPL1 /* \PPL1 */
PLEN = PL1E /* \PL1E */
CLMP = CLP1 /* \CLP1 */
If ((PWRU == 0x00))
{
PPUU = 0x01
}
Else
{
PPUU = (PWRU-- << 0x02)
}
Local0 = (PLVL * PPUU) /* \SPL1.PPUU */
Local1 = (Local0 / 0x03E8)
PPL1 = Local1
PL1E = 0x01
CLP1 = 0x01
}
Method (RPL1, 0, Serialized)
{
PPL1 = PLSV /* \PLSV */
PL1E = PLEN /* \PLEN */
CLP1 = CLMP /* \CLMP */
CSEM = 0x00
}
Name (UAMS, 0x00)
Name (GLCK, 0x00)
Name (DDPS, 0x00)
Method (GUAM, 1, Serialized)
{
Switch (ToInteger (Arg0))
{
Case (0x00)
{
If ((GLCK == 0x01))
{
GLCK = 0x00
P8XH (0x00, 0xE1)
P8XH (0x01, 0xAB)
ADBG ("Exit Resiliency")
If ((OSYS < 0x07DF))
{
\_SB.PCI0.LPCB.EC.ECNT (0x00)
}
If (PSCP)
{
If (CondRefOf (\_PR.PR00._PPC))
{
\_PR.CPPC = Zero
PNOT ()
}
}
If (PLCS)
{
RPL1 ()
}
}
}
Case (0x01)
{
If ((GLCK == 0x00))
{
GLCK = 0x01
P8XH (0x00, 0xE0)
P8XH (0x01, 0x00)
ADBG ("Enter Resiliency")
If ((OSYS < 0x07DF))
{
\_SB.PCI0.LPCB.EC.ECNT (0x01)
}
If (PSCP)
{
If ((CondRefOf (\_PR.PR00._PSS) && CondRefOf (\_PR.PR00._PPC)))
{
If ((\PC00 & 0x0400))
{
\_PR.CPPC = (SizeOf (\_PR.PR00.TPSS) - One)
}
Else
{
\_PR.CPPC = (SizeOf (\_PR.PR00.LPSS) - One)
}
PNOT ()
}
}
If (PLCS)
{
SPL1 ()
}
}
}
Default
{
Return (Zero)
}
}
UAMS = (Arg0 && !PWRS)
P_CS ()
If ((NLID && (OSYS < 0x07DF)))
{
If (((Arg0 == 0x00) && \_SB.LID._LID ()))
{
Notify (\_SB.LID, 0x80) // Status Change
}
}
}
Method (P_CS, 0, Serialized)
{
If (CondRefOf (\_SB.PCI0.PAUD.PUAM))
{
\_SB.PCI0.PAUD.PUAM ()
}
If ((OSYS == 0x07DC))
{
If (CondRefOf (\_SB.PCI0.XHC.DUAM))
{
\_SB.PCI0.XHC.DUAM ()
}
}
}
Scope (\)
{
OperationRegion (IO_H, SystemIO, 0x1000, 0x04)
Field (IO_H, ByteAcc, NoLock, Preserve)
{
TRPH, 8
}
}
Method (TRAP, 2, Serialized)
{
SMIF = Arg1
If ((Arg0 == 0x02))
{
\_PR.DTSF = Arg1
\_PR.TRPD = 0x00
Return (\_PR.DTSF) /* External reference */
}
If ((Arg0 == 0x03))
{
TRPH = 0x00
}
If ((Arg0 == 0x04))
{
\_PR.TRPF = 0x00
}
Return (SMIF) /* \SMIF */
}
Scope (\_SB.PCI0)
{
Method (PTMA, 0, NotSerialized)
{
Return (\_PR.BGMA) /* External reference */
}
Method (PTMS, 0, NotSerialized)
{
Return (\_PR.BGMS) /* External reference */
}
Method (PTIA, 0, NotSerialized)
{
Return (\_PR.BGIA) /* External reference */
}
Method (OINI, 0, NotSerialized)
{
ADBG ("Init _INI")
If ((\_REV >= 0x02))
{
\H8DR = 0x01
}
\OSIF = 0x01
\PWRS = \_SB.PCI0.LPCB.EC.AC._PSR ()
If (\LNUX)
{
\_SB.PCI0.LPCB.EC.SAUM (0x02)
\UCMS (0x1C)
}
\_SB.PCI0.RID = \SRAH
If (VIGD)
{
\_SB.PCI0.GFX0.RID = \SRHE
}
Else
{
\_SB.PCI0.PEG0.RID = \SRHE
}
\_SB.PCI0.RP01.RID = \SRE1
\_SB.PCI0.RP02.RID = \SRE2
\_SB.PCI0.RP03.RID = \SRE3
\_SB.PCI0.RP04.RID = \SRE4
\_SB.PCI0.RP05.RID = \SRE4
\_SB.PCI0.LPCB.RID = \SRLP
\_SB.PCI0.SAT0.RID = \SRSA
\_SB.PCI0.SBUS.RID = \SRSM
\PMMD = \_SB.PCI0.LPCB.EC.CMMD
If ((\PMMD >= 0x07))
{
\PMMD = 0x00
}
\LVMD = \_SB.PCI0.LPCB.EC.CMMD
If (((\LVMD == 0x00) || (\LVMD >= 0x07)))
{
\LVMD = 0x01
}
ElseIf (((\LVMD == 0x02) || (\LVMD == 0x03)))
{
\LVMD = 0x02
}
Else
{
\LVMD = 0x03
}
If ((\PMMD >= 0x04))
{
\_SB.PCI0.LPCB.EC.VGBI.STPR = 0x01
}
Else
{
\_SB.PCI0.LPCB.EC.VGBI.STPR = 0x00
}
If (\_SB.PCI0.LPCB.EC.HPLD)
{
\_SB.SGOV (0x02030017, 0x01)
}
Else
{
\_SB.SGOV (0x02030017, 0x00)
}
If ((\LCME >= 0x01))
{
\_SB.PCI0.LPCB.EC.ECCM = 0x01
}
Else
{
\_SB.PCI0.LPCB.EC.ECCM = 0x00
}
\_SB.PCI0.LPCB.EC.INOS = 0x01
}
Method (_INI, 0, Serialized) // _INI: Initialize
{
OSYS = 0x07D0
If (CondRefOf (\_OSI))
{
If (\_OSI ("Windows 2001"))
{
\WNTF = 0x01
\WXPF = 0x01
\WSPV = 0x00
OSYS = 0x07D1
}
If (\_OSI ("Windows 2001 SP1"))
{
\WSPV = 0x01
OSYS = 0x07D1
}
If (\_OSI ("Windows 2001 SP2"))
{
\WSPV = 0x02
OSYS = 0x07D2
}
If (\_OSI ("Windows 2006"))
{
\WVIS = 0x01
OSYS = 0x07D6
}
If (\_OSI ("Windows 2009"))
{
\WIN7 = 0x01
OSYS = 0x07D9
}
If (\_OSI ("Windows 2012"))
{
\WIN8 = 0x01
OSYS = 0x07DC
}
If (\_OSI ("Windows 2013"))
{
\WIN8 = 0x01
OSYS = 0x07DD
}
If (\_OSI ("Windows 2015"))
{
\WIN8 = 0x01
OSYS = 0x07DF
}
If (\_OSI ("Linux"))
{
\LNUX = 0x01
OSYS = 0x03E8
}
If (\_OSI ("FreeBSD"))
{
\LNUX = 0x01
OSYS = 0x03E8
}
}
ElseIf ((\SCMP (\_OS, "Microsoft Windows NT") == Zero))
{
\WNTF = 0x01
}
If (CondRefOf (\_PR.DTSE))
{
If ((\_PR.DTSE >= 0x01))
{
\_PR.DSAE = 0x01
}
}
If ((TBTS == 0x01))
{
Acquire (OSUM, 0xFFFF)
Local0 = \_GPE.TINI (TBSE)
Release (OSUM)
If ((Local0 == 0x01))
{
Local1 = 0xC8
ADBG ("Out of While")
While ((Local1 > 0x00))
{
ADBG ("In While _INI")
Local2 = HPFI /* \HPFI */
If ((Local2 == 0x01))
{
ADBG ("STBT Again")
\_GPE.STBT (TBSE, CPGN)
ADBG ("STBT Again End")
Break
}
Local1 = (Local1 - 0x01)
Sleep (0x32)
}
}
If ((TBMP == 0x01))
{
Acquire (OSUM, 0xFFFF)
\_GPE.TINI (TBS1)
Release (OSUM)
}
Signal (WFEV)
}
OINI ()
}
Method (NHPG, 0, Serialized)
{
^RP01.HPEX = 0x00
^RP02.HPEX = 0x00
^RP03.HPEX = 0x00
^RP04.HPEX = 0x00
^RP05.HPEX = 0x00
^RP06.HPEX = 0x00
^RP07.HPEX = 0x00
^RP08.HPEX = 0x00
^RP09.HPEX = 0x00
^RP10.HPEX = 0x00
^RP11.HPEX = 0x00
^RP12.HPEX = 0x00
^RP13.HPEX = 0x00
^RP14.HPEX = 0x00
^RP15.HPEX = 0x00
^RP16.HPEX = 0x00
^RP17.HPEX = 0x00
^RP18.HPEX = 0x00
^RP19.HPEX = 0x00
^RP20.HPEX = 0x00
^RP01.HPSX = 0x01
^RP02.HPSX = 0x01
^RP03.HPSX = 0x01
^RP04.HPSX = 0x01
^RP05.HPSX = 0x01
^RP06.HPSX = 0x01
^RP07.HPSX = 0x01
^RP08.HPSX = 0x01
^RP09.HPSX = 0x01
^RP10.HPSX = 0x01
^RP11.HPSX = 0x01
^RP12.HPSX = 0x01
^RP13.HPSX = 0x01
^RP14.HPSX = 0x01
^RP15.HPSX = 0x01
^RP16.HPSX = 0x01
^RP17.HPSX = 0x01
^RP18.HPSX = 0x01
^RP19.HPSX = 0x01
^RP20.HPSX = 0x01
^RP01.PDCX = 0x01
^RP02.PDCX = 0x01
^RP03.PDCX = 0x01
^RP04.PDCX = 0x01
^RP05.PDCX = 0x01
^RP06.PDCX = 0x01
^RP07.PDCX = 0x01
^RP08.PDCX = 0x01
^RP09.PDCX = 0x01
^RP10.PDCX = 0x01
^RP11.PDCX = 0x01
^RP12.PDCX = 0x01
^RP13.PDCX = 0x01
^RP14.PDCX = 0x01
^RP15.PDCX = 0x01
^RP16.PDCX = 0x01
^RP17.PDCX = 0x01
^RP18.PDCX = 0x01
^RP19.PDCX = 0x01
^RP20.PDCX = 0x01
}
Method (NPME, 0, Serialized)
{
^RP01.PMEX = 0x00
^RP02.PMEX = 0x00
^RP03.PMEX = 0x00
^RP04.PMEX = 0x00
^RP05.PMEX = 0x00
^RP06.PMEX = 0x00
^RP07.PMEX = 0x00
^RP08.PMEX = 0x00
^RP09.PMEX = 0x00
^RP10.PMEX = 0x00
^RP11.PMEX = 0x00
^RP12.PMEX = 0x00
^RP13.PMEX = 0x00
^RP14.PMEX = 0x00
^RP15.PMEX = 0x00
^RP16.PMEX = 0x00
^RP17.PMEX = 0x00
^RP18.PMEX = 0x00
^RP19.PMEX = 0x00
^RP20.PMEX = 0x00
^RP01.PMSX = 0x01
^RP02.PMSX = 0x01
^RP03.PMSX = 0x01
^RP04.PMSX = 0x01
^RP05.PMSX = 0x01
^RP06.PMSX = 0x01
^RP07.PMSX = 0x01
^RP08.PMSX = 0x01
^RP09.PMSX = 0x01
^RP10.PMSX = 0x01
^RP11.PMSX = 0x01
^RP12.PMSX = 0x01
^RP13.PMSX = 0x01
^RP14.PMSX = 0x01
^RP15.PMSX = 0x01
^RP16.PMSX = 0x01
^RP17.PMSX = 0x01
^RP18.PMSX = 0x01
^RP19.PMSX = 0x01
^RP20.PMSX = 0x01
}
}
Scope (\)
{
Name (PICM, 0x00)
Name (PRWP, Package (0x02)
{
Zero,
Zero
})
Method (GPRW, 2, NotSerialized)
{
PRWP [0x00] = Arg0
Local0 = (SS1 << 0x01)
Local0 |= (SS2 << 0x02)
Local0 |= (SS3 << 0x03)
Local0 |= (SS4 << 0x04)
If (((0x01 << Arg1) & Local0))
{
PRWP [0x01] = Arg1
}
Else
{
Local0 >>= 0x01
FindSetLeftBit (Local0, PRWP [0x01])
}
Return (PRWP) /* \PRWP */
}
}
Scope (\_SB)
{
Name (OSCI, 0x00)
Name (OSCO, 0x00)
Name (OSCP, 0x00)
Method (_OSC, 4, Serialized) // _OSC: Operating System Capabilities
{
CreateDWordField (Arg3, 0x00, STS0)
CreateDWordField (Arg3, 0x04, CAP0)
If ((S0ID == One))
{
\_SB.SCGE = 0x01
}
If ((Arg0 == ToUUID ("0811b06e-4a27-44f9-8d60-3cbbc22e7b48") /* Platform-wide Capabilities */))
{
If ((Arg1 == One))
{
OSCP = CAP0 /* \_SB_._OSC.CAP0 */
If ((CAP0 & 0x04))
{
OSCO = 0x04
If (((SGMD & 0x0F) != 0x02))
{
If ((RTD3 == 0x00))
{
CAP0 &= 0x3B
STS0 |= 0x10
}
}
}
If ((CAP0 & 0x20))
{
\CPPX = 0x01
}
Else
{
CAP0 &= 0x9F
STS0 |= 0x10
}
}
ElseIf ((Arg0 == ToUUID ("ed855e0c-6c90-47bf-a62a-26de0fc5ad5c")))
{
Return (Arg3)
}
Else
{
STS0 &= 0xFFFFFF00
STS0 |= 0x0A
}
}
Else
{
STS0 &= 0xFFFFFF00
STS0 |= 0x06
}
Return (Arg3)
}
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
,, _Y2F, AddressRangeMemory, TypeStatic)
})
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
CreateQWordField (RBUF, \_SB.EPC._Y2F._MIN, EMIN) // _MIN: Minimum Base Address
CreateQWordField (RBUF, \_SB.EPC._Y2F._MAX, EMAX) // _MAX: Maximum Base Address
CreateQWordField (RBUF, \_SB.EPC._Y2F._LEN, ELEN) // _LEN: Length
EMIN = \_PR.EMNA /* External reference */
ELEN = \_PR.ELNG /* External reference */
EMAX = ((\_PR.EMNA + \_PR.ELNG) - 0x01)
Return (RBUF) /* \_SB_.EPC_.RBUF */
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If ((\_PR.EPCS != 0x00))
{
Return (0x0F)
}
Return (0x00)
}
}
}
Scope (\_SB)
{
Device (BTKL)
{
Name (_HID, "INT3420" /* Intel Bluetooth RF Kill */) // _HID: Hardware ID
Method (_STA, 0, NotSerialized) // _STA: Status
{
Return (0x00)
}
Method (_PS0, 0, Serialized) // _PS0: Power State 0
{
}
Method (_PS3, 0, Serialized) // _PS3: Power State 3
{
}
Method (PSTS, 0, NotSerialized)
{
}
}
}
Scope (\_SB)
{
Device (SLPB)
{
Name (_HID, EisaId ("PNP0C0E") /* Sleep Button Device */) // _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)
{
\_SB.PCI0.LPCB.EC.HWFN = 0x01
}
Else
{
\_SB.PCI0.LPCB.EC.HWFN = 0x00
}
}
ElseIf (Arg0)
{
\MBEC (0x32, 0xFF, 0x10)
}
Else
{
\MBEC (0x32, 0xEF, 0x00)
}
}
}
}
If ((RTVM == 0x01))
{
Scope (\_SB)
{
Name (VMEN, 0xFF)
Method (VMON, 0, Serialized)
{
If ((VMEN == 0x01))
{
Return (Zero)
}
}
Method (VMOF, 0, Serialized)
{
If ((VMEN == 0x00))
{
Return (Zero)
}
}
}
}
Name (TDMA, 0x80000000)
Name (TDPG, 0x80000000)
Name (TDTI, 0x80000000)
Name (TRD3, 0x00)
Scope (\_GPE)
{
Method (OSUP, 1, Serialized)
{
ADBG (Concatenate ("OSUP=", ToHexString (Arg0)))
Local0 = (Arg0 + 0x0548)
OperationRegion (PXVD, SystemMemory, Local0, 0x08)
Field (PXVD, DWordAcc, NoLock, Preserve)
{
TB2P, 32,
P2TB, 32
}
Local1 = 0x64
P2TB = 0x0D
While ((Local1 > 0x00))
{
Local1 = (Local1 - 0x01)
Local2 = TB2P /* \_GPE.OSUP.TB2P */
If ((Local2 == 0xFFFFFFFF))
{
ADBG ("Dev gone")
Return (0x02)
}
If ((Local2 & 0x01))
{
ADBG ("Cmd acknowledged")
Break
}
Sleep (0x32)
}
If ((TRWA == 0x01))
{
P2TB = 0x0C
}
Else
{
P2TB = 0x00
}
ADBG ("End-of-OSUP")
Return (0x01)
}
Method (PGWA, 1, Serialized)
{
ADBG ("PGWA")
If ((Arg0 >= 0x15))
{
Local0 = \_SB.PCI0.GPCB ()
Local0 += (TBTD (Arg0) << 0x0F)
Local0 += (TBTF (Arg0) << 0x0C)
ADBG (Local0)
OperationRegion (ABCD, SystemMemory, Local0, 0x1000)
Field (ABCD, AnyAcc, NoLock, Preserve)
{
Offset (0x84),
PWRS, 2,
Offset (0xB0),
, 4,
LNKD, 1,
Offset (0x11A),
, 1,
VCNP, 1,
Offset (0x508),
TREN, 1
}
If ((PWRS != 0x00))
{
ADBG ("Force D0")
PWRS = 0x00
\_PR.POWS = 0x00
Sleep (0x10)
}
If ((LNKD != 0x00))
{
ADBG ("Link Enable")
LNKD = 0x00
TREN = 0x01
Local6 = 0x00
Local7 = 0x64
While ((Local6 < Local7))
{
If ((VCNP == 0x00))
{
Break
}
Sleep (0x10)
Local6 += 0x10
}
}
}
}
Method (TBFF, 1, Serialized)
{
ADBG ("TBFF")
Local0 = MMTB (Arg0)
OperationRegion (PXVD, SystemMemory, Local0, 0x04)
Field (PXVD, DWordAcc, NoLock, Preserve)
{
VEDI, 32
}
Local1 = VEDI /* \_GPE.TBFF.VEDI */
If ((Local1 == 0xFFFFFFFF))
{
Return (OSUP (Local0))
}
Else
{
ADBG ("Dev Present")
Return (0x00)
}
}
Method (TSUB, 1, Serialized)
{
ADBG ("TSUB")
Local0 = \_SB.PCI0.GPCB ()
Local0 += (TBTD (Arg0) << 0x0F)
Local0 += (TBTF (Arg0) << 0x0C)
ADBG ("ADR")
ADBG (Local0)
OperationRegion (MMMM, SystemMemory, Local0, 0x1A)
Field (MMMM, AnyAcc, NoLock, Preserve)
{
Offset (0x19),
SBUS, 8
}
ADBG ("Sec Bus")
ADBG (SBUS)
Return (SBUS) /* \_GPE.TSUB.SBUS */
}
Method (WSUB, 1, Serialized)
{
ADBG ("WSUB")
Local0 = 0x00
Local1 = 0x00
While (0x01)
{
Local1 = TSUB (Arg0)
If (Local1)
{
ADBG ("WSUB-Finished")
Break
}
Else
{
Local0 += 0x01
If ((Local0 > 0x03E8))
{
Sleep (0x03E8)
ADBG ("WSUB-Deadlock")
}
Else
{
Sleep (0x10)
}
}
}
}
Method (WWAK, 0, NotSerialized)
{
ADBG ("WWAK")
Wait (WFEV, 0xFFFF)
Signal (WFEV)
}
Method (NTFY, 1, Serialized)
{
ADBG ("NTFY")
If ((NOHP == 0x01))
{
Switch (ToInteger (Arg0))
{
Case (0x01)
{
ADBG ("Notify RP01")
Notify (\_SB.PCI0.RP01, 0x00) // Bus Check
}
Case (0x02)
{
ADBG ("Notify RP02")
Notify (\_SB.PCI0.RP02, 0x00) // Bus Check
}
Case (0x03)
{
ADBG ("Notify RP03")
Notify (\_SB.PCI0.RP03, 0x00) // Bus Check
}
Case (0x04)
{
ADBG ("Notify RP04")
Notify (\_SB.PCI0.RP04, 0x00) // Bus Check
}
Case (0x05)
{
ADBG ("Notify RP05")
Notify (\_SB.PCI0.RP05, 0x00) // Bus Check
}
Case (0x06)
{
ADBG ("Notify RP06")
Notify (\_SB.PCI0.RP06, 0x00) // Bus Check
}
Case (0x07)
{
ADBG ("Notify RP07")
Notify (\_SB.PCI0.RP07, 0x00) // Bus Check
}
Case (0x08)
{
ADBG ("Notify RP08")
Notify (\_SB.PCI0.RP08, 0x00) // Bus Check
}
Case (0x09)
{
ADBG ("Notify RP09")
Notify (\_SB.PCI0.RP09, 0x00) // Bus Check
}
Case (0x0A)
{
ADBG ("Notify RP10")
Notify (\_SB.PCI0.RP10, 0x00) // Bus Check
}
Case (0x0B)
{
ADBG ("Notify RP11")
Notify (\_SB.PCI0.RP11, 0x00) // Bus Check
}
Case (0x0C)
{
ADBG ("Notify RP12")
Notify (\_SB.PCI0.RP12, 0x00) // Bus Check
}
Case (0x0D)
{
ADBG ("Notify RP13")
Notify (\_SB.PCI0.RP13, 0x00) // Bus Check
}
Case (0x0E)
{
ADBG ("Notify RP14")
Notify (\_SB.PCI0.RP14, 0x00) // Bus Check
}
Case (0x0F)
{
ADBG ("Notify RP15")
Notify (\_SB.PCI0.RP15, 0x00) // Bus Check
}
Case (0x10)
{
ADBG ("Notify RP16")
Notify (\_SB.PCI0.RP16, 0x00) // Bus Check
}
Case (0x11)
{
ADBG ("Notify RP17")
Notify (\_SB.PCI0.RP17, 0x00) // Bus Check
}
Case (0x12)
{
ADBG ("Notify RP18")
Notify (\_SB.PCI0.RP18, 0x00) // Bus Check
}
Case (0x13)
{
ADBG ("Notify RP19")
Notify (\_SB.PCI0.RP19, 0x00) // Bus Check
}
Case (0x14)
{
ADBG ("Notify RP20")
Notify (\_SB.PCI0.RP20, 0x00) // Bus Check
}
Case (0x15)
{
ADBG ("Notify PEG0")
Notify (\_SB.PCI0.PEG0, 0x00) // Bus Check
}
Case (0x16)
{
ADBG ("Notify PEG1")
Notify (\_SB.PCI0.PEG1, 0x00) // Bus Check
}
Case (0x17)
{
ADBG ("Notify PEG2")
Notify (\_SB.PCI0.PEG2, 0x00) // Bus Check
}
}
}
P8XH (0x00, 0xC2)
P8XH (0x01, 0xC2)
}
Method (NFYG, 0, NotSerialized)
{
ADBG ("NFYG")
If ((TDGS == 0x01))
{
If ((DCKE == 0x01))
{
ADBG ("NFYG.DCKE")
Notify (\_SB.PCI0.GFX0, 0x81) // Information Change
}
ElseIf ((SUDK == 0x01))
{
ADBG ("NFYG.SUDK")
Notify (\_SB.PCI0.GFX0, 0x81) // Information Change
}
}
}
Method (TFPS, 0, NotSerialized)
{
ADBG ("TFPS")
Local0 = \_SB.CGRD (FPAT, FPEN, FPGN, 0x00)
If (Local0)
{
ADBG ("ExtFrcPwr1")
}
Else
{
ADBG ("ExtFrcPwr0")
}
Return (Local0)
}
Method (CNCT, 0, NotSerialized)
{
ADBG ("CNCT")
ADBG ("Read")
ADBG ("ACPI_GPE_STS")
Local7 = CPAD /* \CPAD */
Local6 = CPAB /* \CPAB */
While ((Local6 > 0x08))
{
Local7 += 0x01
Local6 -= 0x08
}
OperationRegion (GPE0, SystemIO, Local7, 0x01)
Field (GPE0, ByteAcc, Lock, Preserve)
{
TEMP, 8
}
Local0 = TEMP /* \_GPE.CNCT.TEMP */
Local0 >>= Local6
Local0 &= 0x01
Return (Local0)
}
Method (CLNE, 0, NotSerialized)
{
ADBG ("CLNE")
ADBG ("Clear")
ADBG ("ACPI_GPE_STS")
Local7 = CPAD /* \CPAD */
Local6 = CPAB /* \CPAB */
While ((Local6 > 0x08))
{
Local7 += 0x01
Local6 -= 0x08
}
OperationRegion (GPE0, SystemIO, Local7, 0x01)
Field (GPE0, ByteAcc, Lock, Preserve)
{
TEMP, 8
}
Local6 = (0x01 << Local6)
TEMP |= Local6
}
Method (DRPM, 1, Serialized)
{
ADBG ("DRPM")
Local7 = \_SB.STDC (\_SB.PCI0.GPCB (), 0x00, TBTD (Arg0), TBTF (Arg0), 0x05)
Local6 = MMRP (Arg0)
Local0 = (Local7 + Local6)
OperationRegion (MMMS, SystemMemory, Local0, 0x02)
Field (MMMS, WordAcc, NoLock, Preserve)
{
MSIC, 1
}
MSIC = 0x00
}
Method (DMSI, 1, Serialized)
{
ADBG ("DMSI")
Local0 = (MMTB (Arg0) + 0x0548)
OperationRegion (PXVD, SystemMemory, Local0, 0x08)
Field (PXVD, DWordAcc, NoLock, Preserve)
{
TB2P, 32,
P2TB, 32
}
OperationRegion (SPRT, SystemIO, 0xB2, 0x02)
Field (SPRT, ByteAcc, Lock, Preserve)
{
SSMP, 8
}
Local1 = TB2P /* \_GPE.DMSI.TB2P */
If ((Local1 == 0x25))
{
TBSF = 0x17
SSMP = 0xF7
ADBG ("0x25->P2TB")
P2TB = 0x25
Local2 = 0x64
While ((Local2 > 0x00))
{
Local2 = (Local2 - 0x01)
Local1 = TB2P /* \_GPE.DMSI.TB2P */
If ((Local1 == 0xFFFFFFFF))
{
ADBG ("DMSiF")
Return (0x00)
}
If ((Local1 == 0x24))
{
Break
}
Sleep (0x32)
}
P2TB = 0x00
ADBG ("DMSi 1")
Return (0x01)
}
ADBG ("DMSi 0")
Return (0x00)
}
Method (RSMI, 1, Serialized)
{
ADBG ("RSMI")
Local0 = TFPS ()
Local1 = (MMTB (Arg0) + 0x00)
OperationRegion (PXVD, SystemMemory, Local1, 0x0550)
Field (PXVD, DWordAcc, NoLock, Preserve)
{
VIDI, 32,
Offset (0x548),
TB2P, 32,
P2TB, 32
}
Local2 = TB2P /* \_GPE.RSMI.TB2P */
If ((Local2 != 0xFFFFFFFF))
{
ADBG ("RSMi 1")
Return (0x01)
}
If (!CNCT ())
{
ADBG ("RSMi 2")
Return (0x02)
}
DRPM (Arg0)
If (Local0)
{
\_SB.TBFP (0x00)
}
Else
{
\_SB.TBFP (0x01)
}
Local3 = 0x00
While ((FFTB (Arg0) || CNCT ()))
{
Sleep (0x05)
CLNE ()
Local3 += 0x01
If ((Local3 > 0x14))
{
Sleep (0x03E8)
ADBG ("RSMi PCIe down")
}
If ((Local3 > 0x19))
{
ADBG ("RSMi Oops")
If (Local0)
{
\_SB.TBFP (0x01)
}
Else
{
\_SB.TBFP (0x00)
}
Return (0x00)
}
}
If (Local0)
{
\_SB.TBFP (0x01)
}
Else
{
\_SB.TBFP (0x00)
}
ADBG ("RSMi 0")
Return (0x00)
}
Method (GNIS, 1, Serialized)
{
ADBG ("GNIS")
If ((GP5F == 0x00))
{
ADBG ("GNIS_Dis=0")
Return (0x00)
}
Local1 = TB2P /* \TB2P */
ADBG (Concatenate ("TB2P=", ToHexString (Local1)))
If ((Local1 == 0xFFFFFFFF))
{
ADBG ("GNIS=0")
Return (0x00)
}
Local2 = HPFI /* \HPFI */
ADBG (Concatenate ("HPFI=", ToHexString (Local2)))
If ((Local2 == 0x01))
{
HPFI = 0x00
ADBG ("GNIS=0")
Return (0x00)
}
ADBG ("GNIS=1")
Return (0x01)
}
OperationRegion (SPRT, SystemIO, 0xB2, 0x02)
Field (SPRT, ByteAcc, Lock, Preserve)
{
SSMP, 8
}
Method (CTBT, 3, NotSerialized)
{
WSUB (Arg0)
If ((TNAT == 0x01))
{
Local0 = RSMI (Arg0)
If (!Local0)
{
Return (Zero)
}
If (DMSI (Arg0))
{
Return (Zero)
}
}
If (GNIS (Arg0))
{
ADBG ("GNIS Return")
Return (Zero)
}
ADBG ("TBT-HP-Handler")
ADBG ("PEG WorkAround")
PGWA (Arg0)
Acquire (OSUM, 0xFFFF)
Local1 = TBFF (Arg0)
If ((Local1 == 0x01))
{
Sleep (0x10)
Release (OSUM)
ADBG ("OS_Up_Received")
Local2 = 0xC8
ADBG ("Out of While")
While ((Local2 > 0x00))
{
ADBG ("In While CTBT")
Local3 = HPFI /* \HPFI */
If ((Local3 == 0x01))
{
If ((Arg2 == 0x01))
{
ADBG ("XTBT Again")
\_GPE.XTBT (Arg0, Arg1)
ADBG ("XTBT Again End")
}
Else
{
ADBG ("STBT Again")
\_GPE.STBT (Arg0, Arg1)
ADBG ("STBT Again End")
}
Return (Zero)
}
Local2 = (Local2 - 0x01)
Sleep (0x32)
}
Return (Zero)
}
If ((Local1 == 0x02))
{
ADBG ("Disconnect")
If ((OHPN == 0x01))
{
NTFY (Arg0)
}
If ((GHPN == 0x01))
{
NFYG ()
}
Sleep (0x10)
Release (OSUM)
ADBG ("Disconnect")
Return (Zero)
}
If ((SOHP == 0x01))
{
If ((Arg1 == CPG1))
{
ADBG ("TBT SW SMI 2")
TBSF = 0x18
SSMP = 0xF7
TBSF = 0x1B
SSMP = 0xF7
}
Else
{
ADBG ("TBT SW SMI")
TBSF = 0x15
SSMP = 0xF7
TBSF = 0x1A
SSMP = 0xF7
}
}
If ((OHPN == 0x01))
{
NTFY (Arg0)
}
If ((GHPN == 0x01))
{
NFYG ()
}
Sleep (0x10)
Release (OSUM)
}
Method (XTBT, 2, Serialized)
{
ADBG ("XTBT")
If ((CF2T == 0x01))
{
ADBG ("Clear")
ADBG ("GPI_GPE_STS")
\_SB.CAGS (Arg1)
}
If (TRD3)
{
ADBG ("During TBT_OFF")
Return (Zero)
}
WWAK ()
CTBT (Arg0, Arg1, 0x01)
ADBG ("End-of-XTBT")
}
Method (STBT, 2, Serialized)
{
ADBG ("STBT")
If ((CF2T == 0x01))
{
ADBG ("Clear")
ADBG ("GPI_GPE_STS")
\_SB.CAGS (Arg1)
}
CTBT (Arg0, Arg1, 0x00)
ADBG ("End-of-STBT")
}
Method (TINI, 1, Serialized)
{
ADBG ("TINI")
Local0 = MMRP (Arg0)
OperationRegion (RP_X, SystemMemory, Local0, 0x20)
Field (RP_X, DWordAcc, NoLock, Preserve)
{
REG0, 32,
REG1, 32,
REG2, 32,
REG3, 32,
REG4, 32,
REG5, 32,
REG6, 32,
REG7, 32
}
Local1 = REG6 /* \_GPE.TINI.REG6 */
Local2 = MMTB (Arg0)
Local3 = OSUP (Local2)
REG6 = Local1
ADBG ("End-of-TINI")
Return (Local3)
}
}
Scope (\_SB)
{
Method (THDR, 2, Serialized)
{
ADBG ("THDR")
\_GPE.XTBT (Arg0, Arg1)
}
}
Scope (\_SB)
{
Method (CGWR, 4, Serialized)
{
If ((Arg0 == 0x01))
{
If (CondRefOf (\_SB.SGOV))
{
\_SB.SGOV (Arg2, Arg3)
}
}
ElseIf ((Arg0 == 0x02))
{
If (CondRefOf (\_SB.PCI0.GEXP.SGEP))
{
\_SB.PCI0.GEXP.SGEP (Arg1, Arg2, Arg3)
}
}
}
Method (CGRD, 4, Serialized)
{
Local0 = 0x01
If ((Arg0 == 0x01))
{
If ((Arg3 == 0x00))
{
If (CondRefOf (\_SB.GGOV))
{
Local0 = \_SB.GGOV (Arg2)
}
}
ElseIf ((Arg3 == 0x01))
{
If (CondRefOf (\_SB.GGIV))
{
Local0 = \_SB.GGIV (Arg2)
}
}
}
ElseIf ((Arg0 == 0x02))
{
If (CondRefOf (\_SB.PCI0.GEXP.GEPS))
{
Local0 = \_SB.PCI0.GEXP.GEPS (Arg1, Arg2)
}
}
Return (Local0)
}
Method (WRGP, 2, Serialized)
{
Local0 = Arg0
Local1 = Arg0
Local0 &= 0xFFFFFFFF
Local1 >>= 0x20
If (((Local0 & 0xFF) == 0x01))
{
\_SB.CGWR ((Local0 & 0xFF), (Local1 >> 0x18), Local1, Arg1)
}
ElseIf (((Local0 & 0xFF) == 0x02))
{
\_SB.CGWR ((Local0 & 0xFF), (Local1 >> 0x18), ((Local1 <<
0x08) >> 0x18), Arg1)
}
}
Method (RDGP, 2, Serialized)
{
Local7 = 0x01
Local0 = Arg0
Local1 = Arg0
Local0 &= 0xFFFFFFFF
Local1 >>= 0x20
If (((Local0 & 0xFF) == 0x01))
{
Local7 = \_SB.CGRD ((Local0 & 0xFF), (Local1 >> 0x18), Local1,
Arg1)
}
ElseIf (((Local0 & 0xFF) == 0x02))
{
Local7 = \_SB.CGRD ((Local0 & 0xFF), (Local1 >> 0x18), (
(Local1 << 0x08) >> 0x18), Arg1)
}
Return (Local7)
}
}
Scope (\_SB)
{
Method (TBFP, 1, NotSerialized)
{
If (Arg0)
{
CGWR (FPAT, FPEN, FPGN, FPLV)
}
Else
{
CGWR (FPAT, FPEN, FPGN, !FPLV)
}
}
Device (WTBT)
{
Name (_HID, "PNP0C14" /* Windows Management Instrumentation Device */) // _HID: Hardware ID
Name (_UID, "TBFP") // _UID: Unique ID
Name (_WDG, Buffer (0x14)
{
/* 0000 */ 0x48, 0xFD, 0xCC, 0x86, 0x5E, 0x20, 0x77, 0x4A, // H...^ wJ
/* 0008 */ 0x9C, 0x48, 0x20, 0x21, 0xCB, 0xED, 0xE3, 0x41, // .H !...A
/* 0010 */ 0x54, 0x46, 0x01, 0x02 // TF..
})
Method (WMTF, 3, NotSerialized)
{
CreateByteField (Arg2, 0x00, FP)
If (FP)
{
TBFP (0x01)
}
Else
{
TBFP (0x00)
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x01) || (TBS1 == 0x01))))
{
Scope (\_SB.PCI0.RP01)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x02) || (TBS1 == 0x02))))
{
Scope (\_SB.PCI0.RP02)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x03) || (TBS1 == 0x03))))
{
Scope (\_SB.PCI0.RP03)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x04) || (TBS1 == 0x04))))
{
Scope (\_SB.PCI0.RP04)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x05) || (TBS1 == 0x05))))
{
Scope (\_SB.PCI0.RP05)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x06) || (TBS1 == 0x06))))
{
Scope (\_SB.PCI0.RP06)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x07) || (TBS1 == 0x07))))
{
Scope (\_SB.PCI0.RP07)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x08) || (TBS1 == 0x08))))
{
Scope (\_SB.PCI0.RP08)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x09) || (TBS1 == 0x09))))
{
Scope (\_SB.PCI0.RP09)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x0A) || (TBS1 == 0x0A))))
{
Scope (\_SB.PCI0.RP10)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x0B) || (TBS1 == 0x0B))))
{
Scope (\_SB.PCI0.RP11)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x0C) || (TBS1 == 0x0C))))
{
Scope (\_SB.PCI0.RP12)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x0D) || (TBS1 == 0x0D))))
{
Scope (\_SB.PCI0.RP13)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x0E) || (TBS1 == 0x0E))))
{
Scope (\_SB.PCI0.RP14)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x0F) || (TBS1 == 0x0F))))
{
Scope (\_SB.PCI0.RP15)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x10) || (TBS1 == 0x10))))
{
Scope (\_SB.PCI0.RP16)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x11) || (TBS1 == 0x11))))
{
Scope (\_SB.PCI0.RP17)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x12) || (TBS1 == 0x12))))
{
Scope (\_SB.PCI0.RP18)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x13) || (TBS1 == 0x13))))
{
Scope (\_SB.PCI0.RP19)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x14) || (TBS1 == 0x14))))
{
Scope (\_SB.PCI0.RP20)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x15) || (TBS1 == 0x15))))
{
Scope (\_SB.PCI0.PEG0)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x16) || (TBS1 == 0x16))))
{
Scope (\_SB.PCI0.PEG1)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
If (((TBTS == 0x01) && ((TBSE == 0x17) || (TBS1 == 0x17))))
{
Scope (\_SB.PCI0.PEG2)
{
Device (HRUS)
{
Name (_ADR, 0x00) // _ADR: Address
Method (_RMV, 0, NotSerialized) // _RMV: Removal Status
{
Return (TARS) /* \TARS */
}
}
}
}
Scope (\_SB)
{
Method (R008, 1, Serialized)
{
ADBG ("R008")
Local7 = Arg0
OperationRegion (MEM0, SystemMemory, Local7, 0x01)
Field (MEM0, ByteAcc, NoLock, Preserve)
{
TEMP, 8
}
Return (TEMP) /* \_SB_.R008.TEMP */
}
Method (W008, 2, Serialized)
{
ADBG ("W008")
Local7 = Arg0
OperationRegion (MEM0, SystemMemory, Local7, 0x01)
Field (MEM0, ByteAcc, NoLock, Preserve)
{
TEMP, 8
}
TEMP = Arg1
}
Method (R016, 1, Serialized)
{
ADBG ("R016")
Local7 = Arg0
OperationRegion (MEM0, SystemMemory, Local7, 0x02)
Field (MEM0, ByteAcc, NoLock, Preserve)
{
TEMP, 16
}
Return (TEMP) /* \_SB_.R016.TEMP */
}
Method (W016, 2, Serialized)
{
ADBG ("W016")
Local7 = Arg0
OperationRegion (MEM0, SystemMemory, Local7, 0x02)
Field (MEM0, ByteAcc, NoLock, Preserve)
{
TEMP, 16
}
TEMP = Arg1
}
Method (R032, 1, Serialized)
{
ADBG ("R032")
Local7 = Arg0
OperationRegion (MEM0, SystemMemory, Local7, 0x04)
Field (MEM0, ByteAcc, NoLock, Preserve)
{
TEMP, 32
}
Return (TEMP) /* \_SB_.R032.TEMP */
}
Method (W032, 2, Serialized)
{
ADBG ("W032")
Local7 = Arg0
OperationRegion (MEM0, SystemMemory, Local7, 0x04)
Field (MEM0, ByteAcc, NoLock, Preserve)
{
TEMP, 32
}
TEMP = Arg1
}
Method (PERB, 5, Serialized)
{
ADBG ("PERB")
Local7 = Arg0
Local7 |= (Arg1 << 0x14)
Local7 |= (Arg2 << 0x0F)
Local7 |= (Arg3 << 0x0C)
Local7 |= Arg4
OperationRegion (PCI0, SystemMemory, Local7, 0x01)
Field (PCI0, ByteAcc, NoLock, Preserve)
{
TEMP, 8
}
Return (TEMP) /* \_SB_.PERB.TEMP */
}
Method (PEWB, 6, Serialized)
{
ADBG ("PEWB")
Local7 = Arg0
Local7 |= (Arg1 << 0x14)
Local7 |= (Arg2 << 0x0F)
Local7 |= (Arg3 << 0x0C)
Local7 |= Arg4
OperationRegion (PCI0, SystemMemory, Local7, 0x01)
Field (PCI0, ByteAcc, NoLock, Preserve)
{
TEMP, 8
}
TEMP = Arg5
}
Method (PERW, 5, Serialized)
{
ADBG ("PERW")
Local7 = Arg0
Local7 |= (Arg1 << 0x14)
Local7 |= (Arg2 << 0x0F)
Local7 |= (Arg3 << 0x0C)
Local7 |= Arg4
OperationRegion (PCI0, SystemMemory, Local7, 0x02)
Field (PCI0, ByteAcc, NoLock, Preserve)
{
TEMP, 16
}
Return (TEMP) /* \_SB_.PERW.TEMP */
}
Method (PEWW, 6, Serialized)
{
ADBG ("PEWW")
Local7 = Arg0
Local7 |= (Arg1 << 0x14)
Local7 |= (Arg2 << 0x0F)
Local7 |= (Arg3 << 0x0C)
Local7 |= Arg4
OperationRegion (PCI0, SystemMemory, Local7, 0x02)
Field (PCI0, ByteAcc, NoLock, Preserve)
{
TEMP, 16
}
TEMP = Arg5
}
Method (PERD, 5, Serialized)
{
ADBG ("PERD")
Local7 = Arg0
Local7 |= (Arg1 << 0x14)
Local7 |= (Arg2 << 0x0F)
Local7 |= (Arg3 << 0x0C)
Local7 |= Arg4
OperationRegion (PCI0, SystemMemory, Local7, 0x04)
Field (PCI0, ByteAcc, NoLock, Preserve)
{
TEMP, 32
}
Return (TEMP) /* \_SB_.PERD.TEMP */
}
Method (PEWD, 6, Serialized)
{
ADBG ("PEWD")
Local7 = Arg0
Local7 |= (Arg1 << 0x14)
Local7 |= (Arg2 << 0x0F)
Local7 |= (Arg3 << 0x0C)
Local7 |= Arg4
OperationRegion (PCI0, SystemMemory, Local7, 0x04)
Field (PCI0, ByteAcc, NoLock, Preserve)
{
TEMP, 32
}
TEMP = Arg5
}
Method (STDC, 5, Serialized)
{
ADBG ("STDC")
Local7 = PERW (Arg0, Arg1, Arg2, Arg3, 0x00)
If ((Local7 == 0xFFFF))
{
ADBG ("Referenced device is not present")
Return (0x00)
}
Local0 = PERW (Arg0, Arg1, Arg2, Arg3, 0x06)
If (((Local0 & 0x10) == 0x00))
{
ADBG ("No Capabilities linked list is available")
Return (0x00)
}
Local2 = PERB (Arg0, Arg1, Arg2, Arg3, 0x34)
While (0x01)
{
Local2 &= 0xFC
If ((Local2 == 0x00))
{
ADBG ("Capability ID is not found")
Return (0x00)
}
Local1 = PERB (Arg0, Arg1, Arg2, Arg3, Local2)
If ((Arg4 == Local1))
{
ADBG ("Capability ID is found")
ADBG ("Capability Offset : ")
ADBG (Local2)
Return (Local2)
}
Local2 = PERB (Arg0, Arg1, Arg2, Arg3, (Local2 + 0x01))
Return (0x00)
}
}
}
Method (RDCM, 1, Serialized)
{
ADBG ("RDCM")
ADBG ("CMOS Offset")
ADBG (Arg0)
OperationRegion (CMOS, SystemIO, 0x70, 0x04)
Field (CMOS, AnyAcc, NoLock, Preserve)
{
LIND, 8,
LDAT, 8,
HIND, 8,
HDAT, 8
}
If ((Arg0 <= 0x7F))
{
LIND = Arg0
Local0 = LDAT /* \RDCM.LDAT */
}
ElseIf ((Arg0 <= 0xFF))
{
HIND = Arg0
Local0 = HDAT /* \RDCM.HDAT */
}
ADBG ("CMOS Data")
ADBG (Local0)
Return (Local0)
}
Method (WRCM, 2, Serialized)
{
ADBG ("WRCM")
ADBG ("CMOS Offset")
ADBG (Arg0)
ADBG ("CMOS Data")
ADBG (Arg1)
OperationRegion (CMOS, SystemIO, 0x70, 0x04)
Field (CMOS, AnyAcc, NoLock, Preserve)
{
LIND, 8,
LDAT, 8,
HIND, 8,
HDAT, 8
}
If ((Arg0 <= 0x7F))
{
LIND = Arg0
LDAT = Arg1
}
ElseIf ((Arg0 <= 0xFF))
{
HIND = Arg0
HDAT = Arg1
}
}
Scope (\_PR)
{
Processor (PR00, 0x01, 0x00001810, 0x06){}
Processor (PR01, 0x02, 0x00001810, 0x06){}
Processor (PR02, 0x03, 0x00001810, 0x06){}
Processor (PR03, 0x04, 0x00001810, 0x06){}
Processor (PR04, 0x05, 0x00001810, 0x06){}
Processor (PR05, 0x06, 0x00001810, 0x06){}
Processor (PR06, 0x07, 0x00001810, 0x06){}
Processor (PR07, 0x08, 0x00001810, 0x06){}
Processor (PR08, 0x09, 0x00001810, 0x06){}
Processor (PR09, 0x0A, 0x00001810, 0x06){}
Processor (PR10, 0x0B, 0x00001810, 0x06){}
Processor (PR11, 0x0C, 0x00001810, 0x06){}
Processor (PR12, 0x0D, 0x00001810, 0x06){}
Processor (PR13, 0x0E, 0x00001810, 0x06){}
Processor (PR14, 0x0F, 0x00001810, 0x06){}
Processor (PR15, 0x10, 0x00001810, 0x06){}
}
Scope (\_PR.PR00)
{
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
})
Name (CPOC, Package (0x15)
{
0x15,
0x02,
0xFF,
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
})
}
Scope (\_SB)
{
Device (PAGD)
{
Name (_HID, "ACPI000C" /* Processor Aggregator Device */) // _HID: Hardware ID
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (\_OSI ("Processor Aggregator Device"))
{
Return (0x0F)
}
Else
{
Return (0x00)
}
}
Name (_PUR, Package (0x02) // _PUR: Processor Utilization Request
{
0x01,
0x00
})
}
}
Scope (\)
{
Method (PNTF, 1, NotSerialized)
{
If ((\_PR.CFGD & 0x0200))
{
If ((((PC00 & 0x08) && ((Arg0 == 0x80) || (
Arg0 == 0x82))) || ((PC00 & 0x10) && (Arg0 == 0x81))))
{
Notify (\_PR.PR00, Arg0)
}
If ((((PC01 & 0x08) && ((Arg0 == 0x80) || (
Arg0 == 0x82))) || ((PC01 & 0x10) && (Arg0 == 0x81))))
{
Notify (\_PR.PR01, Arg0)
}
If ((((PC02 & 0x08) && ((Arg0 == 0x80) || (
Arg0 == 0x82))) || ((PC02 & 0x10) && (Arg0 == 0x81))))
{
Notify (\_PR.PR02, Arg0)
}
If ((((PC03 & 0x08) && ((Arg0 == 0x80) || (
Arg0 == 0x82))) || ((PC03 & 0x10) && (Arg0 == 0x81))))
{
Notify (\_PR.PR03, Arg0)
}
If ((((PC04 & 0x08) && ((Arg0 == 0x80) || (
Arg0 == 0x82))) || ((PC04 & 0x10) && (Arg0 == 0x81))))
{
Notify (\_PR.PR04, Arg0)
}
If ((((PC05 & 0x08) && ((Arg0 == 0x80) || (
Arg0 == 0x82))) || ((PC05 & 0x10) && (Arg0 == 0x81))))
{
Notify (\_PR.PR05, Arg0)
}
If ((((PC06 & 0x08) && ((Arg0 == 0x80) || (
Arg0 == 0x82))) || ((PC06 & 0x10) && (Arg0 == 0x81))))
{
Notify (\_PR.PR06, Arg0)
}
If ((((PC07 & 0x08) && ((Arg0 == 0x80) || (
Arg0 == 0x82))) || ((PC07 & 0x10) && (Arg0 == 0x81))))
{
Notify (\_PR.PR07, Arg0)
}
}
ElseIf (((Arg0 == 0x80) || ((Arg0 == 0x81) || (Arg0 ==
0x82))))
{
Notify (\_PR.PR00, Arg0)
}
}
}
Scope (\_SB.PCI0)
{
Device (PDRC)
{
Name (_HID, EisaId ("PNP0C02") /* PNP Motherboard Resources */) // _HID: Hardware ID
Name (_UID, 0x01) // _UID: Unique ID
Name (BUF0, ResourceTemplate ()
{
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00008000, // Address Length
_Y30)
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00001000, // Address Length
_Y31)
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00001000, // Address Length
_Y32)
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00000000, // Address Length
_Y33)
Memory32Fixed (ReadWrite,
0xFED20000, // Address Base
0x00020000, // Address Length
)
Memory32Fixed (ReadOnly,
0xFED90000, // Address Base
0x00004000, // Address Length
)
Memory32Fixed (ReadWrite,
0xFED45000, // Address Base
0x0004B000, // Address Length
)
Memory32Fixed (ReadOnly,
0xFF000000, // Address Base
0x01000000, // Address Length
)
Memory32Fixed (ReadOnly,
0xFEE00000, // Address Base
0x00100000, // Address Length
)
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00000000, // Address Length
_Y34)
Memory32Fixed (ReadWrite,
0x00000000, // Address Base
0x00000000, // Address Length
_Y35)
})
Method (_CRS, 0, Serialized) // _CRS: Current Resource Settings
{
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y30._BAS, MBR0) // _BAS: Base Address
MBR0 = \_SB.PCI0.GMHB ()
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y31._BAS, DBR0) // _BAS: Base Address
DBR0 = \_SB.PCI0.GDMB ()
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y32._BAS, EBR0) // _BAS: Base Address
EBR0 = \_SB.PCI0.GEPB ()
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y33._BAS, XBR0) // _BAS: Base Address
XBR0 = \_SB.PCI0.GPCB ()
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y33._LEN, XSZ0) // _LEN: Length
XSZ0 = \_SB.PCI0.GPCL ()
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y34._BAS, SXRA) // _BAS: Base Address
SXRA = SXRB /* \SXRB */
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y34._LEN, SXRL) // _LEN: Length
SXRL = SXRS /* \SXRS */
If (!HPTE)
{
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y35._BAS, HBAS) // _BAS: Base Address
CreateDWordField (BUF0, \_SB.PCI0.PDRC._Y35._LEN, HLEN) // _LEN: Length
HBAS = HPTB /* \HPTB */
HLEN = 0x0400
}
Return (BUF0) /* \_SB_.PCI0.PDRC.BUF0 */
}
}
}
Method (BRTN, 1, Serialized)
{
If (((DIDX & 0x0F00) == 0x0400))
{
Notify (\_SB.PCI0.GFX0.DD1F, Arg0)
}
}
Scope (\_GPE)
{
Method (_L17, 0, NotSerialized) // _Lxx: Level-Triggered GPE, xx=0x00-0xFF
{
Local0 = \_SB.PCI0.LPCB.EC.HWAC
\RRBF = Local0
Sleep (0x0A)
If ((Local0 & 0x02)){}
If ((Local0 & 0x04))
{
Notify (\_SB.LID, 0x02) // Device Wake
}
If ((Local0 & 0x08))
{
Notify (\_SB.SLPB, 0x02) // Device Wake
}
If ((Local0 & 0x10))
{
Notify (\_SB.SLPB, 0x02) // Device Wake
}
If ((Local0 & 0x40)){}
If ((Local0 & 0x80))
{
Notify (\_SB.SLPB, 0x02) // Device Wake
}
}
Method (_L69, 0, NotSerialized) // _Lxx: Level-Triggered GPE, xx=0x00-0xFF
{
If (\_SB.PCI0.RP01.PSPX)
{
\_SB.PCI0.RP01.PSPX = 0x01
\_SB.PCI0.RP01.PMSX = 0x01
Notify (\_SB.PCI0.RP01, 0x02) // Device Wake
}
If (\_SB.PCI0.RP02.PSPX)
{
\_SB.PCI0.RP02.PSPX = 0x01
\_SB.PCI0.RP02.PMSX = 0x01
Notify (\_SB.PCI0.RP02, 0x02) // Device Wake
Notify (\_SB.PCI0.RP02.PXSX, 0x02) // Device Wake
}
If (\_SB.PCI0.RP03.PSPX)
{
\_SB.PCI0.RP03.PSPX = 0x01
\_SB.PCI0.RP03.PMSX = 0x01
Notify (\_SB.PCI0.RP03, 0x02) // Device Wake
}
If (\_SB.PCI0.RP04.PSPX)
{
\_SB.PCI0.RP04.PSPX = 0x01
\_SB.PCI0.RP04.PMSX = 0x01
Notify (\_SB.PCI0.RP04, 0x02) // Device Wake
}
If (\_SB.PCI0.RP05.PSPX)
{
\_SB.PCI0.RP05.PSPX = 0x01
\_SB.PCI0.RP05.PMSX = 0x01
Notify (\_SB.PCI0.RP05, 0x02) // Device Wake
}
}
Method (_L61, 0, NotSerialized) // _Lxx: Level-Triggered GPE, xx=0x00-0xFF
{
}
Method (_L62, 0, NotSerialized) // _Lxx: Level-Triggered GPE, xx=0x00-0xFF
{
\_SB.PCI0.LPCB.SWGE = 0x00
}
Method (_L66, 0, NotSerialized) // _Lxx: Level-Triggered GPE, xx=0x00-0xFF
{
If (\_SB.PCI0.GFX0.GSSE)
{
\_SB.PCI0.GFX0.GSCI ()
}
Else
{
\_SB.PCI0.SBUS.CPSC = 0x01
}
}
Method (_E14, 0, NotSerialized) // _Exx: Edge-Triggered GPE, xx=0x00-0xFF
{
ADBG ("GPE_TBT")
If ((TBTS == 0x01))
{
\_GPE.XTBT (TBSE, CPGN)
}
}
}
Scope (\_SB.PCI0.RP03.PXSX)
{
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If (PCIC (Arg0))
{
Return (PCID (Arg0, Arg1, Arg2, Arg3))
}
If ((Arg0 == ToUUID ("1730e71d-e5dd-4a34-be57-4d76b6a2fe37")))
{
If ((Arg2 == Zero))
{
If ((Arg1 == Zero))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x00 // .
})
}
}
If ((Arg2 == One))
{
Switch (ToInteger (DerefOf (Arg3 [0x00])))
{
Case (0x00)
{
}
Case (0x01)
{
If (CondRefOf (\_SB.SLPB))
{
Notify (\_SB.SLPB, 0x80) // Status Change
}
}
Case (0x02)
{
}
Case (0x03)
{
}
Case (0x04)
{
If (CondRefOf (\_SB.SLPB))
{
Notify (\_SB.SLPB, 0x02) // Device Wake
}
}
}
}
Return (0x00)
}
ElseIf ((Arg0 == ToUUID ("7574eb17-d1a2-4cc2-9929-4a08fcc29107")))
{
Switch (ToInteger (Arg2))
{
Case (0x00)
{
If ((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 // .
})
}
}
Method (WGST, 0, Serialized)
{
If (CondRefOf (VDID))
{
Switch (ToInteger (VDID))
{
Case (0x093C8086)
{
Return (0x01)
}
Case (0x097C8086)
{
Return (0x01)
}
Default
{
Return (0x00)
}
}
}
Else
{
Return (0x00)
}
}
OperationRegion (RPXX, PCI_Config, 0x00, 0x10)
Field (RPXX, AnyAcc, NoLock, Preserve)
{
VDID, 32
}
OperationRegion (RPXY, PCI_Config, 0x2C, 0x10)
Field (RPXY, AnyAcc, NoLock, Preserve)
{
SVID, 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)
{
DerefOf (SPLX [0x01]) [0x00] = \DOM1
DerefOf (SPLX [0x01]) [0x01] = \LIM1
DerefOf (SPLX [0x01]) [0x02] = \TIM1
DerefOf (SPLX [0x02]) [0x00] = \DOM2
DerefOf (SPLX [0x02]) [0x01] = \LIM2
DerefOf (SPLX [0x02]) [0x02] = \TIM2
DerefOf (SPLX [0x03]) [0x00] = \DOM3
DerefOf (SPLX [0x03]) [0x01] = \LIM3
DerefOf (SPLX [0x03]) [0x02] = \TIM3
Return (SPLX) /* \_SB_.PCI0.RP03.PXSX.SPLX */
}
PowerResource (WRST, 0x05, 0x0000)
{
Method (_STA, 0, NotSerialized) // _STA: Status
{
ADBG ("PXSX _STA")
Return (0x01)
}
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 ((DCAP & 0x10000000))
{
Local0 = DCTR /* \_SB_.PCI0.RP03.PXSX.DCTR */
Local0 |= 0x8000
DCTR = Local0
}
}
}
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)
{
DerefOf (WANX [0x01]) [0x00] = 0x00
DerefOf (WANX [0x01]) [0x01] = \TRD0
DerefOf (WANX [0x01]) [0x02] = \TRL0
DerefOf (WANX [0x02]) [0x00] = 0x01
DerefOf (WANX [0x02]) [0x01] = \TRD1
DerefOf (WANX [0x02]) [0x02] = \TRL1
Return (WANX) /* \_SB_.PCI0.RP03.PXSX.WANX */
}
Name (WRDX, Package (0x03)
{
0x00,
Package (0x02)
{
0x80000000,
0x8000
},
Package (0x02)
{
0x80000000,
0x8000
}
})
Method (WRDD, 0, Serialized)
{
If (CondRefOf (SVID))
{
If (((SVID == 0x81108086) || (SVID == 0x91108086)))
{
Name (WRDG, Package (0x02)
{
0x00,
Package (0x02)
{
0x07,
0x4150
}
})
Return (WRDG) /* \_SB_.PCI0.RP03.PXSX.WRDD.WRDG */
}
}
}
Name (WRDY, Package (0x03)
{
0x00,
Package (0x0C)
{
0x07,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80
},
Package (0x06)
{
0x10,
0x80,
0x80,
0x80,
0x80,
0x80
}
})
Method (WRDS, 0, Serialized)
{
If (CondRefOf (SVID))
{
If (((SVID == 0x81108086) || (SVID == 0x91108086)))
{
Name (WRDI, Package (0x02)
{
0x00,
Package (0x0C)
{
0x07,
0x01,
0x70,
0x64,
0x64,
0x64,
0x64,
0x70,
0x64,
0x64,
0x64,
0x64
}
})
Return (WRDI) /* \_SB_.PCI0.RP03.PXSX.WRDS.WRDI */
}
}
}
Method (AWVC, 0, Serialized)
{
Return (0x0101)
}
Method (WOWG, 0, Serialized)
{
Return (WGWS) /* \WGWS */
}
Method (WIST, 0, Serialized)
{
If (CondRefOf (VDID))
{
Switch (ToInteger (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)
}
Case (0x24FD8086)
{
Return (0x01)
}
Case (0x24FB8086)
{
Return (0x01)
}
Default
{
Return (0x00)
}
}
}
Else
{
Return (0x00)
}
}
}
Scope (\_SB.PCI0.RP04.PXSX)
{
OperationRegion (RPXX, PCI_Config, 0x00, 0x10)
Field (RPXX, AnyAcc, NoLock, Preserve)
{
VDID, 32
}
OperationRegion (RPXY, PCI_Config, 0x2C, 0x10)
Field (RPXY, AnyAcc, NoLock, Preserve)
{
SVID, 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)
{
DerefOf (SPLX [0x01]) [0x00] = \DOM1
DerefOf (SPLX [0x01]) [0x01] = \LIM1
DerefOf (SPLX [0x01]) [0x02] = \TIM1
DerefOf (SPLX [0x02]) [0x00] = \DOM2
DerefOf (SPLX [0x02]) [0x01] = \LIM2
DerefOf (SPLX [0x02]) [0x02] = \TIM2
DerefOf (SPLX [0x03]) [0x00] = \DOM3
DerefOf (SPLX [0x03]) [0x01] = \LIM3
DerefOf (SPLX [0x03]) [0x02] = \TIM3
Return (SPLX) /* \_SB_.PCI0.RP04.PXSX.SPLX */
}
PowerResource (WRST, 0x05, 0x0000)
{
Method (_STA, 0, NotSerialized) // _STA: Status
{
ADBG ("PXSX _STA")
Return (0x01)
}
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 ((DCAP & 0x10000000))
{
Local0 = DCTR /* \_SB_.PCI0.RP04.PXSX.DCTR */
Local0 |= 0x8000
DCTR = Local0
}
}
}
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)
{
DerefOf (WANX [0x01]) [0x00] = 0x00
DerefOf (WANX [0x01]) [0x01] = \TRD0
DerefOf (WANX [0x01]) [0x02] = \TRL0
DerefOf (WANX [0x02]) [0x00] = 0x01
DerefOf (WANX [0x02]) [0x01] = \TRD1
DerefOf (WANX [0x02]) [0x02] = \TRL1
Return (WANX) /* \_SB_.PCI0.RP04.PXSX.WANX */
}
Name (WRDX, Package (0x03)
{
0x00,
Package (0x02)
{
0x80000000,
0x8000
},
Package (0x02)
{
0x80000000,
0x8000
}
})
Method (WRDD, 0, Serialized)
{
If (CondRefOf (SVID))
{
If (((SVID == 0x81108086) || (SVID == 0x91108086)))
{
Name (WRDG, Package (0x02)
{
0x00,
Package (0x02)
{
0x07,
0x4150
}
})
Return (WRDG) /* \_SB_.PCI0.RP04.PXSX.WRDD.WRDG */
}
}
}
Name (WRDY, Package (0x03)
{
0x00,
Package (0x0C)
{
0x07,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80,
0x80
},
Package (0x06)
{
0x10,
0x80,
0x80,
0x80,
0x80,
0x80
}
})
Method (WRDS, 0, Serialized)
{
If (CondRefOf (SVID))
{
If (((SVID == 0x81108086) || (SVID == 0x91108086)))
{
Name (WRDI, Package (0x02)
{
0x00,
Package (0x0C)
{
0x07,
0x01,
0x70,
0x64,
0x64,
0x64,
0x64,
0x70,
0x64,
0x64,
0x64,
0x64
}
})
Return (WRDI) /* \_SB_.PCI0.RP04.PXSX.WRDS.WRDI */
}
}
}
Method (AWVC, 0, Serialized)
{
Return (0x0101)
}
Method (WOWG, 0, Serialized)
{
Return (WGWS) /* \WGWS */
}
Method (WIST, 0, Serialized)
{
If (CondRefOf (VDID))
{
Switch (ToInteger (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)
}
Case (0x24FD8086)
{
Return (0x01)
}
Case (0x24FB8086)
{
Return (0x01)
}
Default
{
Return (0x00)
}
}
}
Else
{
Return (0x00)
}
}
}
Scope (\_SB.PCI0)
{
Method (WHIT, 0, NotSerialized)
{
Return (Package (0x01)
{
Package (0x05)
{
"?*",
"?*",
0x00,
0x02,
0x02
}
})
}
Method (SELF, 0, NotSerialized)
{
Return (Package (0x02)
{
"LENOVO",
"TP-N1O "
})
}
}
Scope (\_SB.PCI0.GFX0)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_SB.PCI0.SAT0)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If ((((S0ID == 0x01) || (OSYS >= 0x07DF)) && (
(PEPC & 0x03) != 0x00)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_SB.PCI0.SAT0.VOL0)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If ((OSYS == 0x07DD))
{
Return (Package (0x00){})
}
Return (Package (0x01)
{
\_SB.PEPD
})
}
}
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Scope (\_SB.PCI0.I2C0)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.I2C1)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.I2C2)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.I2C3)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.I2C4)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.I2C5)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.SPI0)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.SPI1)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.UA00)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.UA01)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
Scope (\_SB.PCI0.UA02)
{
Name (_DEP, Package (0x01) // _DEP: Dependencies
{
\_SB.PEPD
})
}
}
Scope (\_SB.PCI0.XHC)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_SB.PCI0.HDAS)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If ((S0ID == 0x01))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_SB.PCI0.RP05.PXSX)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If ((PAHC () || PNVM ()))
{
If ((((S0ID == 0x01) || (OSYS >= 0x07DF)) && ((
(PEPC & 0x0400) == 0x0400) || ((PEPC & 0x0800) == 0x0800))))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
}
Return (Package (0x00){})
}
OperationRegion (PCCX, PCI_Config, 0x09, 0x04)
Field (PCCX, ByteAcc, NoLock, Preserve)
{
PIXX, 8,
SCCX, 8,
BCCX, 8
}
Method (PAHC, 0, Serialized)
{
If ((BCCX == 0x01))
{
If ((SCCX == 0x06))
{
If ((PIXX == 0x01))
{
Return (0x01)
}
}
}
Return (0x00)
}
Method (PNVM, 0, Serialized)
{
If ((BCCX == 0x01))
{
If ((SCCX == 0x08))
{
If ((PIXX == 0x02))
{
Return (0x01)
}
}
}
Return (0x00)
}
}
Scope (\_PR.PR00)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_PR.PR01)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_PR.PR02)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_PR.PR03)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_PR.PR04)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_PR.PR05)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_PR.PR06)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_PR.PR07)
{
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (((S0ID == 0x01) || (OSYS >= 0x07DF)))
{
Return (Package (0x01)
{
\_SB.PEPD
})
}
Else
{
Return (Package (0x00){})
}
}
}
Scope (\_SB)
{
Device (PEPD)
{
Name (_HID, "INT33A1" /* Intel Power Engine */) // _HID: Hardware ID
Name (_CID, EisaId ("PNP0D80") /* Windows-compatible System Power Management Controller */) // _CID: Compatible ID
Name (_UID, 0x01) // _UID: Unique ID
Name (DEVY, Package (0x38)
{
Package (0x03)
{
"\\_PR.PR00",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x00
}
}
},
Package (0x03)
{
"\\_PR.PR01",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x00
}
}
},
Package (0x03)
{
"\\_PR.PR02",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x00
}
}
},
Package (0x03)
{
"\\_PR.PR03",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x00
}
}
},
Package (0x03)
{
"\\_PR.PR04",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x00
}
}
},
Package (0x03)
{
"\\_PR.PR05",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x00
}
}
},
Package (0x03)
{
"\\_PR.PR06",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x00
}
}
},
Package (0x03)
{
"\\_PR.PR07",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x00
}
}
},
Package (0x03)
{
"\\_SB.PCI0.GFX0",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.UA00",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.UA01",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.I2C0",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.I2C1",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.XHC",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.HDAS",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.PEMC",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.PSDC",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.I2C2",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.I2C3",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.I2C4",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.I2C5",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.UA02",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SPI0",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SPI1",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP01.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP02.PXSX",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP03.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP04.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP05.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP06.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP07.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP08.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP09.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP10.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP11.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP12.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP13.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP14.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP15.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP16.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP17.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP18.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP19.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.RP20.PXSX",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
},
Package (0x03)
{
"\\_SB.PCI0.ISP0",
0x01,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.PRT0",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.PRT1",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.PRT2",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.PRT3",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.PRT4",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.PRT5",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.NVM1",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.NVM2",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.NVM3",
0x00,
Package (0x02)
{
0x00,
Package (0x02)
{
0xFF,
0x03
}
}
},
Package (0x03)
{
"\\_SB.PCI0.SAT0.VOL0",
0x00,
Package (0x02)
{
0x00,
Package (0x03)
{
0xFF,
0x00,
0x81
}
}
}
})
Name (BCCD, Package (0x09)
{
Package (0x02)
{
"\\_SB.PCI0.SAT0",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x3E80
}
}
},
Package (0x02)
{
"\\_SB.PCI0.SAT0.PRT0",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x3E80
}
}
},
Package (0x02)
{
"\\_SB.PCI0.SAT0.PRT1",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x3E80
}
}
},
Package (0x02)
{
"\\_SB.PCI0.SAT0.PRT2",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x3E80
}
}
},
Package (0x02)
{
"\\_SB.PCI0.SAT0.PRT3",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x3E80
}
}
},
Package (0x02)
{
"\\_SB.PCI0.RP02.PXSX",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x000186A0
}
}
},
Package (0x02)
{
"\\_SB.PCI0.RP03.PXSX",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x000186A0
}
}
},
Package (0x02)
{
"\\_SB.PCI0.RP04.PXSX",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x000186A0
}
}
},
Package (0x02)
{
"\\_SB.PCI0.RP05.PXSX",
Package (0x01)
{
Package (0x03)
{
Package (0x05)
{
0x01,
0x08,
0x00,
0x01,
0xB2
},
Package (0x03)
{
0x00,
0xCD,
0x01
},
0x000186A0
}
}
}
})
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (((OSYS >= 0x07DF) || ((OSYS >= 0x07DC) && (
S0ID == 0x01))))
{
Return (0x0F)
}
Return (0x00)
}
Method (_DSM, 4, Serialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("c4eb40a0-6cd2-11e2-bcfd-0800200c9a66")))
{
If ((Arg2 == Zero))
{
Return (Buffer (One)
{
0x7F // .
})
}
If ((Arg2 == One))
{
If ((S0ID == 0x00))
{
Return (Package (0x00){})
}
If (((PEPC & 0x00100000) != 0x00))
{
If ((\_SB.PCI0.RP05.PXSX.PAHC () || \_SB.PCI0.RP05.PXSX.PNVM ()))
{
DerefOf (DEVY [0x1D]) [0x01] = 0x01
}
}
If (((PEPC & 0x00200000) != 0x00))
{
DerefOf (DEVY [0x37]) [0x01] = 0x01
}
If (((PEPC & 0x00400000) != 0x00))
{
DerefOf (DEVY [0x2E]) [0x01] = 0x01
}
If (((PEPC & 0x00800000) != 0x00))
{
DerefOf (DEVY [0x2F]) [0x01] = 0x01
}
If (((PEPC & 0x01000000) != 0x00))
{
DerefOf (DEVY [0x30]) [0x01] = 0x01
}
If (((PEPC & 0x02000000) != 0x00))
{
DerefOf (DEVY [0x31]) [0x01] = 0x01
}
If (((PEPC & 0x04000000) != 0x00))
{
DerefOf (DEVY [0x32]) [0x01] = 0x01
}
If (((PEPC & 0x08000000) != 0x00))
{
DerefOf (DEVY [0x33]) [0x01] = 0x01
}
If (((PEPC & 0x10000000) != 0x00))
{
DerefOf (DEVY [0x34]) [0x01] = 0x01
}
If (((PEPC & 0x20000000) != 0x00))
{
DerefOf (DEVY [0x35]) [0x01] = 0x01
}
If (((PEPC & 0x40000000) != 0x00))
{
DerefOf (DEVY [0x36]) [0x01] = 0x01
}
If (((PEPC & 0x04) == 0x00))
{
DerefOf (DEVY [0x0A]) [0x01] = 0x00
}
If (((PEPC & 0x08) == 0x00))
{
DerefOf (DEVY [0x0B]) [0x01] = 0x00
}
If (((PEPC & 0x10) == 0x00)){}
If (((PEPC & 0x20) == 0x00))
{
DerefOf (DEVY [0x0C]) [0x01] = 0x00
}
If (((PEPC & 0x40) == 0x00))
{
DerefOf (DEVY [0x0D]) [0x01] = 0x00
}
If (((PEPC & 0x80) == 0x00))
{
DerefOf (DEVY [0x0E]) [0x01] = 0x00
}
If (((PEPC & 0x0100) == 0x00))
{
DerefOf (DEVY [0x0F]) [0x01] = 0x00
}
If (((PEPC & 0x0200) == 0x00))
{
DerefOf (DEVY [0x08]) [0x01] = 0x00
}
If ((TCNT >= 0x01))
{
DerefOf (DEVY [0x00]) [0x01] = 0x01
}
If ((TCNT >= 0x02))
{
DerefOf (DEVY [0x01]) [0x01] = 0x01
}
If ((TCNT >= 0x03))
{
DerefOf (DEVY [0x02]) [0x01] = 0x01
}
If ((TCNT >= 0x04))
{
DerefOf (DEVY [0x03]) [0x01] = 0x01
}
If ((TCNT >= 0x05))
{
DerefOf (DEVY [0x04]) [0x01] = 0x01
}
If ((TCNT >= 0x06))
{
DerefOf (DEVY [0x05]) [0x01] = 0x01
}
If ((TCNT >= 0x07))
{
DerefOf (DEVY [0x06]) [0x01] = 0x01
}
If ((TCNT >= 0x08))
{
DerefOf (DEVY [0x07]) [0x01] = 0x01
}
If (((PEPC & 0x0400) == 0x00))
{
DerefOf (DEVY [0x00]) [0x01] = 0x00
DerefOf (DEVY [0x01]) [0x01] = 0x00
DerefOf (DEVY [0x02]) [0x01] = 0x00
DerefOf (DEVY [0x03]) [0x01] = 0x00
DerefOf (DEVY [0x04]) [0x01] = 0x00
DerefOf (DEVY [0x05]) [0x01] = 0x00
DerefOf (DEVY [0x06]) [0x01] = 0x00
DerefOf (DEVY [0x07]) [0x01] = 0x00
}
If (((PEPC & 0x0800) == 0x00))
{
DerefOf (DEVY [0x10]) [0x01] = 0x00
}
If (((PEPC & 0x1000) == 0x00))
{
DerefOf (DEVY [0x11]) [0x01] = 0x00
}
If (((PEPC & 0x2000) == 0x00))
{
DerefOf (DEVY [0x12]) [0x01] = 0x00
}
If (((PEPC & 0x4000) == 0x00))
{
DerefOf (DEVY [0x13]) [0x01] = 0x00
}
If (((PEPC & 0x8000) == 0x00))
{
DerefOf (DEVY [0x14]) [0x01] = 0x00
}
If (((PEPC & 0x00010000) == 0x00))
{
DerefOf (DEVY [0x15]) [0x01] = 0x00
}
If (((PEPC & 0x00020000) == 0x00))
{
DerefOf (DEVY [0x16]) [0x01] = 0x00
}
If (((PEPC & 0x00040000) == 0x00))
{
DerefOf (DEVY [0x17]) [0x01] = 0x00
}
If (((PEPC & 0x00080000) == 0x00))
{
DerefOf (DEVY [0x18]) [0x01] = 0x00
}
If (((PEPC & 0x02) == 0x00))
{
DerefOf (DEVY [0x2D]) [0x01] = 0x00
}
If ((OSYS >= 0x07DF))
{
If (\_SB.PCI0.RP04.PXSX.WIST ())
{
DerefOf (DerefOf (DerefOf (DEVY [0x1C]) [0x02]
) [0x01]) [0x01] = 0x03
DerefOf (DerefOf (DerefOf (DEVY [0x1C]) [0x02]
) [0x01]) [0x02] = 0x00
DerefOf (DEVY [0x1C]) [0x01] = 0x01
}
}
If (((OSYS >= 0x07DF) && (PWIG == 0x01)))
{
If (\_SB.PCI0.RP03.PXSX.WGST ())
{
DerefOf (DEVY [0x1B]) [0x01] = 0x01
}
}
Return (DEVY) /* \_SB_.PEPD.DEVY */
}
If ((Arg2 == 0x02))
{
Return (BCCD) /* \_SB_.PEPD.BCCD */
}
If ((Arg2 == 0x03))
{
If ((S0ID == 0x01))
{
DDPS = 0x01
\_SB.PCI0.LPCB.EC.INOS = 0x00
\_SB.PCI0.LPCB.EC.ECNT (0x01)
}
}
If ((Arg2 == 0x04))
{
If ((S0ID == 0x01))
{
DDPS = 0x00
\_SB.PCI0.LPCB.EC.INOS = 0x01
\_SB.PCI0.LPCB.EC.ECNT (0x00)
If (NLID)
{
If (\_SB.LID._LID ())
{
Notify (\_SB.LID, 0x80) // Status Change
}
}
}
}
If ((Arg2 == 0x05))
{
If ((S0ID == 0x01))
{
\GUAM (0x01)
}
\_SB.PCI0.LPCB.EC.ECNT (0x03)
}
If ((Arg2 == 0x06))
{
If ((S0ID == 0x01))
{
\GUAM (0x00)
}
\_SB.PCI0.LPCB.EC.ECNT (0x02)
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
}
Device (PSM)
{
Name (_HID, EisaId ("INT3420") /* Intel Bluetooth RF Kill */) // _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 ((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)
{
DerefOf (SPLX [0x01]) [0x00] = \PDT1
DerefOf (SPLX [0x01]) [0x01] = \PLM1
DerefOf (SPLX [0x01]) [0x02] = \PTW1
DerefOf (SPLX [0x02]) [0x00] = \PDT2
DerefOf (SPLX [0x02]) [0x01] = \PLM2
DerefOf (SPLX [0x02]) [0x02] = \PTW2
Return (SPLX) /* \PSM_.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)
{
DerefOf (DPLX [0x01]) [0x00] = \DDT1
DerefOf (DPLX [0x01]) [0x01] = \DDP1
DerefOf (DerefOf (DPLX [0x01]) [0x02]) [0x00]
= \DLI1
DerefOf (DerefOf (DPLX [0x01]) [0x02]) [0x01]
= \DPL1
DerefOf (DerefOf (DPLX [0x01]) [0x02]) [0x02]
= \DTW1
DerefOf (DerefOf (DPLX [0x01]) [0x02]) [0x03]
= \DMI1
DerefOf (DerefOf (DPLX [0x01]) [0x02]) [0x04]
= \DMA1
DerefOf (DerefOf (DPLX [0x01]) [0x02]) [0x05]
= \DMT1
DerefOf (DPLX [0x02]) [0x00] = \DDT2
DerefOf (DPLX [0x02]) [0x01] = \DDP2
DerefOf (DerefOf (DPLX [0x02]) [0x02]) [0x00]
= \DLI2
DerefOf (DerefOf (DPLX [0x02]) [0x02]) [0x01]
= \DPL2
DerefOf (DerefOf (DPLX [0x02]) [0x02]) [0x02]
= \DTW2
DerefOf (DerefOf (DPLX [0x02]) [0x02]) [0x03]
= \DMI2
DerefOf (DerefOf (DPLX [0x02]) [0x02]) [0x04]
= \DMA2
DerefOf (DerefOf (DPLX [0x02]) [0x02]) [0x05]
= \DMT2
Return (DPLX) /* \PSM_.DPLX */
}
}
Scope (\_SB.PCI0)
{
Method (IICB, 2, Serialized)
{
Switch (ToInteger (Arg1))
{
Case (0x00)
{
Name (IIC0, ResourceTemplate ()
{
I2cSerialBusV2 (0x0000, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C0",
0x00, ResourceConsumer, _Y36, Exclusive,
)
})
CreateWordField (IIC0, \_SB.PCI0.IICB._Y36._ADR, DAD0) // _ADR: Address
DAD0 = Arg0
Return (IIC0) /* \_SB_.PCI0.IICB.IIC0 */
}
Case (0x01)
{
Name (IIC1, ResourceTemplate ()
{
I2cSerialBusV2 (0x0000, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C1",
0x00, ResourceConsumer, _Y37, Exclusive,
)
})
CreateWordField (IIC1, \_SB.PCI0.IICB._Y37._ADR, DAD1) // _ADR: Address
DAD1 = Arg0
Return (IIC1) /* \_SB_.PCI0.IICB.IIC1 */
}
Case (0x02)
{
Name (IIC2, ResourceTemplate ()
{
I2cSerialBusV2 (0x0000, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C2",
0x00, ResourceConsumer, _Y38, Exclusive,
)
})
CreateWordField (IIC2, \_SB.PCI0.IICB._Y38._ADR, DAD2) // _ADR: Address
DAD2 = Arg0
Return (IIC2) /* \_SB_.PCI0.IICB.IIC2 */
}
Case (0x03)
{
Name (IIC3, ResourceTemplate ()
{
I2cSerialBusV2 (0x0000, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C3",
0x00, ResourceConsumer, _Y39, Exclusive,
)
})
CreateWordField (IIC3, \_SB.PCI0.IICB._Y39._ADR, DAD3) // _ADR: Address
DAD3 = Arg0
Return (IIC3) /* \_SB_.PCI0.IICB.IIC3 */
}
Case (0x04)
{
Name (IIC4, ResourceTemplate ()
{
I2cSerialBusV2 (0x0000, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C4",
0x00, ResourceConsumer, _Y3A, Exclusive,
)
})
CreateWordField (IIC4, \_SB.PCI0.IICB._Y3A._ADR, DAD4) // _ADR: Address
DAD4 = Arg0
Return (IIC4) /* \_SB_.PCI0.IICB.IIC4 */
}
Default
{
Name (IIC5, ResourceTemplate ()
{
I2cSerialBusV2 (0x0000, ControllerInitiated, 0x00061A80,
AddressingMode7Bit, "\\_SB.PCI0.I2C5",
0x00, ResourceConsumer, _Y3B, Exclusive,
)
})
CreateWordField (IIC5, \_SB.PCI0.IICB._Y3B._ADR, DAD5) // _ADR: Address
DAD5 = Arg0
Return (IIC5) /* \_SB_.PCI0.IICB.IIC5 */
}
}
}
Method (PINR, 2, Serialized)
{
Name (GPIR, ResourceTemplate ()
{
GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly,
"\\_SB.PCI0.GPI0", 0x00, ResourceConsumer, ,
)
{ // Pin list
0xFFFF
}
})
CreateWordField (GPIR, 0x17, PINF)
PINF = ((0x18 * Arg1) + Arg0)
Return (GPIR) /* \_SB_.PCI0.PINR.GPIR */
}
Method (DSMI, 4, Serialized)
{
Local3 = (Arg3 << 0x18)
Local2 = (Arg2 << 0x10)
Local1 = (Arg1 << 0x08)
Local0 = (Local1 | Arg0)
Local0 |= Local2
Local0 |= Local3
Return (Local0)
}
Method (GPPI, 4, Serialized)
{
Local3 = (Arg3 << 0x18)
Local2 = (Arg2 << 0x10)
Local1 = (Arg1 << 0x08)
Local0 = (Local1 | Arg0)
Local0 |= Local2
Local0 |= Local3
Return (Local0)
}
Method (GRID, 1, Serialized)
{
Name (BUF, Buffer (0x09){})
Switch (ToInteger (Arg0))
{
Case (0x00)
{
BUF [0x00] = L0H0 /* \L0H0 */
BUF [0x01] = L0H1 /* \L0H1 */
BUF [0x02] = L0H2 /* \L0H2 */
BUF [0x03] = L0H3 /* \L0H3 */
BUF [0x04] = L0H4 /* \L0H4 */
BUF [0x05] = L0H5 /* \L0H5 */
BUF [0x06] = L0H6 /* \L0H6 */
BUF [0x07] = L0H7 /* \L0H7 */
BUF [0x08] = L0H8 /* \L0H8 */
}
Case (0x01)
{
BUF [0x00] = L1H0 /* \L1H0 */
BUF [0x01] = L1H1 /* \L1H1 */
BUF [0x02] = L1H2 /* \L1H2 */
BUF [0x03] = L1H3 /* \L1H3 */
BUF [0x04] = L1H4 /* \L1H4 */
BUF [0x05] = L1H5 /* \L1H5 */
BUF [0x06] = L1H6 /* \L1H6 */
BUF [0x07] = L1H7 /* \L1H7 */
BUF [0x08] = L1H8 /* \L1H8 */
}
Case (0x02)
{
BUF [0x00] = L2H0 /* \L2H0 */
BUF [0x01] = L2H1 /* \L2H1 */
BUF [0x02] = L2H2 /* \L2H2 */
BUF [0x03] = L2H3 /* \L2H3 */
BUF [0x04] = L2H4 /* \L2H4 */
BUF [0x05] = L2H5 /* \L2H5 */
BUF [0x06] = L2H6 /* \L2H6 */
BUF [0x07] = L2H7 /* \L2H7 */
BUF [0x08] = L2H8 /* \L2H8 */
}
Default
{
BUF [0x00] = L3H0 /* \L3H0 */
BUF [0x01] = L3H1 /* \L3H1 */
BUF [0x02] = L3H2 /* \L3H2 */
BUF [0x03] = L3H3 /* \L3H3 */
BUF [0x04] = L3H4 /* \L3H4 */
BUF [0x05] = L3H5 /* \L3H5 */
BUF [0x06] = L3H6 /* \L3H6 */
BUF [0x07] = L3H7 /* \L3H7 */
BUF [0x08] = L3H8 /* \L3H8 */
}
}
Return (ToString (BUF, Ones))
}
Method (HCID, 1, Serialized)
{
Switch (ToInteger (Arg0))
{
Case (0x00)
{
Local0 = L0SM /* \L0SM */
}
Case (0x01)
{
Local0 = L1SM /* \L1SM */
}
Case (0x02)
{
Local0 = L2SM /* \L2SM */
}
Default
{
Local0 = L3SM /* \L3SM */
}
}
Switch (ToInteger (Local0))
{
Case (0x00)
{
Return ("INT3471")
}
Case (0x01)
{
Return ("INT33BE")
}
Case (0x02)
{
Return ("INT3476")
}
Case (0x03)
{
Return ("INT3477")
}
Case (0x04)
{
Return ("INT3474")
}
Case (0x05)
{
Return ("INT3473")
}
Case (0x06)
{
Return ("INT3475")
}
Case (0x07)
{
Return ("INT3478")
}
Case (0x08)
{
Return ("INT3479")
}
Case (0x09)
{
Return ("INT347A")
}
Case (0x0A)
{
Return ("INT347B")
}
Case (0x0B)
{
Return ("OVTI2742")
}
Case (0x0C)
{
Return ("OVTI9234")
}
Case (0x0D)
{
Return ("OVTI8856")
}
Case (0x0E)
{
Return ("OVTIF860")
}
Default
{
Return (GRID (Arg0))
}
}
}
Method (CDEP, 1, Serialized)
{
If ((Arg0 == 0x00))
{
If ((C0TP == 0x01))
{
Switch (ToInteger (L0BS))
{
Case (0x00)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC0,
\_SB.PCI0.I2C0
})
}
Case (0x01)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC0,
\_SB.PCI0.I2C1
})
}
Case (0x02)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC0,
\_SB.PCI0.I2C2
})
}
Case (0x03)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC0,
\_SB.PCI0.I2C3
})
}
Case (0x04)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC0,
\_SB.PCI0.I2C4
})
}
Case (0x05)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC0,
\_SB.PCI0.I2C5
})
}
Default
{
Return (Package (0x01)
{
\_SB.PCI0.DSC0
})
}
}
}
If ((C0TP > 0x01))
{
Return (Package (0x01)
{
\_SB.PCI0.CLP0
})
}
}
If ((Arg0 == 0x01))
{
If ((C1TP == 0x01))
{
Switch (ToInteger (L1BS))
{
Case (0x00)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC1,
\_SB.PCI0.I2C0
})
}
Case (0x01)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC1,
\_SB.PCI0.I2C1
})
}
Case (0x02)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC1,
\_SB.PCI0.I2C2
})
}
Case (0x03)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC1,
\_SB.PCI0.I2C3
})
}
Case (0x04)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC1,
\_SB.PCI0.I2C4
})
}
Case (0x05)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC1,
\_SB.PCI0.I2C5
})
}
Default
{
Return (Package (0x01)
{
\_SB.PCI0.DSC1
})
}
}
}
If ((C1TP > 0x01))
{
Return (Package (0x01)
{
\_SB.PCI0.CLP1
})
}
}
If ((Arg0 == 0x02))
{
If ((C2TP == 0x01))
{
Switch (ToInteger (L2BS))
{
Case (0x00)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC2,
\_SB.PCI0.I2C0
})
}
Case (0x01)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC2,
\_SB.PCI0.I2C1
})
}
Case (0x02)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC2,
\_SB.PCI0.I2C2
})
}
Case (0x03)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC2,
\_SB.PCI0.I2C3
})
}
Case (0x04)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC2,
\_SB.PCI0.I2C4
})
}
Case (0x05)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC2,
\_SB.PCI0.I2C5
})
}
Default
{
Return (Package (0x01)
{
\_SB.PCI0.DSC2
})
}
}
}
If ((C2TP > 0x01))
{
Return (Package (0x01)
{
\_SB.PCI0.CLP2
})
}
}
If ((Arg0 == 0x03))
{
If ((C3TP == 0x01))
{
Switch (ToInteger (L3BS))
{
Case (0x00)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC3,
\_SB.PCI0.I2C0
})
}
Case (0x01)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC3,
\_SB.PCI0.I2C1
})
}
Case (0x02)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC3,
\_SB.PCI0.I2C2
})
}
Case (0x03)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC3,
\_SB.PCI0.I2C3
})
}
Case (0x04)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC3,
\_SB.PCI0.I2C4
})
}
Case (0x05)
{
Return (Package (0x02)
{
\_SB.PCI0.DSC3,
\_SB.PCI0.I2C5
})
}
Default
{
Return (Package (0x01)
{
\_SB.PCI0.DSC3
})
}
}
}
If ((C3TP > 0x01))
{
Return (Package (0x01)
{
\_SB.PCI0.CLP3
})
}
}
Return (Package (0x01)
{
\_SB.PCI0
})
}
Method (CDEG, 1, Serialized)
{
Switch (ToInteger (Arg0))
{
Case (0x00)
{
Return (0x00)
}
Case (0x01)
{
Return (0x2D)
}
Case (0x02)
{
Return (0x5A)
}
Case (0x03)
{
Return (0x87)
}
Case (0x04)
{
Return (0xB4)
}
Case (0x05)
{
Return (0xE1)
}
Case (0x06)
{
Return (0x010E)
}
Case (0x07)
{
Return (0x013B)
}
Default
{
Return (0x00)
}
}
}
Device (DSC0)
{
Name (_ADR, Zero) // _ADR: Address
Name (_HID, "INT3472") // _HID: Hardware ID
Name (_CID, "INT3472") // _CID: Compatible ID
Name (_DDN, "PMIC-CRDG") // _DDN: DOS Device Name
Name (_UID, 0x00) // _UID: Unique ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((C0GP > 0x00))
{
Local1 = PINR (C0P0, C0G0)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C0GP > 0x01))
{
Local1 = PINR (C0P1, C0G1)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C0GP > 0x02))
{
Local1 = PINR (C0P2, C0G2)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C0GP > 0x03))
{
Local1 = PINR (C0P3, C0G3)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
Return (Local0)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (CL00)
{
If ((C0TP == 0x01))
{
Return (0x0F)
}
}
Return (0x00)
}
Method (CLDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x20)
{
/* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0010 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // ........
})
PAR [0x00] = C0VE /* \C0VE */
PAR [0x01] = C0TP /* \C0TP */
PAR [0x03] = C0CV /* \C0CV */
PAR [0x08] = C0W0 /* \C0W0 */
PAR [0x09] = C0W1 /* \C0W1 */
PAR [0x0A] = C0W2 /* \C0W2 */
PAR [0x0B] = C0W3 /* \C0W3 */
PAR [0x0C] = C0W4 /* \C0W4 */
PAR [0x0D] = C0W5 /* \C0W5 */
Return (PAR) /* \_SB_.PCI0.DSC0.CLDB.PAR_ */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("79234640-9e10-4fea-a5c1-b5aa8b19756f")))
{
If ((Arg2 == 0x00))
{
Return (Buffer (0x01)
{
0x3F // ?
})
}
If ((Arg2 == 0x01))
{
Return (C0GP) /* \C0GP */
}
If ((Arg2 == 0x02))
{
Return (GPPI (C0F0, ((0x18 * C0G0) + C0P0), C0I0, C0A0))
}
If ((Arg2 == 0x03))
{
Return (GPPI (C0F1, ((0x18 * C0G1) + C0P1), C0I1, C0A1))
}
If ((Arg2 == 0x04))
{
Return (GPPI (C0F2, ((0x18 * C0G2) + C0P2), C0I2, C0A2))
}
If ((Arg2 == 0x05))
{
Return (GPPI (C0F3, ((0x18 * C0G3) + C0P3), C0I3, C0A3))
}
Return (Buffer (0x01)
{
0x00 // .
})
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (DSC1)
{
Name (_ADR, Zero) // _ADR: Address
Name (_HID, "INT3472") // _HID: Hardware ID
Name (_CID, "INT3472") // _CID: Compatible ID
Name (_DDN, "PMIC-CRDG") // _DDN: DOS Device Name
Name (_UID, 0x01) // _UID: Unique ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((C1GP > 0x00))
{
Local1 = PINR (C1P0, C1G0)
ConcatenateResTemplate (Local0, Local1, Local0)
}
If ((C1GP > 0x01))
{
Local1 = PINR (C1P1, C1G1)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C1GP > 0x02))
{
Local1 = PINR (C1P2, C1G2)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C1GP > 0x03))
{
Local1 = PINR (C1P3, C1G3)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
Return (Local0)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (CL01)
{
If ((C1TP == 0x01))
{
Return (0x0F)
}
}
Return (0x00)
}
Method (CLDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x20)
{
/* 0000 */ 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0010 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // ........
})
PAR [0x00] = C1VE /* \C1VE */
PAR [0x01] = C1TP /* \C1TP */
PAR [0x03] = C1CV /* \C1CV */
PAR [0x08] = C1W0 /* \C1W0 */
PAR [0x09] = C1W1 /* \C1W1 */
PAR [0x0A] = C1W2 /* \C1W2 */
PAR [0x0B] = C1W3 /* \C1W3 */
PAR [0x0C] = C1W4 /* \C1W4 */
PAR [0x0D] = C1W5 /* \C1W5 */
Return (PAR) /* \_SB_.PCI0.DSC1.CLDB.PAR_ */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("79234640-9e10-4fea-a5c1-b5aa8b19756f")))
{
If ((Arg2 == 0x00))
{
Return (Buffer (0x01)
{
0x3F // ?
})
}
If ((Arg2 == 0x01))
{
Return (C1GP) /* \C1GP */
}
If ((Arg2 == 0x02))
{
Return (GPPI (C1F0, ((0x18 * C1G0) + C1P0), C1I0, C1A0))
}
If ((Arg2 == 0x03))
{
Return (GPPI (C1F1, ((0x18 * C1G1) + C1P1), C1I1, C1A1))
}
If ((Arg2 == 0x04))
{
Return (GPPI (C1F2, ((0x18 * C1G2) + C1P2), C1I2, C1A2))
}
If ((Arg2 == 0x05))
{
Return (GPPI (C1F3, ((0x18 * C1G3) + C1P3), C1I3, C1A3))
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (DSC2)
{
Name (_ADR, Zero) // _ADR: Address
Name (_HID, "INT3472") // _HID: Hardware ID
Name (_CID, "INT3472") // _CID: Compatible ID
Name (_DDN, "PMIC-CRDG") // _DDN: DOS Device Name
Name (_UID, 0x02) // _UID: Unique ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((C2GP > 0x00))
{
Local1 = PINR (C2P0, C2G0)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C2GP > 0x01))
{
Local1 = PINR (C2P1, C2G1)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C2GP > 0x02))
{
Local1 = PINR (C2P2, C2G2)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C2GP > 0x03))
{
Local1 = PINR (C2P3, C2G3)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
Return (Local0)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (CL02)
{
If ((C2TP == 0x01))
{
Return (0x0F)
}
}
Return (0x00)
}
Method (CLDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x20)
{
/* 0000 */ 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0010 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // ........
})
PAR [0x00] = C2VE /* \C2VE */
PAR [0x01] = C2TP /* \C2TP */
PAR [0x03] = C2CV /* \C2CV */
PAR [0x08] = C2W0 /* \C2W0 */
PAR [0x09] = C2W1 /* \C2W1 */
PAR [0x0A] = C2W2 /* \C2W2 */
PAR [0x0B] = C2W3 /* \C2W3 */
PAR [0x0C] = C2W4 /* \C2W4 */
PAR [0x0D] = C2W5 /* \C2W5 */
Return (PAR) /* \_SB_.PCI0.DSC2.CLDB.PAR_ */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("79234640-9e10-4fea-a5c1-b5aa8b19756f")))
{
If ((Arg2 == 0x00))
{
Return (Buffer (0x01)
{
0x3F // ?
})
}
If ((Arg2 == 0x01))
{
Return (C2GP) /* \C2GP */
}
If ((Arg2 == 0x02))
{
Return (GPPI (C2F0, ((0x18 * C2G0) + C2P0), C2I0, C2A0))
}
If ((Arg2 == 0x03))
{
Return (GPPI (C2F1, ((0x18 * C2G1) + C2P1), C2I1, C2A1))
}
If ((Arg2 == 0x04))
{
Return (GPPI (C2F2, ((0x18 * C2G2) + C2P2), C2I2, C2A2))
}
If ((Arg2 == 0x05))
{
Return (GPPI (C2F3, ((0x18 * C2G3) + C2P3), C2I3, C2A3))
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (DSC3)
{
Name (_ADR, Zero) // _ADR: Address
Name (_HID, "INT3472") // _HID: Hardware ID
Name (_CID, "INT3472") // _CID: Compatible ID
Name (_DDN, "PMIC-CRDG") // _DDN: DOS Device Name
Name (_UID, 0x03) // _UID: Unique ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((C3GP > 0x00))
{
Local1 = PINR (C3P0, C3G0)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C3GP > 0x01))
{
Local1 = PINR (C3P1, C3G1)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C3GP > 0x02))
{
Local1 = PINR (C3P2, C3G2)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((C3GP > 0x03))
{
Local1 = PINR (C3P3, C3G3)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
Return (Local0)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (CL03)
{
If ((C3TP == 0x01))
{
Return (0x0F)
}
}
Return (0x00)
}
Method (CLDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x20)
{
/* 0000 */ 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0010 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // ........
})
PAR [0x00] = C3VE /* \C3VE */
PAR [0x01] = C3TP /* \C3TP */
PAR [0x03] = C3CV /* \C3CV */
PAR [0x08] = C3W0 /* \C3W0 */
PAR [0x09] = C3W1 /* \C3W1 */
PAR [0x0A] = C3W2 /* \C3W2 */
PAR [0x0B] = C3W3 /* \C3W3 */
PAR [0x0C] = C3W4 /* \C3W4 */
PAR [0x0D] = C3W5 /* \C3W5 */
Return (PAR) /* \_SB_.PCI0.DSC3.CLDB.PAR_ */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("79234640-9e10-4fea-a5c1-b5aa8b19756f")))
{
If ((Arg2 == 0x00))
{
Return (Buffer (0x01)
{
0x3F // ?
})
}
If ((Arg2 == 0x01))
{
Return (C3GP) /* \C3GP */
}
If ((Arg2 == 0x02))
{
Return (GPPI (C3F0, ((0x18 * C3G0) + C3P0), C3I0, C3A0))
}
If ((Arg2 == 0x03))
{
Return (GPPI (C3F1, ((0x18 * C3G1) + C3P1), C3I1, C3A1))
}
If ((Arg2 == 0x04))
{
Return (GPPI (C3F2, ((0x18 * C3G2) + C3P2), C3I2, C3A2))
}
If ((Arg2 == 0x05))
{
Return (GPPI (C3F3, ((0x18 * C3G3) + C3P3), C3I3, C3A3))
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (CLP0)
{
Name (_ADR, Zero) // _ADR: Address
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (CL00)
{
If ((C0IB == 0x02))
{
Return (Package (0x01)
{
\_SB.PCI0.I2C2
})
}
If ((C0IB == 0x03))
{
Return (Package (0x01)
{
\_SB.PCI0.I2C3
})
}
}
Return (Package (0x01)
{
\_SB.PCI0
})
}
Name (_UID, 0x00) // _UID: Unique ID
Name (_HID, "INT3472") // _HID: Hardware ID
Name (_CID, "INT3472") // _CID: Compatible ID
Name (_DDN, "PMIC-CRDG") // _DDN: DOS Device Name
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
ConcatenateResTemplate (Local0, IICB (C0IA, C0IB), Local2)
Local0 = Local2
Return (Local0)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (CL00)
{
If ((C0TP > 0x01))
{
Return (0x0F)
}
}
Return (0x00)
}
Method (CLDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x20)
{
/* 0000 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0010 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // ........
})
PAR [0x00] = C0VE /* \C0VE */
PAR [0x01] = C0TP /* \C0TP */
PAR [0x03] = C0CV /* \C0CV */
PAR [0x08] = C0W0 /* \C0W0 */
PAR [0x09] = C0W1 /* \C0W1 */
PAR [0x0A] = C0W2 /* \C0W2 */
PAR [0x0B] = C0W3 /* \C0W3 */
PAR [0x0C] = C0W4 /* \C0W4 */
PAR [0x0D] = C0W5 /* \C0W5 */
Return (PAR) /* \_SB_.PCI0.CLP0.CLDB.PAR_ */
}
Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device
{
Name (PLDB, Package (0x01)
{
Buffer (0x14)
{
/* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x29, 0x0D, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, // ).......
/* 0010 */ 0xFF, 0xFF, 0xFF, 0xFF // ....
}
})
CreateByteField (DerefOf (PLDB [0x00]), 0x08, BPOS)
BPOS = C0PL /* \C0PL */
Return (PLDB) /* \_SB_.PCI0.CLP0._PLD.PLDB */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("26257549-9271-4ca4-bb43-c4899d5a4881")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x07 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Return (0x01)
}
If ((Arg2 == 0x02))
{
Return (DSMI (0x0B, C0IA, 0x00, C0IB))
}
}
If ((Arg0 == ToUUID ("5815c5c8-c47d-477b-9a8d-76173176414b")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (DSMB, Buffer ((0x0D * 0x04)){})
CreateDWordField (DSMB, 0x00, I2CC)
CreateDWordField (DSMB, 0x04, DEV0)
I2CC = 0x01
DEV0 = DSMI (0x0B, C0IA, 0x00, C0IB)
Return (DSMB) /* \_SB_.PCI0.CLP0._DSM.DSMB */
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (CLP1)
{
Name (_ADR, Zero) // _ADR: Address
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (CL01)
{
If ((C1IB == 0x02))
{
Return (Package (0x01)
{
\_SB.PCI0.I2C2
})
}
If ((C1IB == 0x03))
{
Return (Package (0x01)
{
\_SB.PCI0.I2C3
})
}
}
Return (Package (0x01)
{
\_SB.PCI0
})
}
Name (_HID, "INT3472") // _HID: Hardware ID
Name (_CID, "INT3472") // _CID: Compatible ID
Name (_DDN, "PMIC-CRDG") // _DDN: DOS Device Name
Name (_UID, 0x01) // _UID: Unique ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
ConcatenateResTemplate (Local0, IICB (C1IA, C1IB), Local2)
Local0 = Local2
Return (Local0)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (CL01)
{
If ((C1TP > 0x01))
{
Return (0x0F)
}
}
Return (0x00)
}
Method (CLDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x20)
{
/* 0000 */ 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0010 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // ........
})
PAR [0x00] = C1VE /* \C1VE */
PAR [0x01] = C1TP /* \C1TP */
PAR [0x03] = C1CV /* \C1CV */
PAR [0x08] = C1W0 /* \C1W0 */
PAR [0x09] = C1W1 /* \C1W1 */
PAR [0x0A] = C1W2 /* \C1W2 */
PAR [0x0B] = C1W3 /* \C1W3 */
PAR [0x0C] = C1W4 /* \C1W4 */
PAR [0x0D] = C1W5 /* \C1W5 */
Return (PAR) /* \_SB_.PCI0.CLP1.CLDB.PAR_ */
}
Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device
{
Name (PLDB, Package (0x01)
{
Buffer (0x14)
{
/* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x29, 0x0D, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, // ).......
/* 0010 */ 0xFF, 0xFF, 0xFF, 0xFF // ....
}
})
CreateByteField (DerefOf (PLDB [0x00]), 0x08, BPOS)
BPOS = C1PL /* \C1PL */
Return (PLDB) /* \_SB_.PCI0.CLP1._PLD.PLDB */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("26257549-9271-4ca4-bb43-c4899d5a4881")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x07 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Return (0x01)
}
If ((Arg2 == 0x02))
{
Return (DSMI (0x0B, C1IA, 0x00, C1IB))
}
}
If ((Arg0 == ToUUID ("5815c5c8-c47d-477b-9a8d-76173176414b")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (DSMB, Buffer ((0x0D * 0x04)){})
CreateDWordField (DSMB, 0x00, I2CC)
CreateDWordField (DSMB, 0x04, DEV0)
I2CC = 0x01
DEV0 = DSMI (0x0B, C1IA, 0x00, C1IB)
Return (DSMB) /* \_SB_.PCI0.CLP1._DSM.DSMB */
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (CLP2)
{
Name (_ADR, Zero) // _ADR: Address
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (CL02)
{
If ((C2IB == 0x02))
{
Return (Package (0x01)
{
\_SB.PCI0.I2C2
})
}
If ((C2IB == 0x03))
{
Return (Package (0x01)
{
\_SB.PCI0.I2C3
})
}
}
Return (Package (0x01)
{
\_SB.PCI0
})
}
Name (_HID, "INT3472") // _HID: Hardware ID
Name (_CID, "INT3472") // _CID: Compatible ID
Name (_DDN, "PMIC-CRDG") // _DDN: DOS Device Name
Name (_UID, 0x02) // _UID: Unique ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
ConcatenateResTemplate (Local0, IICB (C2IA, C2IB), Local2)
Local0 = Local2
Return (Local0)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (CL02)
{
If ((C2TP > 0x01))
{
Return (0x0F)
}
}
Return (0x00)
}
Method (CLDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x20)
{
/* 0000 */ 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0010 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // ........
})
PAR [0x00] = C2VE /* \C2VE */
PAR [0x01] = C2TP /* \C2TP */
PAR [0x03] = C2CV /* \C2CV */
PAR [0x08] = C2W0 /* \C2W0 */
PAR [0x09] = C2W1 /* \C2W1 */
PAR [0x0A] = C2W2 /* \C2W2 */
PAR [0x0B] = C2W3 /* \C2W3 */
PAR [0x0C] = C2W4 /* \C2W4 */
PAR [0x0D] = C2W5 /* \C2W5 */
Return (PAR) /* \_SB_.PCI0.CLP2.CLDB.PAR_ */
}
Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device
{
Name (PLDB, Package (0x01)
{
Buffer (0x14)
{
/* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x29, 0x0D, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, // ).......
/* 0010 */ 0xFF, 0xFF, 0xFF, 0xFF // ....
}
})
CreateByteField (DerefOf (PLDB [0x00]), 0x08, BPOS)
BPOS = C2PL /* \C2PL */
Return (PLDB) /* \_SB_.PCI0.CLP2._PLD.PLDB */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("26257549-9271-4ca4-bb43-c4899d5a4881")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x07 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Return (0x01)
}
If ((Arg2 == 0x02))
{
Return (DSMI (0x0B, C2IA, 0x00, C2IB))
}
}
If ((Arg0 == ToUUID ("5815c5c8-c47d-477b-9a8d-76173176414b")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (DSMB, Buffer ((0x0D * 0x04)){})
CreateDWordField (DSMB, 0x00, I2CC)
CreateDWordField (DSMB, 0x04, DEV0)
I2CC = 0x01
DEV0 = DSMI (0x0B, C2IA, 0x00, C2IB)
Return (DSMB) /* \_SB_.PCI0.CLP2._DSM.DSMB */
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (CLP3)
{
Name (_ADR, Zero) // _ADR: Address
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (CL03)
{
If ((C3IB == 0x02))
{
Return (Package (0x01)
{
\_SB.PCI0.I2C2
})
}
If ((C3IB == 0x03))
{
Return (Package (0x01)
{
\_SB.PCI0.I2C3
})
}
}
Return (Package (0x01)
{
\_SB.PCI0
})
}
Name (_HID, "INT3472") // _HID: Hardware ID
Name (_CID, "INT3472") // _CID: Compatible ID
Name (_DDN, "PMIC-CRDG") // _DDN: DOS Device Name
Name (_UID, 0x03) // _UID: Unique ID
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
ConcatenateResTemplate (Local0, IICB (C3IA, C3IB), Local2)
Local0 = Local2
Return (Local0)
}
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (CL03)
{
If ((C3TP > 0x01))
{
Return (0x0F)
}
}
Return (0x00)
}
Method (CLDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x20)
{
/* 0000 */ 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0010 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // ........
})
PAR [0x00] = C3VE /* \C3VE */
PAR [0x01] = C3TP /* \C3TP */
PAR [0x03] = C3CV /* \C3CV */
PAR [0x08] = C3W0 /* \C3W0 */
PAR [0x09] = C3W1 /* \C3W1 */
PAR [0x0A] = C3W2 /* \C3W2 */
PAR [0x0B] = C3W3 /* \C3W3 */
PAR [0x0C] = C3W4 /* \C3W4 */
PAR [0x0D] = C3W5 /* \C3W5 */
Return (PAR) /* \_SB_.PCI0.CLP3.CLDB.PAR_ */
}
Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device
{
Name (PLDB, Package (0x01)
{
Buffer (0x14)
{
/* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x29, 0x0D, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, // ).......
/* 0010 */ 0xFF, 0xFF, 0xFF, 0xFF // ....
}
})
CreateByteField (DerefOf (PLDB [0x00]), 0x08, BPOS)
BPOS = C3PL /* \C3PL */
Return (PLDB) /* \_SB_.PCI0.CLP3._PLD.PLDB */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("26257549-9271-4ca4-bb43-c4899d5a4881")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x07 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Return (0x01)
}
If ((Arg2 == 0x02))
{
Return (DSMI (0x0B, C3IA, 0x00, C3IB))
}
}
If ((Arg0 == ToUUID ("5815c5c8-c47d-477b-9a8d-76173176414b")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (DSMB, Buffer ((0x0D * 0x04)){})
CreateDWordField (DSMB, 0x00, I2CC)
CreateDWordField (DSMB, 0x04, DEV0)
I2CC = 0x01
DEV0 = DSMI (0x0B, C3IA, 0x00, C3IB)
Return (DSMB) /* \_SB_.PCI0.CLP3._DSM.DSMB */
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (LNK0)
{
Name (_ADR, Zero) // _ADR: Address
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (L0EN)
{
Return (0x0F)
}
Else
{
Return (0x00)
}
}
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (L0EN)
{
Return (CDEP (L0CL))
}
Else
{
Return (Package (0x01)
{
\_SB.PCI0
})
}
}
Name (_UID, 0x00) // _UID: Unique ID
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
Return (HCID (0x00))
}
Method (_CID, 0, NotSerialized) // _CID: Compatible ID
{
Return (HCID (0x00))
}
Method (_DDN, 0, NotSerialized) // _DDN: DOS Device Name
{
Name (BUF, Buffer (0x10){})
BUF [0x00] = L0M0 /* \L0M0 */
BUF [0x01] = L0M1 /* \L0M1 */
BUF [0x02] = L0M2 /* \L0M2 */
BUF [0x03] = L0M3 /* \L0M3 */
BUF [0x04] = L0M4 /* \L0M4 */
BUF [0x05] = L0M5 /* \L0M5 */
BUF [0x06] = L0M6 /* \L0M6 */
BUF [0x07] = L0M7 /* \L0M7 */
BUF [0x08] = L0M8 /* \L0M8 */
BUF [0x09] = L0M9 /* \L0M9 */
BUF [0x0A] = L0MA /* \L0MA */
BUF [0x0B] = L0MB /* \L0MB */
BUF [0x0C] = L0MC /* \L0MC */
BUF [0x0D] = L0MD /* \L0MD */
BUF [0x0E] = L0ME /* \L0ME */
BUF [0x0F] = L0MF /* \L0MF */
Return (ToString (BUF, Ones))
}
Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device
{
Name (PLDB, Package (0x01)
{
Buffer (0x14)
{
/* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x69, 0x0E, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, // i.......
/* 0010 */ 0xFF, 0xFF, 0xFF, 0xFF // ....
}
})
CreateByteField (DerefOf (PLDB [0x00]), 0x08, BPOS)
CreateField (DerefOf (PLDB [0x00]), 0x73, 0x04, RPOS)
BPOS = L0PL /* \L0PL */
RPOS = L0DG /* \L0DG */
Return (PLDB) /* \_SB_.PCI0.LNK0._PLD.PLDB */
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((L0DI > 0x00))
{
Local1 = IICB (L0A0, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x01))
{
Local1 = IICB (L0A1, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x02))
{
Local1 = IICB (L0A2, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x03))
{
Local1 = IICB (L0A3, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x04))
{
Local1 = IICB (L0A4, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x05))
{
Local1 = IICB (L0A5, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x06))
{
Local1 = IICB (L0A6, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x07))
{
Local1 = IICB (L0A7, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x08))
{
Local1 = IICB (L0A8, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x09))
{
Local1 = IICB (L0A9, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x0A))
{
Local1 = IICB (L0AA, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L0DI > 0x0B))
{
Local1 = IICB (L0AB, L0BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
Return (Local0)
}
Method (SSDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x6C)
{
/* 0000 */ 0x00, 0x00, 0x69, 0x56, 0x39, 0x8A, 0xF7, 0x11, // ..iV9...
/* 0008 */ 0xA9, 0x4E, 0x9C, 0x7D, 0x20, 0xEE, 0x0A, 0xB5, // .N.} ...
/* 0010 */ 0xCA, 0x40, 0xA3, 0x00, 0x00, 0x00, 0x00, 0x00, // .@......
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0020 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0028 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0030 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0038 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0040 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0048 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0050 */ 0x09, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, // ........
/* 0058 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0060 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0068 */ 0x00, 0x00, 0x00, 0x00 // ....
})
PAR [0x00] = L0DV /* \L0DV */
PAR [0x01] = L0CV /* \L0CV */
PAR [0x18] = CDIV /* \CDIV */
PAR [0x1C] = L0LU /* \L0LU */
PAR [0x1D] = L0NL /* \L0NL */
PAR [0x4E] = L0EE /* \L0EE */
PAR [0x4F] = L0VC /* \L0VC */
PAR [0x52] = L0FS /* \L0FS */
PAR [0x53] = L0LE /* \L0LE */
PAR [0x54] = CDEG (L0DG)
CreateDWordField (PAR, 0x56, DAT)
DAT = L0CK /* \L0CK */
PAR [0x5A] = L0CL /* \L0CL */
PAR [0x5F] = L0PP /* \L0PP */
PAR [0x60] = L0VR /* \L0VR */
Return (PAR) /* \_SB_.PCI0.LNK0.SSDB.PAR_ */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("822ace8f-2814-4174-a56b-5f029fe079ee")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (BUF, Buffer (0x10){})
BUF [0x00] = L0M0 /* \L0M0 */
BUF [0x01] = L0M1 /* \L0M1 */
BUF [0x02] = L0M2 /* \L0M2 */
BUF [0x03] = L0M3 /* \L0M3 */
BUF [0x04] = L0M4 /* \L0M4 */
BUF [0x05] = L0M5 /* \L0M5 */
BUF [0x06] = L0M6 /* \L0M6 */
BUF [0x07] = L0M7 /* \L0M7 */
BUF [0x08] = L0M8 /* \L0M8 */
BUF [0x09] = L0M9 /* \L0M9 */
BUF [0x0A] = L0MA /* \L0MA */
BUF [0x0B] = L0MB /* \L0MB */
BUF [0x0C] = L0MC /* \L0MC */
BUF [0x0D] = L0MD /* \L0MD */
BUF [0x0E] = L0ME /* \L0ME */
BUF [0x0F] = L0MF /* \L0MF */
Return (ToString (BUF, Ones))
}
}
If ((Arg0 == ToUUID ("5815c5c8-c47d-477b-9a8d-76173176414b")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (DSMB, Buffer ((0x0D * 0x04)){})
CreateDWordField (DSMB, 0x00, I2CC)
CreateDWordField (DSMB, 0x04, DEV0)
CreateDWordField (DSMB, 0x08, DEV1)
CreateDWordField (DSMB, 0x0C, DEV2)
CreateDWordField (DSMB, 0x10, DEV3)
CreateDWordField (DSMB, 0x14, DEV4)
CreateDWordField (DSMB, 0x18, DEV5)
CreateDWordField (DSMB, 0x1C, DEV6)
CreateDWordField (DSMB, 0x20, DEV7)
CreateDWordField (DSMB, 0x24, DEV8)
CreateDWordField (DSMB, 0x28, DEV9)
CreateDWordField (DSMB, 0x2C, DEVA)
CreateDWordField (DSMB, 0x30, DEVB)
I2CC = L0DI /* \L0DI */
DEV0 = DSMI (L0D0, L0A0, 0x00, L0BS)
DEV1 = DSMI (L0D1, L0A1, 0x00, L0BS)
DEV2 = DSMI (L0D2, L0A2, 0x00, L0BS)
DEV3 = DSMI (L0D3, L0A3, 0x00, L0BS)
DEV4 = DSMI (L0D4, L0A4, 0x00, L0BS)
DEV5 = DSMI (L0D5, L0A5, 0x00, L0BS)
DEV6 = DSMI (L0D6, L0A6, 0x00, L0BS)
DEV7 = DSMI (L0D7, L0A7, 0x00, L0BS)
DEV8 = DSMI (L0D8, L0A8, 0x00, L0BS)
DEV9 = DSMI (L0D9, L0A9, 0x00, L0BS)
DEVA = DSMI (L0DA, L0AA, 0x00, L0BS)
DEVB = DSMI (L0DB, L0AB, 0x00, L0BS)
Return (DSMB) /* \_SB_.PCI0.LNK0._DSM.DSMB */
}
Return (Buffer (0x01)
{
0x00 // .
})
}
If ((Arg0 == ToUUID ("26257549-9271-4ca4-bb43-c4899d5a4881")))
{
If ((Arg2 == 0x00))
{
Return (Buffer (0x02)
{
0xFF, 0x1F // ..
})
}
If ((Arg2 == 0x01))
{
Return (L0DI) /* \L0DI */
}
If ((Arg2 == 0x02))
{
If ((L0DI > 0x00))
{
Return (DSMI (L0D0, L0A0, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x03))
{
If ((L0DI > 0x01))
{
Return (DSMI (L0D1, L0A1, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x04))
{
If ((L0DI > 0x02))
{
Return (DSMI (L0D2, L0A2, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x05))
{
If ((L0DI > 0x03))
{
Return (DSMI (L0D3, L0A3, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x06))
{
If ((L0DI > 0x04))
{
Return (DSMI (L0D4, L0A4, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x07))
{
If ((L0DI > 0x05))
{
Return (DSMI (L0D5, L0A5, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x08))
{
If ((L0DI > 0x06))
{
Return (DSMI (L0D6, L0A6, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x08))
{
If ((L0DI > 0x07))
{
Return (DSMI (L0D7, L0A7, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x09))
{
If ((L0DI > 0x08))
{
Return (DSMI (L0D8, L0A8, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0A))
{
If ((L0DI > 0x09))
{
Return (DSMI (L0D9, L0A9, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0B))
{
If ((L0DI > 0x0A))
{
Return (DSMI (L0DA, L0AA, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0C))
{
If ((L0DI > 0x0B))
{
Return (DSMI (L0DB, L0AB, 0x00, L0BS))
}
Else
{
Return (0x00)
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (LNK1)
{
Name (_ADR, Zero) // _ADR: Address
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (L1EN)
{
Return (0x0F)
}
Else
{
Return (0x00)
}
}
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (L1EN)
{
Return (CDEP (L1CL))
}
Else
{
Return (Package (0x01)
{
\_SB.PCI0
})
}
}
Name (_UID, 0x01) // _UID: Unique ID
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
Return (HCID (0x01))
}
Method (_CID, 0, NotSerialized) // _CID: Compatible ID
{
Return (HCID (0x01))
}
Method (_DDN, 0, NotSerialized) // _DDN: DOS Device Name
{
Name (BUF, Buffer (0x10){})
BUF [0x00] = L1M0 /* \L1M0 */
BUF [0x01] = L1M1 /* \L1M1 */
BUF [0x02] = L1M2 /* \L1M2 */
BUF [0x03] = L1M3 /* \L1M3 */
BUF [0x04] = L1M4 /* \L1M4 */
BUF [0x05] = L1M5 /* \L1M5 */
BUF [0x06] = L1M6 /* \L1M6 */
BUF [0x07] = L1M7 /* \L1M7 */
BUF [0x08] = L1M8 /* \L1M8 */
BUF [0x09] = L1M9 /* \L1M9 */
BUF [0x0A] = L1MA /* \L1MA */
BUF [0x0B] = L1MB /* \L1MB */
BUF [0x0C] = L1MC /* \L1MC */
BUF [0x0D] = L1MD /* \L1MD */
BUF [0x0E] = L1ME /* \L1ME */
BUF [0x0F] = L1MF /* \L1MF */
Return (ToString (BUF, Ones))
}
Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device
{
Name (PLDB, Package (0x01)
{
Buffer (0x14)
{
/* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x69, 0x0E, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, // i.......
/* 0010 */ 0xFF, 0xFF, 0xFF, 0xFF // ....
}
})
CreateByteField (DerefOf (PLDB [0x00]), 0x08, BPOS)
CreateField (DerefOf (PLDB [0x00]), 0x73, 0x04, RPOS)
RPOS = L1DG /* \L1DG */
BPOS = L1PL /* \L1PL */
Return (PLDB) /* \_SB_.PCI0.LNK1._PLD.PLDB */
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((L1DI > 0x00))
{
Local1 = IICB (L1A0, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x01))
{
Local1 = IICB (L1A1, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x02))
{
Local1 = IICB (L1A2, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x03))
{
Local1 = IICB (L1A3, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x04))
{
Local1 = IICB (L1A4, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x05))
{
Local1 = IICB (L1A5, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x06))
{
Local1 = IICB (L1A6, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x07))
{
Local1 = IICB (L1A7, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x08))
{
Local1 = IICB (L1A8, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x09))
{
Local1 = IICB (L1A9, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x0A))
{
Local1 = IICB (L1AA, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L1DI > 0x0B))
{
Local1 = IICB (L1AB, L1BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
Return (Local0)
}
Method (SSDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x6C)
{
/* 0000 */ 0x00, 0x00, 0x69, 0x56, 0x39, 0x8A, 0xF7, 0x11, // ..iV9...
/* 0008 */ 0xA9, 0x4E, 0x9C, 0x7D, 0x20, 0xEE, 0x0A, 0xB5, // .N.} ...
/* 0010 */ 0xCA, 0x40, 0xA3, 0x00, 0x00, 0x00, 0x00, 0x00, // .@......
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0020 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0028 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0030 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0038 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0040 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0048 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0050 */ 0x09, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, // ........
/* 0058 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0060 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0068 */ 0x00, 0x00, 0x00, 0x00 // ....
})
PAR [0x00] = L1DV /* \L1DV */
PAR [0x01] = L1CV /* \L1CV */
PAR [0x18] = CDIV /* \CDIV */
PAR [0x1C] = L1LU /* \L1LU */
PAR [0x1D] = L1NL /* \L1NL */
PAR [0x4E] = L1EE /* \L1EE */
PAR [0x4F] = L1VC /* \L1VC */
PAR [0x52] = L1FS /* \L1FS */
PAR [0x53] = L1LE /* \L1LE */
PAR [0x54] = CDEG (L1DG)
CreateDWordField (PAR, 0x56, DAT)
DAT = L1CK /* \L1CK */
PAR [0x5A] = L1CL /* \L1CL */
PAR [0x5F] = L1PP /* \L1PP */
PAR [0x60] = L1VR /* \L1VR */
Return (PAR) /* \_SB_.PCI0.LNK1.SSDB.PAR_ */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("822ace8f-2814-4174-a56b-5f029fe079ee")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (BUF, Buffer (0x10){})
BUF [0x00] = L1M0 /* \L1M0 */
BUF [0x01] = L1M1 /* \L1M1 */
BUF [0x02] = L1M2 /* \L1M2 */
BUF [0x03] = L1M3 /* \L1M3 */
BUF [0x04] = L1M4 /* \L1M4 */
BUF [0x05] = L1M5 /* \L1M5 */
BUF [0x06] = L1M6 /* \L1M6 */
BUF [0x07] = L1M7 /* \L1M7 */
BUF [0x08] = L1M8 /* \L1M8 */
BUF [0x09] = L1M9 /* \L1M9 */
BUF [0x0A] = L1MA /* \L1MA */
BUF [0x0B] = L1MB /* \L1MB */
BUF [0x0C] = L1MC /* \L1MC */
BUF [0x0D] = L1MD /* \L1MD */
BUF [0x0E] = L1ME /* \L1ME */
BUF [0x0F] = L1MF /* \L1MF */
Return (ToString (BUF, Ones))
}
}
If ((Arg0 == ToUUID ("5815c5c8-c47d-477b-9a8d-76173176414b")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (DSMB, Buffer ((0x0D * 0x04)){})
CreateDWordField (DSMB, 0x00, I2CC)
CreateDWordField (DSMB, 0x04, DEV0)
CreateDWordField (DSMB, 0x08, DEV1)
CreateDWordField (DSMB, 0x0C, DEV2)
CreateDWordField (DSMB, 0x10, DEV3)
CreateDWordField (DSMB, 0x14, DEV4)
CreateDWordField (DSMB, 0x18, DEV5)
CreateDWordField (DSMB, 0x1C, DEV6)
CreateDWordField (DSMB, 0x20, DEV7)
CreateDWordField (DSMB, 0x24, DEV8)
CreateDWordField (DSMB, 0x28, DEV9)
CreateDWordField (DSMB, 0x2C, DEVA)
CreateDWordField (DSMB, 0x30, DEVB)
I2CC = L1DI /* \L1DI */
DEV0 = DSMI (L1D0, L1A0, 0x00, L1BS)
DEV1 = DSMI (L1D1, L1A1, 0x00, L1BS)
DEV2 = DSMI (L1D2, L1A2, 0x00, L1BS)
DEV3 = DSMI (L1D3, L1A3, 0x00, L1BS)
DEV4 = DSMI (L1D4, L1A4, 0x00, L1BS)
DEV5 = DSMI (L1D5, L1A5, 0x00, L1BS)
DEV6 = DSMI (L1D6, L1A6, 0x00, L1BS)
DEV7 = DSMI (L1D7, L1A7, 0x00, L1BS)
DEV8 = DSMI (L1D8, L1A8, 0x00, L1BS)
DEV9 = DSMI (L1D9, L1A9, 0x00, L1BS)
DEVA = DSMI (L1DA, L1AA, 0x00, L1BS)
DEVB = DSMI (L1DB, L1AB, 0x00, L1BS)
Return (DSMB) /* \_SB_.PCI0.LNK1._DSM.DSMB */
}
Return (Buffer (0x01)
{
0x00 // .
})
}
If ((Arg0 == ToUUID ("26257549-9271-4ca4-bb43-c4899d5a4881")))
{
If ((Arg2 == 0x00))
{
Return (Buffer (0x02)
{
0xFF, 0x1F // ..
})
}
If ((Arg2 == 0x01))
{
Return (L1DI) /* \L1DI */
}
If ((Arg2 == 0x02))
{
If ((L1DI > 0x00))
{
Return (DSMI (L1D0, L1A0, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x03))
{
If ((L1DI > 0x01))
{
Return (DSMI (L1D1, L1A1, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x04))
{
If ((L1DI > 0x02))
{
Return (DSMI (L1D2, L1A2, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x05))
{
If ((L1DI > 0x03))
{
Return (DSMI (L1D3, L1A3, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x06))
{
If ((L1DI > 0x04))
{
Return (DSMI (L1D4, L1A4, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x07))
{
If ((L1DI > 0x05))
{
Return (DSMI (L1D5, L1A5, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x08))
{
If ((L1DI > 0x06))
{
Return (DSMI (L1D6, L1A6, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x08))
{
If ((L1DI > 0x07))
{
Return (DSMI (L1D7, L1A7, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x09))
{
If ((L1DI > 0x08))
{
Return (DSMI (L1D8, L1A8, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0A))
{
If ((L1DI > 0x09))
{
Return (DSMI (L1D9, L1A9, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0B))
{
If ((L1DI > 0x0A))
{
Return (DSMI (L1DA, L1AA, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0C))
{
If ((L1DI > 0x0B))
{
Return (DSMI (L1DB, L1AB, 0x00, L1BS))
}
Else
{
Return (0x00)
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (LNK2)
{
Name (_ADR, Zero) // _ADR: Address
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (L2EN)
{
Return (0x0F)
}
Else
{
Return (0x00)
}
}
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (L2EN)
{
Return (CDEP (L2CL))
}
Else
{
Return (Package (0x01)
{
\_SB.PCI0
})
}
}
Name (_UID, 0x02) // _UID: Unique ID
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
Return (HCID (0x02))
}
Method (_CID, 0, NotSerialized) // _CID: Compatible ID
{
Return (HCID (0x02))
}
Method (_DDN, 0, NotSerialized) // _DDN: DOS Device Name
{
Name (BUF, Buffer (0x10){})
BUF [0x00] = L2M0 /* \L2M0 */
BUF [0x01] = L2M1 /* \L2M1 */
BUF [0x02] = L2M2 /* \L2M2 */
BUF [0x03] = L2M3 /* \L2M3 */
BUF [0x04] = L2M4 /* \L2M4 */
BUF [0x05] = L2M5 /* \L2M5 */
BUF [0x06] = L2M6 /* \L2M6 */
BUF [0x07] = L2M7 /* \L2M7 */
BUF [0x08] = L2M8 /* \L2M8 */
BUF [0x09] = L2M9 /* \L2M9 */
BUF [0x0A] = L2MA /* \L2MA */
BUF [0x0B] = L2MB /* \L2MB */
BUF [0x0C] = L2MC /* \L2MC */
BUF [0x0D] = L2MD /* \L2MD */
BUF [0x0E] = L2ME /* \L2ME */
BUF [0x0F] = L2MF /* \L2MF */
Return (ToString (BUF, Ones))
}
Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device
{
Name (PLDB, Package (0x01)
{
Buffer (0x14)
{
/* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x69, 0x0E, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, // i.......
/* 0010 */ 0xFF, 0xFF, 0xFF, 0xFF // ....
}
})
CreateByteField (DerefOf (PLDB [0x00]), 0x08, BPOS)
CreateField (DerefOf (PLDB [0x00]), 0x73, 0x04, RPOS)
BPOS = L2PL /* \L2PL */
RPOS = L2DG /* \L2DG */
Return (PLDB) /* \_SB_.PCI0.LNK2._PLD.PLDB */
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((L2DI > 0x00))
{
Local1 = IICB (L2A0, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x01))
{
Local1 = IICB (L2A1, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x02))
{
Local1 = IICB (L2A2, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x03))
{
Local1 = IICB (L2A3, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x04))
{
Local1 = IICB (L2A4, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x05))
{
Local1 = IICB (L2A5, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x06))
{
Local1 = IICB (L2A6, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x07))
{
Local1 = IICB (L2A7, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x08))
{
Local1 = IICB (L2A8, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x09))
{
Local1 = IICB (L2A9, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x0A))
{
Local1 = IICB (L2AA, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L2DI > 0x0B))
{
Local1 = IICB (L2AB, L2BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
Return (Local0)
}
Method (SSDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x6C)
{
/* 0000 */ 0x00, 0x00, 0x69, 0x56, 0x39, 0x8A, 0xF7, 0x11, // ..iV9...
/* 0008 */ 0xA9, 0x4E, 0x9C, 0x7D, 0x20, 0xEE, 0x0A, 0xB5, // .N.} ...
/* 0010 */ 0xCA, 0x40, 0xA3, 0x00, 0x00, 0x00, 0x00, 0x00, // .@......
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0020 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0028 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0030 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0038 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0040 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0048 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0050 */ 0x09, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, // ........
/* 0058 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0060 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0068 */ 0x00, 0x00, 0x00, 0x00 // ....
})
PAR [0x00] = L2DV /* \L2DV */
PAR [0x01] = L2CV /* \L2CV */
PAR [0x18] = CDIV /* \CDIV */
PAR [0x1C] = L2LU /* \L2LU */
PAR [0x1D] = L2NL /* \L2NL */
PAR [0x4E] = L2EE /* \L2EE */
PAR [0x4F] = L2VC /* \L2VC */
PAR [0x52] = L2FS /* \L2FS */
PAR [0x53] = L2LE /* \L2LE */
PAR [0x54] = CDEG (L2DG)
CreateDWordField (PAR, 0x56, DAT)
DAT = L2CK /* \L2CK */
PAR [0x5A] = L2CL /* \L2CL */
PAR [0x5F] = L2PP /* \L2PP */
PAR [0x60] = L2VR /* \L2VR */
Return (PAR) /* \_SB_.PCI0.LNK2.SSDB.PAR_ */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("822ace8f-2814-4174-a56b-5f029fe079ee")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (BUF, Buffer (0x10){})
BUF [0x00] = L2M0 /* \L2M0 */
BUF [0x01] = L2M1 /* \L2M1 */
BUF [0x02] = L2M2 /* \L2M2 */
BUF [0x03] = L2M3 /* \L2M3 */
BUF [0x04] = L2M4 /* \L2M4 */
BUF [0x05] = L2M5 /* \L2M5 */
BUF [0x06] = L2M6 /* \L2M6 */
BUF [0x07] = L2M7 /* \L2M7 */
BUF [0x08] = L2M8 /* \L2M8 */
BUF [0x09] = L2M9 /* \L2M9 */
BUF [0x0A] = L2MA /* \L2MA */
BUF [0x0B] = L2MB /* \L2MB */
BUF [0x0C] = L2MC /* \L2MC */
BUF [0x0D] = L2MD /* \L2MD */
BUF [0x0E] = L2ME /* \L2ME */
BUF [0x0F] = L2MF /* \L2MF */
Return (ToString (BUF, Ones))
}
}
If ((Arg0 == ToUUID ("5815c5c8-c47d-477b-9a8d-76173176414b")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (DSMB, Buffer ((0x0D * 0x04)){})
CreateDWordField (DSMB, 0x00, I2CC)
CreateDWordField (DSMB, 0x04, DEV0)
CreateDWordField (DSMB, 0x08, DEV1)
CreateDWordField (DSMB, 0x0C, DEV2)
CreateDWordField (DSMB, 0x10, DEV3)
CreateDWordField (DSMB, 0x14, DEV4)
CreateDWordField (DSMB, 0x18, DEV5)
CreateDWordField (DSMB, 0x1C, DEV6)
CreateDWordField (DSMB, 0x20, DEV7)
CreateDWordField (DSMB, 0x24, DEV8)
CreateDWordField (DSMB, 0x28, DEV9)
CreateDWordField (DSMB, 0x2C, DEVA)
CreateDWordField (DSMB, 0x30, DEVB)
I2CC = L2DI /* \L2DI */
DEV0 = DSMI (L2D0, L2A0, 0x00, L2BS)
DEV1 = DSMI (L2D1, L2A1, 0x00, L2BS)
DEV2 = DSMI (L2D2, L2A2, 0x00, L2BS)
DEV3 = DSMI (L2D3, L2A3, 0x00, L2BS)
DEV4 = DSMI (L2D4, L2A4, 0x00, L2BS)
DEV5 = DSMI (L2D5, L2A5, 0x00, L2BS)
DEV6 = DSMI (L2D6, L2A6, 0x00, L2BS)
DEV7 = DSMI (L2D7, L2A7, 0x00, L2BS)
DEV8 = DSMI (L2D8, L2A8, 0x00, L2BS)
DEV9 = DSMI (L2D9, L2A9, 0x00, L2BS)
DEVA = DSMI (L2DA, L2AA, 0x00, L2BS)
DEVB = DSMI (L2DB, L2AB, 0x00, L2BS)
Return (DSMB) /* \_SB_.PCI0.LNK2._DSM.DSMB */
}
Return (Buffer (0x01)
{
0x00 // .
})
}
If ((Arg0 == ToUUID ("26257549-9271-4ca4-bb43-c4899d5a4881")))
{
If ((Arg2 == 0x00))
{
Return (Buffer (0x02)
{
0xFF, 0x1F // ..
})
}
If ((Arg2 == 0x01))
{
Return (L2DI) /* \L2DI */
}
If ((Arg2 == 0x02))
{
If ((L2DI > 0x00))
{
Return (DSMI (L2D0, L2A0, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x03))
{
If ((L2DI > 0x01))
{
Return (DSMI (L2D1, L2A1, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x04))
{
If ((L2DI > 0x02))
{
Return (DSMI (L2D2, L2A2, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x05))
{
If ((L2DI > 0x03))
{
Return (DSMI (L2D3, L2A3, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x06))
{
If ((L2DI > 0x04))
{
Return (DSMI (L2D4, L2A4, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x07))
{
If ((L2DI > 0x05))
{
Return (DSMI (L2D5, L2A5, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x08))
{
If ((L2DI > 0x06))
{
Return (DSMI (L2D6, L2A6, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x08))
{
If ((L2DI > 0x07))
{
Return (DSMI (L2D7, L2A7, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x09))
{
If ((L2DI > 0x08))
{
Return (DSMI (L2D8, L2A8, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0A))
{
If ((L2DI > 0x09))
{
Return (DSMI (L2D9, L2A9, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0B))
{
If ((L2DI > 0x0A))
{
Return (DSMI (L2DA, L2AA, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
If ((Arg2 == 0x0C))
{
If ((L2DI > 0x0B))
{
Return (DSMI (L2DB, L2AB, 0x00, L2BS))
}
Else
{
Return (0x00)
}
}
}
Return (Buffer (0x01)
{
0x00 // .
})
}
}
Device (LNK3)
{
Name (_ADR, Zero) // _ADR: Address
Method (_STA, 0, NotSerialized) // _STA: Status
{
If (L3EN)
{
Return (0x0F)
}
Else
{
Return (0x00)
}
}
Method (_DEP, 0, NotSerialized) // _DEP: Dependencies
{
If (L3EN)
{
Return (CDEP (L3CL))
}
Else
{
Return (Package (0x01)
{
\_SB.PCI0
})
}
}
Name (_UID, 0x03) // _UID: Unique ID
Method (_HID, 0, NotSerialized) // _HID: Hardware ID
{
Return (HCID (0x03))
}
Method (_CID, 0, NotSerialized) // _CID: Compatible ID
{
Return (HCID (0x03))
}
Method (_DDN, 0, NotSerialized) // _DDN: DOS Device Name
{
Name (BUF, Buffer (0x10){})
BUF [0x00] = L3M0 /* \L3M0 */
BUF [0x01] = L3M1 /* \L3M1 */
BUF [0x02] = L3M2 /* \L3M2 */
BUF [0x03] = L3M3 /* \L3M3 */
BUF [0x04] = L3M4 /* \L3M4 */
BUF [0x05] = L3M5 /* \L3M5 */
BUF [0x06] = L3M6 /* \L3M6 */
BUF [0x07] = L3M7 /* \L3M7 */
BUF [0x08] = L3M8 /* \L3M8 */
BUF [0x09] = L3M9 /* \L3M9 */
BUF [0x0A] = L3MA /* \L3MA */
BUF [0x0B] = L3MB /* \L3MB */
BUF [0x0C] = L3MC /* \L3MC */
BUF [0x0D] = L3MD /* \L3MD */
BUF [0x0E] = L3ME /* \L3ME */
BUF [0x0F] = L3MF /* \L3MF */
Return (ToString (BUF, Ones))
}
Method (_PLD, 0, Serialized) // _PLD: Physical Location of Device
{
Name (PLDB, Package (0x01)
{
Buffer (0x14)
{
/* 0000 */ 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0008 */ 0x69, 0x0E, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, // i.......
/* 0010 */ 0xFF, 0xFF, 0xFF, 0xFF // ....
}
})
CreateByteField (DerefOf (PLDB [0x00]), 0x08, BPOS)
CreateField (DerefOf (PLDB [0x00]), 0x73, 0x04, RPOS)
BPOS = L3PL /* \L3PL */
RPOS = L3DG /* \L3DG */
Return (PLDB) /* \_SB_.PCI0.LNK3._PLD.PLDB */
}
Method (_CRS, 0, NotSerialized) // _CRS: Current Resource Settings
{
Local0 = Buffer (0x02)
{
0x79, 0x00 // y.
}
If ((L3DI > 0x00))
{
Local1 = IICB (L3A0, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x01))
{
Local1 = IICB (L3A1, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x02))
{
Local1 = IICB (L3A2, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x03))
{
Local1 = IICB (L3A3, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x04))
{
Local1 = IICB (L3A4, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x05))
{
Local1 = IICB (L3A5, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x06))
{
Local1 = IICB (L3A6, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x07))
{
Local1 = IICB (L3A7, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x08))
{
Local1 = IICB (L3A8, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x09))
{
Local1 = IICB (L3A9, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x0A))
{
Local1 = IICB (L3AA, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
If ((L3DI > 0x0B))
{
Local1 = IICB (L3AB, L3BS)
ConcatenateResTemplate (Local0, Local1, Local2)
Local0 = Local2
}
Return (Local0)
}
Method (SSDB, 0, NotSerialized)
{
Name (PAR, Buffer (0x6C)
{
/* 0000 */ 0x00, 0x00, 0x69, 0x56, 0x39, 0x8A, 0xF7, 0x11, // ..iV9...
/* 0008 */ 0xA9, 0x4E, 0x9C, 0x7D, 0x20, 0xEE, 0x0A, 0xB5, // .N.} ...
/* 0010 */ 0xCA, 0x40, 0xA3, 0x00, 0x00, 0x00, 0x00, 0x00, // .@......
/* 0018 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0020 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0028 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0030 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0038 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0040 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0048 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0050 */ 0x09, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, // ........
/* 0058 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0060 */ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // ........
/* 0068 */ 0x00, 0x00, 0x00, 0x00 // ....
})
PAR [0x00] = L3DV /* \L3DV */
PAR [0x01] = L3CV /* \L3CV */
PAR [0x18] = CDIV /* \CDIV */
PAR [0x1C] = L3LU /* \L3LU */
PAR [0x1D] = L3NL /* \L3NL */
PAR [0x4E] = L3EE /* \L3EE */
PAR [0x4F] = L3VC /* \L3VC */
PAR [0x52] = L3FS /* \L3FS */
PAR [0x53] = L3LE /* \L3LE */
PAR [0x54] = CDEG (L3DG)
CreateDWordField (PAR, 0x56, DAT)
DAT = L3CK /* \L3CK */
PAR [0x5A] = L3CL /* \L3CL */
PAR [0x5F] = L3PP /* \L3PP */
PAR [0x60] = L3VR /* \L3VR */
Return (PAR) /* \_SB_.PCI0.LNK3.SSDB.PAR_ */
}
Method (_DSM, 4, NotSerialized) // _DSM: Device-Specific Method
{
If ((Arg0 == ToUUID ("822ace8f-2814-4174-a56b-5f029fe079ee")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (BUF, Buffer (0x10){})
BUF [0x00] = L3M0 /* \L3M0 */
BUF [0x01] = L3M1 /* \L3M1 */
BUF [0x02] = L3M2 /* \L3M2 */
BUF [0x03] = L3M3 /* \L3M3 */
BUF [0x04] = L3M4 /* \L3M4 */
BUF [0x05] = L3M5 /* \L3M5 */
BUF [0x06] = L3M6 /* \L3M6 */
BUF [0x07] = L3M7 /* \L3M7 */
BUF [0x08] = L3M8 /* \L3M8 */
BUF [0x09] = L3M9 /* \L3M9 */
BUF [0x0A] = L3MA /* \L3MA */
BUF [0x0B] = L3MB /* \L3MB */
BUF [0x0C] = L3MC /* \L3MC */
BUF [0x0D] = L3MD /* \L3MD */
BUF [0x0E] = L3ME /* \L3ME */
BUF [0x0F] = L3MF /* \L3MF */
Return (ToString (BUF, Ones))
}
}
If ((Arg0 == ToUUID ("5815c5c8-c47d-477b-9a8d-76173176414b")))
{
If ((Arg2 == 0x00))
{
If ((Arg1 == 0x00))
{
Return (Buffer (0x01)
{
0x03 // .
})
}
Else
{
Return (Buffer (0x01)
{
0x01 // .
})
}
}
If ((Arg2 == 0x01))
{
Name (DSMB, Buffer ((0x0D * 0x04)){})
CreateDWordField (DSMB, 0x00, I2CC)
CreateDWordField (DSMB, 0x04, DEV0)
CreateDWordField (DSMB, 0x08, DEV1)
CreateDWordField (DSMB, 0x0C, DEV2)
CreateDWordField (DSMB, 0x10, DEV3)
CreateDWordField (DSMB, 0x14, DEV4)
CreateDWordField (DSMB, 0x18, DEV5)
CreateDWordField (DSMB, 0x1C, DEV6)
CreateDWordField (DSMB, 0x20, DEV7)
CreateDWordField (DSMB, 0x24, DEV8)
CreateDWordField (DSMB, 0x28, DEV9)
CreateDWordField (DSMB, 0x2C, DEVA)
CreateDWordField (DSMB, 0x30, DEVB)
I2CC = L3DI /* \L3DI */
DEV0 = DSMI (L3D0, L3A0, 0x00, L3BS)
DEV1 = DSMI (L3D1, L3A1, 0x00, L3BS)
DEV2 = DSMI (L3D2, L3A2, 0x00, L3BS)
DEV3 = DSMI (L3D3, L3A3, 0x00, L3BS)
DEV4 = DSMI (L3D4, L3A4, 0x00, L3BS)
DEV5 = DSMI (L3D5, L3A5, 0x00, L3BS)
DEV6 = DSMI (L3D6, L3A6, 0x00, L3BS)
DEV7 = DSMI (L3D7, L3A7, 0x00, L3BS)
DEV8 = DSMI (L3D8, L3A8, 0x00, L3BS)
DEV9 = DSMI (L3D9, L3A9, 0x00, L3BS)
DEVA = DSMI (L3DA, L3AA, 0x00, L3BS)
DEVB = DSMI (L3DB, L3AB, 0x00, L3BS)
Return (DSMB) /* \_SB_.PCI0.LNK3._DSM.DSMB */
}
Return (Buffer (0x01)
{
0x00 // .
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment