rulimine/Makefile

92 lines
2.7 KiB
Makefile
Raw Normal View History

2020-09-13 15:36:18 +03:00
CC = cc
CFLAGS = -O2 -pipe -Wall -Wextra
PATH := $(shell pwd)/toolchain/bin:$(PATH)
2020-07-06 23:59:28 +03:00
.PHONY: all clean stage2 stage2-clean decompressor decompressor-clean toolchain test.img echfs-test ext2-test fat32-test
2020-09-14 21:02:36 +03:00
all: stage2 decompressor
gzip -n -9 < stage2/stage2.bin > stage2/stage2.bin.gz
cd bootsect && nasm bootsect.asm -fbin -o ../limine.bin
2020-11-05 03:37:45 +03:00
cd pxeboot && nasm bootsect.asm -fbin -o ../limine-pxe.bin
2020-11-15 19:56:10 +03:00
cp stage2/stage2.map ./
2020-09-14 21:02:36 +03:00
clean: stage2-clean decompressor-clean test-clean
rm -f stage2/stage2.bin.gz
2020-09-13 16:47:43 +03:00
2020-10-04 01:01:05 +03:00
distclean: clean
rm limine-install
2020-09-14 20:32:11 +03:00
stage2:
$(MAKE) -C stage2 all
2020-09-14 20:32:11 +03:00
stage2-clean:
$(MAKE) -C stage2 clean
decompressor:
$(MAKE) -C decompressor all
decompressor-clean:
$(MAKE) -C decompressor clean
2019-05-15 07:08:56 +03:00
test-clean:
$(MAKE) -C test clean
toolchain:
cd toolchain && ./make_toolchain.sh -j`nproc`
2020-09-14 20:32:11 +03:00
limine-install: limine-install.c
$(CC) $(CFLAGS) limine-install.c -o limine-install
2020-09-14 20:32:11 +03:00
2020-07-06 23:59:28 +03:00
test.img:
2020-03-25 03:04:18 +03:00
rm -f test.img
dd if=/dev/zero bs=1M count=0 seek=64 of=test.img
2020-07-06 23:59:28 +03:00
parted -s test.img mklabel msdos
parted -s test.img mkpart primary 2048s 100%
echfs-test: all limine-install test.img
$(MAKE) -C test
2020-11-01 23:25:35 +03:00
echfs-utils -m -p0 test.img quick-format 512 > part_guid
sed "s/@GUID@/`cat part_guid`/g" < test/limine.cfg > limine.cfg.tmp
echfs-utils -m -p0 test.img import limine.cfg.tmp limine.cfg
rm -f limine.cfg.tmp part_guid
echfs-utils -m -p0 test.img import stage2.map boot/stage2.map
2020-07-06 23:59:28 +03:00
echfs-utils -m -p0 test.img import test/test.elf boot/test.elf
echfs-utils -m -p0 test.img import test/bg.bmp boot/bg.bmp
./limine-install limine.bin test.img
qemu-system-x86_64 -net none -smp 4 -enable-kvm -cpu host -hda test.img -debugcon stdio
2020-05-01 18:19:29 +03:00
ext2-test: all limine-install test.img
2020-05-01 18:19:29 +03:00
$(MAKE) -C test
2020-11-15 19:56:10 +03:00
cp stage2.map test/
2020-07-06 23:59:28 +03:00
rm -rf test_image/
2020-05-01 18:19:29 +03:00
mkdir test_image
sudo losetup -Pf --show test.img > loopback_dev
sudo partprobe `cat loopback_dev`
2020-07-06 23:59:28 +03:00
sudo mkfs.ext2 `cat loopback_dev`p1
sudo mount `cat loopback_dev`p1 test_image
2020-05-01 18:19:29 +03:00
sudo mkdir test_image/boot
2020-11-15 19:56:10 +03:00
sudo cp -rv test/* test_image/boot/
2020-05-01 18:19:29 +03:00
sync
sudo umount test_image/
sudo losetup -d `cat loopback_dev`
rm -rf test_image loopback_dev
./limine-install limine.bin test.img
2020-09-29 23:00:09 +03:00
qemu-system-x86_64 -net none -smp 4 -enable-kvm -cpu host -hda test.img -debugcon stdio
fat32-test: all limine-install test.img
$(MAKE) -C test
2020-07-06 23:59:28 +03:00
rm -rf test_image/
mkdir test_image
sudo losetup -Pf --show test.img > loopback_dev
sudo partprobe `cat loopback_dev`
2020-07-06 23:59:28 +03:00
sudo mkfs.fat -F 32 `cat loopback_dev`p1
sudo mount `cat loopback_dev`p1 test_image
sudo mkdir test_image/boot
2020-11-15 19:56:10 +03:00
sudo cp -rv test/* test_image/boot/
sync
sudo umount test_image/
sudo losetup -d `cat loopback_dev`
rm -rf test_image loopback_dev
./limine-install limine.bin test.img
2020-09-29 23:02:45 +03:00
qemu-system-x86_64 -net none -smp 4 -enable-kvm -cpu host -hda test.img -debugcon stdio