Skip to content

Commit

Permalink
more memory protections
Browse files Browse the repository at this point in the history
Signed-off-by: Slice <[email protected]>
  • Loading branch information
SergeySlice committed Dec 25, 2023
1 parent 00466c6 commit 48ff604
Show file tree
Hide file tree
Showing 5 changed files with 113 additions and 66 deletions.
9 changes: 5 additions & 4 deletions Clover.dsc
Original file line number Diff line number Diff line change
Expand Up @@ -198,6 +198,7 @@
OcFlexArrayLib|OpenCorePkg/Library/OcFlexArrayLib/OcFlexArrayLib.inf
OcMainLib|OpenCorePkg/Library/OcMainLib/OcMainLibClover.inf
OcMemoryLib|OpenCorePkg/Library/OcMemoryLib/OcMemoryLib.inf
# OcMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
OcMiscLib|OpenCorePkg/Library/OcMiscLib/OcMiscLib.inf
OcOSInfoLib|OpenCorePkg/Library/OcOSInfoLib/OcOSInfoLib.inf
# OcPngLib|OpenCorePkg/Library/OcPngLib/OcPngLib.inf
Expand Down Expand Up @@ -372,10 +373,10 @@
<BuildOptions>
*_*_*_CC_FLAGS = $(OC_INCLUDE_FLAG)
}
OpenCorePkg/Library/OcMemoryLib/OcMemoryLib.inf {
<BuildOptions>
*_*_*_CC_FLAGS = $(OC_INCLUDE_FLAG)
}
# OpenCorePkg/Library/OcMemoryLib/OcMemoryLib.inf {
# <BuildOptions>
# *_*_*_CC_FLAGS = $(OC_INCLUDE_FLAG)
# }
OpenCorePkg/Library/OcMiscLib/OcMiscLib.inf {
<BuildOptions>
*_*_*_CC_FLAGS = $(OC_INCLUDE_FLAG)
Expand Down
8 changes: 4 additions & 4 deletions Qemu/launch
Original file line number Diff line number Diff line change
Expand Up @@ -70,9 +70,9 @@ then

bios_file=("$(dirname "$qemu_path")"/bios*)

diskutil umount /dev/disk4s1
diskutil umount /dev/disk4s2
diskutil eject disk4
diskutil umount /dev/disk3s1
diskutil umount /dev/disk3s2
diskutil eject disk3

"$qemu_path" \
-L "$(dirname "$qemu_path")" \
Expand All @@ -94,7 +94,7 @@ diskutil eject disk4
# -hdc /JiefLand/5.Devel/Clover/CloverEfi.vmw/ElCapitan.vmdk \

hdiutil attach ./disk_image_gpt.img
diskutil mount disk4s1
diskutil mount disk3s1

fi

26 changes: 13 additions & 13 deletions buildme
Original file line number Diff line number Diff line change
Expand Up @@ -31,9 +31,9 @@ tell application "Terminal"
activate
set bounds of window 1 to {0, 23, 615, 420}
set current settings of window 1 to settings set "Pro"
set font name of window 1 to "Monaco"
set font size of window 1 to "11"
set normal text color of window 1 to {3341, 35186, 50092}
# set font name of window 1 to "Monaco"
# set font size of window 1 to "11"
# set normal text color of window 1 to {3341, 35186, 50092}
set position of first window to {650, 420}
end tell
EOF
Expand Down Expand Up @@ -895,8 +895,12 @@ do
makeV2
break
;;
"build Clover with HFSPlus ")
buildCloverHFSPlus
"make Release (Default Toolchain) ")
makeRelease
BLC
buildPkg
buildIso
makeV2
break
;;
"update Clover ")
Expand Down Expand Up @@ -928,14 +932,6 @@ do
makeV2
break
;;
"make Release (Default Toolchain)")
makeRelease
BLC
buildPkg
buildIso
makeV2
break
;;
"make Release (with XCode)")
makeReleaseXC
BLC
Expand All @@ -944,6 +940,10 @@ do
makeV2
break
;;
"build Clover with HFSPlus ")
buildCloverHFSPlus
break
;;
"Extra Options")
Extra
break
Expand Down
134 changes: 90 additions & 44 deletions rEFIt_UEFI/refit/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -142,32 +142,73 @@ extern EFI_DXE_SERVICES *gDS;

