/* SPDX-License-Identifier: GPL-2.0-only */ /* This file is part of the coreboot project. */ Device (LNKA) { Name (_HID, EISAID("PNP0C0F")) Name (_UID, 1) /* Disable method */ Method (_DIS, 0, Serialized) { Store (0x80, PRTA) } /* Possible Resource Settings for this Link */ Name (_PRS, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 1, 3, 4, 5, 6, 7, 10, 11, 12, 14, 15 } }) /* Current Resource Settings for this link */ Method (_CRS, 0, Serialized) { Name (RTLA, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) {} }) CreateWordField(RTLA, 1, IRQ0) /* Clear the WordField */ Store (Zero, IRQ0) /* Set the bit from PRTA */ ShiftLeft(1, And(PRTA, 0x0f), IRQ0) Return (RTLA) } /* Set Resource Setting for this IRQ link */ Method (_SRS, 1, Serialized) { CreateWordField(Arg0, 1, IRQ0) /* Which bit is set? */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PRTA) } /* Status */ Method (_STA, 0, Serialized) { If(And(PRTA, 0x80)) { Return (0x9) } Else { Return (0xb) } } } Device (LNKB) { Name (_HID, EISAID("PNP0C0F")) Name (_UID, 2) /* Disable method */ Method (_DIS, 0, Serialized) { Store (0x80, PRTB) } /* Possible Resource Settings for this Link */ Name (_PRS, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 1, 3, 4, 5, 6, 7, 10, 11, 12, 14, 15 } }) /* Current Resource Settings for this link */ Method (_CRS, 0, Serialized) { Name (RTLB, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) {} }) CreateWordField(RTLB, 1, IRQ0) /* Clear the WordField */ Store (Zero, IRQ0) /* Set the bit from PRTB */ ShiftLeft(1, And(PRTB, 0x0f), IRQ0) Return (RTLB) } /* Set Resource Setting for this IRQ link */ Method (_SRS, 1, Serialized) { CreateWordField(Arg0, 1, IRQ0) /* Which bit is set? */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PRTB) } /* Status */ Method (_STA, 0, Serialized) { If(And(PRTB, 0x80)) { Return (0x9) } Else { Return (0xb) } } } Device (LNKC) { Name (_HID, EISAID("PNP0C0F")) Name (_UID, 3) /* Disable method */ Method (_DIS, 0, Serialized) { Store (0x80, PRTC) } /* Possible Resource Settings for this Link */ Name (_PRS, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 1, 3, 4, 5, 6, 7, 10, 11, 12, 14, 15 } }) /* Current Resource Settings for this link */ Method (_CRS, 0, Serialized) { Name (RTLC, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) {} }) CreateWordField(RTLC, 1, IRQ0) /* Clear the WordField */ Store (Zero, IRQ0) /* Set the bit from PRTC */ ShiftLeft(1, And(PRTC, 0x0f), IRQ0) Return (RTLC) } /* Set Resource Setting for this IRQ link */ Method (_SRS, 1, Serialized) { CreateWordField(Arg0, 1, IRQ0) /* Which bit is set? */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PRTC) } /* Status */ Method (_STA, 0, Serialized) { If(And(PRTC, 0x80)) { Return (0x9) } Else { Return (0xb) } } } Device (LNKD) { Name (_HID, EISAID("PNP0C0F")) Name (_UID, 4) /* Disable method */ Method (_DIS, 0, Serialized) { Store (0x80, PRTD) } /* Possible Resource Settings for this Link */ Name (_PRS, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 1, 3, 4, 5, 6, 7, 10, 11, 12, 14, 15 } }) /* Current Resource Settings for this link */ Method (_CRS, 0, Serialized) { Name (RTLD, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) {} }) CreateWordField(RTLD, 1, IRQ0) /* Clear the WordField */ Store (Zero, IRQ0) /* Set the bit from PRTD */ ShiftLeft(1, And(PRTD, 0x0f), IRQ0) Return (RTLD) } /* Set Resource Setting for this IRQ link */ Method (_SRS, 1, Serialized) { CreateWordField(Arg0, 1, IRQ0) /* Which bit is set? */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PRTD) } /* Status */ Method (_STA, 0, Serialized) { If(And(PRTD, 0x80)) { Return (0x9) } Else { Return (0xb) } } } Device (LNKE) { Name (_HID, EISAID("PNP0C0F")) Name (_UID, 5) /* Disable method */ Method (_DIS, 0, Serialized) { Store (0x80, PRTE) } /* Possible Resource Settings for this Link */ Name (_PRS, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 1, 3, 4, 5, 6, 7, 10, 11, 12, 14, 15 } }) /* Current Resource Settings for this link */ Method (_CRS, 0, Serialized) { Name (RTLE, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) {} }) CreateWordField(RTLE, 1, IRQ0) /* Clear the WordField */ Store (Zero, IRQ0) /* Set the bit from PRTE */ ShiftLeft(1, And(PRTE, 0x0f), IRQ0) Return (RTLE) } /* Set Resource Setting for this IRQ link */ Method (_SRS, 1, Serialized) { CreateWordField(Arg0, 1, IRQ0) /* Which bit is set? */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PRTE) } /* Status */ Method (_STA, 0, Serialized) { If(And(PRTE, 0x80)) { Return (0x9) } Else { Return (0xb) } } } Device (LNKF) { Name (_HID, EISAID("PNP0C0F")) Name (_UID, 6) /* Disable method */ Method (_DIS, 0, Serialized) { Store (0x80, PRTF) } /* Possible Resource Settings for this Link */ Name (_PRS, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 1, 3, 4, 5, 6, 7, 10, 11, 12, 14, 15 } }) /* Current Resource Settings for this link */ Method (_CRS, 0, Serialized) { Name (RTLF, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) {} }) CreateWordField(RTLF, 1, IRQ0) /* Clear the WordField */ Store (Zero, IRQ0) /* Set the bit from PRTF */ ShiftLeft(1, And(PRTF, 0x0f), IRQ0) Return (RTLF) } /* Set Resource Setting for this IRQ link */ Method (_SRS, 1, Serialized) { CreateWordField(Arg0, 1, IRQ0) /* Which bit is set? */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PRTF) } /* Status */ Method (_STA, 0, Serialized) { If(And(PRTF, 0x80)) { Return (0x9) } Else { Return (0xb) } } } Device (LNKG) { Name (_HID, EISAID("PNP0C0F")) Name (_UID, 7) /* Disable method */ Method (_DIS, 0, Serialized) { Store (0x80, PRTG) } /* Possible Resource Settings for this Link */ Name (_PRS, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 1, 3, 4, 5, 6, 7, 10, 11, 12, 14, 15 } }) /* Current Resource Settings for this link */ Method (_CRS, 0, Serialized) { Name (RTLG, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) {} }) CreateWordField(RTLG, 1, IRQ0) /* Clear the WordField */ Store (Zero, IRQ0) /* Set the bit from PRTG */ ShiftLeft(1, And(PRTG, 0x0f), IRQ0) Return (RTLG) } /* Set Resource Setting for this IRQ link */ Method (_SRS, 1, Serialized) { CreateWordField(Arg0, 1, IRQ0) /* Which bit is set? */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PRTG) } /* Status */ Method (_STA, 0, Serialized) { If(And(PRTG, 0x80)) { Return (0x9) } Else { Return (0xb) } } } Device (LNKH) { Name (_HID, EISAID("PNP0C0F")) Name (_UID, 8) /* Disable method */ Method (_DIS, 0, Serialized) { Store (0x80, PRTH) } /* Possible Resource Settings for this Link */ Name (_PRS, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) { 1, 3, 4, 5, 6, 7, 10, 11, 12, 14, 15 } }) /* Current Resource Settings for this link */ Method (_CRS, 0, Serialized) { Name (RTLH, ResourceTemplate() { IRQ(Level, ActiveLow, Shared) {} }) CreateWordField(RTLH, 1, IRQ0) /* Clear the WordField */ Store (Zero, IRQ0) /* Set the bit from PRTH */ ShiftLeft(1, And(PRTH, 0x0f), IRQ0) Return (RTLH) } /* Set Resource Setting for this IRQ link */ Method (_SRS, 1, Serialized) { CreateWordField(Arg0, 1, IRQ0) /* Which bit is set? */ FindSetRightBit(IRQ0, Local0) Decrement(Local0) Store(Local0, PRTH) } /* Status */ Method (_STA, 0, Serialized) { If(And(PRTH, 0x80)) { Return (0x9) } Else { Return (0xb) } } }