2023-03-23 18:03:58 +03:00
|
|
|
.PHONY: test-clean
|
|
|
|
test-clean:
|
|
|
|
$(MAKE) -C test clean
|
|
|
|
rm -rf test_image test.hdd test.iso
|
|
|
|
|
|
|
|
ovmf-x64:
|
|
|
|
$(MKDIR_P) ovmf-x64
|
2023-06-06 00:14:44 +03:00
|
|
|
cd ovmf-x64 && curl -o OVMF.fd https://retrage.github.io/edk2-nightly/bin/RELEASEX64_OVMF.fd
|
2023-03-23 18:03:58 +03:00
|
|
|
|
|
|
|
ovmf-aa64:
|
2023-06-06 00:14:44 +03:00
|
|
|
$(MKDIR_P) ovmf-aa64
|
|
|
|
cd ovmf-aa64 && curl -o OVMF.fd https://retrage.github.io/edk2-nightly/bin/RELEASEAARCH64_QEMU_EFI.fd
|
2023-03-23 18:03:58 +03:00
|
|
|
|
2023-06-04 02:36:06 +03:00
|
|
|
ovmf-rv64:
|
2023-06-06 00:14:44 +03:00
|
|
|
$(MKDIR_P) ovmf-rv64
|
2023-09-20 20:55:13 +03:00
|
|
|
cd ovmf-rv64 && curl -o OVMF.fd https://retrage.github.io/edk2-nightly/bin/RELEASERISCV64_VIRT_CODE.fd && dd if=/dev/zero of=OVMF.fd bs=1 count=0 seek=33554432
|
2023-06-04 02:36:06 +03:00
|
|
|
|
2023-03-23 18:03:58 +03:00
|
|
|
ovmf-ia32:
|
|
|
|
$(MKDIR_P) ovmf-ia32
|
2023-06-06 00:14:44 +03:00
|
|
|
cd ovmf-ia32 && curl -o OVMF.fd https://retrage.github.io/edk2-nightly/bin/RELEASEIa32_OVMF.fd
|
2023-03-23 18:03:58 +03:00
|
|
|
|
|
|
|
.PHONY: test.hdd
|
|
|
|
test.hdd:
|
|
|
|
rm -f test.hdd
|
|
|
|
dd if=/dev/zero bs=1M count=0 seek=64 of=test.hdd
|
|
|
|
parted -s test.hdd mklabel gpt
|
|
|
|
parted -s test.hdd mkpart primary 2048s 100%
|
|
|
|
|
|
|
|
.PHONY: mbrtest.hdd
|
|
|
|
mbrtest.hdd:
|
|
|
|
rm -f mbrtest.hdd
|
|
|
|
dd if=/dev/zero bs=1M count=0 seek=64 of=mbrtest.hdd
|
|
|
|
echo -e "o\nn\np\n1\n2048\n\nt\n6\na\nw\n" | fdisk mbrtest.hdd -H 16 -S 63
|
|
|
|
|
|
|
|
.PHONY: ext2-test
|
|
|
|
ext2-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2023-04-11 23:04:05 +03:00
|
|
|
$(MAKE) limine
|
2023-03-23 18:03:58 +03:00
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.ext2 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2023-04-11 23:04:05 +03:00
|
|
|
$(BINDIR)/limine bios-install test.hdd
|
2023-03-23 18:03:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
|
|
|
|
|
|
|
.PHONY: fat12-test
|
|
|
|
fat12-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2023-04-11 23:04:05 +03:00
|
|
|
$(MAKE) limine
|
2023-03-23 18:03:58 +03:00
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 12 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2023-04-11 23:04:05 +03:00
|
|
|
$(BINDIR)/limine bios-install test.hdd
|
2023-03-23 18:03:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
|
|
|
|
|
|
|
.PHONY: fat16-test
|
|
|
|
fat16-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2023-04-11 23:04:05 +03:00
|
|
|
$(MAKE) limine
|
2023-03-23 18:03:58 +03:00
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 16 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2023-04-11 23:04:05 +03:00
|
|
|
$(BINDIR)/limine bios-install test.hdd
|
2023-03-23 18:03:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
|
|
|
|
|
|
|
.PHONY: legacy-fat16-test
|
|
|
|
legacy-fat16-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) mbrtest.hdd
|
|
|
|
fdisk -l mbrtest.hdd
|
|
|
|
$(MAKE) limine-bios
|
2023-04-11 23:04:05 +03:00
|
|
|
$(MAKE) limine
|
2023-03-23 18:03:58 +03:00
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show mbrtest.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 16 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2023-04-11 23:04:05 +03:00
|
|
|
$(BINDIR)/limine bios-install mbrtest.hdd
|
2023-03-23 18:03:58 +03:00
|
|
|
qemu-system-i386 -cpu pentium2 -m 16M -M isapc -net none -hda mbrtest.hdd -debugcon stdio
|
|
|
|
|
|
|
|
.PHONY: fat32-test
|
|
|
|
fat32-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2023-04-11 23:04:05 +03:00
|
|
|
$(MAKE) limine
|
2023-03-23 18:03:58 +03:00
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 32 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2023-04-11 23:04:05 +03:00
|
|
|
$(BINDIR)/limine bios-install test.hdd
|
2023-03-23 18:03:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
|
|
|
|
|
|
|
.PHONY: iso9660-test
|
|
|
|
iso9660-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
$(MKDIR_P) test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2023-06-15 02:07:44 +03:00
|
|
|
xorriso -as mkisofs -b boot/limine-bios-cd.bin -no-emul-boot -boot-load-size 4 -boot-info-table test_image/ -o test.iso
|
2023-03-23 18:03:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -cdrom test.iso -debugcon stdio
|
|
|
|
|
|
|
|
.PHONY: full-hybrid-test
|
|
|
|
full-hybrid-test:
|
|
|
|
$(MAKE) ovmf-x64
|
|
|
|
$(MAKE) ovmf-ia32
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) all
|
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
$(MKDIR_P) test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2023-06-15 02:07:44 +03:00
|
|
|
xorriso -as mkisofs -b boot/limine-bios-cd.bin -no-emul-boot -boot-load-size 4 -boot-info-table --efi-boot boot/limine-uefi-cd.bin -efi-boot-part --efi-boot-image --protective-msdos-label test_image/ -o test.iso
|
2023-04-11 23:04:05 +03:00
|
|
|
$(BINDIR)/limine bios-install test.iso
|
2023-03-23 18:03:58 +03:00
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-x64/OVMF.fd -net none -smp 4 -cdrom test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-x64/OVMF.fd -net none -smp 4 -hda test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-ia32/OVMF.fd -net none -smp 4 -cdrom test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-ia32/OVMF.fd -net none -smp 4 -hda test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -net none -smp 4 -cdrom test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -net none -smp 4 -hda test.iso -debugcon stdio
|
|
|
|
|
|
|
|
.PHONY: pxe-test
|
|
|
|
pxe-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) limine-bios
|
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
$(MKDIR_P) test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2023-06-14 04:04:01 +03:00
|
|
|
qemu-system-x86_64 -smp 4 -netdev user,id=n0,tftp=./test_image,bootfile=boot/limine-bios-pxe.bin -device rtl8139,netdev=n0,mac=00:00:00:11:11:11 -debugcon stdio
|
2023-03-23 18:03:58 +03:00
|
|
|
|
|
|
|
.PHONY: uefi-x86-64-test
|
|
|
|
uefi-x86-64-test:
|
|
|
|
$(MAKE) ovmf-x64
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-uefi-x86-64
|
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 32 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sudo $(MKDIR_P) test_image/EFI/BOOT
|
|
|
|
sudo cp $(BINDIR)/BOOTX64.EFI test_image/EFI/BOOT/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-x64/OVMF.fd -net none -smp 4 -hda test.hdd -debugcon stdio
|
|
|
|
|
|
|
|
.PHONY: uefi-aa64-test
|
|
|
|
uefi-aa64-test:
|
|
|
|
$(MAKE) ovmf-aa64
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-uefi-aarch64
|
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-aarch64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 32 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sudo $(MKDIR_P) test_image/EFI/BOOT
|
|
|
|
sudo cp $(BINDIR)/BOOTAA64.EFI test_image/EFI/BOOT/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
|
|
|
qemu-system-aarch64 -m 512M -M virt -cpu cortex-a72 -bios ovmf-aa64/OVMF.fd -net none -smp 4 -device ramfb -device qemu-xhci -device usb-kbd -hda test.hdd -serial stdio
|
|
|
|
|
2023-06-04 02:36:06 +03:00
|
|
|
.PHONY: uefi-rv64-test
|
|
|
|
uefi-rv64-test:
|
|
|
|
$(MAKE) ovmf-rv64
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-uefi-riscv64
|
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-riscv64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 32 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sudo $(MKDIR_P) test_image/EFI/BOOT
|
|
|
|
sudo cp $(BINDIR)/BOOTRISCV64.EFI test_image/EFI/BOOT/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2023-09-20 20:55:13 +03:00
|
|
|
qemu-system-riscv64 -m 512M -M virt -cpu rv64 -drive if=pflash,unit=0,format=raw,file=ovmf-rv64/OVMF.fd -net none -smp 4 -device ramfb -device qemu-xhci -device usb-kbd -device virtio-blk-device,drive=hd0 -drive id=hd0,format=raw,file=test.hdd -serial stdio
|
2023-06-04 02:36:06 +03:00
|
|
|
|
2023-03-23 18:03:58 +03:00
|
|
|
.PHONY: uefi-ia32-test
|
|
|
|
uefi-ia32-test:
|
|
|
|
$(MAKE) ovmf-ia32
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-uefi-ia32
|
|
|
|
$(MAKE) -C test TOOLCHAIN_FILE='$(call SHESCAPE,$(BUILDDIR))/toolchain-files/uefi-x86_64-toolchain.mk'
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 32 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sudo $(MKDIR_P) test_image/EFI/BOOT
|
|
|
|
sudo cp $(BINDIR)/BOOTIA32.EFI test_image/EFI/BOOT/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-ia32/OVMF.fd -net none -smp 4 -hda test.hdd -debugcon stdio
|