Refactor of disk image handling

This commit is contained in:
Jeremy Soller 2022-09-07 08:28:12 -06:00
parent ebf1983b6f
commit 087825fa8b
No known key found for this signature in database
GPG key ID: 87F211AF2BE4C2FE
7 changed files with 44 additions and 52 deletions

View file

@ -4,13 +4,11 @@ include mk/config.mk
# Dependencies
include mk/depends.mk
all: build/harddrive.bin
all: build/harddrive.img
coreboot: build/coreboot.elf
live: build/livedisk.bin
iso: build/livedisk.iso
live: build/livedisk.iso
rebuild:
touch $(FILESYSTEM_CONFIG)
@ -62,15 +60,14 @@ include mk/bochs.mk
include mk/virtualbox.mk
# CI image target
IMG_TAG?=$(shell git describe --tags)
ci-img: FORCE
$(MAKE) INSTALLER_FLAGS= \
build/harddrive.bin.gz \
build/livedisk.bin.gz \
build/harddrive.img.gz \
build/livedisk.iso.gz
rm -rf build/img
mkdir -p build/img
cp "build/harddrive.bin.gz" "build/img/redox_$(IMG_TAG)_harddrive.bin.gz"
cp "build/livedisk.bin.gz" "build/img/redox_$(IMG_TAG)_livedisk.bin.gz"
cp "build/harddrive.img.gz" "build/img/redox_$(IMG_TAG)_harddrive.img.gz"
cp "build/livedisk.iso.gz" "build/img/redox_$(IMG_TAG)_livedisk.iso.gz"
cd build/img && sha256sum -b * > SHA256SUM

View file

@ -1,6 +1,6 @@
megs: 1024
boot: disk
ata0-master: type=disk, path="build/harddrive.bin", mode=flat
ata0-master: type=disk, path="build/harddrive.img", mode=flat
#com1: enabled=1, mode=file, dev=build/serial.log
cpu: model=p2_klamath

View file

@ -1,6 +1,6 @@
megs: 1024
boot: disk
ata0-master: type=disk, path="build/harddrive.bin", mode=flat
ata0-master: type=disk, path="build/harddrive.img", mode=flat
#com1: enabled=1, mode=file, dev=build/serial.log
#cpu: model=corei7_haswell_4770

View file

@ -1,2 +1,2 @@
bochs: build/harddrive.bin
bochs: build/harddrive.img
bochs -f bochs.$(ARCH)

View file

@ -1,4 +1,4 @@
build/harddrive.bin: $(FILESYSTEM_CONFIG)
build/harddrive.img: $(FILESYSTEM_CONFIG)
$(HOST_CARGO) build --manifest-path installer/Cargo.toml --release
mkdir -p build
rm -rf $@ $@.partial
@ -6,7 +6,7 @@ build/harddrive.bin: $(FILESYSTEM_CONFIG)
$(INSTALLER) -c $(FILESYSTEM_CONFIG) $@.partial
mv $@.partial $@
build/livedisk.bin: $(FILESYSTEM_CONFIG)
build/livedisk.iso: $(FILESYSTEM_CONFIG)
$(HOST_CARGO) build --manifest-path installer/Cargo.toml --release
mkdir -p build
rm -rf $@ $@.partial
@ -14,27 +14,17 @@ build/livedisk.bin: $(FILESYSTEM_CONFIG)
$(INSTALLER) -c $(FILESYSTEM_CONFIG) --live $@.partial
mv $@.partial $@
build/livedisk.iso: build/livedisk.bin
rm -rf build/iso/ $@.partial
mkdir -p build/iso/
cp -v $< build/iso/livedisk.bin
genisoimage -o $@.partial \
-hard-disk-boot \
-b livedisk.bin \
build/iso/
mv $@.partial $@
mount: FORCE
mkdir -p build/filesystem/
$(HOST_CARGO) build --manifest-path redoxfs/Cargo.toml --release --bin redoxfs
redoxfs/target/release/redoxfs build/harddrive.bin build/filesystem/
redoxfs/target/release/redoxfs build/harddrive.img build/filesystem/
sleep 2
pgrep redoxfs
mount_extra: FORCE
mkdir -p build/filesystem/
$(HOST_CARGO) build --manifest-path redoxfs/Cargo.toml --release --bin redoxfs
redoxfs/target/release/redoxfs build/extra.bin build/filesystem/
redoxfs/target/release/redoxfs build/extra.img build/filesystem/
sleep 2
pgrep redoxfs

View file

