-$(OBJECT_DIR):
- @mkdir -p $(OBJECT_DIR)
-
-$(BIN_DIR):
- @mkdir -p $(BIN_DIR)
-
-$(USR_DIR):
- @mkdir -p $(USR_DIR)
-
-$(ISO_DIR):
- @mkdir -p $(ISO_DIR)
- @mkdir -p $(ISO_BOOT_DIR)
- @mkdir -p $(ISO_GRUB_DIR)
+$(kbuild_dir):
+ @mkdir -p $(kbin_dir)
+ @mkdir -p $(os_img_dir)
+ @mkdir -p $(os_img_dir)/boot
+ @mkdir -p $(os_img_dir)/boot/grub
+ @mkdir -p $(os_img_dir)/usr
+
+.PHONY: kernel
+export BUILD_DIR=$(kbin_dir)
+export BUILD_NAME=$(kbin)
+kernel:
+ $(call status,TASK,$(notdir $@))
+ @$(MAKE) $(MKFLAGS) -I $(mkinc_dir) -f kernel.mk all
+
+.PHONY: image
+export KCMD=$(CMDLINE)
+export _OS_NAME=$(OS_NAME)
+image: usr/build kernel
+ $(call status,TASK,$(notdir $@))
+ @./config-grub.sh $(os_img_dir)/boot/grub/grub.cfg
+ @cp -r usr/build/* $(os_img_dir)/usr
+ @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