/* * * Copyright (c) 2020 Jief * 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. */ #ifndef __menu_items_H__ #define __menu_items_H__ #include "../../libeg/libeg.h" #include "../../refit/lib.h" #include #include "../../Platform/boot.h" #include "../../cpp_foundation/XObjArray.h" #include "../../cpp_foundation/XStringArray.h" #include "../../cpp_foundation/XString.h" #include "../../libeg/XPointer.h" // //#define REFIT_DEBUG (2) //#define Print if ((!GlobalConfig.Quiet) || (GlobalConfig.TextOnly)) Print ////#include "GenericBdsLib.h" //#define TAG_ABOUT_OLD (1) //#define TAG_RESET_OLD (2) //#define TAG_SHUTDOWN_OLD (3) //#define TAG_TOOL_OLD (4) ////#define TAG_LOADER (5) ////#define TAG_LEGACY (6) //#define TAG_INFO_OLD (7) //#define TAG_OPTIONS (8) //#define TAG_INPUT_OLD (9) //#define TAG_HELP_OLD (10) // wasn't used ? //#define TAG_SWITCH_OLD (11) //#define TAG_CHECKBIT_OLD (12) //#define TAG_SECURE_BOOT_OLD (13) //#define TAG_SECURE_BOOT_CONFIG_OLD (14) //#define TAG_CLOVER_OLD (100) //#define TAG_EXIT_OLD (101) //#define TAG_RETURN_OLD ((UINTN)(-1)) //typedef struct _refit_menu_screen REFIT_MENU_SCREEN; class REFIT_MENU_SCREEN; class REFIT_MENU_SWITCH; class REFIT_MENU_CHECKBIT; class REFIT_MENU_ENTRY_CLOVER; class REFIT_MENU_ITEM_RETURN; class REFIT_INPUT_DIALOG; class REFIT_INFO_DIALOG; class REFIT_MENU_ENTRY_LOADER_TOOL; class REFIT_MENU_ITEM_SHUTDOWN; class REFIT_MENU_ITEM_RESET; class REFIT_MENU_ITEM_ABOUT; class REFIT_MENU_ITEM_OPTIONS; class REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER; class LOADER_ENTRY; class LEGACY_ENTRY; class REFIT_MENU_ENTRY_OTHER; class REFIT_SIMPLE_MENU_ENTRY_TAG; class REFIT_MENU_ENTRY_ITEM_ABSTRACT; class REFIT_MENU_ITEM_BOOTNUM; class XPointer; /********************************************************** REFIT_ABSTRACT_MENU_ENTRY *************************************************************/ class REFIT_ABSTRACT_MENU_ENTRY { public: XStringW Title; bool Hidden; UINTN Row; CHAR16 ShortcutDigit; CHAR16 ShortcutLetter; XIcon Image; EG_RECT Place; ACTION AtClick; ACTION AtDoubleClick; ACTION AtRightClick; ACTION AtMouseOver; REFIT_MENU_SCREEN *SubScreen; virtual XIcon* getDriveImage() { return nullptr; }; virtual XIcon* getBadgeImage() { return nullptr; }; virtual REFIT_SIMPLE_MENU_ENTRY_TAG* getREFIT_SIMPLE_MENU_ENTRY_TAG() { return nullptr; }; virtual REFIT_MENU_SWITCH* getREFIT_MENU_SWITCH() { return nullptr; }; virtual REFIT_MENU_CHECKBIT* getREFIT_MENU_CHECKBIT() { return nullptr; }; virtual REFIT_MENU_ENTRY_CLOVER* getREFIT_MENU_ENTRY_CLOVER() { return nullptr; }; virtual REFIT_MENU_ITEM_RETURN* getREFIT_MENU_ITEM_RETURN() { return nullptr; }; virtual REFIT_INPUT_DIALOG* getREFIT_INPUT_DIALOG() { return nullptr; }; virtual REFIT_INFO_DIALOG* getREFIT_INFO_DIALOG() { return nullptr; }; virtual REFIT_MENU_ENTRY_LOADER_TOOL* getREFIT_MENU_ENTRY_LOADER_TOOL() { return nullptr; }; virtual REFIT_MENU_ITEM_SHUTDOWN* getREFIT_MENU_ITEM_SHUTDOWN() { return nullptr; }; virtual REFIT_MENU_ITEM_RESET* getREFIT_MENU_ITEM_RESET() { return nullptr; }; virtual REFIT_MENU_ITEM_ABOUT* getREFIT_MENU_ITEM_ABOUT() { return nullptr; }; virtual REFIT_MENU_ITEM_OPTIONS* getREFIT_MENU_ITEM_OPTIONS() { return nullptr; }; virtual REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER* getREFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER() { return nullptr; }; virtual LOADER_ENTRY* getLOADER_ENTRY() { return nullptr; }; virtual LEGACY_ENTRY* getLEGACY_ENTRY() { return nullptr; }; virtual REFIT_MENU_ENTRY_OTHER* getREFIT_MENU_ENTRY_OTHER() { return nullptr; }; virtual REFIT_MENU_ENTRY_ITEM_ABSTRACT* getREFIT_MENU_ITEM_IEM_ABSTRACT() { return nullptr; }; virtual REFIT_MENU_ITEM_BOOTNUM* getREFIT_MENU_ITEM_BOOTNUM() { return nullptr; }; virtual void StartLoader() {}; virtual void StartLegacy() {}; virtual void StartTool() {}; REFIT_ABSTRACT_MENU_ENTRY() : Title(), Hidden(0), Row(0), ShortcutDigit(0), ShortcutLetter(0), Image(), Place(), AtClick(ActionNone), AtDoubleClick(ActionNone), AtRightClick(ActionNone), AtMouseOver(ActionNone), SubScreen(NULL) {}; REFIT_ABSTRACT_MENU_ENTRY(const XStringW& Title_) : Title(Title_), Hidden(0), Row(0), ShortcutDigit(0), ShortcutLetter(0), Image(), Place(), AtClick(ActionNone), AtDoubleClick(ActionNone), AtRightClick(ActionNone), AtMouseOver(ActionNone), SubScreen(NULL) {}; REFIT_ABSTRACT_MENU_ENTRY(const XStringW& Title_, ACTION AtClick_) : Title(Title_), Hidden(0), Row(0), ShortcutDigit(0), ShortcutLetter(0), Image(), Place(), AtClick(AtClick_), AtDoubleClick(ActionNone), AtRightClick(ActionNone), AtMouseOver(ActionNone), SubScreen(NULL) {}; REFIT_ABSTRACT_MENU_ENTRY(const XStringW& Title_, UINTN Row_, CHAR16 ShortcutDigit_, CHAR16 ShortcutLetter_, ACTION AtClick_) : Title(Title_), Hidden(0), Row(Row_), ShortcutDigit(ShortcutDigit_), ShortcutLetter(ShortcutLetter_), Image(), Place(), AtClick(AtClick_), AtDoubleClick(ActionNone), AtRightClick(ActionNone), AtMouseOver(ActionNone), SubScreen(NULL) {}; // REFIT_ABSTRACT_MENU_ENTRY(const XStringW& Title_, UINTN Row_, // CHAR16 ShortcutDigit_, CHAR16 ShortcutLetter_, const XIcon& Icon_, // EG_RECT Place_, ACTION AtClick_, ACTION AtDoubleClick_, ACTION AtRightClick_, ACTION AtMouseOver_, // REFIT_MENU_SCREEN *SubScreen_) // : Title(Title_), Row(Row_), ShortcutDigit(ShortcutDigit_), ShortcutLetter(ShortcutLetter_), // Image(Icon_), Place(Place_), // AtClick(AtClick_), AtDoubleClick(AtDoubleClick_), AtRightClick(AtRightClick_), AtMouseOver(AtMouseOver_), // SubScreen(SubScreen_) // {}; REFIT_ABSTRACT_MENU_ENTRY(const REFIT_ABSTRACT_MENU_ENTRY&) = delete; REFIT_ABSTRACT_MENU_ENTRY& operator=(const REFIT_ABSTRACT_MENU_ENTRY&) = delete; virtual ~REFIT_ABSTRACT_MENU_ENTRY() {}; // virtual destructor : this is vital }; /********************************************************** REFIT_ABSTRACT_MENU_ENTRY *************************************************************/ class REFIT_SIMPLE_MENU_ENTRY_TAG : public REFIT_ABSTRACT_MENU_ENTRY { public: UINTN Tag; REFIT_SIMPLE_MENU_ENTRY_TAG(const XStringW& Title_, UINTN Tag_, ACTION AtClick_) : REFIT_ABSTRACT_MENU_ENTRY(Title_, AtClick_), Tag(Tag_) {}; virtual REFIT_SIMPLE_MENU_ENTRY_TAG* getREFIT_SIMPLE_MENU_ENTRY_TAG() { return this; }; }; /********************************************************** Simple entries. Inherit from REFIT_ABSTRACT_MENU_ENTRY *************************************************************/ class REFIT_MENU_ITEM_RETURN : public REFIT_ABSTRACT_MENU_ENTRY { public: REFIT_MENU_ITEM_RETURN() : REFIT_ABSTRACT_MENU_ENTRY() {}; REFIT_MENU_ITEM_RETURN(const XStringW& Title_, UINTN Row_, CHAR16 ShortcutDigit_, CHAR16 ShortcutLetter_, ACTION AtClick_) : REFIT_ABSTRACT_MENU_ENTRY(Title_, Row_, ShortcutDigit_, ShortcutLetter_, AtClick_) {}; virtual REFIT_MENU_ITEM_RETURN* getREFIT_MENU_ITEM_RETURN() { return this; }; }; class REFIT_MENU_ITEM_SHUTDOWN : public REFIT_ABSTRACT_MENU_ENTRY { public: REFIT_MENU_ITEM_SHUTDOWN() : REFIT_ABSTRACT_MENU_ENTRY() {}; REFIT_MENU_ITEM_SHUTDOWN(const XStringW& Title_, UINTN Row_, CHAR16 ShortcutDigit_, CHAR16 ShortcutLetter_, ACTION AtClick_) : REFIT_ABSTRACT_MENU_ENTRY(Title_, Row_, ShortcutDigit_, ShortcutLetter_, AtClick_) {}; virtual REFIT_MENU_ITEM_SHUTDOWN* getREFIT_MENU_ITEM_SHUTDOWN() { return this; }; }; class REFIT_MENU_ITEM_RESET : public REFIT_ABSTRACT_MENU_ENTRY { public: REFIT_MENU_ITEM_RESET() : REFIT_ABSTRACT_MENU_ENTRY() {}; REFIT_MENU_ITEM_RESET(const XStringW& Title_, UINTN Row_, CHAR16 ShortcutDigit_, CHAR16 ShortcutLetter_, ACTION AtClick_) : REFIT_ABSTRACT_MENU_ENTRY(Title_, Row_, ShortcutDigit_, ShortcutLetter_, AtClick_) {}; virtual REFIT_MENU_ITEM_RESET* getREFIT_MENU_ITEM_RESET() { return this; }; }; class REFIT_MENU_ITEM_ABOUT : public REFIT_ABSTRACT_MENU_ENTRY { public: REFIT_MENU_ITEM_ABOUT() : REFIT_ABSTRACT_MENU_ENTRY() {}; REFIT_MENU_ITEM_ABOUT(const XStringW& Title_, UINTN Row_, CHAR16 ShortcutDigit_, CHAR16 ShortcutLetter_, ACTION AtClick_) : REFIT_ABSTRACT_MENU_ENTRY(Title_, Row_, ShortcutDigit_, ShortcutLetter_, AtClick_) {}; virtual REFIT_MENU_ITEM_ABOUT* getREFIT_MENU_ITEM_ABOUT() { return this; }; }; class REFIT_MENU_ITEM_OPTIONS : public REFIT_ABSTRACT_MENU_ENTRY { public: REFIT_MENU_ITEM_OPTIONS() : REFIT_ABSTRACT_MENU_ENTRY() {}; REFIT_MENU_ITEM_OPTIONS(const XStringW& Title_, UINTN Row_, CHAR16 ShortcutDigit_, CHAR16 ShortcutLetter_, ACTION AtClick_) : REFIT_ABSTRACT_MENU_ENTRY(Title_, Row_, ShortcutDigit_, ShortcutLetter_, AtClick_) {}; virtual REFIT_MENU_ITEM_OPTIONS* getREFIT_MENU_ITEM_OPTIONS() { return this; }; }; class REFIT_INFO_DIALOG : public REFIT_ABSTRACT_MENU_ENTRY { public: virtual REFIT_INFO_DIALOG* getREFIT_INFO_DIALOG() { return this; }; }; /********************************************************** *************************************************************/ class REFIT_MENU_ENTRY_ITEM_ABSTRACT : public REFIT_ABSTRACT_MENU_ENTRY { public: INPUT_ITEM *Item; REFIT_MENU_ENTRY_ITEM_ABSTRACT() : Item(0) {} REFIT_MENU_ENTRY_ITEM_ABSTRACT(const REFIT_MENU_ENTRY_ITEM_ABSTRACT&) = delete; REFIT_MENU_ENTRY_ITEM_ABSTRACT& operator=(const REFIT_MENU_ENTRY_ITEM_ABSTRACT&) = delete; virtual REFIT_MENU_ENTRY_ITEM_ABSTRACT* getREFIT_MENU_ITEM_IEM_ABSTRACT() { return this; }; }; /* Classes that needs a Item member */ class REFIT_INPUT_DIALOG : public REFIT_MENU_ENTRY_ITEM_ABSTRACT { public: virtual REFIT_INPUT_DIALOG* getREFIT_INPUT_DIALOG() { return this; }; }; class REFIT_MENU_SWITCH : public REFIT_MENU_ENTRY_ITEM_ABSTRACT { public: virtual REFIT_MENU_SWITCH* getREFIT_MENU_SWITCH() { return this; }; }; class REFIT_MENU_CHECKBIT : public REFIT_MENU_ENTRY_ITEM_ABSTRACT { public: virtual REFIT_MENU_CHECKBIT* getREFIT_MENU_CHECKBIT() { return this; }; }; /********************************************************** Loader entries *************************************************************/ /* * Super class of LOADER_ENTRY & LEGACY_ENTRY */ class REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER : public REFIT_ABSTRACT_MENU_ENTRY { public: XStringW DevicePathString; XString8Array LoadOptions; //moved here for compatibility with legacy XStringW LoaderPath; XIcon DriveImage; XIcon BadgeImage; REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER() : REFIT_ABSTRACT_MENU_ENTRY(), DevicePathString(0), LoadOptions(), LoaderPath(), DriveImage(), BadgeImage() {} REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER(const REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER&) = delete; REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER& operator=(const REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER&) = delete; virtual XIcon* getDriveImage() { return &DriveImage; }; virtual XIcon* getBadgeImage() { return &BadgeImage; }; virtual REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER* getREFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER() { return this; }; }; //--------------------------------------- REFIT_MENU_ENTRY_LOADER_TOOL ---------------------------------------// class REFIT_MENU_ENTRY_LOADER_TOOL : public REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER { public: UINT8 NoMemset; //HACK - some non zero value UINT16 Flags; EFI_DEVICE_PATH *DevicePath; void StartTool(); REFIT_MENU_ENTRY_LOADER_TOOL() : REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER(), NoMemset(1), Flags(0), DevicePath(0) {}; REFIT_MENU_ENTRY_LOADER_TOOL(const REFIT_MENU_ENTRY_LOADER_TOOL&) = delete; REFIT_MENU_ENTRY_LOADER_TOOL& operator=(const REFIT_MENU_ENTRY_LOADER_TOOL&) = delete; virtual REFIT_MENU_ENTRY_LOADER_TOOL* getREFIT_MENU_ENTRY_LOADER_TOOL() { return this; }; }; //--------------------------------------- REFIT_MENU_ENTRY_CLOVER ---------------------------------------// class REFIT_MENU_ENTRY_CLOVER : public REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER { public: REFIT_VOLUME *Volume; XStringW VolName; EFI_DEVICE_PATH *DevicePath; UINT16 Flags; REFIT_MENU_ENTRY_CLOVER() : REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER(), Volume(NULL), VolName(), DevicePath(NULL), Flags(0) {}; REFIT_MENU_ENTRY_CLOVER(const REFIT_MENU_ENTRY_CLOVER&) = delete; REFIT_MENU_ENTRY_CLOVER& operator=(const REFIT_MENU_ENTRY_CLOVER&) = delete; REFIT_MENU_ENTRY_CLOVER* getPartiallyDuplicatedEntry() const; virtual REFIT_MENU_ENTRY_CLOVER* getREFIT_MENU_ENTRY_CLOVER() { return this; }; }; //--------------------------------------- REFIT_MENU_ITEM_BOOTNUM ---------------------------------------// class REFIT_MENU_ITEM_BOOTNUM : public REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER { public: REFIT_VOLUME *Volume; UINTN BootNum; REFIT_MENU_ITEM_BOOTNUM() : REFIT_MENU_ITEM_ABSTRACT_ENTRY_LOADER(), Volume(NULL), BootNum(0) {}; REFIT_MENU_ITEM_BOOTNUM(const REFIT_MENU_ITEM_BOOTNUM&) = delete; REFIT_MENU_ITEM_BOOTNUM& operator=(const REFIT_MENU_ITEM_BOOTNUM&) = delete; virtual REFIT_MENU_ITEM_BOOTNUM* getREFIT_MENU_ITEM_BOOTNUM() { return this; }; } ; //--------------------------------------- LEGACY_ENTRY ---------------------------------------// class LEGACY_ENTRY : public REFIT_MENU_ITEM_BOOTNUM { public: LEGACY_ENTRY() : REFIT_MENU_ITEM_BOOTNUM() {}; void StartLegacy(); virtual LEGACY_ENTRY* getLEGACY_ENTRY() { return this; }; }; //--------------------------------------- LOADER_ENTRY ---------------------------------------// class LOADER_ENTRY : public REFIT_MENU_ITEM_BOOTNUM { public: XStringW APFSTargetUUID; XStringW DisplayedVolName; EFI_DEVICE_PATH *DevicePath; UINT16 Flags; UINT8 LoaderType; XString8 OSVersion; XString8 BuildVersion; EFI_GRAPHICS_OUTPUT_BLT_PIXEL BootBgColor; UINT8 CustomBoot; XImage CustomLogo; KERNEL_AND_KEXT_PATCHES KernelAndKextPatches; XStringW Settings; UINT8 *KernelData; UINT32 AddrVtable; UINT32 SizeVtable; UINT32 NamesTable; INT32 SegVAddr; INT32 shift; BOOLEAN PatcherInited; BOOLEAN gSNBEAICPUFixRequire; // SandyBridge-E AppleIntelCpuPowerManagement patch require or not BOOLEAN gBDWEIOPCIFixRequire; // Broadwell-E IOPCIFamily fix require or not BOOLEAN isKernelcache; BOOLEAN is64BitKernel; UINT32 KernelSlide; UINT32 KernelOffset; // notes: // - 64bit segCmd64->vmaddr is 0xffffff80xxxxxxxx and we are taking // only lower 32bit part into PrelinkTextAddr // - PrelinkTextAddr is segCmd64->vmaddr + KernelRelocBase UINT32 PrelinkTextLoadCmdAddr; UINT32 PrelinkTextAddr; UINT32 PrelinkTextSize; // notes: // - 64bit sect->addr is 0xffffff80xxxxxxxx and we are taking // only lower 32bit part into PrelinkInfoAddr ... Why??? // - PrelinkInfoAddr is sect->addr + KernelRelocBase UINT32 PrelinkInfoLoadCmdAddr; UINT32 PrelinkInfoAddr; UINT32 PrelinkInfoSize; EFI_PHYSICAL_ADDRESS KernelRelocBase; BootArgs1 *bootArgs1; BootArgs2 *bootArgs2; CHAR8 *dtRoot; UINT32 *dtLength; LOADER_ENTRY() : REFIT_MENU_ITEM_BOOTNUM(), APFSTargetUUID(), DisplayedVolName(), DevicePath(0), Flags(0), LoaderType(0), OSVersion(), BuildVersion(), BootBgColor({0,0,0,0}), CustomBoot(0), CustomLogo(), KernelAndKextPatches(), Settings(), KernelData(0), AddrVtable(0), SizeVtable(0), NamesTable(0), SegVAddr(0), shift(0), PatcherInited(false), gSNBEAICPUFixRequire(false), gBDWEIOPCIFixRequire(false), isKernelcache(false), is64BitKernel(false), KernelSlide(0), KernelOffset(0), PrelinkTextLoadCmdAddr(0), PrelinkTextAddr(0), PrelinkTextSize(0), PrelinkInfoLoadCmdAddr(0), PrelinkInfoAddr(0), PrelinkInfoSize(0), KernelRelocBase(0), bootArgs1(0), bootArgs2(0), dtRoot(0), dtLength(0) {}; LOADER_ENTRY(const LOADER_ENTRY&) = delete; LOADER_ENTRY& operator=(const LOADER_ENTRY&) = delete; void SetKernelRelocBase(); void FindBootArgs(); EFI_STATUS getVTable(); void Get_PreLink(); UINT32 Get_Symtab(UINT8* binary); UINT32 GetTextExec(); UINTN searchProc(const XString8& procedure); UINTN searchProcInDriver(UINT8 * driver, UINT32 driverLen, const XString8& procedure); UINT32 searchSectionByNum(UINT8 * Binary, UINT32 Num); void KernelAndKextsPatcherStart(); void KernelAndKextPatcherInit(); BOOLEAN KernelUserPatch(); BOOLEAN KernelPatchPm(); BOOLEAN KernelLapicPatch_32(); BOOLEAN KernelLapicPatch_64(); BOOLEAN BooterPatch(IN UINT8 *BooterData, IN UINT64 BooterSize); void EFIAPI KernelBooterExtensionsPatch(); BOOLEAN KernelPanicNoKextDump(); void KernelCPUIDPatch(); BOOLEAN PatchCPUID(const UINT8* Location, INT32 LenLoc, const UINT8* Search4, const UINT8* Search10, const UINT8* ReplaceModel, const UINT8* ReplaceExt, INT32 Len); void KernelPatcher_32(); // void KernelPatcher_64(); void FilterKernelPatches(); void FilterKextPatches(); void FilterBootPatches(); void applyKernPatch(const UINT8 *find, UINTN size, const UINT8 *repl, const CHAR8 *comment); EFI_STATUS SetFSInjection(); EFI_STATUS InjectKexts(IN UINT32 deviceTreeP, IN UINT32 *deviceTreeLength); EFI_STATUS LoadKexts(); // int is_mkext_v1(UINT8* drvPtr); // void patch_mkext_v1(UINT8 *drvPtr); //not used EFI_STATUS LoadKext(IN EFI_FILE *RootDir, IN CONST CHAR16 *FileName, IN cpu_type_t archCpuType, IN OUT void *kext); EFI_STATUS AddKext(IN EFI_FILE *RootDir, IN CONST CHAR16 *FileName, IN cpu_type_t archCpuType); void LoadPlugInKexts(IN EFI_FILE *RootDir, IN CONST CHAR16 *DirName, IN cpu_type_t archCpuType, IN BOOLEAN Force); void AddKexts(const XStringW& SrcDir, const XStringW& Path, cpu_type_t archCpuType); void KextPatcherRegisterKexts(void *FSInject, void *ForceLoadKexts); void KextPatcherStart(); void PatchPrelinkedKexts(); void PatchLoadedKexts(); void PatchKext(UINT8 *Driver, UINT32 DriverSize, CHAR8 *InfoPlist, UINT32 InfoPlistSize); void AnyKextPatch(UINT8 *Driver, UINT32 DriverSize, CHAR8 *InfoPlist, UINT32 InfoPlistSize, size_t N); void ATIConnectorsPatchInit(); void ATIConnectorsPatch(UINT8 *Driver, UINT32 DriverSize, CHAR8 *InfoPlist, UINT32 InfoPlistSize); void ATIConnectorsPatchRegisterKexts(void *FSInject_v, void *ForceLoadKexts_v); void AppleIntelCPUPMPatch(UINT8 *Driver, UINT32 DriverSize, CHAR8 *InfoPlist, UINT32 InfoPlistSize); void AppleRTCPatch(UINT8 *Driver, UINT32 DriverSize, CHAR8 *InfoPlist, UINT32 InfoPlistSize); // void CheckForFakeSMC(CHAR8 *InfoPlist); void DellSMBIOSPatch(UINT8 *Driver, UINT32 DriverSize, CHAR8 *InfoPlist, UINT32 InfoPlistSize); void SNBE_AICPUPatch(UINT8 *Driver, UINT32 DriverSize, CHAR8 *InfoPlist, UINT32 InfoPlistSize); void BDWE_IOPCIPatch(UINT8 *Driver, UINT32 DriverSize, CHAR8 *InfoPlist, UINT32 InfoPlistSize); BOOLEAN SandyBridgeEPM(); BOOLEAN HaswellEXCPM(); BOOLEAN HaswellLowEndXCPM(); BOOLEAN BroadwellEPM(); BOOLEAN KernelIvyBridgeXCPM(); BOOLEAN KernelIvyE5XCPM(); void EightApplePatch(UINT8 *Driver, UINT32 DriverSize); void Stall(int Pause) { if ( KernelAndKextPatches.KPDebug ) { gBS->Stall(Pause); } }; void StartLoader(); void AddDefaultMenu(); LOADER_ENTRY* getPartiallyDuplicatedEntry() const; virtual LOADER_ENTRY* getLOADER_ENTRY() { return this; }; LOADER_ENTRY* SubMenuKextInjectMgmt(); } ; #endif /* EOF */