vmm: debug user code page fault

This commit is contained in:
RaphProductions 2025-05-11 15:35:45 +02:00
parent a379d66784
commit 5168cfa4e1
4 changed files with 113 additions and 84 deletions

View file

@ -31,7 +31,8 @@ run-hdd: run-hdd-$(ARCH)
.PHONY: ints .PHONY: ints
ints: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso ints: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).iso"
@qemu-system-$(ARCH) \
-M q35 \ -M q35 \
-drive if=pflash,unit=0,format=raw,file=ovmf/ovmf-code-$(ARCH).fd,readonly=on \ -drive if=pflash,unit=0,format=raw,file=ovmf/ovmf-code-$(ARCH).fd,readonly=on \
-cdrom $(IMAGE_NAME).iso \ -cdrom $(IMAGE_NAME).iso \
@ -40,7 +41,8 @@ ints: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
.PHONY: run-x86_64 .PHONY: run-x86_64
gdb-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso gdb-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).iso"
@qemu-system-$(ARCH) \
-M q35 \ -M q35 \
-drive if=pflash,unit=0,format=raw,file=ovmf/ovmf-code-$(ARCH).fd,readonly=on \ -drive if=pflash,unit=0,format=raw,file=ovmf/ovmf-code-$(ARCH).fd,readonly=on \
-cdrom $(IMAGE_NAME).iso \ -cdrom $(IMAGE_NAME).iso \
@ -49,7 +51,8 @@ gdb-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
.PHONY: run-x86_64 .PHONY: run-x86_64
run-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso run-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).iso"
@qemu-system-$(ARCH) \
-M q35 \ -M q35 \
-drive if=pflash,unit=0,format=raw,file=ovmf/ovmf-code-$(ARCH).fd,readonly=on \ -drive if=pflash,unit=0,format=raw,file=ovmf/ovmf-code-$(ARCH).fd,readonly=on \
-cdrom $(IMAGE_NAME).iso \ -cdrom $(IMAGE_NAME).iso \
@ -57,7 +60,8 @@ run-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
.PHONY: run-hdd-x86_64 .PHONY: run-hdd-x86_64
run-hdd-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd run-hdd-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).hdd"
@qemu-system-$(ARCH) \
-M q35 \ -M q35 \
-drive if=pflash,unit=0,format=raw,file=ovmf/ovmf-code-$(ARCH).fd,readonly=on \ -drive if=pflash,unit=0,format=raw,file=ovmf/ovmf-code-$(ARCH).fd,readonly=on \
-hda $(IMAGE_NAME).hdd \ -hda $(IMAGE_NAME).hdd \
@ -65,7 +69,8 @@ run-hdd-x86_64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd
.PHONY: run-aarch64 .PHONY: run-aarch64
run-aarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso run-aarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).iso"
@qemu-system-$(ARCH) \
-M virt \ -M virt \
-cpu cortex-a72 \ -cpu cortex-a72 \
-device ramfb \ -device ramfb \
@ -78,7 +83,8 @@ run-aarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
.PHONY: run-hdd-aarch64 .PHONY: run-hdd-aarch64
run-hdd-aarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd run-hdd-aarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).hdd"
@qemu-system-$(ARCH) \
-M virt \ -M virt \
-cpu cortex-a72 \ -cpu cortex-a72 \
-device ramfb \ -device ramfb \
@ -91,7 +97,8 @@ run-hdd-aarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd
.PHONY: run-riscv64 .PHONY: run-riscv64
run-riscv64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso run-riscv64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).iso"
@qemu-system-$(ARCH) \
-M virt \ -M virt \
-cpu rv64 \ -cpu rv64 \
-device ramfb \ -device ramfb \
@ -104,7 +111,8 @@ run-riscv64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
.PHONY: run-hdd-riscv64 .PHONY: run-hdd-riscv64
run-hdd-riscv64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd run-hdd-riscv64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).hdd"
@qemu-system-$(ARCH) \
-M virt \ -M virt \
-cpu rv64 \ -cpu rv64 \
-device ramfb \ -device ramfb \
@ -117,7 +125,8 @@ run-hdd-riscv64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd
.PHONY: run-loongarch64 .PHONY: run-loongarch64
run-loongarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso run-loongarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).iso"
@qemu-system-$(ARCH) \
-M virt \ -M virt \
-cpu la464 \ -cpu la464 \
-device ramfb \ -device ramfb \
@ -130,7 +139,8 @@ run-loongarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).iso
.PHONY: run-hdd-loongarch64 .PHONY: run-hdd-loongarch64
run-hdd-loongarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd run-hdd-loongarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).hdd"
@qemu-system-$(ARCH) \
-M virt \ -M virt \
-cpu la464 \ -cpu la464 \
-device ramfb \ -device ramfb \
@ -144,7 +154,8 @@ run-hdd-loongarch64: ovmf/ovmf-code-$(ARCH).fd $(IMAGE_NAME).hdd
.PHONY: run-bios .PHONY: run-bios
run-bios: $(IMAGE_NAME).iso run-bios: $(IMAGE_NAME).iso
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).iso"
@qemu-system-$(ARCH) \
-M q35 \ -M q35 \
-cdrom $(IMAGE_NAME).iso \ -cdrom $(IMAGE_NAME).iso \
-boot d \ -boot d \
@ -152,122 +163,132 @@ run-bios: $(IMAGE_NAME).iso
.PHONY: run-hdd-bios .PHONY: run-hdd-bios
run-hdd-bios: $(IMAGE_NAME).hdd run-hdd-bios: $(IMAGE_NAME).hdd
qemu-system-$(ARCH) \ @echo " Starting QEMU with $(IMAGE_NAME).hdd"
@qemu-system-$(ARCH) \
-M q35 \ -M q35 \
-hda $(IMAGE_NAME).hdd \ -hda $(IMAGE_NAME).hdd \
$(QEMUFLAGS) $(QEMUFLAGS)
ovmf/ovmf-code-$(ARCH).fd: ovmf/ovmf-code-$(ARCH).fd:
mkdir -p ovmf @mkdir -p ovmf
curl -Lo $@ https://github.com/osdev0/edk2-ovmf-nightly/releases/latest/download/ovmf-code-$(ARCH).fd @curl -Lo $@ https://github.com/osdev0/edk2-ovmf-nightly/releases/latest/download/ovmf-code-$(ARCH).fd
case "$(ARCH)" in \ @case "$(ARCH)" in \
aarch64) dd if=/dev/zero of=$@ bs=1 count=0 seek=67108864 2>/dev/null;; \ aarch64) dd if=/dev/zero of=$@ bs=1 count=0 seek=67108864 2>/dev/null;; \
riscv64) dd if=/dev/zero of=$@ bs=1 count=0 seek=33554432 2>/dev/null;; \ riscv64) dd if=/dev/zero of=$@ bs=1 count=0 seek=33554432 2>/dev/null;; \
esac @esac
limine/limine: limine/limine:
rm -rf limine @rm -rf limine
git clone https://github.com/limine-bootloader/limine.git --branch=v9.x-binary --depth=1 @git clone https://github.com/limine-bootloader/limine.git --branch=v9.x-binary --depth=1
$(MAKE) -C limine \ @$(MAKE) -C limine \
CC="$(HOST_CC)" \ CC="$(HOST_CC)" \
CFLAGS="$(HOST_CFLAGS)" \ CFLAGS="$(HOST_CFLAGS)" \
CPPFLAGS="$(HOST_CPPFLAGS)" \ CPPFLAGS="$(HOST_CPPFLAGS)" \
LDFLAGS="$(HOST_LDFLAGS)" \ LDFLAGS="$(HOST_LDFLAGS)" \
LIBS="$(HOST_LIBS)" LIBS="$(HOST_LIBS)"
@echo " Limine installer has been built"
kernel-deps: kernel-deps:
./kernel/get-deps @./kernel/get-deps
touch kernel-deps @touch kernel-deps
@echo " Kernel dependencies have been downloaded"
.PHONY: kernel .PHONY: kernel
kernel: kernel-deps kernel: kernel-deps
$(MAKE) -C kernel $(MAKE) -C kernel
$(IMAGE_NAME).iso: limine/limine kernel $(IMAGE_NAME).iso: limine/limine kernel
rm -rf iso_root @rm -rf iso_root
mkdir -p iso_root/boot @mkdir -p iso_root/boot
cp -v kernel/bin-$(ARCH)/soaplin iso_root/boot/ @cp -v kernel/bin-$(ARCH)/soaplin iso_root/boot/
mkdir -p iso_root/boot/limine @mkdir -p iso_root/boot/limine
cp -v limine.conf iso_root/boot/limine/ @cp -v limine.conf iso_root/boot/limine/
mkdir -p iso_root/EFI/BOOT @mkdir -p iso_root/EFI/BOOT
ifeq ($(ARCH),x86_64) ifeq ($(ARCH),x86_64)
cp -v testing/sk-hello.elf iso_root/ @cp -v testing/sk-hello.elf iso_root/
cp -v limine/limine-bios.sys limine/limine-bios-cd.bin limine/limine-uefi-cd.bin iso_root/boot/limine/ @cp -v limine/limine-bios.sys limine/limine-bios-cd.bin limine/limine-uefi-cd.bin iso_root/boot/limine/
cp -v limine/BOOTX64.EFI iso_root/EFI/BOOT/ @cp -v limine/BOOTX64.EFI iso_root/EFI/BOOT/
cp -v limine/BOOTIA32.EFI iso_root/EFI/BOOT/ @cp -v limine/BOOTIA32.EFI iso_root/EFI/BOOT/
xorriso -as mkisofs -R -r -J -b boot/limine/limine-bios-cd.bin \ @xorriso -as mkisofs -R -r -J -b boot/limine/limine-bios-cd.bin \
-no-emul-boot -boot-load-size 4 -boot-info-table -hfsplus \ -no-emul-boot -boot-load-size 4 -boot-info-table -hfsplus \
-apm-block-size 2048 --efi-boot boot/limine/limine-uefi-cd.bin \ -apm-block-size 2048 --efi-boot boot/limine/limine-uefi-cd.bin \
-efi-boot-part --efi-boot-image --protective-msdos-label \ -efi-boot-part --efi-boot-image --protective-msdos-label \
iso_root -o $(IMAGE_NAME).iso iso_root -o $(IMAGE_NAME).iso
./limine/limine bios-install $(IMAGE_NAME).iso @./limine/limine bios-install $(IMAGE_NAME).iso
endif endif
ifeq ($(ARCH),aarch64) ifeq ($(ARCH),aarch64)
cp -v limine/limine-uefi-cd.bin iso_root/boot/limine/ @cp -v limine/limine-uefi-cd.bin iso_root/boot/limine/
cp -v limine/BOOTAA64.EFI iso_root/EFI/BOOT/ @cp -v limine/BOOTAA64.EFI iso_root/EFI/BOOT/
xorriso -as mkisofs -R -r -J \ @xorriso -as mkisofs -R -r -J \
-hfsplus -apm-block-size 2048 \ -hfsplus -apm-block-size 2048 \
--efi-boot boot/limine/limine-uefi-cd.bin \ --efi-boot boot/limine/limine-uefi-cd.bin \
-efi-boot-part --efi-boot-image --protective-msdos-label \ -efi-boot-part --efi-boot-image --protective-msdos-label \
iso_root -o $(IMAGE_NAME).iso iso_root -o $(IMAGE_NAME).iso
endif endif
ifeq ($(ARCH),riscv64) ifeq ($(ARCH),riscv64)
cp -v limine/limine-uefi-cd.bin iso_root/boot/limine/ @cp -v limine/limine-uefi-cd.bin iso_root/boot/limine/
cp -v limine/BOOTRISCV64.EFI iso_root/EFI/BOOT/ @cp -v limine/BOOTRISCV64.EFI iso_root/EFI/BOOT/
xorriso -as mkisofs -R -r -J \ @xorriso -as mkisofs -R -r -J \
-hfsplus -apm-block-size 2048 \ -hfsplus -apm-block-size 2048 \
--efi-boot boot/limine/limine-uefi-cd.bin \ --efi-boot boot/limine/limine-uefi-cd.bin \
-efi-boot-part --efi-boot-image --protective-msdos-label \ -efi-boot-part --efi-boot-image --protective-msdos-label \
iso_root -o $(IMAGE_NAME).iso iso_root -o $(IMAGE_NAME).iso
endif endif
ifeq ($(ARCH),loongarch64) ifeq ($(ARCH),loongarch64)
cp -v limine/limine-uefi-cd.bin iso_root/boot/limine/ @cp -v limine/limine-uefi-cd.bin iso_root/boot/limine/
cp -v limine/BOOTLOONGARCH64.EFI iso_root/EFI/BOOT/ @cp -v limine/BOOTLOONGARCH64.EFI iso_root/EFI/BOOT/
xorriso -as mkisofs -R -r -J \ @xorriso -as mkisofs -R -r -J \
-hfsplus -apm-block-size 2048 \ -hfsplus -apm-block-size 2048 \
--efi-boot boot/limine/limine-uefi-cd.bin \ --efi-boot boot/limine/limine-uefi-cd.bin \
-efi-boot-part --efi-boot-image --protective-msdos-label \ -efi-boot-part --efi-boot-image --protective-msdos-label \
iso_root -o $(IMAGE_NAME).iso iso_root -o $(IMAGE_NAME).iso
endif endif
rm -rf iso_root @rm -rf iso_root
@echo " The final ISO image has been created: $(IMAGE_NAME).iso"
$(IMAGE_NAME).hdd: limine/limine kernel $(IMAGE_NAME).hdd: limine/limine kernel
rm -f $(IMAGE_NAME).hdd @rm -f $(IMAGE_NAME).hdd
dd if=/dev/zero bs=1M count=0 seek=64 of=$(IMAGE_NAME).hdd @dd if=/dev/zero bs=1M count=0 seek=64 of=$(IMAGE_NAME).hdd
PATH=$$PATH:/usr/sbin:/sbin sgdisk $(IMAGE_NAME).hdd -n 1:2048 -t 1:ef00 @echo " Creating $(IMAGE_NAME).hdd"
@PATH=$$PATH:/usr/sbin:/sbin sgdisk $(IMAGE_NAME).hdd -n 1:2048 -t 1:ef00
@echo " Creating partition table"
ifeq ($(ARCH),x86_64) ifeq ($(ARCH),x86_64)
./limine/limine bios-install $(IMAGE_NAME).hdd @./limine/limine bios-install $(IMAGE_NAME).hdd
endif endif
mformat -i $(IMAGE_NAME).hdd@@1M @mformat -i $(IMAGE_NAME).hdd@@1M
mmd -i $(IMAGE_NAME).hdd@@1M ::/EFI ::/EFI/BOOT ::/boot ::/boot/limine @mmd -i $(IMAGE_NAME).hdd@@1M ::/EFI ::/EFI/BOOT ::/boot ::/boot/limine
mcopy -i $(IMAGE_NAME).hdd@@1M kernel/bin-$(ARCH)/kernel ::/boot @mcopy -i $(IMAGE_NAME).hdd@@1M kernel/bin-$(ARCH)/kernel ::/boot
mcopy -i $(IMAGE_NAME).hdd@@1M limine.conf ::/boot/limine @mcopy -i $(IMAGE_NAME).hdd@@1M limine.conf ::/boot/limine
ifeq ($(ARCH),x86_64) ifeq ($(ARCH),x86_64)
mcopy -i $(IMAGE_NAME).hdd@@1M limine/limine-bios.sys ::/boot/limine @mcopy -i $(IMAGE_NAME).hdd@@1M limine/limine-bios.sys ::/boot/limine
mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTX64.EFI ::/EFI/BOOT @mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTX64.EFI ::/EFI/BOOT
mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTIA32.EFI ::/EFI/BOOT @mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTIA32.EFI ::/EFI/BOOT
endif endif
ifeq ($(ARCH),aarch64) ifeq ($(ARCH),aarch64)
mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTAA64.EFI ::/EFI/BOOT @mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTAA64.EFI ::/EFI/BOOT
endif endif
ifeq ($(ARCH),riscv64) ifeq ($(ARCH),riscv64)
mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTRISCV64.EFI ::/EFI/BOOT @mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTRISCV64.EFI ::/EFI/BOOT
endif endif
ifeq ($(ARCH),loongarch64) ifeq ($(ARCH),loongarch64)
mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTLOONGARCH64.EFI ::/EFI/BOOT @mcopy -i $(IMAGE_NAME).hdd@@1M limine/BOOTLOONGARCH64.EFI ::/EFI/BOOT
endif endif
@echo " Installed Limine bootloader"
.PHONY: clean .PHONY: clean
clean: clean:
$(MAKE) -C kernel clean @$(MAKE) -C kernel clean
rm -rf iso_root $(IMAGE_NAME).iso $(IMAGE_NAME).hdd @rm -rf iso_root $(IMAGE_NAME).iso $(IMAGE_NAME).hdd
@echo " The output files have been removed."
.PHONY: distclean .PHONY: distclean
distclean: distclean:
$(MAKE) -C kernel distclean @$(MAKE) -C kernel distclean
rm -rf iso_root *.iso *.hdd kernel-deps limine ovmf @rm -rf iso_root *.iso *.hdd kernel-deps limine ovmf
@echo " The output & downloaded files have been removed."
# Make some function to run clang-format all over the kernel # Make some function to run clang-format all over the kernel
.PHONY: format .PHONY: format
format: format:
clang-format -i -style=file $(shell find kernel/src -name '*.c' -or -name '*.h') @clang-format -i -style=file $(shell find kernel/src -name '*.c' -or -name '*.h')
@echo " Kernel source code formatted"

