/* SPDX-License-Identifier: GPL-2.0-only */ #include #include #include Device (AAHB) { Name (_HID, "AAHB0000") Name (_UID, 0x0) Name (_CRS, ResourceTemplate() { Memory32Fixed (ReadWrite, ALINK_AHB_ADDRESS, 0x2000) }) Method (_STA, 0x0, NotSerialized) { Return (0x0F) } } Device (GPIO) { Name (_HID, GPIO_DEVICE_NAME) Name (_CID, GPIO_DEVICE_NAME) Name (_UID, 0) Name (_DDN, GPIO_DEVICE_DESC) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Level, ActiveLow, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, 0xFED81500, 0x300) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = IGPI } Else { IRQN = PGPI } If (IRQN == 0x1f) { Return (ResourceTemplate() { Memory32Fixed (ReadWrite, 0xFED81500, 0x300) }) } Else { Return (Local0) } } Method (_STA, 0x0, NotSerialized) { Return (0x0F) } } Device (MMC0) { Name (_HID, "AMDI0040") Name (_UID, 0x0) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Level, ActiveLow, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, APU_EMMC_BASE, 0x1000) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = IMMC } Else { IRQN = PMMC } If (IRQN == 0x1f) { Return (ResourceTemplate(){ Memory32Fixed (ReadWrite, APU_EMMC_BASE, 0x1000) }) } Else { Return (Local0) } } Method (_STA, 0x0, NotSerialized) { Return (0x0F) } } Device (FUR0) { Name (_HID, "AMD0020") Name (_UID, 0x0) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Edge, ActiveHigh, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, APU_UART0_BASE, 0x1000) Memory32Fixed (ReadWrite, APU_DMAC0_BASE, 0x1000) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = IUA0 } Else { IRQN = PUA0 } If (IRQN == 0x1f) { Return (ResourceTemplate() { Memory32Fixed (ReadWrite, APU_UART0_BASE, 0x1000) Memory32Fixed (ReadWrite, APU_DMAC0_BASE, 0x1000) }) } Else { Return (Local0) } } } Device (FUR1) { Name (_HID, "AMD0020") Name (_UID, 0x1) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Edge, ActiveHigh, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, APU_UART1_BASE, 0x1000) Memory32Fixed (ReadWrite, APU_DMAC1_BASE, 0x1000) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = IUA1 } Else { IRQN = PUA1 } If (IRQN == 0x1f) { Return (ResourceTemplate() { Memory32Fixed (ReadWrite, APU_UART1_BASE, 0x1000) Memory32Fixed (ReadWrite, APU_DMAC1_BASE, 0x1000) }) } Else { Return (Local0) } } Name (_PR0, Package () { \_SB.AOAC.FUR1 }) Name (_PR2, Package () { \_SB.AOAC.FUR1 }) Name (_PR3, Package () { \_SB.AOAC.FUR1 }) Method (_PS0, 0, Serialized) { Printf("FUR1._PS0") \_SB.AOAC.FUR1.TDS = 1 } Method (_PS3, 0, Serialized) { Printf("FUR1._PS3") \_SB.AOAC.FUR1.TDS = 3 } } Device (FUR2) { Name (_HID, "AMD0020") Name (_UID, 0x2) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Edge, ActiveHigh, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, APU_UART2_BASE, 0x1000) Memory32Fixed (ReadWrite, APU_DMAC2_BASE, 0x1000) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = IUA2 } Else { IRQN = PUA2 } If (IRQN == 0x1f) { Return (ResourceTemplate() { Memory32Fixed (ReadWrite, APU_UART2_BASE, 0x1000) Memory32Fixed (ReadWrite, APU_DMAC2_BASE, 0x1000) }) } Else { Return (Local0) } } Name (_PR0, Package () { \_SB.AOAC.FUR2 }) Name (_PR2, Package () { \_SB.AOAC.FUR2 }) Name (_PR3, Package () { \_SB.AOAC.FUR2 }) Method (_PS0, 0, Serialized) { Printf("FUR2._PS0") \_SB.AOAC.FUR2.TDS = 1 } Method (_PS3, 0, Serialized) { Printf("FUR2._PS3") \_SB.AOAC.FUR2.TDS = 3 } } Device (FUR3) { Name (_HID, "AMD0020") Name (_UID, 0x3) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Edge, ActiveHigh, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, APU_UART3_BASE, 0x1000) Memory32Fixed (ReadWrite, APU_DMAC3_BASE, 0x1000) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = IUA3 } Else { IRQN = PUA3 } If (IRQN == 0x1f) { Return (ResourceTemplate() { Memory32Fixed (ReadWrite, APU_UART3_BASE, 0x1000) Memory32Fixed (ReadWrite, APU_DMAC3_BASE, 0x1000) }) } Else { Return (Local0) } } Name (_PR0, Package () { \_SB.AOAC.FUR3 }) Name (_PR2, Package () { \_SB.AOAC.FUR3 }) Name (_PR3, Package () { \_SB.AOAC.FUR3 }) Method (_PS0, 0, Serialized) { Printf("FUR3._PS0") \_SB.AOAC.FUR3.TDS = 1 } Method (_PS3, 0, Serialized) { Printf("FUR3._PS3") \_SB.AOAC.FUR3.TDS = 3 } } Device (I2C2) { Name (_HID, "AMD0010") Name (_UID, 0x2) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Edge, ActiveHigh, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, APU_I2C2_BASE, 0x1000) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = II22 } Else { IRQN = PI22 } If (IRQN == 0x1f) { Return (ResourceTemplate() { Memory32Fixed (ReadWrite, APU_I2C2_BASE, 0x1000) }) } Else { Return (Local0) } } Method (_STA, 0x0, NotSerialized) { Return (0x0F) } Name (_PR0, Package () { \_SB.AOAC.I2C2 }) Name (_PR2, Package () { \_SB.AOAC.I2C2 }) Name (_PR3, Package () { \_SB.AOAC.I2C2 }) Method (_PS0, 0, Serialized) { Printf("I2C2._PS0") \_SB.AOAC.I2C2.TDS = 1 } Method (_PS3, 0, Serialized) { Printf("I2C2._PS3") \_SB.AOAC.I2C2.TDS = 3 } } Device (I2C3) { Name (_HID, "AMD0010") Name (_UID, 0x3) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Edge, ActiveHigh, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, APU_I2C3_BASE, 0x1000) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = II23 } Else { IRQN = PI23 } If (IRQN == 0x1f) { Return (ResourceTemplate() { Memory32Fixed (ReadWrite, APU_I2C3_BASE, 0x1000) }) } Else { Return (Local0) } } Method (_STA, 0x0, NotSerialized) { Return (0x0F) } Name (_PR0, Package () { \_SB.AOAC.I2C3 }) Name (_PR2, Package () { \_SB.AOAC.I2C3 }) Name (_PR3, Package () { \_SB.AOAC.I2C3 }) Method (_PS0, 0, Serialized) { Printf("I2C3._PS0") \_SB.AOAC.I2C3.TDS = 1 } Method (_PS3, 0, Serialized) { Printf("I2C3._PS3") \_SB.AOAC.I2C3.TDS = 3 } } Device (I2C4) { Name (_HID, "AMD0010") Name (_UID, 0x4) Method (_CRS, 0) { Local0 = ResourceTemplate() { Interrupt ( ResourceConsumer, Edge, ActiveHigh, Exclusive, , , IRQR) { 0 } Memory32Fixed (ReadWrite, APU_I2C4_BASE, 0x1000) } CreateDWordField (Local0, IRQR._INT, IRQN) If (PMOD) { IRQN = II24 } Else { IRQN = PI24 } If (IRQN == 0x1f) { Return (ResourceTemplate() { Memory32Fixed (ReadWrite, APU_I2C4_BASE, 0x1000) }) } Else { Return (Local0) } } Method (_STA, 0x0, NotSerialized) { Return (0x0F) } Name (_PR0, Package () { \_SB.AOAC.I2C4 }) Name (_PR2, Package () { \_SB.AOAC.I2C4 }) Name (_PR3, Package () { \_SB.AOAC.I2C4 }) Method (_PS0, 0, Serialized) { Printf("I2C4._PS0") \_SB.AOAC.I2C4.TDS = 1 } Method (_PS3, 0, Serialized) { Printf("I2C4._PS3") \_SB.AOAC.I2C4.TDS = 3 } } Device (MISC) { Name (_HID, "AMD0040") Name (_UID, 0x3) Name (_CRS, ResourceTemplate() { Memory32Fixed (ReadWrite, ACPIMMIO_MISC_BASE, 0x100) }) Method (_STA, 0x0, NotSerialized) { Return (0x0F) } }