From 836c825cf64ca43e4a8c1f7a558563a8d46d7471 Mon Sep 17 00:00:00 2001 From: lushifex Date: Wed, 10 May 2017 14:18:07 +0800 Subject: Fixed reconnect -r issue. System will hang up when run reconnect -r with SD Card insert. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: lushifex --- .../PlatformSettings/PlatformDxe/PciDevice.c | 33 +++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) (limited to 'Platform/BroxtonPlatformPkg/Common/PlatformSettings') diff --git a/Platform/BroxtonPlatformPkg/Common/PlatformSettings/PlatformDxe/PciDevice.c b/Platform/BroxtonPlatformPkg/Common/PlatformSettings/PlatformDxe/PciDevice.c index b8645a2771..8c1c621e0b 100644 --- a/Platform/BroxtonPlatformPkg/Common/PlatformSettings/PlatformDxe/PciDevice.c +++ b/Platform/BroxtonPlatformPkg/Common/PlatformSettings/PlatformDxe/PciDevice.c @@ -1,7 +1,7 @@ /** @file Platform PCI Bus Initialization Driver. - Copyright (c) 1999 - 2016, Intel Corporation. All rights reserved.
+ Copyright (c) 1999 - 2017, Intel Corporation. All rights reserved.
This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License @@ -405,6 +405,8 @@ PciBusEvent ( UINTN Index; UINT8 mCacheLineSize = 0x10; UINTN Seg, Bus, Dev, Fun; + UINT32 AcpiIoPortBaseAddr; + UINT32 CmdValue; while (TRUE) { BufferSize = sizeof (EFI_HANDLE); @@ -448,6 +450,35 @@ PciBusEvent ( // Status = PciIo->GetLocation (PciIo, &Seg, &Bus, &Dev, &Fun); if ((Seg ==0) && (Bus == 0) && (Dev == 13) && (Fun == 1)) { + // + // Set PMC acpi io port address + // + AcpiIoPortBaseAddr = (UINT32) PcdGet16 (PcdScAcpiIoPortBaseAddress); + PciIo->Pci.Write ( + PciIo, + EfiPciIoWidthUint32, + 0x20, + 1, + &AcpiIoPortBaseAddr + ); + + PciIo->Pci.Read ( + PciIo, + EfiPciIoWidthUint8, + PCI_COMMAND_OFFSET, + 1, + &CmdValue + ); + + CmdValue |= BIT0; + PciIo->Pci.Write ( + PciIo, + EfiPciIoWidthUint8, + PCI_COMMAND_OFFSET, + 1, + &CmdValue + ); + Supports |= BIT0; } // -- cgit v1.2.3