View file

@ -167,54 +167,60 @@ all: bin-$(ARCH)/$(OUTPUT)
# Link rules for building the C compiler runtime. # Link rules for building the C compiler runtime.
cc-runtime-$(ARCH)/cc-runtime.a: GNUmakefile cc-runtime/* cc-runtime-$(ARCH)/cc-runtime.a: GNUmakefile cc-runtime/*
rm -rf cc-runtime-$(ARCH) @rm -rf cc-runtime-$(ARCH)
cp -r cc-runtime cc-runtime-$(ARCH) @cp -r cc-runtime cc-runtime-$(ARCH)
$(MAKE) -C cc-runtime-$(ARCH) -f cc-runtime.mk \ @$(MAKE) -C cc-runtime-$(ARCH) -f cc-runtime.mk \
CC="$(CC)" \ CC="$(CC)" \
AR="$(AR)" \ AR="$(AR)" \
CFLAGS="$(CFLAGS)" \ CFLAGS="$(CFLAGS)" \
CPPFLAGS='-isystem ../freestnd-c-hdrs -DCC_RUNTIME_NO_FLOAT' CPPFLAGS='-isystem ../freestnd-c-hdrs -DCC_RUNTIME_NO_FLOAT'
@echo " C runtime built"
# Link rules for the final executable. # Link rules for the final executable.
bin-$(ARCH)/$(OUTPUT): GNUmakefile linker-$(ARCH).ld $(OBJ) cc-runtime-$(ARCH)/cc-runtime.a bin-$(ARCH)/$(OUTPUT): GNUmakefile linker-$(ARCH).ld $(OBJ) cc-runtime-$(ARCH)/cc-runtime.a
mkdir -p "$$(dirname $@)" @mkdir -p "$$(dirname $@)"
$(CC) $(CFLAGS) $(LDFLAGS) $(OBJ) cc-runtime-$(ARCH)/cc-runtime.a -o $@ @echo " LD $@"
@$(CC) $(CFLAGS) $(LDFLAGS) $(OBJ) cc-runtime-$(ARCH)/cc-runtime.a -o $@
# Compilation rules for *.c files. # Compilation rules for *.c files.
obj-$(ARCH)/%.c.o: src/%.c GNUmakefile obj-$(ARCH)/%.c.o: src/%.c GNUmakefile
mkdir -p "$$(dirname $@)" @mkdir -p "$$(dirname $@)"
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@ @echo " CC $@"
@$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
# Compilation rules for *.S files. # Compilation rules for *.S files.
obj-$(ARCH)/%.S.o: src/%.S GNUmakefile obj-$(ARCH)/%.S.o: src/%.S GNUmakefile
mkdir -p "$$(dirname $@)" @mkdir -p "$$(dirname $@)"
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@ @echo " AS $@"
@$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
ifeq ($(ARCH),x86_64) ifeq ($(ARCH),x86_64)
# Compilation rules for *.asm (nasm) files. # Compilation rules for *.asm (nasm) files.
obj-$(ARCH)/%.asm.o: src/%.asm GNUmakefile obj-$(ARCH)/%.asm.o: src/%.asm GNUmakefile
mkdir -p "$$(dirname $@)" @mkdir -p "$$(dirname $@)"
nasm $(NASMFLAGS) $< -o $@ @echo " NASM $@"
@nasm $(NASMFLAGS) $< -o $@
endif endif
# Remove object files and the final executable. # Remove object files and the final executable.
.PHONY: clean .PHONY: clean
clean: clean:
rm -rf bin-$(ARCH) obj-$(ARCH) cc-runtime-$(ARCH) @rm -rf bin-$(ARCH) obj-$(ARCH) cc-runtime-$(ARCH)
@echo " The kernel output files have been removed."
# Remove everything built and generated including downloaded dependencies. # Remove everything built and generated including downloaded dependencies.
.PHONY: distclean .PHONY: distclean
distclean: distclean:
rm -rf bin-* obj-* freestnd-c-hdrs cc-runtime* src/limine.h @rm -rf bin-* obj-* freestnd-c-hdrs cc-runtime* src/limine.h
@echo " The kernel output & downloaded files have been removed."
# Install the final built executable to its final on-root location. # Install the final built executable to its final on-root location.
.PHONY: install .PHONY: install
install: all install: all
install -d "$(DESTDIR)$(PREFIX)/share/$(OUTPUT)" @install -d "$(DESTDIR)$(PREFIX)/share/$(OUTPUT)"
install -m 644 bin-$(ARCH)/$(OUTPUT) "$(DESTDIR)$(PREFIX)/share/$(OUTPUT)/$(OUTPUT)-$(ARCH)" @install -m 644 bin-$(ARCH)/$(OUTPUT) "$(DESTDIR)$(PREFIX)/share/$(OUTPUT)/$(OUTPUT)-$(ARCH)"
# Try to undo whatever the "install" target did. # Try to undo whatever the "install" target did.
.PHONY: uninstall .PHONY: uninstall
uninstall: uninstall:
rm -f "$(DESTDIR)$(PREFIX)/share/$(OUTPUT)/$(OUTPUT)-$(ARCH)" @rm -f "$(DESTDIR)$(PREFIX)/share/$(OUTPUT)/$(OUTPUT)-$(ARCH)"
-rmdir "$(DESTDIR)$(PREFIX)/share/$(OUTPUT)" @-rmdir "$(DESTDIR)$(PREFIX)/share/$(OUTPUT)"

View file

@ -226,12 +226,12 @@ void vmm_map_user(pagemap_t *pm, uint64_t vaddr, uint64_t paddr,
uint64_t pml2_entry = (vaddr >> 21) & 0x1ff; uint64_t pml2_entry = (vaddr >> 21) & 0x1ff;
uint64_t pml1_entry = (vaddr >> 12) & 0x1ff; uint64_t pml1_entry = (vaddr >> 12) & 0x1ff;
uint64_t *pml3 =
__vmm_get_next_lvl(pm->toplevel, pml4_entry, flags, uint64_t *pml3 = __vmm_get_next_lvl(pm->toplevel, pml4_entry, flags | VMM_WRITABLE,
true); // PML3 / Page Directory Pointer Entry true); // PML3 / Page Directory Pointer Entry
uint64_t *pml2 = __vmm_get_next_lvl(pml3, pml3_entry, flags, uint64_t *pml2 = __vmm_get_next_lvl(pml3, pml3_entry, flags | VMM_WRITABLE,
true); // PML2 / Page Directory Entry true); // PML2 / Page Directory Entry
uint64_t *pml1 = __vmm_get_next_lvl(pml2, pml2_entry, flags, uint64_t *pml1 = __vmm_get_next_lvl(pml2, pml2_entry, flags | VMM_WRITABLE,
true); // PML1 / Page Table Entry true); // PML1 / Page Table Entry
pml1[pml1_entry] = paddr | flags; pml1[pml1_entry] = paddr | flags;

View file

@ -153,6 +153,8 @@ void schedule(registers_t *regs) {
if (curr_proc == NULL) if (curr_proc == NULL)
curr_proc = proc_list; curr_proc = proc_list;
log("sched - I choosed process %d\n", curr_proc->pid);
// log("sched - I choosed process %d\n", curr_proc->pid); // log("sched - I choosed process %d\n", curr_proc->pid);
memcpy(regs, &curr_proc->regs, sizeof(registers_t)); memcpy(regs, &curr_proc->regs, sizeof(registers_t));