2019-03-22 04:07:17 +01:00
|
|
|
/** @file
|
|
|
|
Flush the cache is required for most architectures while do capsule
|
|
|
|
update. It is not support at Runtime.
|
|
|
|
|
|
|
|
Copyright (c) 2018, Linaro, Ltd. All rights reserved.<BR>
|
|
|
|
Copyright (c) 2019, Intel Corporation. All rights reserved.<BR>
|
|
|
|
|
2019-04-04 01:05:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2019-03-22 04:07:17 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "CapsuleService.h"
|
|
|
|
|
|
|
|
#include <Library/CacheMaintenanceLib.h>
|
|
|
|
|
|
|
|
/**
|
|
|
|
Writes Back a range of data cache lines covering a set of capsules in memory.
|
|
|
|
|
|
|
|
Writes Back the data cache lines specified by ScatterGatherList.
|
|
|
|
|
|
|
|
@param ScatterGatherList Physical address of the data structure that
|
|
|
|
describes a set of capsules in memory
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
CapsuleCacheWriteBack (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN EFI_PHYSICAL_ADDRESS ScatterGatherList
|
2019-03-22 04:07:17 +01:00
|
|
|
)
|
|
|
|
{
|
2021-12-05 23:54:02 +01:00
|
|
|
EFI_CAPSULE_BLOCK_DESCRIPTOR *Desc;
|
2019-03-22 04:07:17 +01:00
|
|
|
|
|
|
|
if (!EfiAtRuntime ()) {
|
|
|
|
Desc = (EFI_CAPSULE_BLOCK_DESCRIPTOR *)(UINTN)ScatterGatherList;
|
|
|
|
do {
|
|
|
|
WriteBackDataCacheRange (
|
|
|
|
(VOID *)(UINTN)Desc,
|
|
|
|
(UINTN)sizeof (*Desc)
|
|
|
|
);
|
|
|
|
|
|
|
|
if (Desc->Length > 0) {
|
|
|
|
WriteBackDataCacheRange (
|
|
|
|
(VOID *)(UINTN)Desc->Union.DataBlock,
|
|
|
|
(UINTN)Desc->Length
|
|
|
|
);
|
|
|
|
Desc++;
|
|
|
|
} else if (Desc->Union.ContinuationPointer > 0) {
|
|
|
|
Desc = (EFI_CAPSULE_BLOCK_DESCRIPTOR *)(UINTN)Desc->Union.ContinuationPointer;
|
|
|
|
}
|
|
|
|
} while (Desc->Length > 0 || Desc->Union.ContinuationPointer > 0);
|
|
|
|
|
|
|
|
WriteBackDataCacheRange (
|
|
|
|
(VOID *)(UINTN)Desc,
|
|
|
|
(UINTN)sizeof (*Desc)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|