2019-09-03 11:58:42 +02:00
|
|
|
|
/*
|
|
|
|
|
* refit/menu.c
|
|
|
|
|
* Menu functions
|
|
|
|
|
*
|
|
|
|
|
* Copyright (c) 2006 Christoph Pfisterer
|
|
|
|
|
* All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
|
* modification, are permitted provided that the following conditions are
|
|
|
|
|
* met:
|
|
|
|
|
*
|
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
|
*
|
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
|
* documentation and/or other materials provided with the
|
|
|
|
|
* distribution.
|
|
|
|
|
*
|
|
|
|
|
* * Neither the name of Christoph Pfisterer nor the names of the
|
|
|
|
|
* contributors may be used to endorse or promote products derived
|
|
|
|
|
* from this software without specific prior written permission.
|
|
|
|
|
*
|
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
*/
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#include "menu.h"
|
2019-09-03 11:58:42 +02:00
|
|
|
|
//#include "Platform.h"
|
2020-03-13 14:11:58 +01:00
|
|
|
|
#include "../libeg/libegint.h" //this includes platform.h
|
2019-09-03 11:58:42 +02:00
|
|
|
|
//#include "../include/scroll_images.h"
|
2020-02-16 13:00:20 +01:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#include "../Platform/Settings.h"
|
2020-03-06 16:30:07 +01:00
|
|
|
|
#include "../../Version.h"
|
2019-09-03 11:58:42 +02:00
|
|
|
|
//#include "colors.h"
|
|
|
|
|
|
2020-03-13 14:11:58 +01:00
|
|
|
|
#include "../libeg/nanosvg.h"
|
|
|
|
|
#include "../libeg/FloatLib.h"
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#include "HdaCodecDump.h"
|
2020-02-29 08:30:21 +01:00
|
|
|
|
#include "menu.h"
|
|
|
|
|
#include "screen.h"
|
2020-03-12 18:45:28 +01:00
|
|
|
|
#include "../cpp_foundation/XString.h"
|
2020-03-18 07:39:11 +01:00
|
|
|
|
#include "../libeg/XTheme.h"
|
2020-03-31 18:05:34 +02:00
|
|
|
|
#include "../libeg/VectorGraphics.h" // for testSVG
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#include "../gui/shared_with_menu.h"
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
#ifndef DEBUG_ALL
|
|
|
|
|
#define DEBUG_MENU 1
|
|
|
|
|
#else
|
|
|
|
|
#define DEBUG_MENU DEBUG_ALL
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if DEBUG_MENU == 0
|
|
|
|
|
#define DBG(...)
|
|
|
|
|
#else
|
|
|
|
|
#define DBG(...) DebugLog(DEBUG_MENU, __VA_ARGS__)
|
|
|
|
|
#endif
|
|
|
|
|
|
2020-03-20 18:48:19 +01:00
|
|
|
|
|
2019-09-03 11:58:42 +02:00
|
|
|
|
//#define PREBOOT_LOG L"EFI\\CLOVER\\misc\\preboot.log"
|
2020-02-23 06:53:21 +01:00
|
|
|
|
//#define VBIOS_BIN L"EFI\\CLOVER\\misc\\c0000.bin"
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//CONST CHAR16 *VBIOS_BIN = L"EFI\\CLOVER\\misc\\c0000.bin"; // tmporarily moved in shared_wint_menu
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
//#define LSTR(s) L##s
|
|
|
|
|
|
|
|
|
|
// scrolling definitions
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//static INTN MaxItemOnScreen = -1;
|
2020-04-04 07:50:30 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//#if USE_XTHEME
|
|
|
|
|
//REFIT_MENU_SCREEN OptionMenu(4, L"Options"_XSW, L""_XSW);
|
|
|
|
|
//#else
|
|
|
|
|
REFIT_MENU_SCREEN OptionMenu(4, L"Options", L""_XSW);
|
|
|
|
|
//#endif
|
2020-04-04 07:50:30 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//
|
|
|
|
|
//extern REFIT_MENU_ITEM_RETURN MenuEntryReturn;
|
|
|
|
|
//extern UINTN ThemesNum;
|
|
|
|
|
//extern CONST CHAR16 *ThemesList[];
|
|
|
|
|
//extern UINTN ConfigsNum;
|
|
|
|
|
//extern CHAR16 *ConfigsList[];
|
|
|
|
|
//extern UINTN DsdtsNum;
|
|
|
|
|
//extern CHAR16 *DsdtsList[];
|
|
|
|
|
//extern UINTN AudioNum;
|
|
|
|
|
//extern HDA_OUTPUTS AudioList[20];
|
2020-03-22 11:48:13 +01:00
|
|
|
|
extern CONST CHAR8 *AudioOutputNames[];
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//extern CHAR8 NonDetected[];
|
|
|
|
|
#include "../Platform/string.h"
|
|
|
|
|
//extern BOOLEAN GetLegacyLanAddress;
|
|
|
|
|
//extern UINT8 gLanMac[4][6]; // their MAC addresses
|
|
|
|
|
//extern EFI_AUDIO_IO_PROTOCOL *AudioIo;
|
|
|
|
|
//
|
|
|
|
|
////layout must be in XTheme
|
|
|
|
|
//#if !USE_XTHEME
|
|
|
|
|
//INTN LayoutBannerOffset = 64;
|
|
|
|
|
//INTN LayoutButtonOffset = 0;
|
|
|
|
|
//INTN LayoutTextOffset = 0;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
INTN LayoutMainMenuHeight = 376;
|
|
|
|
|
INTN LayoutAnimMoveForMenuX = 0;
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//#endif
|
|
|
|
|
//
|
|
|
|
|
//BOOLEAN SavePreBootLog = FALSE;
|
|
|
|
|
//
|
|
|
|
|
//#define SCROLL_LINE_UP (0)
|
|
|
|
|
//#define SCROLL_LINE_DOWN (1)
|
|
|
|
|
//#define SCROLL_PAGE_UP (2)
|
|
|
|
|
//#define SCROLL_PAGE_DOWN (3)
|
|
|
|
|
//#define SCROLL_FIRST (4)
|
|
|
|
|
//#define SCROLL_LAST (5)
|
|
|
|
|
//#define SCROLL_NONE (6)
|
|
|
|
|
//#define SCROLL_SCROLL_DOWN (7)
|
|
|
|
|
//#define SCROLL_SCROLL_UP (8)
|
|
|
|
|
//#define SCROLL_SCROLLBAR_MOVE (9)
|
|
|
|
|
//
|
|
|
|
|
//
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#define TEXT_CORNER_REVISION (1)
|
|
|
|
|
#define TEXT_CORNER_HELP (2)
|
|
|
|
|
#define TEXT_CORNER_OPTIMUS (3)
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//
|
|
|
|
|
//#define TITLE_MAX_LEN (SVALUE_MAX_SIZE / sizeof(CHAR16) + 128)
|
|
|
|
|
//
|
|
|
|
|
//// other menu definitions
|
|
|
|
|
//
|
|
|
|
|
//#define MENU_FUNCTION_INIT (0)
|
|
|
|
|
//#define MENU_FUNCTION_CLEANUP (1)
|
|
|
|
|
//#define MENU_FUNCTION_PAINT_ALL (2)
|
|
|
|
|
//#define MENU_FUNCTION_PAINT_SELECTION (3)
|
|
|
|
|
//#define MENU_FUNCTION_PAINT_TIMEOUT (4)
|
|
|
|
|
//
|
|
|
|
|
//
|
|
|
|
|
//
|
|
|
|
|
//static CHAR16 ArrowUp[2] = { ARROW_UP, 0 };
|
|
|
|
|
//static CHAR16 ArrowDown[2] = { ARROW_DOWN, 0 };
|
|
|
|
|
//
|
|
|
|
|
//BOOLEAN MainAnime = FALSE;
|
|
|
|
|
//
|
|
|
|
|
////TODO Scroll variables must be a part of REFIT_SCREEN
|
|
|
|
|
////BOOLEAN ScrollEnabled = FALSE;
|
|
|
|
|
//BOOLEAN IsDragging = FALSE;
|
|
|
|
|
//#if !USE_XTHEME
|
2019-09-03 11:58:42 +02:00
|
|
|
|
INTN ScrollWidth = 16;
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//INTN ScrollButtonsHeight = 20;
|
|
|
|
|
//INTN ScrollBarDecorationsHeight = 5;
|
|
|
|
|
//INTN ScrollScrollDecorationsHeight = 7;
|
|
|
|
|
//#endif
|
|
|
|
|
//INTN ScrollbarYMovement;
|
|
|
|
|
//
|
|
|
|
|
//
|
|
|
|
|
////#define TextHeight (FONT_CELL_HEIGHT + TEXT_YMARGIN * 2)
|
|
|
|
|
//
|
|
|
|
|
//// clovy - set row height based on text size
|
|
|
|
|
//#define RowHeightFromTextHeight (1.35f)
|
|
|
|
|
//
|
|
|
|
|
////TODO spacing must be a part of layout in XTheme
|
|
|
|
|
//#define TITLEICON_SPACING (16)
|
|
|
|
|
////#define ROW0__TILESIZE (144)
|
|
|
|
|
////#define ROW1_TILESIZE (64)
|
|
|
|
|
//#define TILE1_XSPACING (8)
|
|
|
|
|
////#define TILE_YSPACING (24)
|
|
|
|
|
//#define ROW0_SCROLLSIZE (100)
|
|
|
|
|
//
|
|
|
|
|
////EG_IMAGE *SelectionImages[6] = {NULL, NULL, NULL, NULL, NULL, NULL};
|
|
|
|
|
////EG_IMAGE *Buttons[4] = {NULL, NULL, NULL, NULL};
|
2020-03-24 16:17:12 +01:00
|
|
|
|
#if !USE_XTHEME
|
2019-09-03 11:58:42 +02:00
|
|
|
|
static EG_IMAGE *TextBuffer = NULL;
|
2020-03-24 16:17:12 +01:00
|
|
|
|
#endif
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//
|
|
|
|
|
////EG_PIXEL SelectionBackgroundPixel = { 0xef, 0xef, 0xef, 0xff }; //non-trasparent
|
|
|
|
|
//
|
|
|
|
|
////INTN row0TileSize = 144;
|
|
|
|
|
////INTN row1TileSize = 64;
|
|
|
|
|
//
|
|
|
|
|
//static INTN row0Count, row0PosX, row0PosXRunning;
|
|
|
|
|
//static INTN row1Count, row1PosX, row1PosXRunning;
|
|
|
|
|
//static INTN *itemPosX = NULL;
|
|
|
|
|
//static INTN *itemPosY = NULL;
|
2020-04-02 16:03:58 +02:00
|
|
|
|
#if !USE_XTHEME
|
2020-04-04 14:27:02 +02:00
|
|
|
|
static INTN row0PosY /*, row1PosY, textPosY, FunctextPosY*/;
|
2020-04-04 15:50:13 +02:00
|
|
|
|
#endif
|
2020-04-04 14:27:02 +02:00
|
|
|
|
////static EG_IMAGE* MainImage;
|
|
|
|
|
//static INTN OldX = 0, OldY = 0;
|
|
|
|
|
//static INTN OldTextWidth = 0;
|
|
|
|
|
//static UINTN OldRow = 0;
|
|
|
|
|
//static INTN OldTimeoutTextWidth = 0;
|
|
|
|
|
//static INTN MenuWidth, TimeoutPosY;
|
|
|
|
|
//static INTN EntriesPosX, EntriesPosY;
|
|
|
|
|
//static INTN EntriesWidth, EntriesHeight, EntriesGap;
|
2020-04-05 05:44:27 +02:00
|
|
|
|
#if !USE_XTHEME
|
2020-04-04 14:27:02 +02:00
|
|
|
|
EG_IMAGE* ScrollbarImage = NULL;
|
|
|
|
|
EG_IMAGE* ScrollbarBackgroundImage = NULL;
|
|
|
|
|
EG_IMAGE* UpButtonImage = NULL;
|
|
|
|
|
EG_IMAGE* DownButtonImage = NULL;
|
|
|
|
|
EG_IMAGE* BarStartImage = NULL;
|
|
|
|
|
EG_IMAGE* BarEndImage = NULL;
|
|
|
|
|
EG_IMAGE* ScrollStartImage = NULL;
|
|
|
|
|
EG_IMAGE* ScrollEndImage = NULL;
|
2020-03-24 05:36:39 +01:00
|
|
|
|
EG_RECT BarStart;
|
|
|
|
|
EG_RECT BarEnd;
|
|
|
|
|
EG_RECT ScrollStart;
|
|
|
|
|
EG_RECT ScrollEnd;
|
|
|
|
|
EG_RECT ScrollTotal;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
EG_RECT UpButton;
|
|
|
|
|
EG_RECT DownButton;
|
|
|
|
|
EG_RECT ScrollbarBackground;
|
|
|
|
|
EG_RECT Scrollbar;
|
|
|
|
|
EG_RECT ScrollbarOldPointerPlace;
|
|
|
|
|
EG_RECT ScrollbarNewPointerPlace;
|
2020-04-05 05:44:27 +02:00
|
|
|
|
#endif
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//
|
|
|
|
|
//INPUT_ITEM *InputItems = NULL;
|
|
|
|
|
//UINTN InputItemsCount = 0;
|
|
|
|
|
//
|
|
|
|
|
//INTN OldChosenTheme;
|
|
|
|
|
//INTN OldChosenConfig;
|
|
|
|
|
//INTN OldChosenDsdt;
|
|
|
|
|
//UINTN OldChosenAudio;
|
|
|
|
|
//UINT8 DefaultAudioVolume = 70;
|
|
|
|
|
////INTN NewChosenTheme;
|
|
|
|
|
//#if !USE_XTHEME
|
|
|
|
|
//INTN TextStyle; //why global? It will be class SCREEN member
|
|
|
|
|
//#endif
|
|
|
|
|
////BOOLEAN mGuiReady = FALSE;
|
|
|
|
|
//
|
2020-02-28 21:28:33 +01:00
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
|
|
|
|
|
//REFIT_MENU_ITEM_OPTIONS(CONST CHAR16 *Title_, UINTN Row_, CHAR16 ShortcutDigit_, CHAR16 ShortcutLetter_, ACTION AtClick_)
|
2020-03-31 17:59:35 +02:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS MenuEntryOptions (L"Options"_XSW, 1, 0, 'O', ActionEnter);
|
|
|
|
|
REFIT_MENU_ITEM_ABOUT MenuEntryAbout (L"About Clover"_XSW, 1, 0, 'A', ActionEnter);
|
|
|
|
|
REFIT_MENU_ITEM_RESET MenuEntryReset (L"Restart Computer"_XSW, 1, 0, 'R', ActionSelect);
|
|
|
|
|
REFIT_MENU_ITEM_SHUTDOWN MenuEntryShutdown(L"Exit Clover"_XSW, 1, 0, 'U', ActionSelect);
|
|
|
|
|
REFIT_MENU_ITEM_RETURN MenuEntryReturn (L"Return"_XSW, 0, 0, 0, ActionEnter);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
|
2020-04-04 07:50:30 +02:00
|
|
|
|
#if USE_XTHEME
|
|
|
|
|
REFIT_MENU_SCREEN MainMenu(1, L"Main Menu"_XSW, L"Automatic boot"_XSW);
|
|
|
|
|
REFIT_MENU_SCREEN AboutMenu(2, L"About"_XSW, L""_XSW);
|
|
|
|
|
REFIT_MENU_SCREEN HelpMenu(3, L"Help"_XSW, L""_XSW);
|
|
|
|
|
#else
|
2020-03-04 16:27:41 +01:00
|
|
|
|
REFIT_MENU_SCREEN MainMenu(1, L"Main Menu", L"Automatic boot");
|
|
|
|
|
REFIT_MENU_SCREEN AboutMenu(2, L"About", NULL);
|
|
|
|
|
REFIT_MENU_SCREEN HelpMenu(3, L"Help", NULL);
|
2020-04-04 07:50:30 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
// input - tsc
|
|
|
|
|
// output - milliseconds
|
|
|
|
|
// the caller is responsible for t1 > t0
|
|
|
|
|
UINT64 TimeDiff(UINT64 t0, UINT64 t1)
|
|
|
|
|
{
|
|
|
|
|
return DivU64x64Remainder((t1 - t0), DivU64x32(gCPUStructure.TSCFrequency, 1000), 0);
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
VOID FillInputs(BOOLEAN New)
|
|
|
|
|
{
|
|
|
|
|
UINTN i,j; //for loops
|
|
|
|
|
CHAR8 tmp[41];
|
|
|
|
|
// BOOLEAN bit;
|
|
|
|
|
|
|
|
|
|
tmp[40] = 0; //make it null-terminated
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
UINTN InputItemsCount = 0;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems = (__typeof__(InputItems))AllocateZeroPool(130 * sizeof(INPUT_ITEM)); //XXX
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //0
|
|
|
|
|
//even though Ascii we will keep value as Unicode to convert later
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(SVALUE_MAX_SIZE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, SVALUE_MAX_SIZE, "%s ", gSettings.BootArgs);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = UNIString; //1
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(32);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 32, "%ls", gSettings.DsdtName); // 1-> 2
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = UNIString; //2
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(63);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 63, "%ls", gSettings.BlockKexts);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = RadioSwitch; //3 - Themes chooser
|
|
|
|
|
InputItems[InputItemsCount++].IValue = 3;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //4
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.DropSSDT;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //5
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.GeneratePStates;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //6
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.SlpSmiEnable;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //7
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(8);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 8, "%02d", gSettings.PLimitDict);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //8
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(8);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 8, "%02d", gSettings.UnderVoltStep);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //9
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.GenerateCStates;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //10
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.EnableC2;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //11
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.EnableC4;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //12
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.EnableC6;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //13
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.EnableISS;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //14
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%06d", gSettings.QPI);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //15
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.PatchNMI;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //16
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.PatchVBios;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //17
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(20);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "0x%llX", gPlatformFeature);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //18
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(36);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 36, "0x%X", gSettings.BacklightLevel);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //19
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
if (gSettings.BusSpeed > 20000) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%06d", gSettings.BusSpeed);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%06llu", gCPUStructure.ExternalClock);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
InputItemsCount = 20;
|
|
|
|
|
for (i=0; i<NGFX; i++) {
|
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //20+i*6
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gGraphics[i].Model);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
if (gGraphics[i].Vendor == Ati) {
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //21+i*6
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.InjectATI;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //22+6i
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(20);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
if (StrLen(gSettings.FBName) > 2) { //fool proof: cfg_name is 3 character or more.
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 20, "%ls", gSettings.FBName);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 20, "%s", gGraphics[i].Config);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
} else if (gGraphics[i].Vendor == Nvidia) {
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //21+i*6
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.InjectNVidia;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //22+6i
|
|
|
|
|
for (j=0; j<8; j++) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf((CHAR8*)&tmp[2*j], 3, "%02X", gSettings.Dcfg[j]);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(40);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 40, "%s", tmp);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
//InputItems[InputItemsCount++].SValue = PoolPrint(L"%08x",*(UINT64*)&gSettings.Dcfg[0]);
|
|
|
|
|
} else /*if (gGraphics[i].Vendor == Intel) */ {
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //21+i*6
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.InjectIntel;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //22+6i
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(20);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.IgPlatform);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
// InputItemsCount += 3;
|
|
|
|
|
// continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //23+6i
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(8);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
if (gSettings.VideoPorts > 0) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 8, "%02d", gSettings.VideoPorts);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 8, "%02d", gGraphics[i].Ports);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (gGraphics[i].Vendor == Nvidia) {
|
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //24+6i
|
|
|
|
|
for (j=0; j<20; j++) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf((CHAR8*)&tmp[2*j], 3, "%02X", gSettings.NVCAP[j]);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(84);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 84, "%s", tmp);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else { //ATI and others there will be connectors
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //24+6i
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(20);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 20, "%08x", gGraphics[i].Connectors);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //25+6i
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gGraphics[i].LoadVBios;
|
|
|
|
|
}
|
|
|
|
|
//and so on
|
|
|
|
|
|
|
|
|
|
InputItemsCount = 44;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //44
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KextPatchesAllowed;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //45
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPKernelCpu;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //46
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPAppleIntelCPUPM;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //47
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPAppleRTC;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //48
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPKernelPm;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //49
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.FixMCFG;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //50
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%06d", gSettings.RefCLK);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //51 OS version if non-detected
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(SVALUE_MAX_SIZE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, SVALUE_MAX_SIZE, "%s ", NonDetected);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //52
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.InjectEDID;
|
|
|
|
|
|
|
|
|
|
//VendorEDID & ProductEDID 53, 54
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //53
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "0x%04X", gSettings.VendorEDID);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //54
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "0x%04X", gSettings.ProductEDID);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// ErmaC: NvidiaGeneric menu selector y/n
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //55
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.NvidiaGeneric;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //56
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.NvidiaWeb;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //57
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.ResetHDA;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //58
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.AFGLowPowerState;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //59
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.HDAInjection;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; // 60
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%d", gSettings.HDALayoutId);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// syscl change here
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //61
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPDELLSMBIOS;
|
|
|
|
|
// end of change
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //62
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(24);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 24, "0x%08X", gFwFeatures);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //63
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(24);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 24, "0x%08X", gFwFeaturesMask);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// Debug for KernelAndKextPatches
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //64
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPDebug;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// CSR - aka System Integrity Protection configuration
|
|
|
|
|
InputItems[InputItemsCount].ItemType = CheckBit; //65
|
|
|
|
|
InputItems[InputItemsCount++].IValue = gSettings.BooterConfig;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = CheckBit; //66
|
|
|
|
|
InputItems[InputItemsCount++].IValue = gSettings.CsrActiveConfig;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = CheckBit; //67
|
|
|
|
|
InputItems[InputItemsCount++].IValue = gSettings.FixDsdt;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = CheckBit; //68
|
|
|
|
|
InputItems[InputItemsCount++].IValue = gSettings.OptionsBits;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = CheckBit; //69
|
|
|
|
|
InputItems[InputItemsCount++].IValue = gSettings.FlagsBits;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //70
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(8);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 8, "%02lld", gSettings.PointerSpeed);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //71
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%04llu", gSettings.DoubleClickTime);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //72
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.PointerMirror;
|
|
|
|
|
|
|
|
|
|
//reserve for mouse and continue
|
|
|
|
|
|
|
|
|
|
InputItemsCount = 74;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //74
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.USBFixOwnership;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //75
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "0x%04X", gSettings.C3Latency);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //76
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%02d", gSettings.EnabledCores);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //77
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%02d", gSettings.SavingMode);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //78
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.ProductName);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //79
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.VersionNr);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //80
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.SerialNr);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //81
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.BoardNumber);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //82
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.BoardSerialNumber);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //83
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%d", gSettings.BoardType);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //84
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.BoardVersion);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //85
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%d", gSettings.ChassisType);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //86
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.RomVersion);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //87
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.ReleaseDate);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //88
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.DoubleFirstState;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //89
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.EnableC7;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = RadioSwitch; //90
|
|
|
|
|
InputItems[InputItemsCount++].IValue = 90;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //91
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPKernelLapic;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //92
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.USBInjection;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //93
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.InjectClockID;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //94
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.FakeATI);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //95
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.FakeNVidia);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //96
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.FakeIntel);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //97
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.FakeLAN);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //98
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.FakeWIFI);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //99
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.FakeSATA);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //100
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.FakeXHCI);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = CheckBit; //101
|
|
|
|
|
InputItems[InputItemsCount++].IValue = dropDSM;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //102
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.DebugDSDT;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //103
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.FakeIMEI);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //104
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(26);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 26, "0x%08X", gSettings.KernelAndKextPatches.FakeCPUID);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //105
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPKernelXCPM;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //106
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.StringInjector;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //107
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.NoDefaultProperties;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //108
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelPatchesAllowed;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //109
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%01X", gSettings.DualLink);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //110
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.NvidiaNoEFI;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //111
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.NvidiaSingle;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Hex; //112
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "0x%04X", gSettings.IntelMaxValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //113
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.AutoMerge;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //114
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.DeInit;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //115
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.NoCaches;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = RadioSwitch; //116 - DSDT chooser
|
|
|
|
|
InputItems[InputItemsCount++].IValue = 116;
|
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //117
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.EfiVersion);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputItems[InputItemsCount].ItemType = ASString; //118
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(64);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 64, "%s", gSettings.BooterCfgStr);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = RadioSwitch; //119 - Audio chooser
|
|
|
|
|
InputItems[InputItemsCount++].IValue = 119;
|
|
|
|
|
InputItems[InputItemsCount].ItemType = Decimal; //120
|
|
|
|
|
if (New) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
InputItems[InputItemsCount].SValue = (__typeof__(InputItems[InputItemsCount].SValue))AllocateZeroPool(16);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[InputItemsCount++].SValue, 16, "%04d", DefaultAudioVolume);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
InputItems[InputItemsCount].ItemType = BoolValue; //121
|
|
|
|
|
InputItems[InputItemsCount++].BValue = gSettings.KernelAndKextPatches.KPPanicNoKextDump;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//menu for drop table
|
|
|
|
|
if (gSettings.ACPIDropTables) {
|
|
|
|
|
ACPI_DROP_TABLE *DropTable = gSettings.ACPIDropTables;
|
|
|
|
|
while (DropTable) {
|
|
|
|
|
DropTable->MenuItem.ItemType = BoolValue;
|
|
|
|
|
DropTable = DropTable->Next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (ACPIPatchedAML) {
|
|
|
|
|
ACPI_PATCHED_AML *ACPIPatchedAMLTmp = ACPIPatchedAML;
|
|
|
|
|
while (ACPIPatchedAMLTmp) {
|
|
|
|
|
ACPIPatchedAMLTmp->MenuItem.ItemType = BoolValue;
|
|
|
|
|
ACPIPatchedAMLTmp = ACPIPatchedAMLTmp->Next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
VOID ApplyInputs(VOID)
|
|
|
|
|
{
|
|
|
|
|
EFI_STATUS Status = EFI_NOT_FOUND;
|
|
|
|
|
MACHINE_TYPES Model;
|
|
|
|
|
BOOLEAN NeedSave = TRUE;
|
|
|
|
|
INTN i = 0;
|
|
|
|
|
UINTN j;
|
|
|
|
|
// UINT32 k;
|
|
|
|
|
CHAR16 *ch;
|
|
|
|
|
CHAR8 AString[256];
|
|
|
|
|
TagPtr dict;
|
|
|
|
|
// DBG("ApplyInputs\n");
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
ZeroMem(&gSettings.BootArgs, 256);
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
ch = InputItems[i].SValue;
|
|
|
|
|
do {
|
|
|
|
|
if (*ch == L'\\') {
|
|
|
|
|
*ch = L'_';
|
|
|
|
|
}
|
|
|
|
|
} while (*(++ch));
|
|
|
|
|
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.BootArgs, 255, "%ls ", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //1
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(gSettings.DsdtName, sizeof(gSettings.DsdtName), "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //2
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(gSettings.BlockKexts, sizeof(gSettings.BlockKexts), "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //3
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-30 10:34:16 +02:00
|
|
|
|
#if USE_XTHEME
|
|
|
|
|
if (OldChosenTheme == 0xFFFF) {
|
|
|
|
|
ThemeX.Theme.takeValueFrom("embedded");
|
|
|
|
|
} else {
|
|
|
|
|
ThemeX.Theme.takeValueFrom(ThemesList[OldChosenTheme]);
|
|
|
|
|
ThemeX.DarkEmbedded = FALSE;
|
|
|
|
|
ThemeX.Font = FONT_ALFA;
|
|
|
|
|
}
|
|
|
|
|
#else
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (GlobalConfig.Theme) {
|
|
|
|
|
FreePool(GlobalConfig.Theme);
|
|
|
|
|
}
|
|
|
|
|
if (OldChosenTheme == 0xFFFF) {
|
|
|
|
|
GlobalConfig.Theme = PoolPrint(L"embedded");
|
|
|
|
|
} else {
|
|
|
|
|
GlobalConfig.Theme = PoolPrint(L"%s", ThemesList[OldChosenTheme]);
|
|
|
|
|
GlobalConfig.DarkEmbedded = FALSE;
|
|
|
|
|
GlobalConfig.Font = FONT_ALFA;
|
|
|
|
|
}
|
2020-03-30 10:34:16 +02:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
//will change theme after ESC
|
|
|
|
|
gThemeChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //4
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.DropSSDT = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //5
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.GeneratePStates = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //6
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.SlpSmiEnable = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //7
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-25 19:32:44 +01:00
|
|
|
|
// DBG("InputItems[i]: %ls\n", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
gSettings.PLimitDict = (UINT8)(StrDecimalToUintn(InputItems[i].SValue) & 0x7F);
|
|
|
|
|
// DBG("Item 7=PLimitDict %d\n", gSettings.PLimitDict);
|
|
|
|
|
}
|
|
|
|
|
i++; //8
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.UnderVoltStep = (UINT8)(StrDecimalToUintn(InputItems[i].SValue) & 0x3F);
|
|
|
|
|
// DBG("Item 8=UnderVoltStep %d\n", gSettings.UnderVoltStep);
|
|
|
|
|
}
|
|
|
|
|
i++; //9
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.GenerateCStates = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //10
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.EnableC2 = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //11
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.EnableC4 = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //12
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.EnableC6 = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //13
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.EnableISS = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //14
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.QPI = (UINT16)StrDecimalToUintn(InputItems[i].SValue);
|
|
|
|
|
DBG("applied QPI=%d\n", gSettings.QPI);
|
|
|
|
|
}
|
|
|
|
|
i++; //15
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.PatchNMI = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //16
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.PatchVBios = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //17
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gPlatformFeature = (UINT64)StrHexToUint64(InputItems[i].SValue);
|
2020-03-25 19:32:44 +01:00
|
|
|
|
DBG("applied PlatformFeature=0x%llX\n", gPlatformFeature);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //18 | Download-Fritz: There is no GUI element for BacklightLevel; please revise
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.BacklightLevel = (UINT16)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
gSettings.BacklightLevelConfig = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //19
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.BusSpeed = (UINT32)StrDecimalToUintn(InputItems[i].SValue);
|
|
|
|
|
DBG("applied BusSpeed=%d\n", gSettings.BusSpeed);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i = 19;
|
|
|
|
|
for (j = 0; j < NGFX; j++) {
|
|
|
|
|
i++; //20
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-30 10:34:16 +02:00
|
|
|
|
snprintf(gGraphics[j].Model, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //21
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
if (gGraphics[j].Vendor == Ati) {
|
|
|
|
|
gSettings.InjectATI = InputItems[i].BValue;
|
|
|
|
|
} else if (gGraphics[j].Vendor == Nvidia) {
|
|
|
|
|
gSettings.InjectNVidia = InputItems[i].BValue;
|
|
|
|
|
} else if (gGraphics[j].Vendor == Intel) {
|
|
|
|
|
gSettings.InjectIntel = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
i++; //22
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
if (gGraphics[j].Vendor == Ati) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(gSettings.FBName, 32, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else if (gGraphics[j].Vendor == Nvidia) {
|
|
|
|
|
ZeroMem(AString, 256);
|
2020-03-30 10:34:16 +02:00
|
|
|
|
snprintf(AString, 255, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
hex2bin(AString, (UINT8*)&gSettings.Dcfg[0], 8);
|
|
|
|
|
} else if (gGraphics[j].Vendor == Intel) {
|
|
|
|
|
//ig-platform-id for Ivy+ and snb-platform-id for Sandy
|
|
|
|
|
gSettings.IgPlatform = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
2020-03-25 19:32:44 +01:00
|
|
|
|
DBG("applied *-platform-id=0x%X\n", gSettings.IgPlatform);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (gGraphics[i].Vendor == Intel) {
|
|
|
|
|
i += 3;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //23
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gGraphics[j].Ports = (UINT8)(StrDecimalToUintn(InputItems[i].SValue) & 0x0F);
|
|
|
|
|
}
|
|
|
|
|
i++; //24
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
if (gGraphics[j].Vendor == Nvidia) {
|
|
|
|
|
ZeroMem(AString, 256);
|
|
|
|
|
if (StrLen(InputItems[i].SValue) > 0) {
|
2020-03-30 10:34:16 +02:00
|
|
|
|
snprintf(AString, 255, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
hex2bin(AString, (UINT8*)&gSettings.NVCAP[0], 20);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
gGraphics[j].Connectors = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
gGraphics[j].ConnChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
i++; //25
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gGraphics[j].LoadVBios = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
} //end of Graphics Cards
|
|
|
|
|
// next number == 42
|
|
|
|
|
|
|
|
|
|
i = 44;
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KextPatchesAllowed = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //45
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPKernelCpu = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //46
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPAppleIntelCPUPM = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //47
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPAppleRTC = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //48
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPKernelPm = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //49
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FixMCFG = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //50
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.RefCLK = (UINT32)StrDecimalToUintn(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //51
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(NonDetected, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //52
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.InjectEDID = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //53
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.VendorEDID = (UINT16)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //54
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.ProductEDID = (UINT16)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //55
|
|
|
|
|
// ErmaC: NvidiaGeneric bool(Y/N)
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.NvidiaGeneric = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //56
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.NvidiaWeb = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //57
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.ResetHDA = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //58
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.AFGLowPowerState = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //59
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.HDAInjection = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //60
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.HDALayoutId = (UINT32)(StrDecimalToUintn(InputItems[i].SValue));
|
|
|
|
|
}
|
|
|
|
|
i++; //61
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPDELLSMBIOS = InputItems[i].BValue;
|
|
|
|
|
// yes, we do need to change gRemapSmBiosIsRequire here as well
|
|
|
|
|
gRemapSmBiosIsRequire = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //62
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gFwFeatures = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
2020-03-25 19:32:44 +01:00
|
|
|
|
DBG("applied FirmwareFeatures=0x%X\n", gFwFeatures);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //63
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gFwFeaturesMask = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
2020-03-25 19:32:44 +01:00
|
|
|
|
DBG("applied FirmwareFeaturesMask=0x%X\n", gFwFeaturesMask);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //64
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPDebug = InputItems[i].BValue;
|
|
|
|
|
// gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// CSR
|
|
|
|
|
i = 65;
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.BooterConfig = InputItems[i].IValue & 0x7F;
|
|
|
|
|
}
|
|
|
|
|
i++; //66
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.CsrActiveConfig = InputItems[i].IValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //67
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FixDsdt = InputItems[i].IValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //68
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.OptionsBits = InputItems[i].IValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //69
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FlagsBits = InputItems[i].IValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
i++; //70
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
INTN Minus = 0;
|
|
|
|
|
if (InputItems[i].SValue[0] == '-') {
|
|
|
|
|
Minus = 1;
|
|
|
|
|
}
|
|
|
|
|
gSettings.PointerSpeed = StrDecimalToUintn(&InputItems[i].SValue[Minus]);
|
|
|
|
|
if (Minus) {
|
|
|
|
|
gSettings.PointerSpeed = -gSettings.PointerSpeed;
|
|
|
|
|
}
|
|
|
|
|
// DBG("Pointer Speed=%d\n", gSettings.PointerSpeed);
|
|
|
|
|
}
|
|
|
|
|
i++; //71
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.DoubleClickTime = StrDecimalToUintn(InputItems[i].SValue);
|
|
|
|
|
// DBG("DoubleClickTime=%d ms\n", gSettings.DoubleClickTime);
|
|
|
|
|
}
|
|
|
|
|
i++; //72
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.PointerMirror = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
i = 74;
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.USBFixOwnership = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //75
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.C3Latency = (UINT16)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //76
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.EnabledCores = (UINT8)StrDecimalToUintn(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //77
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.SavingMode = (UINT8)StrDecimalToUintn(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //78
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.ProductName, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
// let's fill all other fields based on this ProductName
|
|
|
|
|
// to serve as default
|
|
|
|
|
Model = GetModelFromString(gSettings.ProductName);
|
|
|
|
|
if (Model != MaxMachineType) {
|
|
|
|
|
SetDMISettingsForModel(Model, FALSE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //79
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.VersionNr, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //80
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.SerialNr, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //81
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.BoardNumber, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //82
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.BoardSerialNumber, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //83
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.BoardType = (UINT8)(StrDecimalToUintn(InputItems[i].SValue) & 0x0F);
|
|
|
|
|
}
|
|
|
|
|
i++; //84
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.BoardVersion, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //85
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.ChassisType = (UINT8)(StrDecimalToUintn(InputItems[i].SValue) & 0x0F);
|
|
|
|
|
}
|
|
|
|
|
i++; //86
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.RomVersion, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //87
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.ReleaseDate, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //88
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.DoubleFirstState = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //89
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.EnableC7 = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //90
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
Status = LoadUserSettings(SelfRootDir, ConfigsList[OldChosenConfig], &dict);
|
|
|
|
|
if (!EFI_ERROR(Status)) {
|
|
|
|
|
Status = GetUserSettings(SelfRootDir, dict);
|
|
|
|
|
if (gConfigDict[2]) FreeTag(gConfigDict[2]);
|
|
|
|
|
gConfigDict[2] = dict;
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(gSettings.ConfigName, 64, "%ls", ConfigsList[OldChosenConfig]);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
gThemeChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
FillInputs(FALSE);
|
|
|
|
|
NeedSave = FALSE;
|
|
|
|
|
}
|
|
|
|
|
i++; //91
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPKernelLapic = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //92
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.USBInjection = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //93
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.InjectClockID = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //94
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FakeATI = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //95
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FakeNVidia = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //96
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FakeIntel = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
2020-03-25 19:32:44 +01:00
|
|
|
|
DBG("applied FakeIntel=0x%X\n", gSettings.FakeIntel);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //97
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FakeLAN = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //98
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FakeWIFI = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //99
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FakeSATA = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //100
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FakeXHCI = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //101
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
// gSettings.DropOEM_DSM = (UINT16)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
gSettings.DropOEM_DSM = (UINT16)InputItems[i].IValue;
|
|
|
|
|
dropDSM = gSettings.DropOEM_DSM; //?
|
|
|
|
|
// defDSM = TRUE;
|
|
|
|
|
}
|
|
|
|
|
i++; //102
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.DebugDSDT = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //103
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.FakeIMEI = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //104
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.FakeCPUID = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
2020-03-25 19:32:44 +01:00
|
|
|
|
DBG("applied FakeCPUID=%06X\n", gSettings.KernelAndKextPatches.FakeCPUID);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //105
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPKernelXCPM = InputItems[i].BValue;
|
|
|
|
|
DBG("applied KernelXCPM\n");
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //106
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.StringInjector = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //107
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.NoDefaultProperties = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //108
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelPatchesAllowed = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //109
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.DualLink = (UINT32)StrHexToUint64(InputItems[i].SValue);
|
2020-03-25 19:32:44 +01:00
|
|
|
|
DBG("applied DualLink=%X\n", gSettings.DualLink);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //110
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.NvidiaNoEFI = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
i++; //111
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.NvidiaSingle = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //112
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.IntelMaxValue = (UINT16)StrHexToUint64(InputItems[i].SValue);
|
|
|
|
|
}
|
|
|
|
|
i++; //113
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.AutoMerge = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //114
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.DeInit = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //115
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.NoCaches = InputItems[i].BValue;
|
|
|
|
|
}
|
|
|
|
|
i++; //116
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
if (OldChosenDsdt == 0xFFFF) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(gSettings.DsdtName, 64, "BIOS.aml");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(gSettings.DsdtName, 64, "%ls", DsdtsList[OldChosenDsdt]);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
i++; //117
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.EfiVersion, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //118
|
|
|
|
|
if (InputItems[i].Valid) {
|
2020-03-29 15:44:08 +02:00
|
|
|
|
snprintf(gSettings.BooterCfgStr, 64, "%ls", InputItems[i].SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
i++; //119
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
EFI_DEVICE_PATH_PROTOCOL* DevicePath = NULL;
|
|
|
|
|
UINT8 TmpIndex = OldChosenAudio & 0xFF;
|
2020-03-25 19:32:44 +01:00
|
|
|
|
DBG("Chosen output %llu:%ls_%s\n", OldChosenAudio, AudioList[OldChosenAudio].Name, AudioOutputNames[OldChosenAudio]);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
DevicePath = DevicePathFromHandle(AudioList[OldChosenAudio].Handle);
|
|
|
|
|
if (DevicePath != NULL) {
|
|
|
|
|
SetNvramVariable(L"Clover.SoundDevice", &gEfiAppleBootGuid,
|
|
|
|
|
EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_RUNTIME_ACCESS,
|
|
|
|
|
GetDevicePathSize(DevicePath), (UINT8 *)DevicePath);
|
|
|
|
|
SetNvramVariable(L"Clover.SoundIndex", &gEfiAppleBootGuid,
|
|
|
|
|
EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_RUNTIME_ACCESS,
|
|
|
|
|
1, (UINT8 *)&TmpIndex);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
i++; //120
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
DefaultAudioVolume = (UINT8)StrDecimalToUintn(InputItems[i].SValue);
|
|
|
|
|
if (DefaultAudioVolume > 100) {
|
|
|
|
|
// correct wrong input
|
|
|
|
|
DefaultAudioVolume = 90;
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(InputItems[i].SValue, 16, "%04d", DefaultAudioVolume);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
SetNvramVariable(L"Clover.SoundVolume", &gEfiAppleBootGuid,
|
|
|
|
|
EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_RUNTIME_ACCESS,
|
|
|
|
|
1, &DefaultAudioVolume);
|
|
|
|
|
}
|
|
|
|
|
i++; //121
|
|
|
|
|
if (InputItems[i].Valid) {
|
|
|
|
|
gSettings.KernelAndKextPatches.KPPanicNoKextDump = InputItems[i].BValue;
|
|
|
|
|
gBootChanged = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (NeedSave) {
|
|
|
|
|
SaveSettings();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
VOID AboutRefit(VOID)
|
|
|
|
|
{
|
2020-03-30 10:34:16 +02:00
|
|
|
|
#if USE_XTHEME
|
|
|
|
|
if (!(ThemeX.HideUIFlags & HIDEUI_FLAG_MENU_TITLE_IMAGE)) {
|
|
|
|
|
AboutMenu.TitleImage = ThemeX.GetIcon((INTN)BUILTIN_ICON_FUNC_ABOUT);
|
|
|
|
|
} else {
|
|
|
|
|
AboutMenu.TitleImage.setEmpty();
|
|
|
|
|
}
|
|
|
|
|
#else
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (!(GlobalConfig.HideUIFlags & HIDEUI_FLAG_MENU_TITLE_IMAGE)) {
|
|
|
|
|
AboutMenu.TitleImage = BuiltinIcon(BUILTIN_ICON_FUNC_ABOUT);
|
|
|
|
|
} else {
|
|
|
|
|
AboutMenu.TitleImage = NULL;
|
|
|
|
|
}
|
2020-03-30 10:34:16 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if (AboutMenu.Entries.size() == 0) {
|
2020-03-12 19:23:32 +01:00
|
|
|
|
// AboutMenu.AddMenuInfo_f(("Clover Version 5.0"));
|
2020-03-05 19:23:21 +01:00
|
|
|
|
#ifdef REVISION_STR
|
2020-04-04 18:22:07 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" %s ", REVISION_STR);
|
2020-03-05 19:23:21 +01:00
|
|
|
|
#else
|
2020-03-12 19:23:32 +01:00
|
|
|
|
AboutMenu.AddMenuInfo_f((L"Clover Revision %s", gFirmwareRevision));
|
2020-03-05 19:23:21 +01:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#ifdef FIRMWARE_BUILDDATE
|
2020-03-12 19:23:32 +01:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" Build: %s", FIRMWARE_BUILDDATE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#else
|
2020-04-04 18:22:07 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" Build: unknown");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#endif
|
2020-04-05 05:44:27 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" ");
|
2020-04-04 18:22:07 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f("Based on rEFIt (c) 2006-2010 Christoph Pfisterer");
|
|
|
|
|
AboutMenu.AddMenuInfo_f("Portions Copyright (c) Intel Corporation");
|
|
|
|
|
AboutMenu.AddMenuInfo_f("Developers:");
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" Slice, dmazar, apianti, JrCs, pene, usrsse2");
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" Kabyl, pcj, jadran, Blackosx, STLVNUB, ycr.ru");
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" FrodoKenny, skoczi, crazybirdy, Oscar09, xsmile");
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" cparm, rehabman, nms42, Sherlocks, Zenith432");
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" stinga11, TheRacerMaster, solstice, SoThOr, DF");
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" cecekpawon, Micky1979, Needy, joevt, ErmaC, vit9696");
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" ath, savvas, syscl, goodwin_c, clovy, jief_machak");
|
|
|
|
|
AboutMenu.AddMenuInfo_f("Credits also:");
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" projectosx.com, applelife.ru, insanelymac.com");
|
2020-04-05 05:44:27 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" ");
|
2020-04-04 18:22:07 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f("Running on:");
|
2020-03-12 19:23:32 +01:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" EFI Revision %d.%02d",
|
|
|
|
|
gST->Hdr.Revision >> 16, gST->Hdr.Revision & ((1 << 16) - 1));
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#if defined(MDE_CPU_IA32)
|
2020-04-04 18:22:07 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" Platform: i386 (32 bit)");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#elif defined(MDE_CPU_X64)
|
2020-04-04 18:22:07 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" Platform: x86_64 (64 bit)");
|
2020-03-12 10:09:33 +01:00
|
|
|
|
#elif defined(_MSC_VER)
|
2020-04-04 18:22:07 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" Platform: x86_64 (64 bit) VS");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#else
|
2020-04-04 18:22:07 +02:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" Platform: unknown");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
#endif
|
2020-03-12 19:23:32 +01:00
|
|
|
|
AboutMenu.AddMenuInfo_f(" Firmware: %ls rev %d.%04d", gST->FirmwareVendor, gST->FirmwareRevision >> 16, gST->FirmwareRevision & ((1 << 16) - 1));
|
|
|
|
|
AboutMenu.AddMenuInfo_f(" Screen Output: %ls", egScreenDescription());
|
2020-03-03 21:44:07 +01:00
|
|
|
|
AboutMenu.AnimeRun = AboutMenu.GetAnime();
|
|
|
|
|
AboutMenu.AddMenuEntry(&MenuEntryReturn, false);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
} else if (AboutMenu.Entries.size() >= 2) {
|
2019-09-03 11:58:42 +02:00
|
|
|
|
/*
|
|
|
|
|
EntryCount instead of InfoLineCount. Lastline == return/back. Is necessary recheck screen res here?
|
|
|
|
|
*/
|
2020-04-02 08:50:44 +02:00
|
|
|
|
// FreePool(AboutMenu.Entries[AboutMenu.Entries.size()-2].Title); //what is FreePool(XStringW)?
|
|
|
|
|
|
2020-03-31 18:10:30 +02:00
|
|
|
|
AboutMenu.Entries[AboutMenu.Entries.size()-2].Title.SWPrintf(" Screen Output: %ls", egScreenDescription());
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
AboutMenu.RunMenu(NULL);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
VOID HelpRefit(VOID)
|
|
|
|
|
{
|
2020-03-30 10:34:16 +02:00
|
|
|
|
#if USE_XTHEME
|
|
|
|
|
if (!(ThemeX.HideUIFlags & HIDEUI_FLAG_MENU_TITLE_IMAGE)) {
|
|
|
|
|
HelpMenu.TitleImage = ThemeX.GetIcon(BUILTIN_ICON_FUNC_HELP);
|
|
|
|
|
} else {
|
|
|
|
|
HelpMenu.TitleImage.setEmpty();
|
|
|
|
|
}
|
|
|
|
|
#else
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (!(GlobalConfig.HideUIFlags & HIDEUI_FLAG_MENU_TITLE_IMAGE)) {
|
|
|
|
|
HelpMenu.TitleImage = BuiltinIcon(BUILTIN_ICON_FUNC_HELP);
|
|
|
|
|
} else {
|
|
|
|
|
HelpMenu.TitleImage = NULL;
|
|
|
|
|
}
|
2020-03-30 10:34:16 +02:00
|
|
|
|
#endif
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if (HelpMenu.Entries.size() == 0) {
|
2019-09-03 11:58:42 +02:00
|
|
|
|
switch (gLanguage)
|
|
|
|
|
{
|
|
|
|
|
case russian:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Выход из подменю, обновление главного меню");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Помощь по горячим клавишам");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Сохранить отчет в preboot.log (только если FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Показать скрытые значки в меню");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Родной DSDT сохранить в EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Патченный DSDT сохранить в EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Сохранить ВидеоБиос в EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Проверить звук на выбранном выходе");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Сделать дамп звуковых устройств в EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Изменить разрешение экрана на одно из возможных");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Снимок экрана в папку EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Извлечь указанный DVD");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Пробел - Дополнительное меню запуска выбранного тома");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Цифры 1-9 - Быстрый запуск тома по порядку в меню");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A (About) - О загрузчике");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O (Options) - Дополнительные настройки");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R (Reset) - Теплый перезапуск");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U (go oUt) - Завершить работу в Кловере");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S (Shell) - Переход в режим командной строки");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case ukrainian:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Вийти з меню, оновити головне меню");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Ця довідка");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Зберегти preboot.log (тiльки FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Відображати приховані розділи");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Зберегти OEM DSDT в EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Зберегти патчений DSDT в EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Зберегти VideoBios в EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Зберегти знімок екрану в EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Відкрити обраний диск (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Пробіл - докладніше про обраний пункт меню");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Клавіші 1-9 - клавіші пунктів меню");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Про систему");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Опції меню");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Перезавантаження");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Відключити ПК");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case spanish:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Salir de submenu o actualizar el menu principal");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Esta Ayuda");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Guardar preboot.log (Solo FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Guardar DSDT oem en EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Guardar DSDT parcheado en EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Guardar VideoBios en EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Guardar Captura de pantalla en EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Expulsar volumen seleccionado (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Espacio - Detalles acerca selected menu entry");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Digitos 1-9 - Atajo a la entrada del menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Menu Acerca de");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Menu Optiones");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Reiniciar Equipo");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Apagar");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case portuguese:
|
|
|
|
|
case brasil:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Sai do submenu, atualiza o menu principal");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Esta ajuda");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Salva preboot.log (somente FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Salva oem DSDT em EFI/CLOVER/ACPI/origin/ (somente FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Salva DSDT corrigido em EFI/CLOVER/ACPI/origin/ (somente FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Salva VideoBios em EFI/CLOVER/misc/ (somente FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Salva screenshot em EFI/CLOVER/misc/ (somente FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Ejeta o volume selecionado (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Espaco - Detalhes sobre a opcao do menu selecionada");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Tecle 1-9 - Atalho para as entradas do menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Sobre o Menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Opcoes do Menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Reiniciar");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Desligar");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case italian:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Esci dal submenu, Aggiorna menu principale");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Aiuto");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Salva il preboot.log (solo su FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Mostra volumi nascosti");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Salva il DSDT oem in EFI/CLOVER/ACPI/origin/ (solo suFAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Salva il patched DSDT in EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Salva il VideoBios in EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Controlla il suono sull'uscita selezionata");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Scarica le uscite audio in EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Cambia la risoluzione dello schermo alla prossima disponibile");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Salva screenshot in EFI/CLOVER/misc/ (solo su FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Resetta NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Espelli il volume selezionato (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Spazio - Dettagli sul menu selezionato");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Digita 1-9 - Abbreviazioni per il menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Informazioni");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Menu Opzioni");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Riavvio");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Spegnimento");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case german:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Zurueck aus Untermenue, Hauptmenue erneuern");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Diese Hilfe");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Sichere preboot.log (nur mit FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Sichere OEM DSDT in EFI/CLOVER/ACPI/origin/ (nur mit FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Sichere gepatchtes DSDT in EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Sichere VideoBios in EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Sichere Bildschirmfoto in EFI/CLOVER/misc/ (nur mit FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Volume auswerfen (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Leertaste - Details über den gewählten Menue Eintrag");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Zahlen 1-9 - Kurzwahl zum Menue Eintrag");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Menue Informationen");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Menue Optionen");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Neustart");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Ausschalten");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case dutch:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Verlaat submenu, Vernieuw hoofdmenu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Onderdeel hulp");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - preboot.log opslaan (Alleen FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Verborgen opties weergeven");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Opslaan oem DSDT in EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Opslaan gepatchte DSDT in EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Opslaan VideoBios in EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Controleer geluid op geselecteerde uitgang");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Opslaan audio uitgangen in EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Wijzig schermresolutie naar eerstvolgende mogelijke modus");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Opslaan schermafdruk in EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Uitwerpen geselecteerd volume (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Spatie - Details over geselecteerd menuoptie");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Cijfers 1-9 - Snelkoppeling naar menuoptie");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Menu Over");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Menu Opties");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Soft Reset");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Verlaten");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case french:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Quitter sous-menu, Retour menu principal");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Aide");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Enregistrer preboot.log (FAT32 only)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Enregistrer oem DSDT dans EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Enregistrer DSDT modifié dans EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Enregistrer VideoBios dans EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Enregistrer la capture d'écran dans EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Ejecter le volume (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Space - Détails a propos du menu selectionné");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Digits 1-9 - Raccourci vers entrée menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - A propos");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Options Menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Redémarrer");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Eteindre");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case indonesian:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Keluar submenu, Refresh main menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Help");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Simpan preboot.log ke EFI/CLOVER/ACPI/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Simpan oem DSDT ke EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Simpan patched DSDT ke EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Simpan VideoBios ke EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Simpan screenshot ke EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Eject volume (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Spasi - Detail dari menu yang dipilih");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Tombol 1-9 - Shortcut pilihan menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - About");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Opsi");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Soft Reset");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Shutdown");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case polish:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Wyjscie z podmenu, Odswiezenie glownego menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Pomoc");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Zapis preboot.log (tylko FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Zapis DSDT do EFI/CLOVER/ACPI/origin/ (tylko FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Zapis poprawionego DSDT do EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Zapis BIOSu k. graficznej do EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Zapis zrzutu ekranu do EFI/CLOVER/misc/ (tylko FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Wysuniecie zaznaczonego dysku (tylko dla DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Spacja - Informacje nt. dostepnych opcji dla zaznaczonego dysku");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Znaki 1-9 - Skroty opcji dla wybranego dysku");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Menu Informacyjne");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Menu Opcje");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Restart komputera");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Wylaczenie komputera");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case croatian:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - izlaz iz podizbornika, Osvježi glavni izbornik");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Ovaj izbornik");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Spremi preboot.log (samo na FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Spremi oem DSDT u EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Spremi patched DSDT into EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Spremi VideoBios into EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Spremi screenshot into EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Izbaci izabrai (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Space - Detalji o odabranom sistemu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Brojevi 1 do 9 su prečac do izbora");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Izbornik o meni");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Izbornik opcije");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Restart računala");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Isključivanje računala");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case czech:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Vrátit se do hlavní nabídky");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Tato Nápověda");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Uložit preboot.log (FAT32 only)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Uložit oem DSDT do EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Uložit patchnuté DSDT do EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Uložit VideoBios do EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Uložit snímek obrazovky do EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Vysunout vybranou mechaniku (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Mezerník - Podrobnosti o vybraném disku");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("čísla 1-9 - Klávesové zkratky pro disky");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Menu O Programu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Menu Možnosti");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Částečný restart");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Odejít");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case korean:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - 하위메뉴에서 나감, 메인메뉴 새로 고침");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - 이 도움말");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - preboot.log를 저장합니다. (FAT32방식에만 해당됨)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - oem DSDT를 EFI/CLOVER/ACPI/origin/에 저장합니다. (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - 패치된 DSDT를 EFI/CLOVER/ACPI/origin/에 저장합니다. (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - VideoBios를 EFI/CLOVER/misc/에 저장합니다. (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - 선택한 출력에서 사운드 확인");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - 오디오 코덱덤프를 EFI/CLOVER/misc/에 저장합니다.");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - 스크린샷을 EFI/CLOVER/misc/에 저장합니다. (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - NVRAM 초기화");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - 선택한 볼륨을 제거합니다. (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Space - 선택한 메뉴의 상세 설명");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Digits 1-9 - 메뉴 단축 번호");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - 단축키 - 이 부트로더에 관하여");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - 단축키 - 부트 옵션");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - 단축키 - 리셋");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - 단축키 - 시스템 종료");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case romanian:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Iesire din sub-meniu, Refresh meniul principal");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - Ajutor");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Salvare preboot.log (doar pentru FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Salvare oem DSDT in EFI/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Salvare DSDT modificat in EFI/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Salvare VideoBios in EFI/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Salvare screenshot in EFI/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Scoatere volum selectat (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Space - Detalii despre item-ul selectat");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Cifre 1-9 - Scurtaturi pentru itemele meniului");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Despre");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Optiuni");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Soft Reset");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Inchidere");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case chinese:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - 离开子菜单, 刷新主菜单");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - 帮助");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - 保存 preboot.log 到 EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - 显示隐藏的启动项");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - 保存原始的 DSDT 到 EFI/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - 保存修正后的 DSDT 到 EFI/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - 保存 VideoBios 到 EFI/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - 检查选中输出设备的声音");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - 生成声卡输出转储到 EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - 调整屏幕分辨率为下一个可用的模式");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - 保存截图到 EFI/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - 重置 NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - 推出选中的卷 (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("空格 - 关于选中项的详情");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("数字 1-9 - 菜单快捷键");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - 关于");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - 选项");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - 软复位");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - 退出");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case english:
|
|
|
|
|
default:
|
2020-04-04 18:22:07 +02:00
|
|
|
|
HelpMenu.AddMenuInfo_f("ESC - Escape from submenu, Refresh main menu");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F1 - This help");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F2 - Save preboot.log into EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F3 - Show hidden entries");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F4 - Save oem DSDT into EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F5 - Save patched DSDT into EFI/CLOVER/ACPI/origin/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F6 - Save VideoBios into EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F7 - Check sound on selected output");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F8 - Make audio outputs dump into EFI/CLOVER/misc/");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F9 - Switch screen resoluton to next possible mode");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F10 - Save screenshot into EFI/CLOVER/misc/ (FAT32)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F11 - Reset NVRAM");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("F12 - Eject selected volume (DVD)");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Space - Details about selected menu entry");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("Digits 1-9 - Shortcut to menu entry");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("A - Menu About");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("O - Menu Options");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("R - Soft Reset");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("U - Exit from Clover");
|
|
|
|
|
HelpMenu.AddMenuInfo_f("S - Shell");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
HelpMenu.AnimeRun = HelpMenu.GetAnime();
|
|
|
|
|
HelpMenu.AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
HelpMenu.RunMenu(NULL);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Graphics helper functions
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
SelectionImages:
|
|
|
|
|
[0] SelectionBig
|
|
|
|
|
[2] SelectionSmall
|
|
|
|
|
[4] SelectionIndicator
|
|
|
|
|
Buttons:
|
|
|
|
|
[0] radio_button
|
|
|
|
|
[1] radio_button_selected
|
|
|
|
|
[2] checkbox
|
|
|
|
|
[3] checkbox_checked
|
|
|
|
|
*/
|
2020-03-26 21:32:31 +01:00
|
|
|
|
#if !USE_XTHEME
|
2019-09-03 11:58:42 +02:00
|
|
|
|
VOID InitSelection(VOID)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if (!AllowGraphicsMode)
|
|
|
|
|
return;
|
|
|
|
|
SelectionBackgroundPixel.r = (GlobalConfig.SelectionColor >> 24) & 0xFF;
|
|
|
|
|
SelectionBackgroundPixel.g = (GlobalConfig.SelectionColor >> 16) & 0xFF;
|
|
|
|
|
SelectionBackgroundPixel.b = (GlobalConfig.SelectionColor >> 8) & 0xFF;
|
|
|
|
|
SelectionBackgroundPixel.a = (GlobalConfig.SelectionColor >> 0) & 0xFF;
|
|
|
|
|
|
|
|
|
|
if (SelectionImages[0] != NULL) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
// load small selection image
|
|
|
|
|
if (GlobalConfig.SelectionSmallFileName != NULL){
|
|
|
|
|
SelectionImages[2] = egLoadImage(ThemeDir, GlobalConfig.SelectionSmallFileName, FALSE);
|
|
|
|
|
}
|
|
|
|
|
if (SelectionImages[2] == NULL){
|
|
|
|
|
SelectionImages[2] = BuiltinIcon(BUILTIN_SELECTION_SMALL);
|
|
|
|
|
SelectionImages[2]->HasAlpha = FALSE; // support transparensy for selection icons
|
|
|
|
|
CopyMem(&BlueBackgroundPixel, &StdBackgroundPixel, sizeof(EG_PIXEL));
|
|
|
|
|
}
|
|
|
|
|
SelectionImages[2] = egEnsureImageSize(SelectionImages[2],
|
|
|
|
|
row1TileSize, row1TileSize, &MenuBackgroundPixel);
|
|
|
|
|
if (SelectionImages[2] == NULL) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
// load big selection image
|
|
|
|
|
if (!GlobalConfig.TypeSVG && GlobalConfig.SelectionBigFileName != NULL) {
|
|
|
|
|
SelectionImages[0] = egLoadImage(ThemeDir, GlobalConfig.SelectionBigFileName, FALSE);
|
|
|
|
|
SelectionImages[0] = egEnsureImageSize(SelectionImages[0],
|
|
|
|
|
row0TileSize, row0TileSize,
|
|
|
|
|
&MenuBackgroundPixel);
|
|
|
|
|
}
|
|
|
|
|
if (SelectionImages[0] == NULL) {
|
|
|
|
|
// calculate big selection image from small one
|
|
|
|
|
SelectionImages[0] = BuiltinIcon(BUILTIN_SELECTION_BIG);
|
|
|
|
|
SelectionImages[0]->HasAlpha = FALSE; // support transparensy for selection icons
|
|
|
|
|
CopyMem(&BlueBackgroundPixel, &StdBackgroundPixel, sizeof(EG_PIXEL));
|
|
|
|
|
if (SelectionImages[0] == NULL) {
|
|
|
|
|
egFreeImage(SelectionImages[2]);
|
|
|
|
|
SelectionImages[2] = NULL;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (GlobalConfig.SelectionOnTop) {
|
|
|
|
|
SelectionImages[0]->HasAlpha = TRUE;
|
|
|
|
|
SelectionImages[2]->HasAlpha = TRUE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// BootCampStyle indicator image
|
|
|
|
|
if (GlobalConfig.BootCampStyle) {
|
|
|
|
|
// load indicator selection image
|
|
|
|
|
if (GlobalConfig.SelectionIndicatorName != NULL) {
|
|
|
|
|
SelectionImages[4] = egLoadImage(ThemeDir, GlobalConfig.SelectionIndicatorName, TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!SelectionImages[4]) {
|
|
|
|
|
SelectionImages[4] = egDecodePNG(ACCESS_EMB_DATA(emb_selection_indicator), ACCESS_EMB_SIZE(emb_selection_indicator), TRUE);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
INTN ScaledIndicatorSize = (INTN)(INDICATOR_SIZE * GlobalConfig.Scale);
|
|
|
|
|
SelectionImages[4] = egEnsureImageSize(SelectionImages[4], ScaledIndicatorSize, ScaledIndicatorSize, &MenuBackgroundPixel);
|
|
|
|
|
if (!SelectionImages[4]) {
|
|
|
|
|
SelectionImages[4] = egCreateFilledImage(ScaledIndicatorSize, ScaledIndicatorSize,
|
|
|
|
|
TRUE, &StdBackgroundPixel);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
SelectionImages[5] = egCreateFilledImage(ScaledIndicatorSize, ScaledIndicatorSize,
|
|
|
|
|
TRUE, &MenuBackgroundPixel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
Button & radio, or any other next icons with builtin icon as fallback should synced to:
|
|
|
|
|
- BUILTIN_ICON_* in lib.h
|
|
|
|
|
- BuiltinIconTable in icns.c
|
|
|
|
|
- Data in egemb_icons.h / scroll_images.h
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
// Radio buttons
|
2020-03-15 21:05:59 +01:00
|
|
|
|
//it was a nonsense egLoadImage is just inluded into egLoadIcon.
|
|
|
|
|
// will be corrected with XTheme support
|
|
|
|
|
//the procedure loadIcon should also check embedded icons
|
2019-09-03 11:58:42 +02:00
|
|
|
|
Buttons[0] = egLoadImage(ThemeDir, GetIconsExt(L"radio_button", L"png"), TRUE); //memory leak
|
|
|
|
|
Buttons[1] = egLoadImage(ThemeDir, GetIconsExt(L"radio_button_selected", L"png"), TRUE);
|
|
|
|
|
if (!Buttons[0]) {
|
|
|
|
|
Buttons[0] = egLoadIcon(ThemeDir, L"radio_button.png", 48);
|
|
|
|
|
}
|
|
|
|
|
if (!Buttons[0]) {
|
|
|
|
|
Buttons[0] = egDecodePNG(ACCESS_EMB_DATA(emb_radio_button), ACCESS_EMB_SIZE(emb_radio_button), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!Buttons[1]) {
|
|
|
|
|
Buttons[1] = egLoadIcon(ThemeDir, L"radio_button_selected.png", 48);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!Buttons[1]) {
|
|
|
|
|
Buttons[1] = egDecodePNG(ACCESS_EMB_DATA(emb_radio_button_selected), ACCESS_EMB_SIZE(emb_radio_button_selected), TRUE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Checkbox
|
|
|
|
|
Buttons[2] = egLoadImage(ThemeDir, GetIconsExt(L"checkbox", L"png"), TRUE);
|
|
|
|
|
Buttons[3] = egLoadImage(ThemeDir, GetIconsExt(L"checkbox_checked", L"png"), TRUE);
|
|
|
|
|
if (!Buttons[2]) {
|
|
|
|
|
// DBG("egLoadIcon checkbox\n");
|
|
|
|
|
Buttons[2] = egLoadIcon(ThemeDir, L"checkbox.png", 48);
|
|
|
|
|
}
|
|
|
|
|
if (!Buttons[3]) {
|
|
|
|
|
// DBG("egLoadIcon checkbox_checked\n");
|
|
|
|
|
Buttons[3] = egLoadIcon(ThemeDir, L"checkbox_checked.png", 48);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!Buttons[2]) {
|
|
|
|
|
// DBG("embedded checkbox\n");
|
|
|
|
|
Buttons[2] = egDecodePNG(ACCESS_EMB_DATA(emb_checkbox), ACCESS_EMB_SIZE(emb_checkbox), TRUE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!Buttons[3]) {
|
|
|
|
|
// DBG("embedded checkbox_checked\n");
|
|
|
|
|
Buttons[3] = egDecodePNG(ACCESS_EMB_DATA(emb_checkbox_checked), ACCESS_EMB_SIZE(emb_checkbox_checked), TRUE);
|
|
|
|
|
}
|
|
|
|
|
// non-selected background images
|
2020-03-15 21:05:59 +01:00
|
|
|
|
//totally wrong
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (GlobalConfig.SelectionBigFileName != NULL) {
|
|
|
|
|
SelectionImages[1] = egCreateFilledImage(row0TileSize, row0TileSize,
|
|
|
|
|
TRUE, &MenuBackgroundPixel);
|
|
|
|
|
SelectionImages[3] = egCreateFilledImage(row1TileSize, row1TileSize,
|
|
|
|
|
TRUE, &MenuBackgroundPixel);
|
|
|
|
|
} else { // using embedded theme (this is an assumption but a better check is required)
|
|
|
|
|
EG_PIXEL BackgroundPixel;
|
|
|
|
|
if (GlobalConfig.DarkEmbedded || GlobalConfig.TypeSVG) {
|
|
|
|
|
BackgroundPixel = DarkEmbeddedBackgroundPixel;
|
|
|
|
|
BackgroundPixel.a = 0x00;
|
|
|
|
|
} else {
|
|
|
|
|
BackgroundPixel = StdBackgroundPixel;
|
|
|
|
|
BackgroundPixel.a = 0xff;
|
|
|
|
|
}
|
2020-03-15 21:05:59 +01:00
|
|
|
|
if (GlobalConfig.DarkEmbedded) { //nonsense then equal else
|
2019-09-03 11:58:42 +02:00
|
|
|
|
SelectionImages[1] = egCreateFilledImage(row0TileSize, row0TileSize,
|
|
|
|
|
TRUE, &BackgroundPixel);
|
|
|
|
|
SelectionImages[3] = egCreateFilledImage(row1TileSize, row1TileSize,
|
|
|
|
|
TRUE, &BackgroundPixel);
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
SelectionImages[1] = egCreateFilledImage(row0TileSize, row0TileSize,
|
|
|
|
|
TRUE, &BackgroundPixel); //&StdBackgroundPixel);
|
|
|
|
|
SelectionImages[3] = egCreateFilledImage(row1TileSize, row1TileSize,
|
|
|
|
|
TRUE, &BackgroundPixel);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// DBG("selections inited\n");
|
|
|
|
|
}
|
2020-03-26 21:32:31 +01:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
//
|
|
|
|
|
// Scrolling functions
|
|
|
|
|
//
|
|
|
|
|
#define CONSTRAIN_MIN(Variable, MinValue) if (Variable < MinValue) Variable = MinValue
|
|
|
|
|
#define CONSTRAIN_MAX(Variable, MaxValue) if (Variable > MaxValue) Variable = MaxValue
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#if !USE_XTHEME
|
|
|
|
|
INTN DrawTextXY(IN CONST CHAR16 *Text, IN INTN XPos, IN INTN YPos, IN UINT8 XAlign)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-04-04 14:27:02 +02:00
|
|
|
|
INTN TextWidth = 0;
|
|
|
|
|
INTN XText = 0;
|
|
|
|
|
INTN Height;
|
|
|
|
|
INTN TextXYStyle = 1;
|
|
|
|
|
EG_IMAGE *TextBufferXY = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!Text) {
|
|
|
|
|
return 0;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!textFace[1].valid) {
|
|
|
|
|
if (textFace[2].valid) {
|
|
|
|
|
TextXYStyle = 2;
|
|
|
|
|
} else {
|
|
|
|
|
TextXYStyle = 0;
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
egMeasureText(Text, &TextWidth, NULL);
|
2020-04-02 16:03:58 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (XAlign == X_IS_LEFT) {
|
|
|
|
|
TextWidth = UGAWidth - XPos - 1;
|
|
|
|
|
XText = XPos;
|
|
|
|
|
}
|
2020-04-02 16:03:58 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
TextWidth += TextHeight * 2; //give more place for buffer
|
|
|
|
|
if (!textFace[TextXYStyle].valid) {
|
|
|
|
|
DBG("no vaid text face for message!\n");
|
|
|
|
|
Height = TextHeight;
|
|
|
|
|
} else {
|
|
|
|
|
Height = (int)(textFace[TextXYStyle].size * RowHeightFromTextHeight * GlobalConfig.Scale);
|
|
|
|
|
}
|
2020-04-02 16:03:58 +02:00
|
|
|
|
} else {
|
2020-04-04 14:27:02 +02:00
|
|
|
|
Height = TextHeight;
|
2020-04-02 16:03:58 +02:00
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
TextBufferXY = egCreateFilledImage(TextWidth, Height, TRUE, &MenuBackgroundPixel);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
// render the text
|
|
|
|
|
TextWidth = egRenderText(Text, TextBufferXY, 0, 0, 0xFFFF, TextXYStyle);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (XAlign != X_IS_LEFT) {
|
|
|
|
|
// shift 64 is prohibited
|
|
|
|
|
XText = XPos - (TextWidth >> XAlign); //X_IS_CENTER = 1
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
// DBG("draw text %ls\n", Text);
|
|
|
|
|
// DBG("pos=%d width=%d xtext=%d Height=%d Y=%d\n", XPos, TextWidth, XText, Height, YPos);
|
|
|
|
|
BltImageAlpha(TextBufferXY, XText, YPos, &MenuBackgroundPixel, 16);
|
|
|
|
|
egFreeImage(TextBufferXY);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
return TextWidth;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-22 11:48:13 +01:00
|
|
|
|
#endif
|
2020-04-04 14:27:02 +02:00
|
|
|
|
/**
|
|
|
|
|
* Helper function to draw text for Boot Camp Style.
|
|
|
|
|
* @author: Needy
|
|
|
|
|
*/
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#if USE_XTHEME
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#else
|
|
|
|
|
VOID DrawMenuText(IN CONST CHAR16 *Text, IN INTN SelectedWidth, IN INTN XPos, IN INTN YPos, IN INTN Cursor)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//use Text=null to reinit the buffer
|
|
|
|
|
if (!Text) {
|
|
|
|
|
if (TextBuffer) {
|
|
|
|
|
egFreeImage(TextBuffer);
|
|
|
|
|
TextBuffer = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
return;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (TextBuffer && (TextBuffer->Height != TextHeight)) {
|
|
|
|
|
egFreeImage(TextBuffer);
|
|
|
|
|
TextBuffer = NULL;
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (TextBuffer == NULL) {
|
|
|
|
|
TextBuffer = egCreateImage(UGAWidth-XPos, TextHeight, TRUE);
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (Cursor != 0xFFFF) {
|
|
|
|
|
egFillImage(TextBuffer, &MenuBackgroundPixel);
|
|
|
|
|
} else {
|
|
|
|
|
egFillImage(TextBuffer, &InputBackgroundPixel);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (SelectedWidth > 0) {
|
|
|
|
|
// draw selection bar background
|
|
|
|
|
egFillImageArea(TextBuffer, 0, 0, (INTN)SelectedWidth, TextHeight,
|
|
|
|
|
&SelectionBackgroundPixel);
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
// render the text
|
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
//clovy - text veltically centred on Height
|
|
|
|
|
egRenderText(Text, TextBuffer, 0,
|
|
|
|
|
(INTN)((TextHeight - (textFace[TextStyle].size * GlobalConfig.Scale)) / 2),
|
|
|
|
|
Cursor, TextStyle);
|
|
|
|
|
} else {
|
|
|
|
|
egRenderText(Text, TextBuffer, TEXT_XMARGIN, TEXT_YMARGIN, Cursor, TextStyle);
|
|
|
|
|
}
|
|
|
|
|
BltImageAlpha(TextBuffer, (INTN)XPos, (INTN)YPos, &MenuBackgroundPixel, 16);
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#if !USE_XTHEME
|
|
|
|
|
VOID FreeScrollBar(VOID)
|
|
|
|
|
{
|
|
|
|
|
if (ScrollbarBackgroundImage) {
|
|
|
|
|
egFreeImage(ScrollbarBackgroundImage);
|
|
|
|
|
ScrollbarBackgroundImage = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (BarStartImage) {
|
|
|
|
|
egFreeImage(BarStartImage);
|
|
|
|
|
BarStartImage = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (BarEndImage) {
|
|
|
|
|
egFreeImage(BarEndImage);
|
|
|
|
|
BarEndImage = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (ScrollbarImage) {
|
|
|
|
|
egFreeImage(ScrollbarImage);
|
|
|
|
|
ScrollbarImage = NULL;
|
2020-03-23 20:10:16 +01:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (ScrollStartImage) {
|
|
|
|
|
egFreeImage(ScrollStartImage);
|
|
|
|
|
ScrollStartImage = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (ScrollEndImage) {
|
|
|
|
|
egFreeImage(ScrollEndImage);
|
|
|
|
|
ScrollEndImage = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (UpButtonImage) {
|
|
|
|
|
egFreeImage(UpButtonImage);
|
|
|
|
|
UpButtonImage = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (DownButtonImage) {
|
|
|
|
|
egFreeImage(DownButtonImage);
|
|
|
|
|
DownButtonImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
VOID InitBar(VOID)
|
|
|
|
|
{
|
|
|
|
|
if (ThemeDir) {
|
|
|
|
|
if (!ScrollbarBackgroundImage) {
|
|
|
|
|
ScrollbarBackgroundImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\bar_fill", L"png"), FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!BarStartImage) {
|
|
|
|
|
BarStartImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\bar_start", L"png"), TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!BarEndImage) {
|
|
|
|
|
BarEndImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\bar_end", L"png"), TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!ScrollbarImage) {
|
|
|
|
|
ScrollbarImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\scroll_fill", L"png"), FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!ScrollStartImage) {
|
|
|
|
|
ScrollStartImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\scroll_start", L"png"), TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!ScrollEndImage) {
|
|
|
|
|
ScrollEndImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\scroll_end", L"png"), TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!UpButtonImage) {
|
|
|
|
|
UpButtonImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\up_button", L"png"), TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!DownButtonImage) {
|
|
|
|
|
DownButtonImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\down_button", L"png"), TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!BarStartImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
BarStartImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_bar_start), ACCESS_EMB_SIZE(emb_scroll_bar_start), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!BarEndImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
BarEndImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_bar_end), ACCESS_EMB_SIZE(emb_scroll_bar_end), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollbarBackgroundImage) {
|
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
ScrollbarBackgroundImage = egLoadIcon(ThemeDir, L"scrollbar-background.png", 48);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!ScrollbarBackgroundImage) {
|
|
|
|
|
ScrollbarBackgroundImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_bar_fill), ACCESS_EMB_SIZE(emb_scroll_bar_fill), TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!ScrollbarImage) {
|
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
ScrollbarImage = egLoadIcon(ThemeDir, L"scrollbar-holder.png", 48);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollbarImage) {
|
|
|
|
|
ScrollbarImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_scroll_fill), ACCESS_EMB_SIZE(emb_scroll_scroll_fill), TRUE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollStartImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
ScrollStartImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_scroll_start), ACCESS_EMB_SIZE(emb_scroll_scroll_start), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollEndImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
ScrollEndImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_scroll_end), ACCESS_EMB_SIZE(emb_scroll_scroll_end), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!UpButtonImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
UpButtonImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_up_button), ACCESS_EMB_SIZE(emb_scroll_up_button), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!DownButtonImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
DownButtonImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_down_button), ACCESS_EMB_SIZE(emb_scroll_down_button), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!GlobalConfig.TypeSVG) {
|
|
|
|
|
UpButton.Width = ScrollWidth; // 16
|
|
|
|
|
UpButton.Height = ScrollButtonsHeight; // 20
|
|
|
|
|
DownButton.Width = UpButton.Width;
|
|
|
|
|
DownButton.Height = ScrollButtonsHeight;
|
|
|
|
|
BarStart.Height = ScrollBarDecorationsHeight; // 5
|
|
|
|
|
BarEnd.Height = ScrollBarDecorationsHeight;
|
|
|
|
|
ScrollStart.Height = ScrollScrollDecorationsHeight; // 7
|
|
|
|
|
ScrollEnd.Height = ScrollScrollDecorationsHeight;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
} else {
|
|
|
|
|
UpButton.Width = ScrollWidth; // 16
|
|
|
|
|
UpButton.Height = 0; // 20
|
|
|
|
|
DownButton.Width = UpButton.Width;
|
|
|
|
|
DownButton.Height = 0;
|
|
|
|
|
BarStart.Height = ScrollBarDecorationsHeight; // 5
|
|
|
|
|
BarEnd.Height = ScrollBarDecorationsHeight;
|
|
|
|
|
ScrollStart.Height = 0; // 7
|
|
|
|
|
ScrollEnd.Height = 0;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
/**
|
2020-04-04 14:27:02 +02:00
|
|
|
|
* Draw entries for GUI.
|
2019-09-03 11:58:42 +02:00
|
|
|
|
*/
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#if USE_XTHEME
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
#else
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
VOID DrawMainMenuEntry(REFIT_ABSTRACT_MENU_ENTRY *Entry, BOOLEAN selected, INTN XPos, INTN YPos)
|
|
|
|
|
{
|
|
|
|
|
EG_IMAGE* MainImage = NULL;
|
|
|
|
|
EG_IMAGE* BadgeImage = NULL;
|
|
|
|
|
bool NewImageCreated = false;
|
|
|
|
|
INTN Scale = GlobalConfig.MainEntriesSize >> 3; //usually it is 128>>3 == 16. if 256>>3 == 32
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (Entry->Row == 0 && Entry->getDriveImage() && !(GlobalConfig.HideBadges & HDBADGES_SWAP)) {
|
|
|
|
|
MainImage = Entry->getDriveImage();
|
|
|
|
|
} else {
|
|
|
|
|
MainImage = Entry->Image;
|
|
|
|
|
}
|
|
|
|
|
//this should be inited by the Theme
|
|
|
|
|
if (!MainImage) {
|
|
|
|
|
if (!IsEmbeddedTheme()) {
|
|
|
|
|
MainImage = egLoadIcon(ThemeDir, GetIconsExt(L"icons\\os_mac", L"icns"), Scale << 3);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (!MainImage) {
|
|
|
|
|
MainImage = DummyImage(Scale << 3);
|
|
|
|
|
}
|
|
|
|
|
if (MainImage) {
|
|
|
|
|
NewImageCreated = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// DBG("Entry title=%ls; Width=%d\n", Entry->Title, MainImage->Width);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
Scale = 16 * (selected ? 1 : -1);
|
|
|
|
|
} else {
|
|
|
|
|
Scale = ((Entry->Row == 0) ? (Scale * (selected ? 1 : -1)): 16) ;
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
if (Entry->Row == 0) {
|
|
|
|
|
BadgeImage = Entry->getBadgeImage();
|
|
|
|
|
} //else null
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 19:05:57 +02:00
|
|
|
|
for (i = ScrollState.FirstVisible; i <= ScrollState.LastVisible && i <= ScrollState.MaxIndex; i++) {
|
2020-03-03 10:45:07 +01:00
|
|
|
|
gST->ConOut->SetCursorPosition (gST->ConOut, 2, MenuPosY + (i - ScrollState.FirstVisible));
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 10:45:07 +01:00
|
|
|
|
if (i == ScrollState.CurrentSelection) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, ATTR_CHOICE_CURRENT);
|
|
|
|
|
} else {
|
|
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, ATTR_CHOICE_BASIC);
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 10:45:07 +01:00
|
|
|
|
StrCpyS(ResultString, TITLE_MAX_LEN, Entries[i].Title);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 10:45:07 +01:00
|
|
|
|
if (Entries[i].getREFIT_INPUT_DIALOG()) {
|
|
|
|
|
REFIT_INPUT_DIALOG& entry = (REFIT_INPUT_DIALOG&) Entries[i];
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if (entry.getREFIT_INPUT_DIALOG()) {
|
|
|
|
|
if ((entry).Item->ItemType == BoolValue) {
|
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, (entry).Item->BValue ? L": [+]" : L": [ ]");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, (entry).Item->SValue);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-02-28 21:28:33 +01:00
|
|
|
|
} else if (entry.getREFIT_MENU_CHECKBIT()) {
|
|
|
|
|
// check boxes
|
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, ((entry).Item->IValue & (entry.Row)) ? L": [+]" : L": [ ]");
|
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()) {
|
|
|
|
|
// radio buttons
|
|
|
|
|
|
|
|
|
|
// update chosen config
|
|
|
|
|
if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 90) {
|
|
|
|
|
OldChosenItem = OldChosenConfig;
|
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 116) {
|
2019-09-03 11:58:42 +02:00
|
|
|
|
OldChosenItem = OldChosenDsdt;
|
2020-02-28 21:28:33 +01:00
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 119) {
|
2019-09-03 11:58:42 +02:00
|
|
|
|
OldChosenItem = OldChosenAudio;
|
|
|
|
|
}
|
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, (entry.Row == OldChosenItem) ? L": (*)" : L": ( )");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-02-28 21:28:33 +01:00
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
for (j = StrLen(ResultString); j < (INTN)TextMenuWidth; j++) {
|
|
|
|
|
ResultString[j] = L' ';
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
ResultString[j] = 0;
|
|
|
|
|
gST->ConOut->OutputString(gST->ConOut, ResultString);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// scrolling indicators
|
|
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, ATTR_SCROLLARROW);
|
|
|
|
|
gST->ConOut->SetCursorPosition (gST->ConOut, 0, MenuPosY);
|
|
|
|
|
|
2020-03-03 10:45:07 +01:00
|
|
|
|
if (ScrollState.FirstVisible > 0) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
gST->ConOut->OutputString (gST->ConOut, ArrowUp);
|
|
|
|
|
} else {
|
|
|
|
|
gST->ConOut->OutputString (gST->ConOut, L" ");
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 10:45:07 +01:00
|
|
|
|
gST->ConOut->SetCursorPosition (gST->ConOut, 0, MenuPosY + ScrollState.MaxVisible);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 10:45:07 +01:00
|
|
|
|
if (ScrollState.LastVisible < ScrollState.MaxIndex) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
gST->ConOut->OutputString (gST->ConOut, ArrowDown);
|
|
|
|
|
} else {
|
|
|
|
|
gST->ConOut->OutputString (gST->ConOut, L" ");
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case MENU_FUNCTION_PAINT_SELECTION:
|
|
|
|
|
// last selection
|
|
|
|
|
// redraw selection cursor
|
2020-03-03 10:45:07 +01:00
|
|
|
|
gST->ConOut->SetCursorPosition (gST->ConOut, 2, MenuPosY + (ScrollState.LastSelection - ScrollState.FirstVisible));
|
2019-09-03 11:58:42 +02:00
|
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, ATTR_CHOICE_BASIC);
|
2020-03-03 10:45:07 +01:00
|
|
|
|
//gST->ConOut->OutputString (gST->ConOut, DisplayStrings[ScrollState.LastSelection]);
|
|
|
|
|
StrCpyS(ResultString, TITLE_MAX_LEN, Entries[ScrollState.LastSelection].Title);
|
|
|
|
|
if (Entries[ScrollState.LastSelection].getREFIT_INPUT_DIALOG()) {
|
|
|
|
|
REFIT_INPUT_DIALOG& entry = (REFIT_INPUT_DIALOG&) Entries[ScrollState.LastSelection];
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if (entry.getREFIT_INPUT_DIALOG()) {
|
|
|
|
|
if (entry.Item->ItemType == BoolValue) {
|
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, entry.Item->BValue ? L": [+]" : L": [ ]");
|
|
|
|
|
} else {
|
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, entry.Item->SValue);
|
|
|
|
|
}
|
|
|
|
|
} else if (entry.getREFIT_MENU_CHECKBIT()) {
|
|
|
|
|
// check boxes
|
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, (entry.Item->IValue & (entry.Row)) ? L": [+]" : L": [ ]");
|
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()) {
|
|
|
|
|
// radio buttons
|
|
|
|
|
|
|
|
|
|
if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 90) {
|
|
|
|
|
OldChosenItem = OldChosenConfig;
|
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 116) {
|
|
|
|
|
OldChosenItem = OldChosenDsdt;
|
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 119) {
|
|
|
|
|
OldChosenItem = OldChosenAudio;
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, (entry.Row == OldChosenItem) ? L": (*)" : L": ( )");
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
for (j = StrLen(ResultString); j < (INTN) TextMenuWidth; j++) {
|
|
|
|
|
ResultString[j] = L' ';
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
ResultString[j] = 0;
|
|
|
|
|
gST->ConOut->OutputString (gST->ConOut, ResultString);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// current selection
|
2020-03-03 10:45:07 +01:00
|
|
|
|
gST->ConOut->SetCursorPosition (gST->ConOut, 2, MenuPosY + (ScrollState.CurrentSelection - ScrollState.FirstVisible));
|
2019-09-03 11:58:42 +02:00
|
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, ATTR_CHOICE_CURRENT);
|
2020-03-03 10:45:07 +01:00
|
|
|
|
StrCpyS(ResultString, TITLE_MAX_LEN, Entries[ScrollState.CurrentSelection].Title);
|
|
|
|
|
if (Entries[ScrollState.CurrentSelection].getREFIT_INPUT_DIALOG()) {
|
|
|
|
|
REFIT_INPUT_DIALOG& entry = (REFIT_INPUT_DIALOG&) Entries[ScrollState.CurrentSelection];
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if (entry.getREFIT_INPUT_DIALOG()) {
|
|
|
|
|
if (entry.Item->ItemType == BoolValue) {
|
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, entry.Item->BValue ? L": [+]" : L": [ ]");
|
|
|
|
|
} else {
|
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, entry.Item->SValue);
|
|
|
|
|
}
|
|
|
|
|
} else if (entry.getREFIT_MENU_CHECKBIT()) {
|
|
|
|
|
// check boxes
|
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, (entry.Item->IValue & (entry.Row)) ? L": [+]" : L": [ ]");
|
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()) {
|
|
|
|
|
// radio buttons
|
|
|
|
|
|
|
|
|
|
if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 90) {
|
|
|
|
|
OldChosenItem = OldChosenConfig;
|
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 116) {
|
|
|
|
|
OldChosenItem = OldChosenDsdt;
|
|
|
|
|
} else if (entry.getREFIT_MENU_SWITCH()->Item->IValue == 119) {
|
|
|
|
|
OldChosenItem = OldChosenAudio;
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
StrCatS(ResultString, TITLE_MAX_LEN, (entry.Row == OldChosenItem) ? L": (*)" : L": ( )");
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
for (j = StrLen(ResultString); j < (INTN) TextMenuWidth; j++) {
|
|
|
|
|
ResultString[j] = L' ';
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
ResultString[j] = 0;
|
|
|
|
|
gST->ConOut->OutputString (gST->ConOut, ResultString);
|
2020-03-03 10:45:07 +01:00
|
|
|
|
//gST->ConOut->OutputString (gST->ConOut, DisplayStrings[ScrollState.CurrentSelection]);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case MENU_FUNCTION_PAINT_TIMEOUT:
|
|
|
|
|
if (ParamText[0] == 0) {
|
|
|
|
|
// clear message
|
|
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, ATTR_BASIC);
|
|
|
|
|
gST->ConOut->SetCursorPosition (gST->ConOut, 0, ConHeight - 1);
|
|
|
|
|
gST->ConOut->OutputString (gST->ConOut, BlankLine + 1);
|
|
|
|
|
} else {
|
|
|
|
|
// paint or update message
|
|
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, ATTR_ERROR);
|
|
|
|
|
gST->ConOut->SetCursorPosition (gST->ConOut, 3, ConHeight - 1);
|
|
|
|
|
TimeoutMessage = PoolPrint(L"%s ", ParamText);
|
|
|
|
|
gST->ConOut->OutputString (gST->ConOut, TimeoutMessage);
|
|
|
|
|
FreePool(TimeoutMessage);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
}
|
2020-04-05 05:44:27 +02:00
|
|
|
|
|
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Draw text with specific coordinates.
|
|
|
|
|
*/
|
2020-03-23 20:10:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if USE_XTHEME
|
2020-04-01 14:57:32 +02:00
|
|
|
|
|
2020-03-23 20:10:16 +01:00
|
|
|
|
#else
|
|
|
|
|
|
|
|
|
|
|
2020-02-17 21:41:09 +01:00
|
|
|
|
INTN DrawTextXY(IN CONST CHAR16 *Text, IN INTN XPos, IN INTN YPos, IN UINT8 XAlign)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
INTN TextWidth = 0;
|
|
|
|
|
INTN XText = 0;
|
|
|
|
|
INTN Height;
|
|
|
|
|
INTN TextXYStyle = 1;
|
|
|
|
|
EG_IMAGE *TextBufferXY = NULL;
|
|
|
|
|
|
|
|
|
|
if (!Text) {
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
if (!textFace[1].valid) {
|
|
|
|
|
if (textFace[2].valid) {
|
|
|
|
|
TextXYStyle = 2;
|
|
|
|
|
} else {
|
|
|
|
|
TextXYStyle = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
egMeasureText(Text, &TextWidth, NULL);
|
|
|
|
|
|
|
|
|
|
if (XAlign == X_IS_LEFT) {
|
|
|
|
|
TextWidth = UGAWidth - XPos - 1;
|
|
|
|
|
XText = XPos;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
TextWidth += TextHeight * 2; //give more place for buffer
|
|
|
|
|
if (!textFace[TextXYStyle].valid) {
|
|
|
|
|
DBG("no vaid text face for message!\n");
|
|
|
|
|
Height = TextHeight;
|
|
|
|
|
} else {
|
|
|
|
|
Height = (int)(textFace[TextXYStyle].size * RowHeightFromTextHeight * GlobalConfig.Scale);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
Height = TextHeight;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TextBufferXY = egCreateFilledImage(TextWidth, Height, TRUE, &MenuBackgroundPixel);
|
|
|
|
|
|
|
|
|
|
// render the text
|
|
|
|
|
TextWidth = egRenderText(Text, TextBufferXY, 0, 0, 0xFFFF, TextXYStyle);
|
|
|
|
|
|
|
|
|
|
if (XAlign != X_IS_LEFT) {
|
|
|
|
|
// shift 64 is prohibited
|
|
|
|
|
XText = XPos - (TextWidth >> XAlign); //X_IS_CENTER = 1
|
|
|
|
|
}
|
2020-03-25 19:32:44 +01:00
|
|
|
|
// DBG("draw text %ls\n", Text);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
// DBG("pos=%d width=%d xtext=%d Height=%d Y=%d\n", XPos, TextWidth, XText, Height, YPos);
|
|
|
|
|
BltImageAlpha(TextBufferXY, XText, YPos, &MenuBackgroundPixel, 16);
|
|
|
|
|
egFreeImage(TextBufferXY);
|
|
|
|
|
|
|
|
|
|
return TextWidth;
|
|
|
|
|
}
|
2020-03-23 20:10:16 +01:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
/**
|
|
|
|
|
* Helper function to draw text for Boot Camp Style.
|
|
|
|
|
* @author: Needy
|
|
|
|
|
*/
|
2020-04-05 05:44:27 +02:00
|
|
|
|
#if !USE_XTHEME
|
2020-04-01 14:57:32 +02:00
|
|
|
|
VOID REFIT_MENU_SCREEN::DrawBCSText(IN CONST CHAR16 *Text, IN INTN XPos, IN INTN YPos, IN UINT8 XAlign)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
// check if text was provided
|
|
|
|
|
if (!Text) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
INTN TextLen = StrLen(Text);
|
|
|
|
|
|
|
|
|
|
// number of chars to be drawn on the screen
|
|
|
|
|
INTN MaxTextLen = 13;
|
|
|
|
|
INTN EllipsisLen = 2;
|
|
|
|
|
|
|
|
|
|
CHAR16 *BCSText = NULL;
|
|
|
|
|
|
|
|
|
|
// more space, more characters
|
|
|
|
|
if (GlobalConfig.TileXSpace >= 25 && GlobalConfig.TileXSpace < 30) {
|
|
|
|
|
MaxTextLen = 14;
|
|
|
|
|
} else if (GlobalConfig.TileXSpace >= 30 && GlobalConfig.TileXSpace < 35) {
|
|
|
|
|
MaxTextLen = 15;
|
|
|
|
|
} else if (GlobalConfig.TileXSpace >= 35 && GlobalConfig.TileXSpace < 40) {
|
|
|
|
|
MaxTextLen = 16;
|
|
|
|
|
} else if (GlobalConfig.TileXSpace >= 40 && GlobalConfig.TileXSpace < 45) {
|
|
|
|
|
MaxTextLen = 17;
|
|
|
|
|
} else if (GlobalConfig.TileXSpace >= 45 && GlobalConfig.TileXSpace < 50) {
|
|
|
|
|
MaxTextLen = 18;
|
|
|
|
|
} else if (GlobalConfig.TileXSpace >= 50) {
|
|
|
|
|
MaxTextLen = 19;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MaxTextLen += EllipsisLen;
|
|
|
|
|
|
|
|
|
|
// if the text exceeds the given limit
|
|
|
|
|
if (TextLen > MaxTextLen) {
|
2019-12-21 01:31:49 +01:00
|
|
|
|
BCSText = (__typeof__(BCSText))AllocatePool((sizeof(CHAR16) * MaxTextLen) + 1);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// error check, not enough memory
|
|
|
|
|
if (!BCSText) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// copy the permited amound of chars minus the ellipsis
|
|
|
|
|
StrnCpyS(BCSText, (MaxTextLen - EllipsisLen) + 1, Text, MaxTextLen - EllipsisLen);
|
|
|
|
|
BCSText[MaxTextLen - EllipsisLen] = '\0';
|
|
|
|
|
|
|
|
|
|
// add ellipsis
|
|
|
|
|
StrnCatS(BCSText, MaxTextLen + 1, L"..", EllipsisLen);
|
|
|
|
|
// redundant, used for safety measures
|
|
|
|
|
BCSText[MaxTextLen] = '\0';
|
|
|
|
|
DrawTextXY(BCSText, XPos, YPos, XAlign);
|
|
|
|
|
FreePool(BCSText);
|
|
|
|
|
} else {
|
|
|
|
|
// draw full text
|
|
|
|
|
DrawTextXY(Text, XPos, YPos, XAlign);
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-04-05 05:44:27 +02:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-24 16:17:12 +01:00
|
|
|
|
#if USE_XTHEME
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-24 16:17:12 +01:00
|
|
|
|
#else
|
2020-02-17 21:41:09 +01:00
|
|
|
|
VOID DrawMenuText(IN CONST CHAR16 *Text, IN INTN SelectedWidth, IN INTN XPos, IN INTN YPos, IN INTN Cursor)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
//use Text=null to reinit the buffer
|
|
|
|
|
if (!Text) {
|
|
|
|
|
if (TextBuffer) {
|
|
|
|
|
egFreeImage(TextBuffer);
|
|
|
|
|
TextBuffer = NULL;
|
|
|
|
|
}
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (TextBuffer && (TextBuffer->Height != TextHeight)) {
|
|
|
|
|
egFreeImage(TextBuffer);
|
|
|
|
|
TextBuffer = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (TextBuffer == NULL) {
|
|
|
|
|
TextBuffer = egCreateImage(UGAWidth-XPos, TextHeight, TRUE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (Cursor != 0xFFFF) {
|
|
|
|
|
egFillImage(TextBuffer, &MenuBackgroundPixel);
|
|
|
|
|
} else {
|
|
|
|
|
egFillImage(TextBuffer, &InputBackgroundPixel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (SelectedWidth > 0) {
|
|
|
|
|
// draw selection bar background
|
|
|
|
|
egFillImageArea(TextBuffer, 0, 0, (INTN)SelectedWidth, TextHeight,
|
|
|
|
|
&SelectionBackgroundPixel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// render the text
|
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
//clovy - text veltically centred on Height
|
|
|
|
|
egRenderText(Text, TextBuffer, 0,
|
2020-03-24 16:17:12 +01:00
|
|
|
|
(INTN)((TextHeight - (textFace[TextStyle].size * GlobalConfig.Scale)) / 2),
|
|
|
|
|
Cursor, TextStyle);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else {
|
|
|
|
|
egRenderText(Text, TextBuffer, TEXT_XMARGIN, TEXT_YMARGIN, Cursor, TextStyle);
|
|
|
|
|
}
|
|
|
|
|
BltImageAlpha(TextBuffer, (INTN)XPos, (INTN)YPos, &MenuBackgroundPixel, 16);
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-24 16:17:12 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
2020-04-02 16:03:58 +02:00
|
|
|
|
#if !USE_XTHEME
|
2019-09-03 11:58:42 +02:00
|
|
|
|
VOID FreeScrollBar(VOID)
|
|
|
|
|
{
|
|
|
|
|
if (ScrollbarBackgroundImage) {
|
|
|
|
|
egFreeImage(ScrollbarBackgroundImage);
|
|
|
|
|
ScrollbarBackgroundImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
if (BarStartImage) {
|
|
|
|
|
egFreeImage(BarStartImage);
|
|
|
|
|
BarStartImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
if (BarEndImage) {
|
|
|
|
|
egFreeImage(BarEndImage);
|
|
|
|
|
BarEndImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
if (ScrollbarImage) {
|
|
|
|
|
egFreeImage(ScrollbarImage);
|
|
|
|
|
ScrollbarImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
if (ScrollStartImage) {
|
|
|
|
|
egFreeImage(ScrollStartImage);
|
|
|
|
|
ScrollStartImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
if (ScrollEndImage) {
|
|
|
|
|
egFreeImage(ScrollEndImage);
|
|
|
|
|
ScrollEndImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
if (UpButtonImage) {
|
|
|
|
|
egFreeImage(UpButtonImage);
|
|
|
|
|
UpButtonImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
if (DownButtonImage) {
|
|
|
|
|
egFreeImage(DownButtonImage);
|
|
|
|
|
DownButtonImage = NULL;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-02 16:03:58 +02:00
|
|
|
|
|
2019-09-03 11:58:42 +02:00
|
|
|
|
VOID InitBar(VOID)
|
|
|
|
|
{
|
|
|
|
|
if (ThemeDir) {
|
|
|
|
|
if (!ScrollbarBackgroundImage) {
|
|
|
|
|
ScrollbarBackgroundImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\bar_fill", L"png"), FALSE);
|
|
|
|
|
}
|
|
|
|
|
if (!BarStartImage) {
|
|
|
|
|
BarStartImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\bar_start", L"png"), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!BarEndImage) {
|
|
|
|
|
BarEndImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\bar_end", L"png"), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollbarImage) {
|
|
|
|
|
ScrollbarImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\scroll_fill", L"png"), FALSE);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollStartImage) {
|
|
|
|
|
ScrollStartImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\scroll_start", L"png"), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollEndImage) {
|
|
|
|
|
ScrollEndImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\scroll_end", L"png"), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!UpButtonImage) {
|
|
|
|
|
UpButtonImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\up_button", L"png"), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!DownButtonImage) {
|
|
|
|
|
DownButtonImage = egLoadImage(ThemeDir, GetIconsExt(L"scrollbar\\down_button", L"png"), TRUE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!BarStartImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
BarStartImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_bar_start), ACCESS_EMB_SIZE(emb_scroll_bar_start), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!BarEndImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
BarEndImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_bar_end), ACCESS_EMB_SIZE(emb_scroll_bar_end), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollbarBackgroundImage) {
|
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
ScrollbarBackgroundImage = egLoadIcon(ThemeDir, L"scrollbar-background.png", 48);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollbarBackgroundImage) {
|
|
|
|
|
ScrollbarBackgroundImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_bar_fill), ACCESS_EMB_SIZE(emb_scroll_bar_fill), TRUE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollbarImage) {
|
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
ScrollbarImage = egLoadIcon(ThemeDir, L"scrollbar-holder.png", 48);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollbarImage) {
|
|
|
|
|
ScrollbarImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_scroll_fill), ACCESS_EMB_SIZE(emb_scroll_scroll_fill), TRUE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollStartImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
ScrollStartImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_scroll_start), ACCESS_EMB_SIZE(emb_scroll_scroll_start), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!ScrollEndImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
ScrollEndImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_scroll_end), ACCESS_EMB_SIZE(emb_scroll_scroll_end), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!UpButtonImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
UpButtonImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_up_button), ACCESS_EMB_SIZE(emb_scroll_up_button), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!DownButtonImage && !GlobalConfig.TypeSVG) {
|
|
|
|
|
DownButtonImage = egDecodePNG(ACCESS_EMB_DATA(emb_scroll_down_button), ACCESS_EMB_SIZE(emb_scroll_down_button), TRUE);
|
|
|
|
|
}
|
|
|
|
|
if (!GlobalConfig.TypeSVG) {
|
|
|
|
|
UpButton.Width = ScrollWidth; // 16
|
|
|
|
|
UpButton.Height = ScrollButtonsHeight; // 20
|
|
|
|
|
DownButton.Width = UpButton.Width;
|
|
|
|
|
DownButton.Height = ScrollButtonsHeight;
|
|
|
|
|
BarStart.Height = ScrollBarDecorationsHeight; // 5
|
|
|
|
|
BarEnd.Height = ScrollBarDecorationsHeight;
|
|
|
|
|
ScrollStart.Height = ScrollScrollDecorationsHeight; // 7
|
|
|
|
|
ScrollEnd.Height = ScrollScrollDecorationsHeight;
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
UpButton.Width = ScrollWidth; // 16
|
|
|
|
|
UpButton.Height = 0; // 20
|
|
|
|
|
DownButton.Width = UpButton.Width;
|
|
|
|
|
DownButton.Height = 0;
|
|
|
|
|
BarStart.Height = ScrollBarDecorationsHeight; // 5
|
|
|
|
|
BarEnd.Height = ScrollBarDecorationsHeight;
|
|
|
|
|
ScrollStart.Height = 0; // 7
|
|
|
|
|
ScrollEnd.Height = 0;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-03-26 21:32:31 +01:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
/**
|
|
|
|
|
* Draw entries for GUI.
|
|
|
|
|
*/
|
2020-03-20 18:48:19 +01:00
|
|
|
|
#if USE_XTHEME
|
2020-04-05 05:44:27 +02:00
|
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
VOID DrawMainMenuEntry(REFIT_ABSTRACT_MENU_ENTRY *Entry, BOOLEAN selected, INTN XPos, INTN YPos)
|
2020-03-20 18:48:19 +01:00
|
|
|
|
{
|
2020-04-05 05:44:27 +02:00
|
|
|
|
EG_IMAGE* MainImage = NULL;
|
|
|
|
|
EG_IMAGE* BadgeImage = NULL;
|
|
|
|
|
bool NewImageCreated = false;
|
|
|
|
|
INTN Scale = GlobalConfig.MainEntriesSize >> 3; //usually it is 128>>3 == 16. if 256>>3 == 32
|
|
|
|
|
|
|
|
|
|
if (Entry->Row == 0 && Entry->getDriveImage() && !(GlobalConfig.HideBadges & HDBADGES_SWAP)) {
|
|
|
|
|
MainImage = Entry->getDriveImage();
|
|
|
|
|
} else {
|
|
|
|
|
MainImage = Entry->Image;
|
2020-03-20 18:48:19 +01:00
|
|
|
|
}
|
2020-04-05 05:44:27 +02:00
|
|
|
|
//this should be inited by the Theme
|
|
|
|
|
if (!MainImage) {
|
|
|
|
|
if (!IsEmbeddedTheme()) {
|
|
|
|
|
MainImage = egLoadIcon(ThemeDir, GetIconsExt(L"icons\\os_mac", L"icns"), Scale << 3);
|
2020-03-20 18:48:19 +01:00
|
|
|
|
}
|
2020-04-05 05:44:27 +02:00
|
|
|
|
if (!MainImage) {
|
|
|
|
|
MainImage = DummyImage(Scale << 3);
|
|
|
|
|
}
|
|
|
|
|
if (MainImage) {
|
|
|
|
|
NewImageCreated = true;
|
2020-03-20 18:48:19 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-04-05 05:44:27 +02:00
|
|
|
|
// DBG("Entry title=%ls; Width=%d\n", Entry->Title, MainImage->Width);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
if (GlobalConfig.TypeSVG) {
|
|
|
|
|
Scale = 16 * (selected ? 1 : -1);
|
|
|
|
|
} else {
|
|
|
|
|
Scale = ((Entry->Row == 0) ? (Scale * (selected ? 1 : -1)): 16) ;
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
if (Entry->Row == 0) {
|
|
|
|
|
BadgeImage = Entry->getBadgeImage();
|
|
|
|
|
} //else null
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
if (GlobalConfig.SelectionOnTop) {
|
|
|
|
|
SelectionImages[0]->HasAlpha = TRUE;
|
|
|
|
|
SelectionImages[2]->HasAlpha = TRUE;
|
|
|
|
|
//MainImage->HasAlpha = TRUE;
|
|
|
|
|
BltImageCompositeBadge(MainImage,
|
|
|
|
|
SelectionImages[((Entry->Row == 0) ? 0 : 2) + (selected ? 0 : 1)],
|
|
|
|
|
BadgeImage,
|
|
|
|
|
XPos, YPos, Scale);
|
|
|
|
|
} else {
|
|
|
|
|
BltImageCompositeBadge(SelectionImages[((Entry->Row == 0) ? 0 : 2) + (selected ? 0 : 1)],
|
|
|
|
|
MainImage,
|
|
|
|
|
BadgeImage,
|
|
|
|
|
XPos, YPos, Scale);
|
|
|
|
|
}
|
|
|
|
|
// draw BCS indicator
|
|
|
|
|
// Needy: if Labels (Titles) are hidden there is no point to draw the indicator
|
|
|
|
|
if (GlobalConfig.BootCampStyle && !(GlobalConfig.HideUIFlags & HIDEUI_FLAG_LABEL)) {
|
|
|
|
|
SelectionImages[4]->HasAlpha = TRUE;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
// indicator is for row 0, main entries, only
|
|
|
|
|
if (Entry->Row == 0) {
|
|
|
|
|
BltImageAlpha(SelectionImages[4 + (selected ? 0 : 1)],
|
|
|
|
|
XPos + (row0TileSize / 2) - (INTN)(INDICATOR_SIZE * 0.5f * GlobalConfig.Scale),
|
|
|
|
|
row0PosY + row0TileSize + TextHeight + (INTN)((BCSMargin * 2) * GlobalConfig.Scale),
|
|
|
|
|
&MenuBackgroundPixel, Scale);
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
Entry->Place.XPos = XPos;
|
|
|
|
|
Entry->Place.YPos = YPos;
|
|
|
|
|
Entry->Place.Width = MainImage->Width;
|
|
|
|
|
Entry->Place.Height = MainImage->Height;
|
|
|
|
|
//we can't free MainImage because it may be new image or it may be a link to entry image
|
|
|
|
|
// a workaround
|
|
|
|
|
if (NewImageCreated) {
|
|
|
|
|
egFreeImage(MainImage);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-03-20 18:48:19 +01:00
|
|
|
|
#endif
|
2020-04-05 05:44:27 +02:00
|
|
|
|
//the purpose of the procedure is restore Background in rect
|
|
|
|
|
//XAlign is always centre, Color is the Backgrounf fill
|
2020-03-22 11:48:13 +01:00
|
|
|
|
#if USE_XTHEME
|
2020-04-02 10:44:42 +02:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
#else
|
|
|
|
|
VOID FillRectAreaOfScreen(IN INTN XPos, IN INTN YPos, IN INTN Width, IN INTN Height, IN EG_PIXEL *Color, IN UINT8 XAlign)
|
|
|
|
|
{
|
|
|
|
|
EG_IMAGE *TmpBuffer = NULL;
|
|
|
|
|
INTN X = XPos - (Width >> XAlign);
|
2020-03-22 11:48:13 +01:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
if (!Width || !Height) return;
|
2020-03-22 11:48:13 +01:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
TmpBuffer = egCreateImage(Width, Height, FALSE);
|
|
|
|
|
if (!BackgroundImage) {
|
|
|
|
|
egFillImage(TmpBuffer, Color);
|
|
|
|
|
} else {
|
|
|
|
|
egRawCopy(TmpBuffer->PixelData,
|
|
|
|
|
BackgroundImage->PixelData + YPos * BackgroundImage->Width + X,
|
|
|
|
|
Width, Height,
|
|
|
|
|
TmpBuffer->Width,
|
|
|
|
|
BackgroundImage->Width);
|
|
|
|
|
}
|
|
|
|
|
BltImage(TmpBuffer, X, YPos);
|
|
|
|
|
egFreeImage(TmpBuffer);
|
|
|
|
|
}
|
|
|
|
|
#endif
|
2020-03-22 11:48:13 +01:00
|
|
|
|
|
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
#if USE_XTHEME
|
2020-03-22 11:48:13 +01:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
#else
|
|
|
|
|
VOID DrawTextCorner(UINTN TextC, UINT8 Align)
|
|
|
|
|
{
|
|
|
|
|
INTN Xpos;
|
|
|
|
|
CHAR16 *Text = NULL;
|
2020-03-22 11:48:13 +01:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
if (
|
|
|
|
|
// HIDEUI_ALL - included
|
|
|
|
|
((TextC == TEXT_CORNER_REVISION) && ((GlobalConfig.HideUIFlags & HIDEUI_FLAG_REVISION) != 0)) ||
|
|
|
|
|
((TextC == TEXT_CORNER_HELP) && ((GlobalConfig.HideUIFlags & HIDEUI_FLAG_HELP) != 0)) ||
|
|
|
|
|
((TextC == TEXT_CORNER_OPTIMUS) && (GlobalConfig.ShowOptimus == FALSE))
|
|
|
|
|
) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2020-03-22 11:48:13 +01:00
|
|
|
|
|
2020-04-05 05:44:27 +02:00
|
|
|
|
switch (TextC) {
|
|
|
|
|
case TEXT_CORNER_REVISION:
|
|
|
|
|
// Display Clover boot volume
|
|
|
|
|
if (SelfVolume->VolLabel && SelfVolume->VolLabel[0] != L'#') {
|
|
|
|
|
Text = PoolPrint(L"%s, booted from %s", gFirmwareRevision, SelfVolume->VolLabel);
|
|
|
|
|
}
|
|
|
|
|
if ( !Text ) {
|
|
|
|
|
Text = PoolPrint(L"%s", gFirmwareRevision, SelfVolume->VolName);
|
2020-03-22 11:48:13 +01:00
|
|
|
|
}
|
|
|
|
|
break;
|
2020-04-05 05:44:27 +02:00
|
|
|
|
case TEXT_CORNER_HELP:
|
|
|
|
|
Text = PoolPrint(L"F1:Help");
|
|
|
|
|
break;
|
|
|
|
|
case TEXT_CORNER_OPTIMUS:
|
|
|
|
|
if (gGraphics[0].Vendor != Intel) {
|
|
|
|
|
Text = PoolPrint(L"Discrete");
|
2020-03-22 11:48:13 +01:00
|
|
|
|
} else {
|
2020-04-05 05:44:27 +02:00
|
|
|
|
Text = PoolPrint(L"Intel");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-26 21:32:31 +01:00
|
|
|
|
// Text = (NGFX == 2)?L"Intel":L"Discrete";
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
switch (Align) {
|
|
|
|
|
case X_IS_LEFT:
|
|
|
|
|
Xpos = (INTN)(TextHeight * 0.75f);
|
|
|
|
|
break;
|
|
|
|
|
case X_IS_RIGHT:
|
|
|
|
|
Xpos = UGAWidth - (INTN)(TextHeight * 0.7f);//2
|
|
|
|
|
break;
|
|
|
|
|
case X_IS_CENTER:
|
|
|
|
|
Xpos = UGAWidth >> 1;
|
|
|
|
|
break;
|
|
|
|
|
default:
|
2020-03-26 21:32:31 +01:00
|
|
|
|
if ( Text ) FreePool(Text);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return;
|
|
|
|
|
}
|
2020-03-25 19:32:44 +01:00
|
|
|
|
// DBG("draw text %ls at (%d, %d)\n", Text, Xpos, UGAHeight - 5 - TextHeight),
|
2020-03-26 21:32:31 +01:00
|
|
|
|
// clovy DrawTextXY(Text, Xpos, UGAHeight - 5 - TextHeight, Align);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
DrawTextXY(Text, Xpos, UGAHeight - (INTN)(TextHeight * 1.5f), Align);
|
2019-12-20 18:18:55 +01:00
|
|
|
|
if ( Text ) FreePool(Text);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-26 21:32:31 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//the purpose of the procedure is restore Background in rect
|
|
|
|
|
//XAlign is always centre, Color is the Backgrounf fill
|
|
|
|
|
#if USE_XTHEME
|
|
|
|
|
#else
|
|
|
|
|
VOID FillRectAreaOfScreen(IN INTN XPos, IN INTN YPos, IN INTN Width, IN INTN Height, IN EG_PIXEL *Color, IN UINT8 XAlign)
|
|
|
|
|
{
|
|
|
|
|
EG_IMAGE *TmpBuffer = NULL;
|
|
|
|
|
INTN X = XPos - (Width >> XAlign);
|
|
|
|
|
|
|
|
|
|
if (!Width || !Height) return;
|
|
|
|
|
|
|
|
|
|
TmpBuffer = egCreateImage(Width, Height, FALSE);
|
|
|
|
|
if (!BackgroundImage) {
|
|
|
|
|
egFillImage(TmpBuffer, Color);
|
|
|
|
|
} else {
|
|
|
|
|
egRawCopy(TmpBuffer->PixelData,
|
|
|
|
|
BackgroundImage->PixelData + YPos * BackgroundImage->Width + X,
|
|
|
|
|
Width, Height,
|
|
|
|
|
TmpBuffer->Width,
|
|
|
|
|
BackgroundImage->Width);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-04-04 14:27:02 +02:00
|
|
|
|
BltImage(TmpBuffer, X, YPos);
|
|
|
|
|
egFreeImage(TmpBuffer);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-26 15:24:20 +01:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// user-callable dispatcher functions
|
|
|
|
|
//
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* NewEntry_(REFIT_ABSTRACT_MENU_ENTRY *Entry, REFIT_MENU_SCREEN **SubScreen, ACTION AtClick, UINTN ID, CONST CHAR8 *Title)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-11 17:41:20 +01:00
|
|
|
|
if ( Title ) Entry->Title.takeValueFrom(Title);
|
|
|
|
|
else Entry->Title.setEmpty();
|
2020-03-10 12:51:04 +01:00
|
|
|
|
// if (Title) {
|
|
|
|
|
// } else {
|
|
|
|
|
// Entry->Title = (__typeof__(Entry->Title))AllocateZeroPool(128);
|
|
|
|
|
// }
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
Entry->Image = OptionMenu.TitleImage;
|
|
|
|
|
Entry->AtClick = AtClick;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
// create the submenu
|
2020-03-03 21:44:07 +01:00
|
|
|
|
// *SubScreen = (__typeof_am__(*SubScreen))AllocateZeroPool(sizeof(**SubScreen));
|
|
|
|
|
*SubScreen = new REFIT_MENU_SCREEN();
|
2020-03-24 16:17:12 +01:00
|
|
|
|
// (*SubScreen)->Title = EfiStrDuplicate(Entry->Title);
|
|
|
|
|
(*SubScreen)->Title = Entry->Title;
|
2020-02-28 21:28:33 +01:00
|
|
|
|
(*SubScreen)->TitleImage = Entry->Image;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
(*SubScreen)->ID = ID;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
(*SubScreen)->AnimeRun = (*SubScreen)->GetAnime();
|
2020-02-28 21:28:33 +01:00
|
|
|
|
Entry->SubScreen = *SubScreen;
|
2020-03-10 10:45:17 +01:00
|
|
|
|
return Entry;
|
2020-02-28 21:28:33 +01:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS* newREFIT_MENU_ITEM_OPTIONS(REFIT_MENU_SCREEN **SubScreen, ACTION AtClick, UINTN ID, CONST CHAR8 *Title)
|
2020-02-28 21:28:33 +01:00
|
|
|
|
{
|
|
|
|
|
//create entry
|
|
|
|
|
// *Entry = (__typeof_am__(*Entry))AllocateZeroPool(sizeof(LOADER_ENTRY)); // carefull, **Entry is not a LOADER_ENTRY. Don't use sizeof.
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS* Entry = new REFIT_MENU_ITEM_OPTIONS();
|
|
|
|
|
return NewEntry_(Entry, SubScreen, AtClick, ID, Title)->getREFIT_MENU_ITEM_OPTIONS();
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// (*Entry)->Tag = TAG_OPTIONS;
|
|
|
|
|
}
|
2020-03-10 10:45:17 +01:00
|
|
|
|
//
|
|
|
|
|
//VOID NewLoaderEntry(LOADER_ENTRY **Entry, REFIT_MENU_SCREEN **SubScreen, ACTION AtClick, UINTN ID, CONST CHAR8 *Title)
|
|
|
|
|
//{
|
|
|
|
|
// //create entry
|
|
|
|
|
//// *Entry = (__typeof_am__(*Entry))AllocateZeroPool(sizeof(LOADER_ENTRY)); // carefull, **Entry is not a LOADER_ENTRY. Don't use sizeof.
|
|
|
|
|
// *Entry = new LOADER_ENTRY();
|
|
|
|
|
// NewEntry_(*Entry, SubScreen, AtClick, ID, Title); // cast ok because super class
|
|
|
|
|
//}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
VOID ModifyTitles(REFIT_ABSTRACT_MENU_ENTRY *ChosenEntry)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
if (ChosenEntry->SubScreen->ID == SCREEN_DSDT) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
// snwprintf((CHAR16*)ChosenEntry->Title, 128, "DSDT fix mask [0x%08X]->", gSettings.FixDsdt); // TODO jief : cast to fix
|
2020-03-31 18:10:30 +02:00
|
|
|
|
ChosenEntry->Title.SWPrintf("DSDT fix mask [0x%08x]->", gSettings.FixDsdt); // TODO jief : cast to fix
|
2020-03-25 19:32:44 +01:00
|
|
|
|
//MsgLog("@ESC: %ls\n", (*ChosenEntry)->Title);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else if (ChosenEntry->SubScreen->ID == SCREEN_CSR) {
|
|
|
|
|
// CSR
|
2020-04-04 15:50:13 +02:00
|
|
|
|
// snwprintf((CHAR16*)ChosenEntry->Title, 128, "System Integrity Protection [0x%04X]->", gSettings.CsrActiveConfig); // TODO jief : cast to fix
|
2020-03-31 18:10:30 +02:00
|
|
|
|
ChosenEntry->Title.SWPrintf("System Integrity Protection [0x%04x]->", gSettings.CsrActiveConfig); // TODO jief : cast to fix
|
2019-09-03 11:58:42 +02:00
|
|
|
|
// check for the right booter flag to allow the application
|
|
|
|
|
// of the new System Integrity Protection configuration.
|
|
|
|
|
if (gSettings.CsrActiveConfig != 0 && gSettings.BooterConfig == 0) {
|
|
|
|
|
gSettings.BooterConfig = 0x28;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} else if (ChosenEntry->SubScreen->ID == SCREEN_BLC) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
// snwprintf((CHAR16*)ChosenEntry->Title, 128, "boot_args->flags [0x%04X]->", gSettings.BooterConfig); // TODO jief : cast to fix
|
2020-03-31 18:10:30 +02:00
|
|
|
|
ChosenEntry->Title.SWPrintf("boot_args->flags [0x%04x]->", gSettings.BooterConfig); // TODO jief : cast to fix
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else if (ChosenEntry->SubScreen->ID == SCREEN_DSM) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
// snwprintf((CHAR16*)ChosenEntry->Title, 128, "Drop OEM _DSM [0x%04X]->", dropDSM); // TODO jief : cast to fix
|
2020-03-31 18:10:30 +02:00
|
|
|
|
ChosenEntry->Title.SWPrintf("Drop OEM _DSM [0x%04x]->", dropDSM); // TODO jief : cast to fix
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY *SubMenuGraphics()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
UINTN i, N, Ven = 97;
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_GRAPHICS, "Graphics Injector->");
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Number of VideoCard%s=%llu",((NGFX!=1)?"s":""), NGFX);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(52, "InjectEDID", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(53, "Fake Vendor EDID:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(54, "Fake Product EDID:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(18, "Backlight Level:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(112, "Intel Max Backlight:", TRUE); //gSettings.IntelMaxValue
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < NGFX; i++) {
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfo_f("----------------------");
|
2020-03-12 19:23:32 +01:00
|
|
|
|
SubScreen->AddMenuInfo_f("Card DeviceID=%04x", gGraphics[i].DeviceID);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
N = 20 + i * 6;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N, "Model:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
if (gGraphics[i].Vendor == Nvidia) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+1, "InjectNVidia", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else if (gGraphics[i].Vendor == Ati) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+1, "InjectATI", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else if (gGraphics[i].Vendor == Intel) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+1, "InjectIntel", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+1, "InjectX3", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (gGraphics[i].Vendor == Nvidia) {
|
|
|
|
|
Ven = 95;
|
|
|
|
|
} else if (gGraphics[i].Vendor == Ati) {
|
|
|
|
|
Ven = 94;
|
|
|
|
|
} else /*if (gGraphics[i].Vendor == Intel)*/ {
|
|
|
|
|
Ven = 96;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ((gGraphics[i].Vendor == Ati) || (gGraphics[i].Vendor == Intel)) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(109, "DualLink:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
if (gGraphics[i].Vendor == Ati) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(114, "DeInit:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(Ven, "FakeID:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
if (gGraphics[i].Vendor == Nvidia) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+2, "DisplayCFG:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else if (gGraphics[i].Vendor == Ati) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+2, "FBConfig:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else /*if (gGraphics[i].Vendor == Intel)*/{
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+2, "*-platform-id:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ErmaC: NvidiaGeneric entry
|
|
|
|
|
if (gGraphics[i].Vendor == Nvidia) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(55, "Generic NVIDIA name", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(110, "NVIDIA No EFI", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(111, "NVIDIA Single", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(56, "Use NVIDIA WEB drivers", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (gGraphics[i].Vendor == Intel) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+3, "Ports:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
if (gGraphics[i].Vendor == Nvidia) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+4, "NVCAP:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
} else {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+4, "Connectors:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(50, "RefCLK:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(N+5, "Load Video Bios", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ErmaC: Audio submenu
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY *SubMenuAudio()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
UINTN i;
|
|
|
|
|
|
|
|
|
|
// init
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
|
|
|
|
// create the entry in the main menu
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_AUDIO, "Audio tuning->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// submenu description
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Choose options to tune the HDA devices");
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("Number of Audio Controller%s=%llu", ((NHDA!=1)?"s":""), NHDA);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
for (i = 0; i < NHDA; i++) {
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("%llu) %ls [%04X][%04X]",
|
2019-09-03 11:58:42 +02:00
|
|
|
|
(i+1),
|
|
|
|
|
gAudios[i].controller_name,
|
|
|
|
|
gAudios[i].controller_vendor_id,
|
2020-04-04 18:22:07 +02:00
|
|
|
|
gAudios[i].controller_device_id
|
2019-09-03 11:58:42 +02:00
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
//SubScreen->AddMenuItemInput(59, "HDAInjection", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (gSettings.HDAInjection) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(60, "HDALayoutId:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// avaiable configuration
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(57, "ResetHDA", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(58, "AFGLowPowerState", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// return
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#define nya(x) x/10,x%10
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuSpeedStep()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_CPU, "CPU tuning->");
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("%s", gCPUStructure.BrandString);
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("Model: %2X/%2X/%2X",
|
|
|
|
|
gCPUStructure.Family, gCPUStructure.Model, gCPUStructure.Stepping);
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("Cores: %d Threads: %d",
|
|
|
|
|
gCPUStructure.Cores, gCPUStructure.Threads);
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("FSB speed MHz: %llu",
|
|
|
|
|
DivU64x32(gCPUStructure.FSBFrequency, Mega));
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("CPU speed MHz: %llu",
|
|
|
|
|
DivU64x32(gCPUStructure.CPUFrequency, Mega));
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("Ratio: Min=%d.%d Max=%d.%d Turbo=%d.%d/%d.%d/%d.%d/%d.%d",
|
2019-09-03 11:58:42 +02:00
|
|
|
|
nya(gCPUStructure.MinRatio), nya(gCPUStructure.MaxRatio),
|
2020-04-04 18:22:07 +02:00
|
|
|
|
nya(gCPUStructure.Turbo4), nya(gCPUStructure.Turbo3), nya(gCPUStructure.Turbo2), nya(gCPUStructure.Turbo1));
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:55:37 +01:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(76, "Cores enabled:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(6, "Halt Enabler", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(7, "PLimitDict:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(8, "UnderVoltStep:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(88, "DoubleFirstState", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(5, "GeneratePStates", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(9, "GenerateCStates", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(10, "EnableC2", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(11, "EnableC4", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(12, "EnableC6", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(89, "EnableC7", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(13, "Use SystemIO", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(75, "C3Latency:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(19, "BusSpeed [kHz]:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(14, "QPI [MHz]:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(77, "Saving Mode:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(15, "PatchAPIC", FALSE); //-> move to ACPI?
|
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuKextPatches()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
REFIT_INPUT_DIALOG *InputBootArgs;
|
|
|
|
|
INTN NrKexts = gSettings.KernelAndKextPatches.NrKexts;
|
|
|
|
|
KEXT_PATCH *KextPatchesMenu = gSettings.KernelAndKextPatches.KextPatches; //zzzz
|
|
|
|
|
INTN Index;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_KEXTS, "Custom kexts patches->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
for (Index = 0; Index < NrKexts; Index++) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf("%30s", KextPatchesMenu[Index].Label);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &(KextPatchesMenu[Index].MenuItem);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuKextBlockInjection(CONST CHAR16* UniSysVer)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry = NULL;
|
2019-12-11 13:52:26 +01:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_INPUT_DIALOG *InputBootArgs;
|
|
|
|
|
UINTN i = 0;
|
|
|
|
|
SIDELOAD_KEXT *Kext = NULL;
|
2019-12-11 13:52:26 +01:00
|
|
|
|
CHAR8 sysVer[256];
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2019-12-11 13:52:26 +01:00
|
|
|
|
UnicodeStrToAsciiStrS(UniSysVer, sysVer, sizeof(sysVer));
|
|
|
|
|
for (i = 0; i < sizeof(sysVer)-2; i++) {
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (sysVer[i] == '\0') {
|
|
|
|
|
sysVer[i+0] = '-';
|
|
|
|
|
sysVer[i+1] = '>';
|
2019-12-11 13:52:26 +01:00
|
|
|
|
sysVer[i+2] = '\0';
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Kext = InjectKextList;
|
|
|
|
|
while (Kext) {
|
2019-12-11 13:52:26 +01:00
|
|
|
|
if (StrCmp(Kext->KextDirNameUnderOEMPath, UniSysVer) == 0) {
|
|
|
|
|
if ( SubScreen == NULL ) {
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_KEXT_INJECT, sysVer);
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Choose/check kext to disable:");
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf("%ls, v.%ls", Kext->FileName, Kext->Version);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &(Kext->MenuItem);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
SIDELOAD_KEXT *plugInKext = Kext->PlugInList;
|
|
|
|
|
while (plugInKext) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf(" |-- %ls, v.%ls", plugInKext->FileName, plugInKext->Version);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &(plugInKext->MenuItem);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
plugInKext = plugInKext->Next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
Kext = Kext->Next;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
if ( SubScreen != NULL ) SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
LOADER_ENTRY *SubMenuKextInjectMgmt(LOADER_ENTRY *Entry)
|
|
|
|
|
{
|
2019-12-11 13:52:26 +01:00
|
|
|
|
LOADER_ENTRY *SubEntry;
|
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
CHAR16 *kextDir = NULL;
|
|
|
|
|
UINTN i;
|
|
|
|
|
CHAR8 ShortOSVersion[8];
|
2019-12-16 15:22:15 +01:00
|
|
|
|
// CHAR16 *UniSysVer = NULL;
|
2019-12-11 13:52:26 +01:00
|
|
|
|
CHAR8 *ChosenOS = Entry->OSVersion;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
SubEntry = new LOADER_ENTRY();
|
|
|
|
|
NewEntry_(SubEntry, &SubScreen, ActionEnter, SCREEN_SYSTEM, "Block injected kexts->");
|
2019-12-11 13:52:26 +01:00
|
|
|
|
SubEntry->Flags = Entry->Flags;
|
|
|
|
|
if (ChosenOS) {
|
2020-03-25 19:32:44 +01:00
|
|
|
|
// DBG("chosen os %s\n", ChosenOS);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
//shorten os version 10.11.6 -> 10.11
|
|
|
|
|
for (i = 0; i < 8; i++) {
|
|
|
|
|
ShortOSVersion[i] = ChosenOS[i];
|
|
|
|
|
if (ShortOSVersion[i] == '\0') {
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (((i > 2) && (ShortOSVersion[i] == '.')) || (i == 5)) {
|
|
|
|
|
ShortOSVersion[i] = '\0';
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:55:37 +01:00
|
|
|
|
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Block injected kexts for target version of macOS: %s",
|
|
|
|
|
ShortOSVersion);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
|
2019-12-13 12:56:57 +01:00
|
|
|
|
// Add kext from 10
|
2019-12-11 13:52:26 +01:00
|
|
|
|
{
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextBlockInjection(L"10"), true);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
|
|
|
|
|
CHAR16 DirName[256];
|
|
|
|
|
if (OSTYPE_IS_OSX_INSTALLER(Entry->LoaderType)) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "10_install");
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
if (OSTYPE_IS_OSX_RECOVERY(Entry->LoaderType)) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "10_recovery");
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
else {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "10_normal");
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextBlockInjection(DirName), true);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2019-12-11 14:22:21 +01:00
|
|
|
|
// Add kext from 10.{version}
|
2019-12-11 13:52:26 +01:00
|
|
|
|
{
|
|
|
|
|
CHAR16 DirName[256];
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "%s", ShortOSVersion);
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextBlockInjection(DirName), true);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
|
|
|
|
|
if (OSTYPE_IS_OSX_INSTALLER(Entry->LoaderType)) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "%s_install", ShortOSVersion);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
if (OSTYPE_IS_OSX_RECOVERY(Entry->LoaderType)) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "%s_recovery", ShortOSVersion);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
else {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "%s_normal", ShortOSVersion);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextBlockInjection(DirName), true);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add kext from :
|
2019-12-11 14:22:21 +01:00
|
|
|
|
// 10.{version}.0 if NO minor version
|
2019-12-11 13:52:26 +01:00
|
|
|
|
// 10.{version}.{minor version} if minor version is > 0
|
|
|
|
|
{
|
|
|
|
|
{
|
|
|
|
|
CHAR16 OSVersionKextsDirName[256];
|
2019-12-11 14:22:21 +01:00
|
|
|
|
if ( AsciiStrCmp(ShortOSVersion, Entry->OSVersion) == 0 ) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(OSVersionKextsDirName, sizeof(OSVersionKextsDirName), "%s.0", Entry->OSVersion);
|
2019-12-11 14:22:21 +01:00
|
|
|
|
}else{
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(OSVersionKextsDirName, sizeof(OSVersionKextsDirName), "%s", Entry->OSVersion);
|
2019-12-11 14:22:21 +01:00
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextBlockInjection(OSVersionKextsDirName), true);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
CHAR16 DirName[256];
|
|
|
|
|
if (OSTYPE_IS_OSX_INSTALLER(Entry->LoaderType)) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "%s_install",
|
2019-12-11 13:52:26 +01:00
|
|
|
|
Entry->OSVersion);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
if (OSTYPE_IS_OSX_RECOVERY(Entry->LoaderType)) {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "%s_recovery",
|
2019-12-11 13:52:26 +01:00
|
|
|
|
Entry->OSVersion);
|
|
|
|
|
}
|
|
|
|
|
else {
|
2020-04-04 15:50:13 +02:00
|
|
|
|
snwprintf(DirName, sizeof(DirName), "%s_normal",
|
2019-12-11 13:52:26 +01:00
|
|
|
|
Entry->OSVersion);
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextBlockInjection(DirName), true);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else {
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Block injected kexts for target version of macOS: %s",
|
|
|
|
|
ChosenOS);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
}
|
|
|
|
|
if ((kextDir = GetOtherKextsDir(TRUE)) != NULL) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextBlockInjection(L"Other"), true);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
FreePool(kextDir);
|
|
|
|
|
}
|
|
|
|
|
if ((kextDir = GetOtherKextsDir(FALSE)) != NULL) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextBlockInjection(L"Off"), true);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
FreePool(kextDir);
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-12-11 13:52:26 +01:00
|
|
|
|
return SubEntry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuKernelPatches()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
REFIT_INPUT_DIALOG *InputBootArgs;
|
|
|
|
|
INTN NrKernels = gSettings.KernelAndKextPatches.NrKernels;
|
|
|
|
|
KERNEL_PATCH *KernelPatchesMenu = gSettings.KernelAndKextPatches.KernelPatches; //zzzz
|
|
|
|
|
INTN Index;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_KERNELS, "Custom kernel patches->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
for (Index = 0; Index < NrKernels; Index++) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf("%30s", KernelPatchesMenu[Index].Label);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &(KernelPatchesMenu[Index].MenuItem);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuBootPatches()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
REFIT_INPUT_DIALOG *InputBootArgs;
|
|
|
|
|
INTN NrBoots = gSettings.KernelAndKextPatches.NrBoots;
|
|
|
|
|
KERNEL_PATCH *BootPatchesMenu = gSettings.KernelAndKextPatches.BootPatches; //zzzz
|
|
|
|
|
INTN Index;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_BOOTER, "Custom booter patches->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
for (Index = 0; Index < NrBoots; Index++) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf("%30s", BootPatchesMenu[Index].Label);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &(BootPatchesMenu[Index].MenuItem);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuBinaries()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_BINARIES, "Binaries patching->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("%s", gCPUStructure.BrandString);
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("Real CPUID: 0x%06X", gCPUStructure.Signature);
|
2020-03-03 21:44:07 +01:00
|
|
|
|
|
2020-03-03 21:55:37 +01:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(64, "Debug", FALSE);
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfo_f("----------------------");
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(104, "Fake CPUID:", TRUE);
|
|
|
|
|
// SubScreen->AddMenuItemInput(108, "Kernel patching allowed", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(45, "Kernel Support CPU", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(91, "Kernel Lapic", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(105, "Kernel XCPM", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(48, "Kernel PM", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(121, "Panic No Kext Dump", FALSE);
|
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKernelPatches(), true);
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfo_f("----------------------");
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(46, "AppleIntelCPUPM Patch", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(47, "AppleRTC Patch", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(61, "Dell SMBIOS Patch", FALSE);
|
|
|
|
|
// SubScreen->AddMenuItemInput(115, "No Caches", FALSE);
|
|
|
|
|
// SubScreen->AddMenuItemInput(44, "Kext patching allowed", FALSE);
|
|
|
|
|
SubScreen->AddMenuEntry(SubMenuKextPatches(), true);
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfo_f("----------------------");
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuBootPatches(), true);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuDropTables()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
CHAR8 sign[5];
|
|
|
|
|
CHAR8 OTID[9];
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
REFIT_INPUT_DIALOG *InputBootArgs;
|
|
|
|
|
|
|
|
|
|
sign[4] = 0;
|
|
|
|
|
OTID[8] = 0;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_TABLES, "Tables dropping->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
if (gSettings.ACPIDropTables) {
|
|
|
|
|
ACPI_DROP_TABLE *DropTable = gSettings.ACPIDropTables;
|
|
|
|
|
while (DropTable) {
|
|
|
|
|
CopyMem((CHAR8*)&sign, (CHAR8*)&(DropTable->Signature), 4);
|
|
|
|
|
CopyMem((CHAR8*)&OTID, (CHAR8*)&(DropTable->TableId), 8);
|
2020-03-25 19:32:44 +01:00
|
|
|
|
//MsgLog("adding to menu %s (%X) %s (%lx) L=%d(0x%X)\n",
|
2019-09-03 11:58:42 +02:00
|
|
|
|
// sign, DropTable->Signature,
|
|
|
|
|
// OTID, DropTable->TableId,
|
|
|
|
|
// DropTable->Length, DropTable->Length);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf("Drop \"%4.4s\" \"%8.8s\" %d", sign, OTID, DropTable->Length);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &(DropTable->MenuItem);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
DropTable = DropTable->Next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(4, "Drop all OEM SSDT", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(113, "Automatic smart merge", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 18:22:07 +02:00
|
|
|
|
//SubScreen->AddMenuInfoLine_f("PATCHED AML:");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (ACPIPatchedAML) {
|
|
|
|
|
ACPI_PATCHED_AML *ACPIPatchedAMLTmp = ACPIPatchedAML;
|
|
|
|
|
while (ACPIPatchedAMLTmp) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf("Drop \"%ls\"", ACPIPatchedAMLTmp->FileName);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &(ACPIPatchedAMLTmp->MenuItem);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
ACPIPatchedAMLTmp = ACPIPatchedAMLTmp->Next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuSmbios()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_SMBIOS, "SMBIOS->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("%s", gCPUStructure.BrandString);
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("%s", gSettings.OEMProduct);
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("with board %s", gSettings.OEMBoard);
|
2020-03-03 21:44:07 +01:00
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuItemInput(78, "Product Name:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(79, "Product Version:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(80, "Product SN:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(81, "Board ID:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(82, "Board SN:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(83, "Board Type:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(84, "Board Version:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(85, "Chassis Type:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(86, "ROM Version:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(87, "ROM Release Date:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(62, "FirmwareFeatures:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(63, "FirmwareFeaturesMask:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(17, "PlatformFeature:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(117, "EFI Version:", TRUE);
|
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuDropDSM()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
// init
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
|
|
|
|
// create the entry in the main menu
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_DSM, NULL);
|
2020-03-10 12:51:04 +01:00
|
|
|
|
// Entry->Title.SPrintf("Drop OEM _DSM [0x%04x]->", gSettings.DropOEM_DSM);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// submenu description
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Choose devices to drop OEM _DSM methods from DSDT");
|
2020-03-03 21:44:07 +01:00
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuCheck("ATI/AMD Graphics", DEV_ATI, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("Nvidia Graphics", DEV_NVIDIA, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("Intel Graphics", DEV_INTEL, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("PCI HDA audio", DEV_HDA, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("HDMI audio", DEV_HDMI, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("PCI LAN Adapter", DEV_LAN, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("PCI WiFi Adapter", DEV_WIFI, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("IDE HDD", DEV_IDE, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("SATA HDD", DEV_SATA, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("USB Controllers", DEV_USB, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("LPC Controller", DEV_LPC, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("SMBUS Controller", DEV_SMBUS, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("IMEI Device", DEV_IMEI, 101);
|
|
|
|
|
SubScreen->AddMenuCheck("Firewire", DEV_FIREWIRE, 101);
|
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
ModifyTitles(Entry);
|
|
|
|
|
|
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuDsdtFix()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry; //, *SubEntry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
// REFIT_INPUT_DIALOG *InputBootArgs;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_DSDT, NULL);
|
2020-03-10 12:51:04 +01:00
|
|
|
|
// Entry->Title.SPrintf("DSDT fix mask [0x%08x]->", gSettings.FixDsdt);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuCheck("Add DTGP", FIX_DTGP, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix Darwin as WinXP", FIX_WARNING, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix Darwin as Win7", FIX_DARWIN, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix shutdown", FIX_SHUTDOWN, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Add MCHC", FIX_MCHC, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix HPET", FIX_HPET, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fake LPC", FIX_LPC, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix IPIC", FIX_IPIC, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Add SMBUS", FIX_SBUS, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix display", FIX_DISPLAY, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix IDE", FIX_IDE, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix SATA", FIX_SATA, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix Firewire", FIX_FIREWIRE, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix USB", FIX_USB, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix LAN", FIX_LAN, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix Airport", FIX_WIFI, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix sound", FIX_HDA, 67);
|
|
|
|
|
// SubScreen->AddMenuCheck("Fix new way", FIX_NEW_WAY, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix RTC", FIX_RTC, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix TMR", FIX_TMR, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Add IMEI", FIX_IMEI, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix IntelGFX", FIX_INTELGFX, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix _WAK", FIX_WAK, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Del unused", FIX_UNUSED, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix ADP1", FIX_ADP1, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Add PNLF", FIX_PNLF, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix S3D", FIX_S3D, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Rename ACST", FIX_ACST, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Add HDMI", FIX_HDMI, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix Regions", FIX_REGIONS, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix Headers", FIX_HEADERS, 67);
|
|
|
|
|
SubScreen->AddMenuCheck("Fix Mutex", FIX_MUTEX, 67);
|
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
ModifyTitles(Entry);
|
|
|
|
|
|
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuDSDTPatches() //yyyy
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
REFIT_INPUT_DIALOG *InputBootArgs;
|
|
|
|
|
|
|
|
|
|
INTN PatchDsdtNum = gSettings.PatchDsdtNum;
|
|
|
|
|
INPUT_ITEM *DSDTPatchesMenu = gSettings.PatchDsdtMenuItem;
|
|
|
|
|
INTN Index;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_DSDT_PATCHES, "Custom DSDT patches->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
for (Index = 0; Index < PatchDsdtNum; Index++) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-10 17:50:55 +01:00
|
|
|
|
InputBootArgs->Title.takeValueFrom(gSettings.PatchDsdtLabel[Index]);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &DSDTPatchesMenu[Index];
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuDsdts()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
2020-02-28 21:28:33 +01:00
|
|
|
|
REFIT_MENU_SWITCH *InputBootArgs;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
UINTN i;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_ACPI, "Dsdt name->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Select a DSDT file:");
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemSwitch(116, "BIOS.aml", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
for (i = 0; i < DsdtsNum; i++) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_MENU_SWITCH;
|
2020-03-10 17:50:55 +01:00
|
|
|
|
InputBootArgs->Title.takeValueFrom(DsdtsList[i]);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_SWITCH_OLD;
|
|
|
|
|
InputBootArgs->Row = i + 1;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &InputItems[116];
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuACPI()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
// init
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
|
|
|
|
// create the entry in the options menu
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_ACPI, "ACPI patching->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// submenu description
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Choose options to patch ACPI");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(102, "Debug DSDT", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuDsdts(), true);
|
|
|
|
|
SubScreen->AddMenuEntry(SubMenuDropTables(), true);
|
|
|
|
|
SubScreen->AddMenuEntry(SubMenuDropDSM(), true);
|
|
|
|
|
SubScreen->AddMenuEntry(SubMenuDsdtFix(), true);
|
|
|
|
|
SubScreen->AddMenuEntry(SubMenuDSDTPatches(), true);
|
|
|
|
|
SubScreen->AddMenuItemInput(49, "Fix MCFG", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuAudioPort()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
2020-02-28 21:28:33 +01:00
|
|
|
|
REFIT_MENU_SWITCH *InputBootArgs;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
UINTN i;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_AUDIOPORTS, "Startup sound output->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Select an audio output, press F7 to test");
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(120, "Volume:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
for (i = 0; i < AudioNum; i++) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_MENU_SWITCH;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf("%ls_%s", AudioList[i].Name, AudioOutputNames[AudioList[i].Device]);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_SWITCH_OLD;
|
|
|
|
|
InputBootArgs->Row = i;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &InputItems[119];
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
VOID CreateMenuProps(REFIT_MENU_SCREEN *SubScreen, DEV_PROPERTY *Prop)
|
|
|
|
|
{
|
|
|
|
|
REFIT_INPUT_DIALOG *InputBootArgs;
|
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_INPUT_DIALOG;
|
2020-03-31 18:10:30 +02:00
|
|
|
|
InputBootArgs->Title.SWPrintf(" key: %s", Prop->Key);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_INPUT;
|
|
|
|
|
InputBootArgs->Row = 0xFFFF; //cursor
|
2019-09-03 11:58:42 +02:00
|
|
|
|
// InputBootArgs->Item = ADDRESS_OF(DEV_PROPERTY, Prop, INPUT_ITEM, MenuItem);
|
|
|
|
|
InputBootArgs->Item = &Prop->MenuItem;
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
switch (Prop->ValueType) {
|
|
|
|
|
case kTagTypeInteger:
|
2020-03-12 19:23:32 +01:00
|
|
|
|
SubScreen->AddMenuInfo_f(" value: 0x%08llx", *(UINT64*)Prop->Value);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case kTagTypeString:
|
2020-03-12 19:23:32 +01:00
|
|
|
|
SubScreen->AddMenuInfo_f(" value: %30s", Prop->Value);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case kTagTypeFalse:
|
2020-03-12 19:23:32 +01:00
|
|
|
|
SubScreen->AddMenuInfo_f((" value: false"));
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
case kTagTypeTrue:
|
2020-03-12 19:23:32 +01:00
|
|
|
|
SubScreen->AddMenuInfo_f((" value: true"));
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default: //type data, print first 24 bytes
|
|
|
|
|
//CHAR8* Bytes2HexStr(UINT8 *data, UINTN len)
|
2020-03-12 19:23:32 +01:00
|
|
|
|
SubScreen->AddMenuInfo_f(" value[%llu]: %24s", Prop->ValueLen, Bytes2HexStr((UINT8*)Prop->Value, MIN(24, Prop->ValueLen)));
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuCustomDevices()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
|
|
|
|
UINT32 DevAddr, OldDevAddr = 0;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_DEVICES, "Custom properties->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
if (gSettings.ArbProperties) {
|
|
|
|
|
DEV_PROPERTY *Prop = gSettings.ArbProperties;
|
|
|
|
|
if (Prop && (Prop->Device == 0))
|
|
|
|
|
{
|
|
|
|
|
DEV_PROPERTY *Props = NULL;
|
|
|
|
|
while (Prop) {
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfo_f("------------");
|
2020-03-12 19:23:32 +01:00
|
|
|
|
SubScreen->AddMenuInfo_f("%s", Prop->Label);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
Props = Prop->Child;
|
|
|
|
|
while (Props) {
|
|
|
|
|
CreateMenuProps(SubScreen, Props);
|
|
|
|
|
Props = Props->Next;
|
|
|
|
|
}
|
|
|
|
|
Prop = Prop->Next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
while (Prop) {
|
|
|
|
|
DevAddr = Prop->Device;
|
|
|
|
|
if (DevAddr != 0 && DevAddr != OldDevAddr) {
|
|
|
|
|
OldDevAddr = DevAddr;
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfo_f("------------");
|
2020-03-12 19:23:32 +01:00
|
|
|
|
SubScreen->AddMenuInfo_f("%s", Prop->Label);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
CreateMenuProps(SubScreen, Prop);
|
|
|
|
|
}
|
|
|
|
|
Prop = Prop->Next;
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
Entry->SubScreen = SubScreen;
|
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuPCI()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_USB, "PCI devices->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(74, "USB Ownership", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(92, "USB Injection", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(93, "Inject ClockID", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(106, "Inject EFI Strings", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(107, "No Default Properties", FALSE);
|
|
|
|
|
SubScreen->AddMenuItemInput(97, "FakeID LAN:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(98, "FakeID WIFI:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(99, "FakeID SATA:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(100, "FakeID XHCI:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(103, "FakeID IMEI:", TRUE);
|
|
|
|
|
SubScreen->AddMenuEntry(SubMenuCustomDevices(), true);
|
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
Entry->SubScreen = SubScreen;
|
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuThemes()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
2020-02-28 21:28:33 +01:00
|
|
|
|
REFIT_MENU_SWITCH *InputBootArgs;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
UINTN i;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_THEME, "Themes->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Installed themes:");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
//add embedded
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemSwitch(3, "embedded", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
for (i = 0; i < ThemesNum; i++) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_MENU_SWITCH;
|
2020-03-10 17:50:55 +01:00
|
|
|
|
InputBootArgs->Title.takeValueFrom(ThemesList[i]);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_SWITCH_OLD;
|
|
|
|
|
InputBootArgs->Row = i + 1;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &InputItems[3];
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuGUI()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
// init
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
|
|
|
|
// create the entry in the options menu
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_GUI, "GUI tuning->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// submenu description
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Choose options to tune the Interface");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(70, "Pointer Speed:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(72, "Mirror Move", FALSE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuThemes(), true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* This is a simple and user friendly submenu which makes it possible to modify
|
|
|
|
|
* the System Integrity Protection configuration from the Clover's GUI.
|
|
|
|
|
* Author: Needy.
|
|
|
|
|
* The below function is based on the SubMenuDsdtFix function.
|
|
|
|
|
*/
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuCSR()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
// init
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
|
|
|
|
// create the entry in the main menu
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_CSR, NULL);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// submenu description
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Modify the System Integrity Protection configuration.");
|
|
|
|
|
SubScreen->AddMenuInfoLine_f("All configuration changes apply to the entire machine.");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// available configurations
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuCheck("Allow Untrusted Kexts", CSR_ALLOW_UNTRUSTED_KEXTS, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Unrestricted FS", CSR_ALLOW_UNRESTRICTED_FS, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Task For PID", CSR_ALLOW_TASK_FOR_PID, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Kernel Debuger", CSR_ALLOW_KERNEL_DEBUGGER, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Apple Internal", CSR_ALLOW_APPLE_INTERNAL, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Unrestricted DTrace", CSR_ALLOW_UNRESTRICTED_DTRACE, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Unrestricted NVRAM", CSR_ALLOW_UNRESTRICTED_NVRAM, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Device Configuration", CSR_ALLOW_DEVICE_CONFIGURATION, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Any Recovery OS", CSR_ALLOW_ANY_RECOVERY_OS, 66);
|
|
|
|
|
SubScreen->AddMenuCheck("Allow Unapproved Kexts", CSR_ALLOW_UNAPPROVED_KEXTS, 66);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// return
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
ModifyTitles(Entry);
|
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuBLC()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
// init
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
|
|
|
|
// create the entry in the main menu
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_BLC, NULL);
|
2020-03-10 12:51:04 +01:00
|
|
|
|
// Entry->Title.SPrintf("boot_args->flags [0x%02x]->", gSettings.BooterConfig);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// submenu description
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Modify flags for boot.efi");
|
2020-03-03 21:44:07 +01:00
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuCheck("Reboot On Panic", kBootArgsFlagRebootOnPanic, 65);
|
|
|
|
|
SubScreen->AddMenuCheck("Hi DPI", kBootArgsFlagHiDPI, 65);
|
|
|
|
|
SubScreen->AddMenuCheck("Black Screen", kBootArgsFlagBlack, 65);
|
|
|
|
|
SubScreen->AddMenuCheck("CSR Active Config", kBootArgsFlagCSRActiveConfig, 65);
|
|
|
|
|
SubScreen->AddMenuCheck("CSR Pending Config", kBootArgsFlagCSRPendingConfig, 65);
|
|
|
|
|
SubScreen->AddMenuCheck("CSR Boot", kBootArgsFlagCSRBoot, 65);
|
|
|
|
|
SubScreen->AddMenuCheck("Black Background", kBootArgsFlagBlackBg, 65);
|
|
|
|
|
SubScreen->AddMenuCheck("Login UI", kBootArgsFlagLoginUI, 65);
|
|
|
|
|
SubScreen->AddMenuCheck("Install UI", kBootArgsFlagInstallUI, 65);
|
|
|
|
|
|
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
ModifyTitles(Entry);
|
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuSystem()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
|
|
|
|
// init
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
|
|
|
|
|
|
|
|
|
// create the entry in the options menu
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_SYSTEM, "System Parameters->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
// submenu description
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Choose options for booted OS");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuItemInput(2, "Block kext:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(51, "Set OS version if not:", TRUE);
|
|
|
|
|
SubScreen->AddMenuItemInput(118, "Booter Cfg Command:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(SubMenuCSR(), true);
|
|
|
|
|
SubScreen->AddMenuEntry(SubMenuBLC(), true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY* SubMenuConfigs()
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-03-10 10:45:17 +01:00
|
|
|
|
REFIT_MENU_ITEM_OPTIONS *Entry;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
REFIT_MENU_SCREEN *SubScreen;
|
2020-02-28 21:28:33 +01:00
|
|
|
|
REFIT_MENU_SWITCH *InputBootArgs;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
UINTN i;
|
|
|
|
|
|
2020-03-10 10:45:17 +01:00
|
|
|
|
Entry = newREFIT_MENU_ITEM_OPTIONS(&SubScreen, ActionEnter, SCREEN_THEME, "Configs->");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-04-04 18:22:07 +02:00
|
|
|
|
SubScreen->AddMenuInfoLine_f("Select a config file:");
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
for (i = 0; i < ConfigsNum; i++) {
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs = (__typeof__(InputBootArgs))AllocateZeroPool(sizeof(REFIT_INPUT_DIALOG));
|
|
|
|
|
InputBootArgs = new REFIT_MENU_SWITCH;
|
2020-03-10 17:50:55 +01:00
|
|
|
|
InputBootArgs->Title.takeValueFrom(ConfigsList[i]);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// InputBootArgs->Tag = TAG_SWITCH_OLD;
|
|
|
|
|
InputBootArgs->Row = i;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
InputBootArgs->Item = &InputItems[90];
|
2020-02-28 21:28:33 +01:00
|
|
|
|
InputBootArgs->AtClick = ActionEnter;
|
|
|
|
|
InputBootArgs->AtRightClick = ActionDetails;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(InputBootArgs, true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
SubScreen->AddMenuEntry(&MenuEntryReturn, false);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
return Entry;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-05 04:37:21 +01:00
|
|
|
|
VOID OptionsMenu(OUT REFIT_ABSTRACT_MENU_ENTRY **ChosenEntry)
|
2019-09-03 11:58:42 +02:00
|
|
|
|
{
|
2020-02-28 21:28:33 +01:00
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY *TmpChosenEntry = NULL;
|
|
|
|
|
REFIT_ABSTRACT_MENU_ENTRY *NextChosenEntry = NULL;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
UINTN MenuExit = 0;
|
|
|
|
|
UINTN SubMenuExit;
|
|
|
|
|
UINTN NextMenuExit;
|
|
|
|
|
//CHAR16* Flags;
|
2020-03-03 15:21:48 +01:00
|
|
|
|
|
2020-03-03 14:52:23 +01:00
|
|
|
|
MENU_STYLE_FUNC Style = &REFIT_MENU_SCREEN::TextMenuStyle;
|
2020-03-03 15:21:48 +01:00
|
|
|
|
|
2019-09-03 11:58:42 +02:00
|
|
|
|
INTN EntryIndex = 0;
|
|
|
|
|
INTN SubEntryIndex = -1; //value -1 means old position to remember
|
|
|
|
|
INTN NextEntryIndex = -1;
|
|
|
|
|
|
|
|
|
|
// REFIT_INPUT_DIALOG* InputBootArgs;
|
2020-03-29 18:17:27 +02:00
|
|
|
|
#if USE_XTHEME
|
|
|
|
|
BOOLEAN OldFontStyle = ThemeX.Proportional;
|
|
|
|
|
ThemeX.Proportional = FALSE; //temporary disable proportional
|
|
|
|
|
#else
|
2019-09-03 11:58:42 +02:00
|
|
|
|
BOOLEAN OldFontStyle = GlobalConfig.Proportional;
|
|
|
|
|
GlobalConfig.Proportional = FALSE; //temporary disable proportional
|
2020-03-29 18:17:27 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
if (AllowGraphicsMode) {
|
2020-03-03 14:52:23 +01:00
|
|
|
|
Style = &REFIT_MENU_SCREEN::GraphicsMenuStyle;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// remember, if you extended this menu then change procedures
|
|
|
|
|
// FillInputs and ApplyInputs
|
2020-03-29 18:17:27 +02:00
|
|
|
|
#if USE_XTHEME
|
|
|
|
|
if (!(ThemeX.HideUIFlags & HIDEUI_FLAG_MENU_TITLE_IMAGE)) {
|
2020-03-30 10:34:16 +02:00
|
|
|
|
OptionMenu.TitleImage = ThemeX.GetIcon(BUILTIN_ICON_FUNC_OPTIONS);
|
2020-03-29 18:17:27 +02:00
|
|
|
|
} else {
|
2020-03-30 10:34:16 +02:00
|
|
|
|
OptionMenu.TitleImage.setEmpty();
|
2020-03-29 18:17:27 +02:00
|
|
|
|
}
|
|
|
|
|
#else
|
2019-09-03 11:58:42 +02:00
|
|
|
|
if (!(GlobalConfig.HideUIFlags & HIDEUI_FLAG_MENU_TITLE_IMAGE)) {
|
|
|
|
|
OptionMenu.TitleImage = BuiltinIcon(BUILTIN_ICON_FUNC_OPTIONS);
|
|
|
|
|
} else {
|
|
|
|
|
OptionMenu.TitleImage = NULL;
|
|
|
|
|
}
|
2020-03-29 18:17:27 +02:00
|
|
|
|
#endif
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
gThemeOptionsChanged = FALSE;
|
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if (OptionMenu.Entries.size() == 0) {
|
2019-09-03 11:58:42 +02:00
|
|
|
|
gThemeOptionsChanged = TRUE;
|
|
|
|
|
OptionMenu.ID = SCREEN_OPTIONS;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
OptionMenu.AnimeRun = OptionMenu.GetAnime(); //FALSE;
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-03-03 21:44:07 +01:00
|
|
|
|
OptionMenu.AddMenuItemInput(0, "Boot Args:", TRUE);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
2020-02-28 21:28:33 +01:00
|
|
|
|
// AddMenuItemInput(&OptionMenu, 90, "Config:", TRUE);
|
|
|
|
|
// InputBootArgs->ShortcutDigit = 0xF1;
|
2020-03-03 21:44:07 +01:00
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuConfigs(), true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
|
|
|
|
|
if (AllowGraphicsMode) {
|
2020-03-03 21:44:07 +01:00
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuGUI(), true);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
2020-03-03 21:44:07 +01:00
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuACPI(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuSmbios(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuPCI(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuSpeedStep(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuGraphics(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuAudio(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuAudioPort(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuBinaries(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( SubMenuSystem(), true);
|
|
|
|
|
OptionMenu.AddMenuEntry( &MenuEntryReturn, false);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
//DBG("option menu created entries=%d\n", OptionMenu.Entries.size());
|
2019-09-03 11:58:42 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
while (!MenuExit) {
|
2020-03-03 15:17:39 +01:00
|
|
|
|
MenuExit = OptionMenu.RunGenericMenu(Style, &EntryIndex, ChosenEntry);
|
2019-09-03 11:58:42 +02:00
|
|
|
|
// MenuExit = RunMenu(&OptionMenu, ChosenEntry);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if ( MenuExit == MENU_EXIT_ESCAPE || (*ChosenEntry)->getREFIT_MENU_ITEM_RETURN() )
|
2019-09-03 11:58:42 +02:00
|
|
|
|
break;
|
|
|
|
|
if (MenuExit == MENU_EXIT_ENTER || MenuExit == MENU_EXIT_DETAILS) {
|
|
|
|
|
//enter input dialog or subscreen
|
|
|
|
|
if ((*ChosenEntry)->SubScreen != NULL) {
|
|
|
|
|
SubMenuExit = 0;
|
|
|
|
|
while (!SubMenuExit) {
|
2020-03-03 15:21:48 +01:00
|
|
|
|
|
2020-03-03 14:52:23 +01:00
|
|
|
|
SubMenuExit = (*ChosenEntry)->SubScreen->RunGenericMenu(Style, &SubEntryIndex, &TmpChosenEntry);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if (SubMenuExit == MENU_EXIT_ESCAPE || TmpChosenEntry->getREFIT_MENU_ITEM_RETURN() ){
|
2019-09-03 11:58:42 +02:00
|
|
|
|
ApplyInputs();
|
|
|
|
|
ModifyTitles(*ChosenEntry);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (SubMenuExit == MENU_EXIT_ENTER || MenuExit == MENU_EXIT_DETAILS) {
|
|
|
|
|
if (TmpChosenEntry->SubScreen != NULL) {
|
|
|
|
|
NextMenuExit = 0;
|
|
|
|
|
while (!NextMenuExit) {
|
2020-03-03 15:21:48 +01:00
|
|
|
|
|
2020-03-03 14:52:23 +01:00
|
|
|
|
NextMenuExit = TmpChosenEntry->SubScreen->RunGenericMenu(Style, &NextEntryIndex, &NextChosenEntry);
|
2020-02-28 21:28:33 +01:00
|
|
|
|
if (NextMenuExit == MENU_EXIT_ESCAPE || NextChosenEntry->getREFIT_MENU_ITEM_RETURN() ){
|
2019-09-03 11:58:42 +02:00
|
|
|
|
ApplyInputs();
|
|
|
|
|
ModifyTitles(TmpChosenEntry);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (NextMenuExit == MENU_EXIT_ENTER || MenuExit == MENU_EXIT_DETAILS) {
|
|
|
|
|
// enter input dialog
|
|
|
|
|
NextMenuExit = 0;
|
|
|
|
|
ApplyInputs();
|
|
|
|
|
ModifyTitles(TmpChosenEntry);
|
|
|
|
|
}
|
|
|
|
|
} //while(!NextMenuExit)
|
|
|
|
|
}
|
|
|
|
|
// enter input dialog
|
|
|
|
|
SubMenuExit = 0;
|
|
|
|
|
ApplyInputs();
|
|
|
|
|
ModifyTitles(TmpChosenEntry);
|
|
|
|
|
}
|
|
|
|
|
} //while(!SubMenuExit)
|
|
|
|
|
}
|
|
|
|
|
MenuExit = 0;
|
|
|
|
|
} // if MENU_EXIT_ENTER
|
|
|
|
|
}
|
|
|
|
|
//exit:
|
2020-03-30 10:34:16 +02:00
|
|
|
|
#if USE_XTHEME
|
|
|
|
|
ThemeX.Proportional = OldFontStyle;
|
|
|
|
|
#else
|
2019-09-03 11:58:42 +02:00
|
|
|
|
GlobalConfig.Proportional = OldFontStyle;
|
2020-03-30 10:34:16 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
2019-09-03 11:58:42 +02:00
|
|
|
|
ApplyInputs();
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-04 14:27:02 +02:00
|
|
|
|
//UINT32 EncodeOptions(CONST CHAR16 *Options)
|
|
|
|
|
//{
|
|
|
|
|
// UINT32 OptionsBits = 0;
|
|
|
|
|
// INTN Index;
|
|
|
|
|
// if (!Options) {
|
|
|
|
|
// return 0;
|
|
|
|
|
// }
|
|
|
|
|
// for (Index = 0; Index < NUM_OPT; Index++) {
|
|
|
|
|
// if (StrStr(Options, ArgOptional[Index])) {
|
|
|
|
|
// OptionsBits |= (1 << Index);
|
|
|
|
|
// if (Index == 1) {
|
|
|
|
|
// OptionsBits &= ~1;
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// return OptionsBits;
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//VOID DecodeOptions(REFIT_MENU_ITEM_BOOTNUM *Entry)
|
|
|
|
|
//{
|
|
|
|
|
// //set checked option
|
|
|
|
|
// INTN Index;
|
|
|
|
|
// if (!Entry) {
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
// for (Index = 0; Index < INX_NVWEBON; Index++) { //not including INX_NVWEBON
|
|
|
|
|
// if (gSettings.OptionsBits & (1 << Index)) {
|
|
|
|
|
// Entry->LoadOptions = AddLoadOption(Entry->LoadOptions, ArgOptional[Index]);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// //remove unchecked options
|
|
|
|
|
// for (Index = 0; Index < INX_NVWEBON; Index++) { //not including INX_NVWEBON
|
|
|
|
|
// if ((gSettings.OptionsBits & (1 << Index)) == 0) {
|
|
|
|
|
// Entry->LoadOptions = RemoveLoadOption(Entry->LoadOptions, ArgOptional[Index]);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// if (Entry->getLOADER_ENTRY()) {
|
|
|
|
|
// LOADER_ENTRY* loaderEntry = Entry->getLOADER_ENTRY();
|
|
|
|
|
// // Only for non-legacy entries, as LEGACY_ENTRY doesn't have OSVersion
|
|
|
|
|
// if (gSettings.OptionsBits & OPT_NVWEBON) {
|
|
|
|
|
// if (AsciiOSVersionToUint64(loaderEntry->OSVersion) >= AsciiOSVersionToUint64("10.12")) {
|
|
|
|
|
// gSettings.NvidiaWeb = TRUE;
|
|
|
|
|
// } else {
|
|
|
|
|
// Entry->LoadOptions = AddLoadOption(loaderEntry->LoadOptions, ArgOptional[INX_NVWEBON]);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// if ((gSettings.OptionsBits & OPT_NVWEBON) == 0) {
|
|
|
|
|
// if (AsciiOSVersionToUint64(loaderEntry->OSVersion) >= AsciiOSVersionToUint64("10.12")) {
|
|
|
|
|
// gSettings.NvidiaWeb = FALSE;
|
|
|
|
|
// } else {
|
|
|
|
|
// Entry->LoadOptions = RemoveLoadOption(loaderEntry->LoadOptions, ArgOptional[INX_NVWEBON]);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
//
|