X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/f09e806d5032150564df39a2f7b1192c4d84cf15..32b9a6d76790c73d3d2d36d9081a2581cc65d184:/lunaix-os/makefile diff --git a/lunaix-os/makefile b/lunaix-os/makefile index bb105d4..09ee4b9 100644 --- a/lunaix-os/makefile +++ b/lunaix-os/makefile @@ -5,12 +5,13 @@ include $(mkinc_dir)/toolchain.mkinc include $(mkinc_dir)/qemu.mkinc include $(mkinc_dir)/utils.mkinc - ARCH ?= i386 export ARCH DEPS := $(CC) $(LD) $(AR) xorriso grub-mkrescue +CMDLINE ?= console=/dev/ttyFB0 + kbuild_dir := build kbin_dir := $(kbuild_dir)/bin os_img_dir := $(kbuild_dir)/img @@ -27,9 +28,7 @@ $(DEPS): echo "failed" && exit 1;\ fi -check-cc: - @echo -n "checking target i686-elf.... " - @test "`i686-elf-gcc -dumpmachine`" = "i686-elf" && echo ok || (echo "failed" && exit 1) +all_lconfigs = $(shell find . -name "LConfig") $(kbuild_dir): @mkdir -p $(kbin_dir) @@ -38,30 +37,43 @@ $(kbuild_dir): @mkdir -p $(os_img_dir)/boot/grub @mkdir -p $(os_img_dir)/usr -export BUILD_DIR=$(kbuild_dir) +.builder/configs.h: $(all_lconfigs) + @echo restarting configuration... + @echo + @./scripts/build-tools/luna_build.py --config --lconfig-file LConfig -o $(@D) + +.builder/lbuild.mkinc: .builder/configs.h + @./scripts/build-tools/luna_build.py LBuild --lconfig-file LConfig -o $(@D) + +.PHONY: kernel +export BUILD_DIR=$(kbin_dir) export BUILD_NAME=$(kbin) -$(kbin): +kernel: .builder/lbuild.mkinc $(call status,TASK,$(notdir $@)) @$(MAKE) $(MKFLAGS) -I $(mkinc_dir) -f kernel.mk all -$(kimg): usr/build $(kbin) +.PHONY: image +export KCMD=$(CMDLINE) +export _OS_NAME=$(OS_NAME) +image: usr/build kernel $(call status,TASK,$(notdir $@)) - @./config-grub.sh ${OS_NAME} $(os_img_dir)/boot/grub/grub.cfg + @./scripts/grub/config-grub.sh $(os_img_dir)/boot/grub/grub.cfg @cp -r usr/build/* $(os_img_dir)/usr - @cp $(kbin) $(os_img_dir)/boot - @grub-mkrescue -o $(kimg) $(os_img_dir) -- -volid "$(OS_ID) $(OS_VER)" -system_id "$(OS_NAME)" + @cp -r $(kbin_dir)/* $(os_img_dir)/boot + @grub-mkrescue -o $(kimg) $(os_img_dir)\ + -- -volid "$(OS_ID) $(OS_VER)" -system_id "$(OS_NAME)" usr/build: user -check: $(DEPS) check-cc GRUB_TEMPLATE +check: $(DEPS) check-cc scripts/grub/GRUB_TEMPLATE prepare: check $(os_img_dir) export BUILD_MODE=release -bootable: $(kbuild_dir) $(kimg) +bootable: $(kbuild_dir) image export BUILD_MODE=debug -bootable-debug: $(kbuild_dir) $(kimg) +bootable-debug: $(kbuild_dir) image user: $(call status,$@) @@ -73,29 +85,26 @@ instable: CFLAGS := -g -std=gnu99 -ffreestanding $(O) $(W) $(ARCH_OPT) -D__LUNAI instable: all all-debug: bootable-debug - @echo "Dumping the disassembled kernel code to $(kbuild_dir)/kdump.txt" - @i686-elf-objdump -S $(kbin) > $(kbuild_dir)/kdump.txt clean: - @rm -rf $(kbuild_dir) || exit 1 @$(MAKE) -C usr clean -I $(mkinc_dir) @$(MAKE) -f kernel.mk clean -I $(mkinc_dir) + @rm -rf $(kbuild_dir) || exit 1 + @rm -f .builder/lbuild.mkinc || exit 1 -run: $(BUILD_DIR)/$(OS_ISO) - @qemu-system-i386 $(QEMU_OPTIONS) +run: all + @qemu-system-i386 $(call get_qemu_options,$(kimg)) @sleep 1 @telnet 127.0.0.1 $(QEMU_MON_PORT) debug-qemu: all-debug - @i686-elf-objcopy --only-keep-debug $(kbin) $(kbuild_dir)/kernel.dbg + @objcopy --only-keep-debug $(kbin) $(kbuild_dir)/kernel.dbg @qemu-system-i386 $(call get_qemu_options,$(kimg)) @sleep 1 - @$(QEMU_MON_TERM) -- telnet 127.0.0.1 $(QEMU_MON_PORT) - @gdb -s $(BUILD_DIR)/kernel.dbg -ex "target remote localhost:1234" + @QMPORT=$(QEMU_MON_PORT) gdb $(kbin) -ex "target remote localhost:1234" debug-qemu-vscode: all-debug - @i686-elf-objcopy --only-keep-debug $(kbin) $(kbuild_dir)/kernel.dbg - @qemu-system-i386 $(QEMU_OPTIONS) + @qemu-system-i386 $(call get_qemu_options,$(kimg)) @sleep 0.5 @telnet 127.0.0.1 $(QEMU_MON_PORT)