mirror of https://github.com/acidanthera/audk.git
OvmfPkg/SmmControl2Dxe: negotiate ICH9_LPC_SMI_F_CPU_HOTPLUG
The ICH9_LPC_SMI_F_BROADCAST and ICH9_LPC_SMI_F_CPU_HOTPLUG feature flags cause QEMU to behave as follows: BROADCAST CPU_HOTPLUG use case / behavior --------- ----------- ------------------------------------------------ clear clear OVMF built without SMM_REQUIRE; or very old OVMF (from before commita316d7ac91
/ 2017-02-07). QEMU permits CPU hotplug operations, and does not cause the OS to inject an SMI upon hotplug. Firmware is not expected to be aware of hotplug events. clear set Invalid feature set; QEMU rejects the feature negotiation. set clear OVMF aftera316d7ac91
/ 2017-02-07, built with SMM_REQUIRE, but no support for CPU hotplug. QEMU gracefully refuses hotplug operations. set set OVMF aftera316d7ac91
/ 2017-02-07, built with SMM_REQUIRE, and supporting CPU hotplug. QEMU permits CPU hotplug operations, and causes the OS to inject an SMI upon hotplug. Firmware is expected to deal with hotplug events. Negotiate ICH9_LPC_SMI_F_CPU_HOTPLUG -- but only if SEV is disabled, as OvmfPkg/CpuHotplugSmm can't deal with SEV yet. Cc: Ard Biesheuvel <ard.biesheuvel@arm.com> Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com> Cc: Igor Mammedov <imammedo@redhat.com> Cc: Jordan Justen <jordan.l.justen@intel.com> Cc: Liran Alon <liran.alon@oracle.com> Cc: Philippe Mathieu-Daudé <philmd@redhat.com> Signed-off-by: Laszlo Ersek <lersek@redhat.com> Message-Id: <20200714184305.9814-1-lersek@redhat.com> Acked-by: Ard Biesheuvel <ard.biesheuvel@arm.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
This commit is contained in:
parent
4535fc312b
commit
5ba203b54e
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include <Library/BaseLib.h>
|
#include <Library/BaseLib.h>
|
||||||
#include <Library/DebugLib.h>
|
#include <Library/DebugLib.h>
|
||||||
|
#include <Library/MemEncryptSevLib.h>
|
||||||
#include <Library/MemoryAllocationLib.h>
|
#include <Library/MemoryAllocationLib.h>
|
||||||
#include <Library/PcdLib.h>
|
#include <Library/PcdLib.h>
|
||||||
#include <Library/QemuFwCfgLib.h>
|
#include <Library/QemuFwCfgLib.h>
|
||||||
|
@ -21,6 +22,12 @@
|
||||||
// "etc/smi/supported-features" and "etc/smi/requested-features" fw_cfg files.
|
// "etc/smi/supported-features" and "etc/smi/requested-features" fw_cfg files.
|
||||||
//
|
//
|
||||||
#define ICH9_LPC_SMI_F_BROADCAST BIT0
|
#define ICH9_LPC_SMI_F_BROADCAST BIT0
|
||||||
|
//
|
||||||
|
// The following bit value stands for "enable CPU hotplug, and inject an SMI
|
||||||
|
// with control value ICH9_APM_CNT_CPU_HOTPLUG upon hotplug", in the
|
||||||
|
// "etc/smi/supported-features" and "etc/smi/requested-features" fw_cfg files.
|
||||||
|
//
|
||||||
|
#define ICH9_LPC_SMI_F_CPU_HOTPLUG BIT1
|
||||||
|
|
||||||
//
|
//
|
||||||
// Provides a scratch buffer (allocated in EfiReservedMemoryType type memory)
|
// Provides a scratch buffer (allocated in EfiReservedMemoryType type memory)
|
||||||
|
@ -67,6 +74,7 @@ NegotiateSmiFeatures (
|
||||||
UINTN SupportedFeaturesSize;
|
UINTN SupportedFeaturesSize;
|
||||||
UINTN RequestedFeaturesSize;
|
UINTN RequestedFeaturesSize;
|
||||||
UINTN FeaturesOkSize;
|
UINTN FeaturesOkSize;
|
||||||
|
UINT64 RequestedFeaturesMask;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Look up the fw_cfg files used for feature negotiation. The selector keys
|
// Look up the fw_cfg files used for feature negotiation. The selector keys
|
||||||
|
@ -104,9 +112,16 @@ NegotiateSmiFeatures (
|
||||||
QemuFwCfgReadBytes (sizeof mSmiFeatures, &mSmiFeatures);
|
QemuFwCfgReadBytes (sizeof mSmiFeatures, &mSmiFeatures);
|
||||||
|
|
||||||
//
|
//
|
||||||
// We want broadcast SMI and nothing else.
|
// We want broadcast SMI, SMI on CPU hotplug, and nothing else.
|
||||||
//
|
//
|
||||||
mSmiFeatures &= ICH9_LPC_SMI_F_BROADCAST;
|
RequestedFeaturesMask = ICH9_LPC_SMI_F_BROADCAST;
|
||||||
|
if (!MemEncryptSevIsEnabled ()) {
|
||||||
|
//
|
||||||
|
// For now, we only support hotplug with SEV disabled.
|
||||||
|
//
|
||||||
|
RequestedFeaturesMask |= ICH9_LPC_SMI_F_CPU_HOTPLUG;
|
||||||
|
}
|
||||||
|
mSmiFeatures &= RequestedFeaturesMask;
|
||||||
QemuFwCfgSelectItem (mRequestedFeaturesItem);
|
QemuFwCfgSelectItem (mRequestedFeaturesItem);
|
||||||
QemuFwCfgWriteBytes (sizeof mSmiFeatures, &mSmiFeatures);
|
QemuFwCfgWriteBytes (sizeof mSmiFeatures, &mSmiFeatures);
|
||||||
|
|
||||||
|
@ -144,6 +159,13 @@ NegotiateSmiFeatures (
|
||||||
DEBUG ((DEBUG_INFO, "%a: using SMI broadcast\n", __FUNCTION__));
|
DEBUG ((DEBUG_INFO, "%a: using SMI broadcast\n", __FUNCTION__));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((mSmiFeatures & ICH9_LPC_SMI_F_CPU_HOTPLUG) == 0) {
|
||||||
|
DEBUG ((DEBUG_INFO, "%a: CPU hotplug not negotiated\n", __FUNCTION__));
|
||||||
|
} else {
|
||||||
|
DEBUG ((DEBUG_INFO, "%a: CPU hotplug with SMI negotiated\n",
|
||||||
|
__FUNCTION__));
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Negotiation successful (although we may not have gotten the optimal
|
// Negotiation successful (although we may not have gotten the optimal
|
||||||
// feature set).
|
// feature set).
|
||||||
|
|
|
@ -46,6 +46,7 @@
|
||||||
BaseLib
|
BaseLib
|
||||||
DebugLib
|
DebugLib
|
||||||
IoLib
|
IoLib
|
||||||
|
MemEncryptSevLib
|
||||||
MemoryAllocationLib
|
MemoryAllocationLib
|
||||||
PcdLib
|
PcdLib
|
||||||
PciLib
|
PciLib
|
||||||
|
|
Loading…
Reference in New Issue