Refactor of disk image handling
This commit is contained in:
parent
ebf1983b6f
commit
087825fa8b
7 changed files with 44 additions and 52 deletions
|
@ -1,2 +1,2 @@
|
|||
bochs: build/harddrive.bin
|
||||
bochs: build/harddrive.img
|
||||
bochs -f bochs.$(ARCH)
|
||||
|
|
18
mk/disk.mk
18
mk/disk.mk
|
@ -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
|
||||
|
||||
|
|
57
mk/qemu.mk
57
mk/qemu.mk
|
@ -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
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
virtualbox: build/harddrive.bin
|
||||
virtualbox: build/harddrive.img
|
||||
echo "Delete VM"
|
||||
-$(VBM) unregistervm Redox --delete; \
|
||||
if [ $$? -ne 0 ]; \
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue