/** @file Initializes PCH CIO2 device ACPI data. Copyright (c) 2017, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #include /** Update ASL definitions for CIO2 device. @retval EFI_SUCCESS The function completed successfully **/ EFI_STATUS UpdateCio2AcpiData ( VOID ) { UINT32 Index; PCH_STEPPING PchStep; DEBUG ((DEBUG_INFO, "UpdateCio2AcpiData() Start\n")); PchStep = PchStepping (); //if CIO2 is enabled as ACPI device then update its ACPI data if (PchStep >= PchLpC0) { mPchNvsAreaProtocol.Area->Cio2EnabledAsAcpiDevice = 0; DEBUG ((DEBUG_INFO, "UpdateCio2AcpiData() Cio2 has not been enabled as ACPI device\n")); } else { mPchNvsAreaProtocol.Area->Cio2EnabledAsAcpiDevice = 0; if (mPchConfigHob->Cio2.DeviceEnable == 1) { mPchNvsAreaProtocol.Area->Cio2EnabledAsAcpiDevice = 1; for (Index = 0; Index < mPchConfigHob->Interrupt.NumOfDevIntConfig; Index++) { if ((mPchConfigHob->Interrupt.DevIntConfig[Index].Device == PCI_DEVICE_NUMBER_PCH_CIO2) && (mPchConfigHob->Interrupt.DevIntConfig[Index].Function == PCI_FUNCTION_NUMBER_PCH_CIO2)) { mPchNvsAreaProtocol.Area->Cio2IrqNumber = mPchConfigHob->Interrupt.DevIntConfig[Index].Irq; DEBUG ((DEBUG_INFO, "UpdateCio2AcpiData() Cio2 has been enabled as ACPI device. Irq number = 0x%x\n", mPchConfigHob->Interrupt.DevIntConfig[Index].Irq)); break; } } } } DEBUG ((DEBUG_INFO, "UpdateCio2AcpiData() End\n")); return EFI_SUCCESS; }