2020-04-16 09:15:26 +02:00
|
|
|
/*
|
|
|
|
* Nvram.h
|
|
|
|
*
|
|
|
|
* Created on: 16 Apr 2020
|
|
|
|
* Author: jief
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PLATFORM_NVRAM_H_
|
|
|
|
#define PLATFORM_NVRAM_H_
|
|
|
|
|
2020-04-16 11:09:22 +02:00
|
|
|
#define NON_APPLE_SMC_SIGNATURE SIGNATURE_64('S','M','C','H','E','L','P','E')
|
|
|
|
|
2020-04-27 11:50:49 +02:00
|
|
|
#include "../cpp_foundation/XString.h"
|
2020-04-16 11:09:22 +02:00
|
|
|
|
2020-04-16 09:15:26 +02:00
|
|
|
extern EFI_GUID *gEfiBootDeviceGuid;
|
|
|
|
extern EFI_DEVICE_PATH_PROTOCOL *gEfiBootDeviceData;
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-02-29 08:30:21 +01:00
|
|
|
|
|
|
|
INTN
|
|
|
|
FindStartupDiskVolume (
|
|
|
|
REFIT_MENU_SCREEN *MainMenu
|
|
|
|
);
|
2020-04-16 09:15:26 +02:00
|
|
|
|
|
|
|
VOID
|
2020-04-28 12:49:24 +02:00
|
|
|
*GetNvramVariable(
|
2020-08-15 15:47:56 +02:00
|
|
|
IN CONST CHAR16 *VariableName,
|
|
|
|
IN EFI_GUID *VendorGuid,
|
|
|
|
OUT UINT32 *Attributes OPTIONAL,
|
|
|
|
OUT UINTN *DataSize OPTIONAL
|
|
|
|
);
|
|
|
|
XString8 GetNvramVariableAsXString8(
|
|
|
|
IN CONST CHAR16 *VariableName,
|
|
|
|
IN EFI_GUID *VendorGuid,
|
|
|
|
OUT UINT32 *Attributes OPTIONAL,
|
|
|
|
OUT UINTN *DataSize OPTIONAL
|
|
|
|
);
|
2020-04-16 09:15:26 +02:00
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
AddNvramVariable (
|
|
|
|
IN CONST CHAR16 *VariableName,
|
|
|
|
IN EFI_GUID *VendorGuid,
|
|
|
|
IN UINT32 Attributes,
|
|
|
|
IN UINTN DataSize,
|
|
|
|
IN VOID *Data
|
|
|
|
);
|
2020-08-15 15:47:56 +02:00
|
|
|
EFI_STATUS
|
|
|
|
AddNvramXString8 (
|
|
|
|
IN CONST CHAR16 *VariableName,
|
|
|
|
IN EFI_GUID *VendorGuid,
|
|
|
|
IN UINT32 Attributes,
|
|
|
|
const XString8& s
|
|
|
|
);
|
2020-04-16 09:15:26 +02:00
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
SetNvramVariable (
|
|
|
|
IN CONST CHAR16 *VariableName,
|
|
|
|
IN EFI_GUID *VendorGuid,
|
|
|
|
IN UINT32 Attributes,
|
|
|
|
IN UINTN DataSize,
|
|
|
|
IN CONST VOID *Data
|
|
|
|
);
|
2020-08-15 15:47:56 +02:00
|
|
|
EFI_STATUS
|
|
|
|
SetNvramXString8 (
|
|
|
|
IN CONST CHAR16 *VariableName,
|
|
|
|
IN EFI_GUID *VendorGuid,
|
|
|
|
IN UINT32 Attributes,
|
|
|
|
const XString8& s
|
|
|
|
);
|
2020-04-16 09:15:26 +02:00
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
DeleteNvramVariable (
|
|
|
|
IN CONST CHAR16 *VariableName,
|
|
|
|
IN EFI_GUID *VendorGuid
|
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
ResetNvram (VOID);
|
|
|
|
|
|
|
|
BOOLEAN
|
|
|
|
IsDeletableVariable (
|
|
|
|
IN CHAR16 *Name,
|
|
|
|
IN EFI_GUID *Guid
|
|
|
|
);
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
ResetNativeNvram (VOID);
|
|
|
|
;
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
GetEfiBootDeviceFromNvram (VOID);
|
|
|
|
|
|
|
|
EFI_GUID
|
|
|
|
*FindGPTPartitionGuidInDevicePath (
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *DevicePath
|
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
PutNvramPlistToRtVars (VOID);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
GetSmcKeys(BOOLEAN WriteToSMC);
|
2020-07-14 09:51:12 +02:00
|
|
|
#if CHECK_SMC
|
|
|
|
VOID DumpSmcKeys();
|
|
|
|
#endif
|
2020-04-16 09:15:26 +02:00
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
SetStartupDiskVolume (
|
|
|
|
IN REFIT_VOLUME *Volume,
|
2020-04-27 11:50:49 +02:00
|
|
|
IN CONST XStringW& LoaderPath
|
2020-04-16 09:15:26 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
RemoveStartupDiskVolume (VOID);
|
|
|
|
|
|
|
|
UINT64
|
|
|
|
GetEfiTimeInMs (IN EFI_TIME *T);
|
|
|
|
|
|
|
|
#endif /* PLATFORM_NVRAM_H_ */
|