File: VariableRuntimeCacheInfo.h

package info (click to toggle)
edk2 2025.11-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 338,556 kB
  • sloc: ansic: 2,166,376; asm: 270,725; perl: 235,301; python: 149,839; sh: 34,744; cpp: 23,311; makefile: 3,326; pascal: 1,602; xml: 806; lisp: 35; ruby: 16; sed: 6; tcl: 4
file content (61 lines) | stat: -rw-r--r-- 1,891 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/** @file
  This Variable Runtime Cache Info HOB is used to store the address
  and the size of the buffer that will be used for variable runtime
  service when the PcdEnableVariableRuntimeCache is TRUE.

  Copyright (c) 2024, Intel Corporation. All rights reserved.<BR>

  SPDX-License-Identifier: BSD-2-Clause-Patent

**/

#ifndef VARIABLE_RUNTIME_CACHE_INFO_H_
#define VARIABLE_RUNTIME_CACHE_INFO_H_

#define VARIABLE_RUNTIME_CACHE_INFO_HOB_REVISION  1

#define VARIABLE_RUNTIME_CACHE_INFO_GUID \
  { \
    0x0f472f7d, 0x6713, 0x4915, {0x96, 0x14, 0x5d, 0xda, 0x28, 0x40, 0x10, 0x56}  \
  }

typedef struct {
  ///
  /// TRUE indicates GetVariable () or GetNextVariable () is being called.
  /// When the value is FALSE, the given update (and any other pending updates)
  /// can be flushed to the runtime cache.
  ///
  BOOLEAN    ReadLock;
  ///
  /// TRUE indicates there is pending update for the given variable store needed
  /// to be flushed to the runtime cache.
  ///
  BOOLEAN    PendingUpdate;
  ///
  /// TRUE indicates all HOB variables have been flushed in flash.
  ///
  BOOLEAN    HobFlushComplete;
} CACHE_INFO_FLAG;

typedef struct {
  EFI_PHYSICAL_ADDRESS    CacheInfoFlagBuffer;
  ///
  /// Base address of the runtime Hob variable cache Buffer.
  ///
  EFI_PHYSICAL_ADDRESS    RuntimeHobCacheBuffer;
  UINT64                  RuntimeHobCachePages;
  ///
  /// Base address of the non-volatile variable runtime cache Buffer.
  ///
  EFI_PHYSICAL_ADDRESS    RuntimeNvCacheBuffer;
  UINT64                  RuntimeNvCachePages;
  ///
  /// Base address of the volatile variable runtime cache Buffer.
  ///
  EFI_PHYSICAL_ADDRESS    RuntimeVolatileCacheBuffer;
  UINT64                  RuntimeVolatileCachePages;
} VARIABLE_RUNTIME_CACHE_INFO;

extern EFI_GUID  gEdkiiVariableRuntimeCacheInfoHobGuid;

#endif