historical/m0-applesillicon.git/xnu-qemu-arm64-5.1.0/roms/edk2/EmulatorPkg
2024-01-16 11:20:27 -06:00
..
AutoScanPei phht hahahahaah 2024-01-16 11:20:27 -06:00
BootModePei phht hahahahaah 2024-01-16 11:20:27 -06:00
CpuRuntimeDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
EmuBlockIoDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
EmuBusDriverDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
EmuGopDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
EmuSimpleFileSystemDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
EmuSnpDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
EmuThunkDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
FirmwareVolumePei phht hahahahaah 2024-01-16 11:20:27 -06:00
FlashMapPei phht hahahahaah 2024-01-16 11:20:27 -06:00
FvbServicesRuntimeDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
Include phht hahahahaah 2024-01-16 11:20:27 -06:00
Library phht hahahahaah 2024-01-16 11:20:27 -06:00
MiscSubClassPlatformDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
PlatformSmbiosDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
RealTimeClockRuntimeDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
ResetRuntimeDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
Sec phht hahahahaah 2024-01-16 11:20:27 -06:00
ThunkPpiToProtocolPei phht hahahahaah 2024-01-16 11:20:27 -06:00
TimerDxe phht hahahahaah 2024-01-16 11:20:27 -06:00
Unix phht hahahahaah 2024-01-16 11:20:27 -06:00
Win phht hahahahaah 2024-01-16 11:20:27 -06:00
build.sh phht hahahahaah 2024-01-16 11:20:27 -06:00
EmulatorPkg.dec phht hahahahaah 2024-01-16 11:20:27 -06:00
EmulatorPkg.dsc phht hahahahaah 2024-01-16 11:20:27 -06:00
EmulatorPkg.fdf phht hahahahaah 2024-01-16 11:20:27 -06:00
Readme.md phht hahahahaah 2024-01-16 11:20:27 -06:00

Overview

EmulatorPkg provides an environment where a UEFI environment can be emulated under an environment where a full UEFI compatible environment is not possible. (For example, running under an OS where an OS process hosts the UEFI emulation environment.)

https://github.com/tianocore/tianocore.github.io/wiki/EmulatorPkg

Status

  • Builds and runs under
    • a posix-like environment with X windows
      • Linux
      • OS X
    • Windows environment
      • Win10 (verified)
      • Win8 (not verified)

How to Build & Run

You can use the following command to build.

  • 32bit emulator in Windows:

    build -p EmulatorPkg\EmulatorPkg.dsc -t VS2017 -D WIN_SEC_BUILD -a IA32

  • 64bit emulator in Windows:

    build -p EmulatorPkg\EmulatorPkg.dsc -t VS2017 -D WIN_SEC_BUILD -a X64

  • 32bit emulator in Linux:

    build -p EmulatorPkg\EmulatorPkg.dsc -t GCC5 -D UNIX_SEC_BUILD -a IA32

  • 64bit emulator in Linux:

    build -p EmulatorPkg\EmulatorPkg.dsc -t GCC5 -D UNIX_SEC_BUILD -a X64

You can start/run the emulator using the following command:

  • 32bit emulator in Windows:

    cd Build\EmulatorIA32\DEBUG_VS2017\IA32\ && WinHost.exe

  • 64bit emulator in Windows:

    cd Build\EmulatorX64\DEBUG_VS2017\X64\ && WinHost.exe

  • 32bit emulator in Linux:

    cd Build/EmulatorIA32/DEBUG_GCC5/IA32/ && ./Host

  • 64bit emulator in Linux:

    cd Build/EmulatorX64/DEBUG_GCC5/X64/ && ./Host

On posix-like environment with the bash shell you can use EmulatorPkg/build.sh to simplify building and running emulator.

For example, to build + run:

$ EmulatorPkg/build.sh
$ EmulatorPkg/build.sh run

The build architecture will match your host machine's architecture.

On X64 host machines, you can build + run IA32 mode as well:

$ EmulatorPkg/build.sh -a IA32
$ EmulatorPkg/build.sh -a IA32 run