EFI_PHYSICAL_ADDRESS ExtraSpace = EFI_SYSTEM_TABLE_MAX_ADDRESS;

//VOID
//PrintMemoryMap()
//{
// apd<EFI_MEMORY_DESCRIPTOR*> MemMap;
// UINTN MemMapSize;
// UINTN MapKey, DescriptorSize;
// UINT32 DescriptorVersion;
// EFI_STATUS Status;
//
// MemMapSize = 0;
// DescriptorSize = 0;
// Status = gBS->GetMemoryMap (&MemMapSize, MemMap, &MapKey, &DescriptorSize, &DescriptorVersion);
// if (Status != EFI_BUFFER_TOO_SMALL) {
// DBG("PrintMemoryMap: GetMemStatus=%s not EFI_BUFFER_TOO_SMALL\n", efiStrError(Status));
// return;
// }
// MemMapSize += EFI_PAGE_SIZE;
// MemMap = (EFI_MEMORY_DESCRIPTOR*)AllocatePool(MemMapSize);
//
// Status = gBS->GetMemoryMap (&MemMapSize, MemMap, &MapKey, &DescriptorSize, &DescriptorVersion);
// if ( EFI_ERROR(Status) ) {
// DBG("PrintMemoryMap: GetMemoryMap failed=%s\n", efiStrError(Status));
// return;
// }
//
// OcPrintMemoryMap(MemMapSize, MemMap, DescriptorSize);
//}

VOID
PrintMemoryMap()
PrintMemoryMap (
VOID
)
{
apd<EFI_MEMORY_DESCRIPTOR*> MemMap;
UINTN MemMapSize;
UINTN MapKey, DescriptorSize;
UINT32 DescriptorVersion;
EFI_STATUS Status;
EFI_MEMORY_DESCRIPTOR *MemMap;
EFI_MEMORY_DESCRIPTOR *MemMapPtr;
UINTN MemMapSize = 0;
UINTN MapKey = 0, DescriptorSize = 0;
UINT32 DescriptorVersion = 0;
UINT64 Bytes;
EFI_STATUS Status = EFI_SUCCESS;

MemMapSize = 0;
DescriptorSize = 0;
MemMap = NULL;
Status = gBS->GetMemoryMap (&MemMapSize, MemMap, &MapKey, &DescriptorSize, &DescriptorVersion);
if (Status != EFI_BUFFER_TOO_SMALL) {
DBG("PrintMemoryMap: GetMemStatus=%s not EFI_BUFFER_TOO_SMALL\n", efiStrError(Status));
return;
}
// ASSERT (Status == EFI_BUFFER_TOO_SMALL);
MemMapSize += EFI_PAGE_SIZE;
MemMap = (EFI_MEMORY_DESCRIPTOR*)AllocatePool(MemMapSize);

Status = gBS->AllocatePool (EfiBootServicesData, MemMapSize, (VOID**)&MemMap);
// ASSERT (Status == EFI_SUCCESS);
if (EFI_ERROR(Status)) return;
Status = gBS->GetMemoryMap (&MemMapSize, MemMap, &MapKey, &DescriptorSize, &DescriptorVersion);
if ( EFI_ERROR(Status) ) {
DBG("PrintMemoryMap: GetMemoryMap failed=%s\n", efiStrError(Status));
return;
// ASSERT (Status == EFI_SUCCESS);
MemMapPtr = MemMap;

// ASSERT (DescriptorVersion == EFI_MEMORY_DESCRIPTOR_VERSION);

for (UINTN Index = 0; Index < MemMapSize / DescriptorSize; Index ++) {
Bytes = LShiftU64 (MemMap->NumberOfPages, 12);
DEBUG ((EFI_D_ERROR, "%lX-%lX %lX %lX %X\n",
MemMap->PhysicalStart,
MemMap->PhysicalStart + Bytes - 1,
MemMap->NumberOfPages,
MemMap->Attribute,
(UINTN)MemMap->Type));
MemMap = (EFI_MEMORY_DESCRIPTOR *)((UINTN)MemMap + DescriptorSize);
}

OcPrintMemoryMap(MemMapSize, MemMap, DescriptorSize);
gBS->FreePool(MemMapPtr);
}


Expand Down Expand Up @@ -215,32 +256,32 @@ void AllocSmallBlocks(UINTN NumberOfPagesMax)
FreePool(MemMap);
}

