#include "menu.h"
#include "mok.h"
#include "gpt.h"
+#include "apple.h"
#include "security_policy.h"
#include "driver_support.h"
#include "../include/Handle.h"
REFIT_MENU_ENTRY MenuEntryReturn = { L"Return to Main Menu", TAG_RETURN, 1, 0, 0, NULL, NULL, NULL };
static REFIT_MENU_ENTRY MenuEntryExit = { L"Exit rEFInd", TAG_EXIT, 1, 0, 0, NULL, NULL, NULL };
static REFIT_MENU_ENTRY MenuEntryFirmware = { L"Reboot to Computer Setup Utility", TAG_FIRMWARE, 1, 0, 0, NULL, NULL, NULL };
+static REFIT_MENU_ENTRY MenuEntryRotateCsr = { L"Change SIP Policy", TAG_CSR_ROTATE, 1, 0, 0, NULL, NULL, NULL };
REFIT_MENU_SCREEN MainMenu = { L"Main Menu", NULL, 0, NULL, 0, NULL, 0, L"Automatic boot",
L"Use arrow keys to move cursor; Enter to boot;",
20, 0, 0, GRAPHICS_FOR_OSX, LEGACY_TYPE_MAC,
0, 0, { DEFAULT_BIG_ICON_SIZE / 4, DEFAULT_SMALL_ICON_SIZE, DEFAULT_BIG_ICON_SIZE },
BANNER_NOSCALE, NULL, NULL, NULL, NULL, CONFIG_FILE_NAME, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
{ TAG_SHELL, TAG_MEMTEST, TAG_GDISK, TAG_APPLE_RECOVERY, TAG_WINDOWS_RECOVERY,
TAG_MOK_TOOL, TAG_ABOUT, TAG_SHUTDOWN, TAG_REBOOT, TAG_FIRMWARE,
0, 0, 0, 0, 0, 0, 0, 0 }
static VOID AboutrEFInd(VOID)
{
- CHAR16 *FirmwareVendor;
+ CHAR16 *FirmwareVendor;
+ UINT32 CsrStatus;
if (AboutMenu.EntryCount == 0) {
AboutMenu.TitleImage = BuiltinIcon(BUILTIN_ICON_FUNC_ABOUT);
- AddMenuInfoLine(&AboutMenu, L"rEFInd Version 0.9.2.2");
+ AddMenuInfoLine(&AboutMenu, L"rEFInd Version 0.10.0");
AddMenuInfoLine(&AboutMenu, L"");
AddMenuInfoLine(&AboutMenu, L"Copyright (c) 2006-2010 Christoph Pfisterer");
AddMenuInfoLine(&AboutMenu, L"Copyright (c) 2012-2015 Roderick W. Smith");
#else
AddMenuInfoLine(&AboutMenu, L" Platform: unknown");
#endif
+ if (GetCsrStatus(&CsrStatus) == EFI_SUCCESS) {
+ RecordgCsrStatus(CsrStatus, FALSE);
+ AddMenuInfoLine(&AboutMenu, gCsrStatus);
+ }
FirmwareVendor = StrDuplicate(ST->FirmwareVendor);
LimitStringLength(FirmwareVendor, MAX_LINE_LENGTH); // More than ~65 causes empty info page on 800x600 display
AddMenuInfoLine(&AboutMenu, PoolPrint(L" Firmware: %s %d.%02d", FirmwareVendor, ST->FirmwareRevision >> 16,
UINTN i, j, VolumeIndex;
UINT64 osind;
CHAR8 *b = 0;
+ UINT32 CsrValue;
MokLocations = StrDuplicate(MOK_LOCATIONS);
if (MokLocations != NULL)
FindTool(MokLocations, MOK_NAMES, L"MOK utility", BUILTIN_ICON_TOOL_MOK_TOOL);
break;
+ case TAG_CSR_ROTATE:
+ if ((GetCsrStatus(&CsrValue) == EFI_SUCCESS) && (GlobalConfig.CsrValues)) {
+ TempMenuEntry = CopyMenuEntry(&MenuEntryRotateCsr);
+ TempMenuEntry->Image = BuiltinIcon(BUILTIN_ICON_FUNC_CSR_ROTATE);
+ AddMenuEntry(&MainMenu, TempMenuEntry);
+ } // if
+ break;
+
case TAG_MEMTEST:
FindTool(MEMTEST_LOCATIONS, MEMTEST_NAMES, L"Memory test utility", BUILTIN_ICON_TOOL_MEMTEST);
break;
} // if
} // VOID SetConfigFilename()
-
-#define EFI_APPLE_SET_OS_PROTOCOL_GUID \
- { 0xc5c5da95, 0x7d5c, 0x45e6, \
- { 0xb2, 0xf1, 0x3f, 0xd5, 0x2b, 0xb1, 0x00, 0x77 } \
- }
-
-typedef struct efi_apple_set_os_interface {
- UINT64 version;
- EFI_STATUS EFIAPI (*set_os_version) (IN CHAR8 *version);
- EFI_STATUS EFIAPI (*set_os_vendor) (IN CHAR8 *vendor);
-} efi_apple_set_os_interface;
-
-// Function to tell the firmware that OS X is being launched. This is
-// required to work around problems on some Macs that don't fully
-// initialize some hardware (especially video displays) when third-party
-// OSes are launched in EFI mode.
-static EFI_STATUS SetAppleOSInfo() {
-// CHAR8 apple_os_version[] = "Mac OS X 10.9";
- CHAR16 *AppleOSVersion = NULL;
- CHAR8 *AppleOSVersion8 = NULL;
-// CHAR8 apple_os_vendor[] = "Apple Inc.";
- EFI_STATUS Status;
- EFI_GUID apple_set_os_guid = EFI_APPLE_SET_OS_PROTOCOL_GUID;
- efi_apple_set_os_interface *set_os = NULL;
-
- Status = refit_call3_wrapper(BS->LocateProtocol, &apple_set_os_guid, NULL, (VOID**) &set_os);
-
- // Not a Mac, so ignore the call....
- if ((Status != EFI_SUCCESS) || (!set_os)) {
- Print(L"Not a Mac!\n");
- PauseForKey();
- return EFI_SUCCESS;
- }
-
- if ((set_os->version != 0) && GlobalConfig.SpoofOSXVersion) {
- AppleOSVersion = StrDuplicate(L"Mac OS X");
- MergeStrings(&AppleOSVersion, GlobalConfig.SpoofOSXVersion, ' ');
- Print(L"Setting OS version to '%s'\n", AppleOSVersion);
- AppleOSVersion8 = AllocateZeroPool((StrLen(AppleOSVersion) + 1) * sizeof(CHAR8));
- UnicodeStrToAsciiStr(AppleOSVersion, AppleOSVersion8);
- if (AppleOSVersion8) {
- Print(L"Calling set_os_version()\n");
- Status = refit_call1_wrapper (set_os->set_os_version, AppleOSVersion8);
- Print(L"Returned %lx\n", Status);
- if (EFI_ERROR(Status))
- Print(L"ERROR! Returned %x\n", Status);
- } else {
- Status = EFI_OUT_OF_RESOURCES;
- Print(L"Out of resources!\n");
- }
- }
-
- if (/* (Status == EFI_SUCCESS) && */ (set_os->version == 2)) {
- Print(L"Setting OS vendor....");
- Status = refit_call1_wrapper (set_os->set_os_vendor, "Apple Inc.");
- Print(L"Returned %x\n", Status);
- }
-
- if (Status != EFI_SUCCESS) {
- Print(L"Unable to set firmware boot type!\n");
- }
-
- MyFreePool(AppleOSVersion);
- MyFreePool(AppleOSVersion8);
- Print(L"Returning %x\n", Status);
- PauseForKey();
- return (Status);
-} // EFI_STATUS SetAppleOSInfo()
-
//
// main entry point
//
SetConfigFilename(ImageHandle);
ReadConfig(GlobalConfig.ConfigFilename);
- if (GlobalConfig.SpoofOSXVersion) {
+ if (GlobalConfig.SpoofOSXVersion && GlobalConfig.SpoofOSXVersion[0] != L'\0')
SetAppleOSInfo();
- }
InitScreen();
WarnIfLegacyProblems();
RebootIntoFirmware();
break;
+ case TAG_CSR_ROTATE:
+ RotateCsrValue();
+ break;
+
} // switch()
} // while()