aboutsummaryrefslogtreecommitdiff
path: root/resources/libreboot/patch/kgpe-d16/0007-southbridge-amd-sb700-Fix-boot-hang-on-ASUS-KGPE-D16.patch
diff options
context:
space:
mode:
Diffstat (limited to 'resources/libreboot/patch/kgpe-d16/0007-southbridge-amd-sb700-Fix-boot-hang-on-ASUS-KGPE-D16.patch')
-rw-r--r--resources/libreboot/patch/kgpe-d16/0007-southbridge-amd-sb700-Fix-boot-hang-on-ASUS-KGPE-D16.patch619
1 files changed, 0 insertions, 619 deletions
diff --git a/resources/libreboot/patch/kgpe-d16/0007-southbridge-amd-sb700-Fix-boot-hang-on-ASUS-KGPE-D16.patch b/resources/libreboot/patch/kgpe-d16/0007-southbridge-amd-sb700-Fix-boot-hang-on-ASUS-KGPE-D16.patch
deleted file mode 100644
index 0cac5229..00000000
--- a/resources/libreboot/patch/kgpe-d16/0007-southbridge-amd-sb700-Fix-boot-hang-on-ASUS-KGPE-D16.patch
+++ /dev/null
@@ -1,619 +0,0 @@
-From c95c41fbedceda4de85a076f8fc600c82106727c Mon Sep 17 00:00:00 2001
-From: Timothy Pearson <tpearson@raptorengineeringinc.com>
-Date: Sat, 5 Sep 2015 17:46:15 -0500
-Subject: [PATCH 007/143] southbridge/amd/sb700: Fix boot hang on ASUS
- KGPE-D16
-
-Change-Id: I1d7d6715663a13ab94fd6d71808e35f0f7384d00
-Signed-off-by: Timothy Pearson <tpearson@raptorengineeringinc.com>
----
- src/southbridge/amd/sb700/Kconfig | 4 +
- src/southbridge/amd/sb700/acpi/ide.asl | 234 +++++++++++++++++++++++++++++++
- src/southbridge/amd/sb700/acpi/sata.asl | 133 ++++++++++++++++++
- src/southbridge/amd/sb700/bootblock.c | 46 +++++-
- src/southbridge/amd/sb700/early_setup.c | 18 +++
- src/southbridge/amd/sb700/lpc.c | 3 +
- src/southbridge/amd/sb700/sm.c | 21 +--
- 7 files changed, 444 insertions(+), 15 deletions(-)
- create mode 100644 src/southbridge/amd/sb700/acpi/ide.asl
- create mode 100644 src/southbridge/amd/sb700/acpi/sata.asl
-
-diff --git a/src/southbridge/amd/sb700/Kconfig b/src/southbridge/amd/sb700/Kconfig
-index 0761934..bca74fb 100644
---- a/src/southbridge/amd/sb700/Kconfig
-+++ b/src/southbridge/amd/sb700/Kconfig
-@@ -42,6 +42,10 @@ config SOUTHBRIDGE_AMD_SB700_SKIP_ISA_DMA_INIT
- bool
- default n
-
-+config SOUTHBRIDGE_AMD_SB700_DISABLE_ISA_DMA
-+ bool
-+ default n
-+
- config EHCI_BAR
- hex
- default 0xfef00000
-diff --git a/src/southbridge/amd/sb700/acpi/ide.asl b/src/southbridge/amd/sb700/acpi/ide.asl
-new file mode 100644
-index 0000000..9b5e3ea
---- /dev/null
-+++ b/src/southbridge/amd/sb700/acpi/ide.asl
-@@ -0,0 +1,234 @@
-+/*
-+ * This file is part of the coreboot project.
-+ *
-+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering
-+ * Copyright (C) 2010 Advanced Micro Devices, Inc.
-+ *
-+ * This program is free software; you can redistribute it and/or modify
-+ * it under the terms of the GNU General Public License as published by
-+ * the Free Software Foundation; version 2 of the License.
-+ *
-+ * This program is distributed in the hope that it will be useful,
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+ * GNU General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU General Public License
-+ * along with this program; if not, write to the Free Software
-+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
-+ */
-+
-+/* Some timing tables */
-+Name(UDTT, Package(){ /* Udma timing table */
-+ 120, 90, 60, 45, 30, 20, 15, 0 /* UDMA modes 0 -> 6 */
-+})
-+
-+Name(MDTT, Package(){ /* MWDma timing table */
-+ 480, 150, 120, 0 /* Legacy DMA modes 0 -> 2 */
-+})
-+
-+Name(POTT, Package(){ /* Pio timing table */
-+ 600, 390, 270, 180, 120, 0 /* PIO modes 0 -> 4 */
-+})
-+
-+/* Some timing register value tables */
-+Name(MDRT, Package(){ /* MWDma timing register table */
-+ 0x77, 0x21, 0x20, 0xFF /* Legacy DMA modes 0 -> 2 */
-+})
-+
-+Name(PORT, Package(){
-+ 0x99, 0x47, 0x34, 0x22, 0x20, 0x99 /* PIO modes 0 -> 4 */
-+})
-+
-+OperationRegion(ICRG, PCI_Config, 0x40, 0x20) /* ide control registers */
-+ Field(ICRG, AnyAcc, NoLock, Preserve)
-+{
-+ PPTS, 8, /* Primary PIO Slave Timing */
-+ PPTM, 8, /* Primary PIO Master Timing */
-+ OFFSET(0x04), PMTS, 8, /* Primary MWDMA Slave Timing */
-+ PMTM, 8, /* Primary MWDMA Master Timing */
-+ OFFSET(0x08), PPCR, 8, /* Primary PIO Control */
-+ OFFSET(0x0A), PPMM, 4, /* Primary PIO master Mode */
-+ PPSM, 4, /* Primary PIO slave Mode */
-+ OFFSET(0x14), PDCR, 2, /* Primary UDMA Control */
-+ OFFSET(0x16), PDMM, 4, /* Primary UltraDMA Mode */
-+ PDSM, 4, /* Primary UltraDMA Mode */
-+}
-+
-+Method(GTTM, 1) /* get total time*/
-+{
-+ Store(And(Arg0, 0x0F), Local0) /* Recovery Width */
-+ Increment(Local0)
-+ Store(ShiftRight(Arg0, 4), Local1) /* Command Width */
-+ Increment(Local1)
-+ Return(Multiply(30, Add(Local0, Local1)))
-+}
-+
-+Device(PRID)
-+{
-+ Name (_ADR, Zero)
-+ Method(_GTM, 0, Serialized)
-+ {
-+ NAME(OTBF, Buffer(20) { /* out buffer */
-+ 0xFF, 0xFF, 0xFF, 0xFF,
-+ 0xFF, 0xFF, 0xFF, 0xFF,
-+ 0xFF, 0xFF, 0xFF, 0xFF,
-+ 0xFF, 0xFF, 0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00
-+ })
-+
-+ CreateDwordField(OTBF, 0, PSD0) /* PIO spd0 */
-+ CreateDwordField(OTBF, 4, DSD0) /* DMA spd0 */
-+ CreateDwordField(OTBF, 8, PSD1) /* PIO spd1 */
-+ CreateDwordField(OTBF, 12, DSD1) /* DMA spd1 */
-+ CreateDwordField(OTBF, 16, BFFG) /* buffer flags */
-+
-+ /* Just return if the channel is disabled */
-+ If(And(PPCR, 0x01)) { /* primary PIO control */
-+ Return(OTBF)
-+ }
-+
-+ /* Always tell them independent timing available and IOChannelReady used on both drives */
-+ Or(BFFG, 0x1A, BFFG)
-+
-+ Store(GTTM(PPTM), PSD0) /* save total time of primary PIO master timming to PIO spd0 */
-+ Store(GTTM(PPTS), PSD1) /* save total time of primary PIO slave Timing to PIO spd1 */
-+
-+ If(And(PDCR, 0x01)) { /* It's under UDMA mode */
-+ Or(BFFG, 0x01, BFFG)
-+ Store(DerefOf(Index(UDTT, PDMM)), DSD0)
-+ }
-+ Else {
-+ Store(GTTM(PMTM), DSD0) /* Primary MWDMA Master Timing, DmaSpd0 */
-+ }
-+
-+ If(And(PDCR, 0x02)) { /* It's under UDMA mode */
-+ Or(BFFG, 0x04, BFFG)
-+ Store(DerefOf(Index(UDTT, PDSM)), DSD1)
-+ }
-+ Else {
-+ Store(GTTM(PMTS), DSD1) /* Primary MWDMA Slave Timing, DmaSpd0 */
-+ }
-+
-+ Return(OTBF) /* out buffer */
-+ } /* End Method(_GTM) */
-+
-+ Method(_STM, 3, Serialized)
-+ {
-+ NAME(INBF, Buffer(20) { /* in buffer */
-+ 0xFF, 0xFF, 0xFF, 0xFF,
-+ 0xFF, 0xFF, 0xFF, 0xFF,
-+ 0xFF, 0xFF, 0xFF, 0xFF,
-+ 0xFF, 0xFF, 0xFF, 0xFF, 0x00, 0x00, 0x00, 0x00
-+ })
-+
-+ CreateDwordField(INBF, 0, PSD0) /* PIO spd0 */
-+ CreateDwordField(INBF, 4, DSD0) /* PIO spd0 */
-+ CreateDwordField(INBF, 8, PSD1) /* PIO spd1 */
-+ CreateDwordField(INBF, 12, DSD1) /* DMA spd1 */
-+ CreateDwordField(INBF, 16, BFFG) /*buffer flag */
-+
-+ Store(Match(POTT, MLE, PSD0, MTR, 0, 0), Local0)
-+ Divide(Local0, 5, PPMM,) /* Primary PIO master Mode */
-+ Store(Match(POTT, MLE, PSD1, MTR, 0, 0), Local1)
-+ Divide(Local1, 5, PPSM,) /* Primary PIO slave Mode */
-+
-+ Store(DerefOf(Index(PORT, Local0)), PPTM) /* Primary PIO Master Timing */
-+ Store(DerefOf(Index(PORT, Local1)), PPTS) /* Primary PIO Slave Timing */
-+
-+ If(And(BFFG, 0x01)) { /* Drive 0 is under UDMA mode */
-+ Store(Match(UDTT, MLE, DSD0, MTR, 0, 0), Local0)
-+ Divide(Local0, 7, PDMM,)
-+ Or(PDCR, 0x01, PDCR)
-+ }
-+ Else {
-+ If(LNotEqual(DSD0, 0xFFFFFFFF)) {
-+ Store(Match(MDTT, MLE, DSD0, MTR, 0, 0), Local0)
-+ Store(DerefOf(Index(MDRT, Local0)), PMTM)
-+ }
-+ }
-+
-+ If(And(BFFG, 0x04)) { /* Drive 1 is under UDMA mode */
-+ Store(Match(UDTT, MLE, DSD1, MTR, 0, 0), Local0)
-+ Divide(Local0, 7, PDSM,)
-+ Or(PDCR, 0x02, PDCR)
-+ }
-+ Else {
-+ If(LNotEqual(DSD1, 0xFFFFFFFF)) {
-+ Store(Match(MDTT, MLE, DSD1, MTR, 0, 0), Local0)
-+ Store(DerefOf(Index(MDRT, Local0)), PMTS)
-+ }
-+ }
-+ /* Return(INBF) */
-+ } /*End Method(_STM) */
-+ Device(MST)
-+ {
-+ Name(_ADR, 0)
-+ Method(_GTF, 0, Serialized) {
-+ Name(CMBF, Buffer(21) {
-+ 0x03, 0x00, 0x00, 0x00, 0x00, 0xFF, 0xEF,
-+ 0x03, 0x00, 0x00, 0x00, 0x00, 0xFF, 0xEF,
-+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xF5
-+ })
-+ CreateByteField(CMBF, 1, POMD)
-+ CreateByteField(CMBF, 8, DMMD)
-+ CreateByteField(CMBF, 5, CMDA)
-+ CreateByteField(CMBF, 12, CMDB)
-+ CreateByteField(CMBF, 19, CMDC)
-+
-+ Store(0xA0, CMDA)
-+ Store(0xA0, CMDB)
-+ Store(0xA0, CMDC)
-+
-+ Or(PPMM, 0x08, POMD)
-+
-+ If(And(PDCR, 0x01)) {
-+ Or(PDMM, 0x40, DMMD)
-+ }
-+ Else {
-+ Store(Match
-+ (MDTT, MLE, GTTM(PMTM),
-+ MTR, 0, 0), Local0)
-+ If(LLess(Local0, 3)) {
-+ Or(0x20, Local0, DMMD)
-+ }
-+ }
-+ Return(CMBF)
-+ }
-+ } /* End Device(MST) */
-+
-+ Device(SLAV)
-+ {
-+ Name(_ADR, 1)
-+ Method(_GTF, 0, Serialized) {
-+ Name(CMBF, Buffer(21) {
-+ 0x03, 0x00, 0x00, 0x00, 0x00, 0xFF, 0xEF,
-+ 0x03, 0x00, 0x00, 0x00, 0x00, 0xFF, 0xEF,
-+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xF5
-+ })
-+ CreateByteField(CMBF, 1, POMD)
-+ CreateByteField(CMBF, 8, DMMD)
-+ CreateByteField(CMBF, 5, CMDA)
-+ CreateByteField(CMBF, 12, CMDB)
-+ CreateByteField(CMBF, 19, CMDC)
-+
-+ Store(0xB0, CMDA)
-+ Store(0xB0, CMDB)
-+ Store(0xB0, CMDC)
-+
-+ Or(PPSM, 0x08, POMD)
-+
-+ If(And(PDCR, 0x02)) {
-+ Or(PDSM, 0x40, DMMD)
-+ }
-+ Else {
-+ Store(Match
-+ (MDTT, MLE, GTTM(PMTS),
-+ MTR, 0, 0), Local0)
-+ If(LLess(Local0, 3)) {
-+ Or(0x20, Local0, DMMD)
-+ }
-+ }
-+ Return(CMBF)
-+ }
-+ } /* End Device(SLAV) */
-+}
-diff --git a/src/southbridge/amd/sb700/acpi/sata.asl b/src/southbridge/amd/sb700/acpi/sata.asl
-new file mode 100644
-index 0000000..46a82b7
---- /dev/null
-+++ b/src/southbridge/amd/sb700/acpi/sata.asl
-@@ -0,0 +1,133 @@
-+/*
-+ * This file is part of the coreboot project.
-+ *
-+ * Copyright (C) 2010 Advanced Micro Devices, Inc.
-+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering
-+ *
-+ * This program is free software; you can redistribute it and/or modify
-+ * it under the terms of the GNU General Public License as published by
-+ * the Free Software Foundation; version 2 of the License.
-+ *
-+ * This program is distributed in the hope that it will be useful,
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-+ * GNU General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU General Public License
-+ * along with this program; if not, write to the Free Software
-+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
-+ */
-+
-+Name(STTM, Buffer(20) {
-+ 0x78, 0x00, 0x00, 0x00, 0x0f, 0x00, 0x00, 0x00,
-+ 0x78, 0x00, 0x00, 0x00, 0x0f, 0x00, 0x00, 0x00,
-+ 0x1f, 0x00, 0x00, 0x00
-+})
-+
-+/* Start by clearing the PhyRdyChg bits */
-+Method(_INI) {
-+ \_GPE._L1F()
-+}
-+
-+Device(PMRY)
-+{
-+ Name(_ADR, 0)
-+ Method(_GTM, 0x0, NotSerialized) {
-+ Return(STTM)
-+ }
-+ Method(_STM, 0x3, NotSerialized) {}
-+
-+ Device(PMST) {
-+ Name(_ADR, 0)
-+ Method(_STA,0) {
-+ if (LGreater(P0IS,0)) {
-+ return (0x0F) /* sata is visible */
-+ } else {
-+ return (0x00) /* sata is missing */
-+ }
-+ }
-+ }/* end of PMST */
-+
-+ Device(PSLA)
-+ {
-+ Name(_ADR, 1)
-+ Method(_STA,0) {
-+ if (LGreater(P1IS,0)) {
-+ return (0x0F) /* sata is visible */
-+ } else {
-+ return (0x00) /* sata is missing */
-+ }
-+ }
-+ } /* end of PSLA */
-+} /* end of PMRY */
-+
-+
-+Device(SEDY)
-+{
-+ Name(_ADR, 1) /* IDE Scondary Channel */
-+ Method(_GTM, 0x0, NotSerialized) {
-+ Return(STTM)
-+ }
-+ Method(_STM, 0x3, NotSerialized) {}
-+
-+ Device(SMST)
-+ {
-+ Name(_ADR, 0)
-+ Method(_STA,0) {
-+ if (LGreater(P2IS,0)) {
-+ return (0x0F) /* sata is visible */
-+ } else {
-+ return (0x00) /* sata is missing */
-+ }
-+ }
-+ } /* end of SMST */
-+
-+ Device(SSLA)
-+ {
-+ Name(_ADR, 1)
-+ Method(_STA,0) {
-+ if (LGreater(P3IS,0)) {
-+ return (0x0F) /* sata is visible */
-+ } else {
-+ return (0x00) /* sata is missing */
-+ }
-+ }
-+ } /* end of SSLA */
-+} /* end of SEDY */
-+
-+/* SATA Hot Plug Support */
-+Scope(\_GPE) {
-+ Method(_L1F,0x0,NotSerialized) {
-+ if (\_SB.P0PR) {
-+ if (LGreater(\_SB.P0IS,0)) {
-+ sleep(32)
-+ }
-+ Notify(\_SB.PCI0.SAT0.PMRY.PMST, 0x01) /* NOTIFY_DEVICE_CHECK */
-+ store(one, \_SB.P0PR)
-+ }
-+
-+ if (\_SB.P1PR) {
-+ if (LGreater(\_SB.P1IS,0)) {
-+ sleep(32)
-+ }
-+ Notify(\_SB.PCI0.SAT0.PMRY.PSLA, 0x01) /* NOTIFY_DEVICE_CHECK */
-+ store(one, \_SB.P1PR)
-+ }
-+
-+ if (\_SB.P2PR) {
-+ if (LGreater(\_SB.P2IS,0)) {
-+ sleep(32)
-+ }
-+ Notify(\_SB.PCI0.SAT0.SEDY.SMST, 0x01) /* NOTIFY_DEVICE_CHECK */
-+ store(one, \_SB.P2PR)
-+ }
-+
-+ if (\_SB.P3PR) {
-+ if (LGreater(\_SB.P3IS,0)) {
-+ sleep(32)
-+ }
-+ Notify(\_SB.PCI0.SAT0.SEDY.SSLA, 0x01) /* NOTIFY_DEVICE_CHECK */
-+ store(one, \_SB.P3PR)
-+ }
-+ }
-+}
-diff --git a/src/southbridge/amd/sb700/bootblock.c b/src/southbridge/amd/sb700/bootblock.c
-index 67e6434..8f722a8 100644
---- a/src/southbridge/amd/sb700/bootblock.c
-+++ b/src/southbridge/amd/sb700/bootblock.c
-@@ -1,6 +1,7 @@
- /*
- * This file is part of the coreboot project.
- *
-+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering
- * Copyright (C) 2010 Advanced Micro Devices, Inc.
- *
- * This program is free software; you can redistribute it and/or modify
-@@ -35,10 +36,17 @@
- static void sb700_enable_rom(void)
- {
- u8 reg8;
-+ u32 dword;
- pci_devfn_t dev;
-
- dev = PCI_DEV(0, 0x14, 3);
-
-+ /* The LPC settings below work for SPI flash as well;
-+ * the hardware does not distinguish between LPC and SPI flash ROM
-+ * aside from offering additional side-channel access to SPI flash
-+ * via a separate register-based interface.
-+ */
-+
- /* Decode variable LPC ROM address ranges 1 and 2. */
- reg8 = pci_io_read_config8(dev, 0x48);
- reg8 |= (1 << 3) | (1 << 4);
-@@ -52,15 +60,41 @@ static void sb700_enable_rom(void)
-
- /* LPC ROM address range 2: */
- /*
-- * Enable LPC ROM range start at:
-- * 0xfff8(0000): 512KB
-- * 0xfff0(0000): 1MB
-- * 0xffe0(0000): 2MB
-- * 0xffc0(0000): 4MB
-- */
-+ * Enable LPC ROM range start at:
-+ * 0xfff8(0000): 512KB
-+ * 0xfff0(0000): 1MB
-+ * 0xffe0(0000): 2MB
-+ * 0xffc0(0000): 4MB
-+ * 0xff80(0000): 8MB
-+ */
- pci_io_write_config16(dev, 0x6c, 0x10000 - (CONFIG_COREBOOT_ROMSIZE_KB >> 6));
- /* Enable LPC ROM range end at 0xffff(ffff). */
- pci_io_write_config16(dev, 0x6e, 0xffff);
-+
-+ /* SB700 LPC Bridge 0x48h.
-+ * Turn on all LPC IO Port decode enables
-+ */
-+ dword = pci_io_read_config32(dev, 0x44);
-+ dword = 0xffffffff;
-+ pci_io_write_config32(dev, 0x44, dword);
-+
-+ /* SB700 LPC Bridge 0x48h.
-+ * BIT0: Port Enable for SuperIO 0x2E-0x2F
-+ * BIT1: Port Enable for SuperIO 0x4E-0x4F
-+ * BIT4: Port Enable for LPC ROM Address Arrage2 (0x68-0x6C)
-+ * BIT6: Port Enable for RTC IO 0x70-0x73
-+ * BIT21: Port Enable for Port 0x80
-+ */
-+ reg8 = pci_io_read_config8(dev, 0x48);
-+ reg8 |= (1<<0) | (1<<1) | (1<<4) | (1<<6);
-+ pci_io_write_config8(dev, 0x48, reg8);
-+
-+ /* SB700 LPC Bridge 0x4ah.
-+ * BIT4: Port Enable for Port 0x80
-+ */
-+ reg8 = pci_io_read_config8(dev, 0x4a);
-+ reg8 |= (1<<4);
-+ pci_io_write_config8(dev, 0x4a, reg8);
- }
-
- static void bootblock_southbridge_init(void)
-diff --git a/src/southbridge/amd/sb700/early_setup.c b/src/southbridge/amd/sb700/early_setup.c
-index d25599e..de3fa97 100644
---- a/src/southbridge/amd/sb700/early_setup.c
-+++ b/src/southbridge/amd/sb700/early_setup.c
-@@ -2,6 +2,7 @@
- * This file is part of the coreboot project.
- *
- * Copyright (C) 2010 Advanced Micro Devices, Inc.
-+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
-@@ -395,6 +396,15 @@ static void sb700_devices_por_init(void)
- byte |= (1 << 0);
- pci_write_config8(dev, 0xd2, byte);
-
-+ /* set auxiliary smbus iobase and enable controller */
-+ pci_write_config32(dev, 0x58, SMBUS_AUX_IO_BASE | 1);
-+
-+ if (inw(SMBUS_IO_BASE) == 0xFF)
-+ printk(BIOS_INFO, "sb700_devices_por_init(): Primary SMBUS controller I/O not found\n");
-+
-+ if (inw(SMBUS_AUX_IO_BASE) == 0xFF)
-+ printk(BIOS_INFO, "sb700_devices_por_init(): Secondary SMBUS controller I/O not found\n");
-+
- /* KB2RstEnable */
- pci_write_config8(dev, 0x40, 0x44);
-
-@@ -439,6 +449,14 @@ static void sb700_devices_por_init(void)
- /*pci_write_config8(dev, 0x79, 0x4F); */
- pci_write_config8(dev, 0x78, 0xFF);
-
-+ if (IS_ENABLED(CONFIG_SOUTHBRIDGE_AMD_SB700_DISABLE_ISA_DMA)) {
-+ printk(BIOS_DEBUG, "sb700_devices_por_init(): Disabling ISA DMA support\n");
-+ /* Disable LPC ISA DMA Capability */
-+ byte = pci_read_config8(dev, 0x78);
-+ byte &= ~(1 << 0);
-+ pci_write_config8(dev, 0x78, byte);
-+ }
-+
- /* Set smbus iospace enable, I don't know why write 0x04 into reg5 that is reserved */
- pci_write_config16(dev, 0x4, 0x0407);
-
-diff --git a/src/southbridge/amd/sb700/lpc.c b/src/southbridge/amd/sb700/lpc.c
-index a39ec18..0cc1e8b 100644
---- a/src/southbridge/amd/sb700/lpc.c
-+++ b/src/southbridge/amd/sb700/lpc.c
-@@ -2,6 +2,7 @@
- * This file is part of the coreboot project.
- *
- * Copyright (C) 2010 Advanced Micro Devices, Inc.
-+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
-@@ -45,6 +46,8 @@ static void lpc_init(device_t dev)
- u32 dword;
- device_t sm_dev;
-
-+ printk(BIOS_SPEW, "%s\n", __func__);
-+
- /* Enable the LPC Controller */
- sm_dev = dev_find_slot(0, PCI_DEVFN(0x14, 0));
- dword = pci_read_config32(sm_dev, 0x64);
-diff --git a/src/southbridge/amd/sb700/sm.c b/src/southbridge/amd/sb700/sm.c
-index 598ebec..71253b5 100644
---- a/src/southbridge/amd/sb700/sm.c
-+++ b/src/southbridge/amd/sb700/sm.c
-@@ -2,6 +2,7 @@
- * This file is part of the coreboot project.
- *
- * Copyright (C) 2010 Advanced Micro Devices, Inc.
-+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
-@@ -62,11 +63,8 @@ static void sm_init(device_t dev)
- printk(BIOS_INFO, "sm_init().\n");
-
- rev = get_sb700_revision(dev);
-- ioapic_base = (void *)(pci_read_config32(dev, 0x74) & (0xffffffe0)); /* some like mem resource, but does not have enable bit */
-- /* Don't rename APIC ID */
-- /* TODO: We should call setup_ioapic() here. But kernel hangs if cpu is K8.
-- * We need to check out why and change back. */
-- clear_ioapic(ioapic_base);
-+ ioapic_base = (void *)(pci_read_config32(dev, 0x74) & (0xffffffe0)); /* some like mem resource, but does not have enable bit */
-+ setup_ioapic(ioapic_base, 0); /* Don't rename IOAPIC ID. */
-
- /* 2.10 Interrupt Routing/Filtering */
- dword = pci_read_config8(dev, 0x62);
-@@ -132,9 +130,10 @@ static void sm_init(device_t dev)
- get_option(&on, "power_on_after_fail");
- byte = pm_ioread(0x74);
- byte &= ~0x03;
-- if (on) {
-- byte |= 2;
-- }
-+ if (on == 1)
-+ byte |= 0x1; /* Force power on */
-+ else if (on == 2)
-+ byte |= 0x2; /* Use last power state */
- byte |= 1 << 2;
- pm_iowrite(0x74, byte);
- printk(BIOS_INFO, "set power %s after power fail\n", on ? "on" : "off");
-@@ -298,6 +297,10 @@ static void sm_init(device_t dev)
- byte &= ~(1 << 1);
- pm_iowrite(0x59, byte);
-
-+ /* Enable SCI as irq9. */
-+ outb(0x4, 0xC00);
-+ outb(0x9, 0xC01);
-+
- printk(BIOS_INFO, "sm_init() end\n");
-
- /* Enable NbSb virtual channel */
-@@ -388,7 +391,7 @@ static void sb700_sm_read_resources(device_t dev)
- struct resource *res;
-
- /* Get the normal pci resources of this device */
-- /* pci_dev_read_resources(dev); */
-+ pci_dev_read_resources(dev);
-
- /* apic */
- res = new_resource(dev, 0x74);
---
-1.7.9.5
-