void AllocSmallBlocks()
{
CONST EFI_MEMORY_ATTRIBUTES_TABLE *MemoryAttributesTable;

PrintMemoryMap();

UINTN size = 64;
UINTN nb = 0;

AllocSmallBlocks(size); // 252KB

MemoryAttributesTable = OcGetMemoryAttributes (NULL);
nb = MemoryAttributesTable->NumberOfEntries;

PrintMemoryMap();
while ( size <= 2048 && nb > 100 ) { // XNU seems to handle max 128 entries. So let's shrink a little bit under 128
size *= 2;
AllocSmallBlocks(size);
MemoryAttributesTable = OcGetMemoryAttributes (NULL);
nb = MemoryAttributesTable->NumberOfEntries;
PrintMemoryMap();
}
if ( size > 2048 ) {
DBG("Cannot shrink memory map enough. Nb entries = %lld\n", nb);
}
}
//void AllocSmallBlocks()
//{
// CONST EFI_MEMORY_ATTRIBUTES_TABLE *MemoryAttributesTable;
//
////PrintMemoryMap();
//
// UINTN size = 64;
// UINTN nb = 0;
//
// AllocSmallBlocks(size); // 252KB
//
// MemoryAttributesTable = OcGetMemoryAttributes (NULL);
// nb = MemoryAttributesTable->NumberOfEntries;
//
////PrintMemoryMap();
// while ( size <= 2048 && nb > 100 ) { // XNU seems to handle max 128 entries. So let's shrink a little bit under 128
// size *= 2;
// AllocSmallBlocks(size);
// MemoryAttributesTable = OcGetMemoryAttributes (NULL);
// nb = MemoryAttributesTable->NumberOfEntries;
////PrintMemoryMap();
// }
// if ( size > 2048 ) {
// DBG("Cannot shrink memory map enough. Nb entries = %lld\n", nb);
// }
//}


static EFI_STATUS LoadEFIImageList(IN EFI_DEVICE_PATH **DevicePaths,
Expand Down Expand Up @@ -1729,9 +1770,11 @@ void LOADER_ENTRY::StartLoader()
Status = SaveBooterLog(&self.getCloverDir(), PREBOOT_LOG);
}
gBS->FreePages (ExtraSpace, 90000);


#ifdef JIEF_DEBUG
AllocSmallBlocks(); // shrink memory map;
PrintMemoryMap();
#ifdef JIEF_DEBUG
displayFreeMemory("Just before launching image"_XS8);
#endif
Status = gBS->StartImage (ImageHandle, 0, NULL); // point to OcStartImage from OC
Expand Down Expand Up @@ -2911,6 +2954,9 @@ RefitMainMain (IN EFI_HANDLE ImageHandle,
#if 0
//testing place
{
//#define ARRAY_SIZE(Array) (sizeof (Array) / sizeof ((Array)[0]))
#define L_STR_LEN(String) (ARRAY_SIZE (String) - 1)
DBG("strlen '<' =%ld or %lld\n", L_STR_LEN("<"), AsciiStrLen("<"));
DBG(" size CHAR8=%ld\n", sizeof(CHAR8));
DBG(" size CHAR16=%ld\n", sizeof(CHAR16));
DBG(" size wchar_t=%ld\n", sizeof(wchar_t));
Expand Down

0 comments on commit 48ff604

Please sign in to comment.