@ -42,9 +42,9 @@ else
endif
ifeq ($(live),yes)
HARDDRIVE=build/livedisk.bin
DISK=build/livedisk.iso
else
HARDDRIVE=build/harddrive.bin
DISK=build/harddrive.img
endif
ifeq ($(serial),no)
@ -102,50 +102,55 @@ ifeq ($(UNAME),Linux)
endif
ifeq ($(UNAME),Linux)
build/extra.bin:
build/extra.img:
fallocate --posix --length 1G $@
else
build/extra.bin:
build/extra.img:
truncate -s 1g $@
endif
build/firmware.rom:
cp $(QEMU_EFI) $@
qemu: $(HARDDRIVE) $(FIRMWARE) build/extra.bin
qemu: $(DISK) $(FIRMWARE) build/extra.img
$(QEMU) $(QEMUFLAGS) \
-drive file=$(HARDDRIVE),format=raw \
-drive file=build/extra.bin,format=raw
-drive file=$(DISK),format=raw \
-drive file=build/extra.img,format=raw
qemu_no_build: $(FIRMWARE) build/extra.bin
qemu_no_build: $(FIRMWARE) build/extra.img
$(QEMU) $(QEMUFLAGS) \
-drive file=$(HARDDRIVE),format=raw \
-drive file=build/extra.bin,format=raw
-drive file=$(DISK),format=raw \
-drive file=build/extra.img,format=raw
qemu_nvme: $(HARDDRIVE) $(FIRMWARE) build/extra.bin
qemu_cdrom: $(DISK) $(FIRMWARE) build/extra.img
$(QEMU) $(QEMUFLAGS) \
-drive file=$(HARDDRIVE),format=raw,if=none,id=drv0 -device nvme,drive=drv0,serial=NVME_SERIAL \
-drive file=build/extra.bin,format=raw,if=none,id=drv1 -device nvme,drive=drv1,serial=NVME_EXTRA
-boot d -cdrom $(DISK) \
-drive file=build/extra.img,format=raw
qemu_nvme_no_build: $(FIRMWARE) build/extra.bin
qemu_cdrom_no_build: $(FIRMWARE) build/extra.img
$(QEMU) $(QEMUFLAGS) \
-drive file=$(HARDDRIVE),format=raw,if=none,id=drv0 -device nvme,drive=drv0,serial=NVME_SERIAL \
-drive file=build/extra.bin,format=raw,if=none,id=drv1 -device nvme,drive=drv1,serial=NVME_EXTRA
-boot d -cdrom $(DISK) \
-drive file=build/extra.img,format=raw
qemu_iso: build/livedisk.iso $(FIRMWARE) build/extra.bin
qemu_nvme: $(DISK) $(FIRMWARE) build/extra.img
$(QEMU) $(QEMUFLAGS) \
-boot d -cdrom build/livedisk.iso \
-drive file=build/extra.bin,format=raw
-drive file=$(DISK),format=raw,if=none,id=drv0 -device nvme,drive=drv0,serial=NVME_SERIAL \
-drive file=build/extra.img,format=raw,if=none,id=drv1 -device nvme,drive=drv1,serial=NVME_EXTRA
qemu_iso_no_build: $(FIRMWARE) build/extra.bin
qemu_nvme_no_build: $(FIRMWARE) build/extra.img
$(QEMU) $(QEMUFLAGS) \
-boot d -cdrom build/livedisk.iso \
-drive file=build/extra.bin,format=raw
-drive file=$(DISK),format=raw,if=none,id=drv0 -device nvme,drive=drv0,serial=NVME_SERIAL \
-drive file=build/extra.img,format=raw,if=none,id=drv1 -device nvme,drive=drv1,serial=NVME_EXTRA
qemu_extra: $(FIRMWARE) build/extra.bin
qemu_usb: $(DISK) $(FIRMWARE)
$(QEMU) $(QEMUFLAGS) \
-drive file=build/extra.bin,format=raw
-drive if=none,id=usbstick,format=raw,file=$(DISK) \
-device usb-storage,drive=usbstick
qemu_nvme_extra: $(FIRMWARE) build/extra.bin
qemu_extra: $(FIRMWARE) build/extra.img
$(QEMU) $(QEMUFLAGS) \
-drive file=build/extra.bin,format=raw,if=none,id=drv1 -device nvme,drive=drv1,serial=NVME_EXTRA
-drive file=build/extra.img,format=raw
qemu_nvme_extra: $(FIRMWARE) build/extra.img
$(QEMU) $(QEMUFLAGS) \
-drive file=build/extra.img,format=raw,if=none,id=drv1 -device nvme,drive=drv1,serial=NVME_EXTRA

View file

@ -1,4 +1,4 @@
virtualbox: build/harddrive.bin
virtualbox: build/harddrive.img
echo "Delete VM"
-$(VBM) unregistervm Redox --delete; \
if [ $$? -ne 0 ]; \