mirror of https://github.com/acidanthera/audk.git
36 lines
1.1 KiB
C
36 lines
1.1 KiB
C
/** @file
|
|
ARM implementation of architecture specific routines related to
|
|
PersistAcrossReset capsules
|
|
|
|
Copyright (c) 2018, Linaro, Ltd. All rights reserved.<BR>
|
|
Copyright (c) 2019, Intel Corporation. All rights reserved.<BR>
|
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
|
|
**/
|
|
|
|
#include "CapsuleService.h"
|
|
|
|
/**
|
|
Whether the platform supports capsules that persist across reset. Note that
|
|
some platforms only support such capsules at boot time.
|
|
|
|
@return TRUE if a PersistAcrossReset capsule may be passed to UpdateCapsule()
|
|
at this time
|
|
FALSE otherwise
|
|
**/
|
|
BOOLEAN
|
|
IsPersistAcrossResetCapsuleSupported (
|
|
VOID
|
|
)
|
|
{
|
|
//
|
|
// ARM requires the capsule payload to be cleaned to the point of coherency
|
|
// (PoC), but only permits doing so using cache maintenance instructions that
|
|
// operate on virtual addresses. Since at runtime, we don't know the virtual
|
|
// addresses of the data structures that make up the scatter/gather list, we
|
|
// cannot perform the maintenance, and all we can do is give up.
|
|
//
|
|
return FeaturePcdGet (PcdSupportUpdateCapsuleReset) && !EfiAtRuntime ();
|
|
}
|