I want to obtain the uefi memory map, so I can implement paging for my OS(for x86 architecture):
Code: Select all
#include <efi.h>
void waitForUser(EFI_SYSTEM_TABLE *st);
EFI_STATUS
efi_main(EFI_HANDLE ImageHandle, EFI_SYSTEM_TABLE *SystemTable)
{
EFI_SYSTEM_TABLE *st = SystemTable;
EFI_STATUS result;
UINTN mapSize = 0, mapKey, descriptorSize;
EFI_MEMORY_DESCRIPTOR memoryMap;
EFI_MEMORY_TYPE memType = EfiLoaderData;
UINT32 descriptorVersion = 1;
// FIRST CALL: Get the required memory pool size for the memory map
result = st->BootServices->GetMemoryMap(&mapSize,
&memoryMap, NULL, &descriptorSize, NULL);
if(result != EFI_BUFFER_TOO_SMALL)
{
st->ConOut->OutputString(st->ConOut, L"Getting memory map size failure\n\r");
return result;
}
// Allocating the pool creates at least one new descriptor
mapSize += 2 * descriptorSize;
memoryMap.PhysicalStart = 0;
VOID *physStr;
result = st->BootServices->AllocatePool(memType, mapSize, &(physStr));
if(result != EFI_SUCCESS)
{
st->ConOut->OutputString(st->ConOut, L"Allocating pool failure\n\r");
return result;
}
//SECOND CALL: get actual memory map
st->ConOut->OutputString(st->ConOut, L"Getting memory map:\n\r");
waitForUser(st);
result = st->BootServices->GetMemoryMap(&mapSize,
&memoryMap, &mapKey, &descriptorSize, &descriptorVersion);
if(result != EFI_SUCCESS)
{
st->ConOut->OutputString(st->ConOut, L"obtaining map failure\n\r");
return result;
}
else
st->ConOut->OutputString(st->ConOut, L"obtaining map success\n\r");
return result;
}
void waitForUser(EFI_SYSTEM_TABLE *st)
{
EFI_STATUS Status;
EFI_INPUT_KEY Key;
//emty console input buffer to flush any keystrokes entered
//before this point
Status = st->ConIn->Reset(st->ConIn, FALSE);
if (EFI_ERROR(Status))
return;
//wait for key to become available
while ((Status = st->ConIn->ReadKeyStroke(st->ConIn, &Key)) == EFI_NOT_READY);
}
As far as I've checked no processor exception is raised during this execution.qemu: fatal: Trying to execute code outside RAM or ROM at 0x000b0000
EAX=00000000 EBX=3ffc10f0 ECX=3ffafd98 EDX=00000000
ESI=3efb0d90 EDI=3ffafeac EBP=3ffafdac ESP=3ffafd50
EIP=000afff8 EFL=00000246 [---Z-P-] CPL=0 II=0 A20=1 SMM=0 HLT=0
ES =0008 00000000 ffffffff 00cf9300 DPL=0 DS [-WA]
CS =0010 00000000 ffffffff 00cf9a00 DPL=0 CS32 [-R-]
SS =0008 00000000 ffffffff 00cf9300 DPL=0 DS [-WA]
DS =0008 00000000 ffffffff 00cf9300 DPL=0 DS [-WA]
FS =0008 00000000 ffffffff 00cf9300 DPL=0 DS [-WA]
GS =0008 00000000 ffffffff 00cf9300 DPL=0 DS [-WA]
LDT=0000 00000000 0000ffff 00008200 DPL=0 LDT
TR =0000 00000000 0000ffff 00008b00 DPL=0 TSS32-busy
GDT= 3ff7ed90 0000003f
IDT= 3fc5d010 000007ff
CR0=40000033 CR2=00000000 CR3=00000000 CR4=00000648
DR0=00000000 DR1=00000000 DR2=00000000 DR3=00000000
DR6=ffff0ff0 DR7=00000400
CCS=00000000 CCD=00000000 CCO=ADDB
EFER=0000000000000000
FCW=027f FSW=0000 [ST=0] FTW=00 MXCSR=00001f80
I'm using gnu-efi, ovmf and qemu. I'll be really grateful for any tip how to fix this.