Skip to content

Commit

Permalink
use RT instead of RS
Browse files Browse the repository at this point in the history
Signed-off-by: Sergey Isakov <[email protected]>
  • Loading branch information
SergeySlice committed Feb 16, 2020
1 parent d836611 commit 60b6eb5
Show file tree
Hide file tree
Showing 9 changed files with 74 additions and 55 deletions.
2 changes: 1 addition & 1 deletion Include/Library/GenericBdsLib.h
Original file line number Diff line number Diff line change
Expand Up @@ -352,7 +352,7 @@ BdsLibVariableToOption (
@retval EFI_SUCCESS The boot#### or driver#### have been successfully
registered.
@retval EFI_STATUS Return the status of gRS->SetVariable ().
@retval EFI_STATUS Return the status of gRT->SetVariable ().
**/
EFI_STATUS
Expand Down
78 changes: 39 additions & 39 deletions rEFIt_UEFI/Platform/DataHubCpu.c
Original file line number Diff line number Diff line change
Expand Up @@ -138,43 +138,43 @@ LogDataHub(IN EFI_GUID *TypeGuid,
}

// SetVariablesForOSX
/** Installs our runtime services overrides. */
/** Original runtime services. */
EFI_RUNTIME_SERVICES gOrgRS;

EFI_STATUS EFIAPI
OvrSetVariable(
IN CHAR16 *VariableName,
IN EFI_GUID *VendorGuid,
IN UINT32 Attributes,
IN UINTN DataSize,
IN VOID *Data
)
{
EFI_STATUS Status;
UINTN i;

for (i = 0; i < RtVariablesNum; i++) {
if (!CompareGuid(&RtVariables[i].VarGuid, VendorGuid)) {
continue;
}
if (!RtVariables[i].Name || RtVariables[i].Name[0] == L'*' || StrCmp(VariableName, RtVariables[i].Name) == 0) {
return EFI_SUCCESS;
}
}
Status = gOrgRS.SetVariable(VariableName, VendorGuid, Attributes, DataSize, Data);
return Status;
}

EFI_STATUS EFIAPI
OvrRuntimeServices(EFI_RUNTIME_SERVICES *RS)
{
EFI_STATUS Status;
CopyMem(&gOrgRS, RS, sizeof(EFI_RUNTIME_SERVICES));
RS->SetVariable = OvrSetVariable;
RS->Hdr.CRC32 = 0;
Status = gBS->CalculateCrc32(RS, RS->Hdr.HeaderSize, &RS->Hdr.CRC32);
return Status;
/** Installs our runtime services overrides. */
/** Original runtime services. */
EFI_RUNTIME_SERVICES gOrgRS;

EFI_STATUS EFIAPI
OvrSetVariable(
IN CHAR16 *VariableName,
IN EFI_GUID *VendorGuid,
IN UINT32 Attributes,
IN UINTN DataSize,
IN VOID *Data
)
{
EFI_STATUS Status;
UINTN i;

for (i = 0; i < RtVariablesNum; i++) {
if (!CompareGuid(&RtVariables[i].VarGuid, VendorGuid)) {
continue;
}
if (!RtVariables[i].Name || RtVariables[i].Name[0] == L'*' || StrCmp(VariableName, RtVariables[i].Name) == 0) {
return EFI_SUCCESS;
}
}
Status = gOrgRS.SetVariable(VariableName, VendorGuid, Attributes, DataSize, Data);
return Status;
}

EFI_STATUS EFIAPI
OvrRuntimeServices(EFI_RUNTIME_SERVICES *RS)
{
EFI_STATUS Status;
CopyMem(&gOrgRS, RS, sizeof(EFI_RUNTIME_SERVICES));
RS->SetVariable = OvrSetVariable;
RS->Hdr.CRC32 = 0;
Status = gBS->CalculateCrc32(RS, RS->Hdr.HeaderSize, &RS->Hdr.CRC32);
return Status;
}

/// Sets the volatile and non-volatile variables used by OS X
Expand All @@ -198,8 +198,8 @@ SetVariablesForOSX(LOADER_ENTRY *Entry)
//
// firmware Variables
//
if (RtVariablesNum > 0) {
OvrRuntimeServices(gRS);
if (RtVariablesNum > 0) {
OvrRuntimeServices(gRT);
}

// As found on a real Mac, the system-id variable solely has the BS flag
Expand Down
4 changes: 2 additions & 2 deletions rEFIt_UEFI/Platform/LegacyBoot.c
Original file line number Diff line number Diff line change
Expand Up @@ -701,7 +701,7 @@ EFI_STATUS bootPBRtest(REFIT_VOLUME* volume)
Facs = (EFI_ACPI_4_0_FIRMWARE_ACPI_CONTROL_STRUCTURE*)(UINTN)(FadtPointer->FirmwareCtrl);
Facs->FirmwareWakingVector = 0x7F00;

gRS->ResetSystem(EfiResetWarm, EFI_SUCCESS, 0, NULL);
gRT->ResetSystem(EfiResetWarm, EFI_SUCCESS, 0, NULL);


/*
Expand Down Expand Up @@ -731,7 +731,7 @@ if (FadtPointer == NULL) {
Facs = (EFI_ACPI_4_0_FIRMWARE_ACPI_CONTROL_STRUCTURE*)(UINTN)(FadtPointer->FirmwareCtrl);
Facs->FirmwareWakingVector = 0x7F00;
gRS->ResetSystem(EfiResetWarm, EFI_SUCCESS, 0, NULL);
gRT->ResetSystem(EfiResetWarm, EFI_SUCCESS, 0, NULL);
*/

#define EFI_CPU_EFLAGS_IF 0x200
Expand Down
2 changes: 1 addition & 1 deletion rEFIt_UEFI/Platform/Nvram.c
Original file line number Diff line number Diff line change
Expand Up @@ -1063,7 +1063,7 @@ PutNvramPlistToRtVars ()
}

// set RT var: all vars visible in nvram.plist are gEfiAppleBootGuid
/* Status = gRS->SetVariable (
/* Status = gRT->SetVariable (
KeyBuf,
VendorGuid,
EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_RUNTIME_ACCESS,
Expand Down
2 changes: 1 addition & 1 deletion rEFIt_UEFI/Platform/Pointer.c
Original file line number Diff line number Diff line change
Expand Up @@ -230,7 +230,7 @@ VOID UpdatePointer()
INTN ScreenRelX;
INTN ScreenRelY;

// Now = gRS->GetTime(&Now, NULL);
// Now = gRT->GetTime(&Now, NULL);
Now = AsmReadTsc();
Status = gPointer.SimplePointerProtocol->GetState(gPointer.SimplePointerProtocol, &tmpState);
if (!EFI_ERROR(Status)) {
Expand Down
2 changes: 1 addition & 1 deletion rEFIt_UEFI/refit/lib.h
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@
extern EFI_HANDLE gImageHandle;
extern EFI_SYSTEM_TABLE* gST;
extern EFI_BOOT_SERVICES* gBS;
extern EFI_RUNTIME_SERVICES* gRS;
extern EFI_RUNTIME_SERVICES* gRT;

#define TAG_ABOUT (1)
#define TAG_RESET (2)
Expand Down
22 changes: 13 additions & 9 deletions rEFIt_UEFI/refit/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ BOOLEAN APFSSupport = FALSE;
//extern EFI_SYSTEM_TABLE* gST;
//extern EFI_BOOT_SERVICES* gBS;
//extern EFI_DXE_SERVICES* gDS;
EFI_RUNTIME_SERVICES* gRS;
//EFI_RUNTIME_SERVICES* gRS;

DRIVERS_FLAGS gDriversFlags; //the initializer is not needed for global variables

Expand Down Expand Up @@ -121,7 +121,9 @@ extern HDA_OUTPUTS AudioList[20];
extern CHAR8 *AudioOutputNames[];
extern EFI_AUDIO_IO_PROTOCOL *AudioIo;

#ifdef __cplusplus
}
#endif

static EFI_STATUS LoadEFIImageList(IN EFI_DEVICE_PATH **DevicePaths,
IN CHAR16 *ImageTitle,
Expand Down Expand Up @@ -1774,9 +1776,9 @@ VOID ResetNvram ()
}

// Attempt warm reboot
// gRS->ResetSystem(EfiResetWarm, EFI_SUCCESS, 0, NULL);
// gRT->ResetSystem(EfiResetWarm, EFI_SUCCESS, 0, NULL);
// Warm reboot may not be supported attempt cold reboot
// gRS->ResetSystem(EfiResetCold, EFI_SUCCESS, 0, NULL);
// gRT->ResetSystem(EfiResetCold, EFI_SUCCESS, 0, NULL);
// Terminate the screen and just exit
// TerminateScreen();
}
Expand Down Expand Up @@ -2071,13 +2073,13 @@ RefitMain (IN EFI_HANDLE ImageHandle,
gST = SystemTable;
gImageHandle = ImageHandle;
gBS = SystemTable->BootServices;
gRS = SystemTable->RuntimeServices;
gRT = SystemTable->RuntimeServices;
/*Status = */EfiGetSystemConfigurationTable (&gEfiDxeServicesTableGuid, (VOID **) &gDS);

ConsoleInHandle = SystemTable->ConsoleInHandle;


gRS->GetTime(&Now, NULL);
gRT->GetTime(&Now, NULL);

// firmware detection
gFirmwareClover = StrCmp(gST->FirmwareVendor, L"CLOVER") == 0;
Expand Down Expand Up @@ -2782,9 +2784,9 @@ destruct_globals_objects(NULL); // That should be done just before quitting clov
// }
}
// Attempt warm reboot
gRS->ResetSystem(EfiResetWarm, EFI_SUCCESS, 0, NULL);
gRT->ResetSystem(EfiResetWarm, EFI_SUCCESS, 0, NULL);
// Warm reboot may not be supported attempt cold reboot
gRS->ResetSystem(EfiResetCold, EFI_SUCCESS, 0, NULL);
gRT->ResetSystem(EfiResetCold, EFI_SUCCESS, 0, NULL);
// Terminate the screen and just exit
TerminateScreen();
MainLoopRunning = FALSE;
Expand All @@ -2794,7 +2796,7 @@ destruct_globals_objects(NULL); // That should be done just before quitting clov

case TAG_SHUTDOWN: // It is not Shut Down, it is Exit from Clover
TerminateScreen();
// gRS->ResetSystem(EfiResetShutdown, EFI_SUCCESS, 0, NULL);
// gRT->ResetSystem(EfiResetShutdown, EFI_SUCCESS, 0, NULL);
MainLoopRunning = FALSE; // just in case we get this far
ReinitDesktop = FALSE;
AfterTool = TRUE;
Expand Down Expand Up @@ -2983,7 +2985,7 @@ destruct_globals_objects(NULL); // That should be done just before quitting clov
// If we end up here, things have gone wrong. Try to reboot, and if that
// fails, go into an endless loop.
//Slice - NO!!! Return to EFI GUI
// gRS->ResetSystem(EfiResetCold, EFI_SUCCESS, 0, NULL);
// gRT->ResetSystem(EfiResetCold, EFI_SUCCESS, 0, NULL);
// EndlessIdleLoop();

#ifdef ENABLE_SECURE_BOOT
Expand All @@ -2997,3 +2999,5 @@ destruct_globals_objects(NULL); // That should be done just before quitting clov
}
return EFI_SUCCESS;
}


15 changes: 15 additions & 0 deletions rEFIt_UEFI/refit/menu.c → rEFIt_UEFI/refit/menu.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,16 @@
//#include "Platform.h"
#include "libegint.h" //this includes platform.h
//#include "../include/scroll_images.h"

//#include "../Platform/Platform.h"
#include "../cpp_util/XStringW.h"
#include "../cpp_util/globals_ctor.h"
#include "../cpp_util/globals_dtor.h"

#ifdef __cplusplus
extern "C" {
#endif

#include "Version.h"
//#include "colors.h"

Expand Down Expand Up @@ -5704,3 +5714,8 @@ UINTN RunMainMenu(IN REFIT_MENU_SCREEN *Screen, IN INTN DefaultSelection, OUT RE
}
return MenuExit;
}

#ifdef __cplusplus
}
#endif

2 changes: 1 addition & 1 deletion rEFIt_UEFI/refit_cpp.inf
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@
refit/icns.c
refit/lib.c
refit/lib.h
refit/menu.c
refit/menu.cpp
refit/screen.c
refit/IO.c
refit/IO.h
Expand Down

0 comments on commit 60b6eb5

Please sign in to comment.