mirror of
https://github.com/CloverHackyColor/CloverBootloader.git
synced 2024-11-23 11:35:19 +01:00
7c0aa811ec
Signed-off-by: Sergey Isakov <isakov-sl@bk.ru>
31 lines
648 B
C
31 lines
648 B
C
/** @file
|
|
SpeculationBarrier() function for IA32 and x64.
|
|
|
|
Copyright (C) 2018 - 2019, Intel Corporation. All rights reserved.<BR>
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
/**
|
|
Uses as a barrier to stop speculative execution.
|
|
|
|
Ensures that no later instruction will execute speculatively, until all prior
|
|
instructions have completed.
|
|
|
|
**/
|
|
VOID
|
|
EFIAPI
|
|
SpeculationBarrier (
|
|
VOID
|
|
)
|
|
{
|
|
if (PcdGet8 (PcdSpeculationBarrierType) == 0x01) {
|
|
AsmLfence ();
|
|
} else if (PcdGet8 (PcdSpeculationBarrierType) == 0x02) {
|
|
AsmCpuid (0x01, NULL, NULL, NULL, NULL);
|
|
}
|
|
}
|