2021-08-07 08:26:34 +03:00
|
|
|
PREFIX ?= /usr/local
|
|
|
|
DESTDIR ?=
|
2020-12-31 06:39:18 +03:00
|
|
|
|
2021-11-20 10:32:06 +03:00
|
|
|
BUILDDIR ?= $(shell pwd)/build
|
2021-12-08 19:41:19 +03:00
|
|
|
override BINDIR := $(BUILDDIR)/bin
|
2021-11-20 10:32:06 +03:00
|
|
|
|
2021-12-08 19:41:19 +03:00
|
|
|
override SPACE := $(subst ,, )
|
2021-12-23 00:08:19 +03:00
|
|
|
override COMMA := ,
|
2021-11-28 21:00:49 +03:00
|
|
|
|
2021-11-28 21:14:34 +03:00
|
|
|
MKESCAPE = $(subst $(SPACE),\ ,$(1))
|
2021-11-28 21:00:49 +03:00
|
|
|
SHESCAPE = $(subst ','\'',$(1))
|
2021-12-23 00:08:19 +03:00
|
|
|
NASMESCAPE = $(subst ','"'$(COMMA) \"'\"$(COMMA) '"',$(1))
|
2021-11-28 21:00:49 +03:00
|
|
|
|
2021-12-08 19:41:19 +03:00
|
|
|
override PATH := $(shell pwd)/toolchain/bin:$(PATH)
|
|
|
|
export PATH
|
2021-07-26 17:09:03 +03:00
|
|
|
|
2021-12-08 19:41:19 +03:00
|
|
|
override NCPUS := $(shell nproc 2>/dev/null || sysctl -n hw.ncpu 2>/dev/null || echo 1)
|
2021-04-08 20:41:46 +03:00
|
|
|
|
2021-12-08 19:41:19 +03:00
|
|
|
override LIMINE_VERSION := $(shell cat version 2>/dev/null || ( git describe --exact-match --tags `git log -n1 --pretty='%h'` 2>/dev/null || git log -n1 --pretty='%h' ) )
|
|
|
|
export LIMINE_VERSION
|
2021-10-24 16:48:52 +03:00
|
|
|
|
2021-12-08 19:41:19 +03:00
|
|
|
override LIMINE_COPYRIGHT := $(shell grep Copyright LICENSE.md)
|
|
|
|
export LIMINE_COPYRIGHT
|
2021-10-24 16:48:52 +03:00
|
|
|
|
2021-08-07 08:26:34 +03:00
|
|
|
TOOLCHAIN ?= limine
|
2021-04-03 01:48:38 +03:00
|
|
|
|
2021-08-07 08:26:34 +03:00
|
|
|
TOOLCHAIN_CC ?= $(TOOLCHAIN)-gcc
|
2021-04-03 02:14:17 +03:00
|
|
|
|
2021-11-28 21:00:49 +03:00
|
|
|
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(TOOLCHAIN_CC) ; ), )
|
2021-08-07 08:26:34 +03:00
|
|
|
override TOOLCHAIN_CC := cc
|
2021-04-08 20:41:46 +03:00
|
|
|
endif
|
|
|
|
|
2022-01-02 14:45:15 +03:00
|
|
|
override USING_CLANG := $(shell $(TOOLCHAIN_CC) --version | grep clang >/dev/null && echo 1)
|
|
|
|
export USING_CLANG
|
|
|
|
|
|
|
|
ifeq ($(USING_CLANG), 1)
|
|
|
|
override ORIG_TOOLCHAIN_CC := $(TOOLCHAIN_CC)
|
2021-08-07 08:26:34 +03:00
|
|
|
override TOOLCHAIN_CC += --target=x86_64-elf
|
|
|
|
endif
|
|
|
|
|
2021-12-08 19:41:19 +03:00
|
|
|
override CC_MACHINE := $(shell PATH='$(call SHESCAPE,$(PATH))' $(TOOLCHAIN_CC) -dumpmachine | dd bs=6 count=1 2>/dev/null)
|
2021-07-26 19:27:05 +03:00
|
|
|
|
2021-05-22 11:25:05 +03:00
|
|
|
ifneq ($(MAKECMDGOALS), toolchain)
|
2021-07-26 17:09:03 +03:00
|
|
|
ifneq ($(MAKECMDGOALS), distclean)
|
|
|
|
ifneq ($(MAKECMDGOALS), distclean2)
|
2021-07-26 19:27:05 +03:00
|
|
|
ifneq ($(CC_MACHINE), x86_64)
|
|
|
|
ifneq ($(CC_MACHINE), amd64-)
|
2021-07-26 17:09:03 +03:00
|
|
|
$(error No suitable x86_64 C compiler found, please install an x86_64 C toolchain or run "make toolchain")
|
|
|
|
endif
|
|
|
|
endif
|
2021-04-08 20:41:46 +03:00
|
|
|
endif
|
2021-05-22 11:25:05 +03:00
|
|
|
endif
|
2021-07-26 19:27:05 +03:00
|
|
|
endif
|
2020-07-06 23:59:28 +03:00
|
|
|
|
2022-01-02 14:45:15 +03:00
|
|
|
ifeq ($(USING_CLANG), 1)
|
|
|
|
override TOOLCHAIN_CC := $(ORIG_TOOLCHAIN_CC)
|
2021-12-22 03:44:33 +03:00
|
|
|
endif
|
|
|
|
|
2021-12-08 19:41:19 +03:00
|
|
|
override STAGE1_FILES := $(shell find -L ./stage1 -type f -name '*.asm')
|
2021-04-03 23:12:40 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: all
|
2022-01-02 14:45:15 +03:00
|
|
|
all: limine-uefi limine-bios
|
2020-12-31 06:39:18 +03:00
|
|
|
|
2021-11-20 10:47:22 +03:00
|
|
|
.PHONY: limine-install
|
|
|
|
limine-install:
|
2021-11-28 21:00:49 +03:00
|
|
|
mkdir -p '$(call SHESCAPE,$(BINDIR))'
|
|
|
|
cp limine-install/* limine-install/.gitignore '$(call SHESCAPE,$(BINDIR))/'
|
|
|
|
$(MAKE) -C '$(call SHESCAPE,$(BINDIR))'
|
2021-02-21 01:04:06 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: clean
|
2022-01-02 14:45:15 +03:00
|
|
|
clean: limine-bios-clean limine-uefi32-clean limine-uefi64-clean
|
2021-12-08 19:41:19 +03:00
|
|
|
rm -rf '$(call SHESCAPE,$(BINDIR))' '$(call SHESCAPE,$(BUILDDIR))/stage1'
|
2020-12-31 06:39:18 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: install
|
2022-01-10 16:12:33 +03:00
|
|
|
install:
|
2021-11-28 21:00:49 +03:00
|
|
|
install -d '$(DESTDIR)$(PREFIX)/bin'
|
2021-12-23 00:08:19 +03:00
|
|
|
install -s '$(call SHESCAPE,$(BINDIR))/limine-install' '$(DESTDIR)$(PREFIX)/bin/' || true
|
2021-11-28 21:00:49 +03:00
|
|
|
install -d '$(DESTDIR)$(PREFIX)/share'
|
|
|
|
install -d '$(DESTDIR)$(PREFIX)/share/limine'
|
|
|
|
install -m 644 '$(call SHESCAPE,$(BINDIR))/limine.sys' '$(DESTDIR)$(PREFIX)/share/limine/' || true
|
|
|
|
install -m 644 '$(call SHESCAPE,$(BINDIR))/limine-cd.bin' '$(DESTDIR)$(PREFIX)/share/limine/' || true
|
|
|
|
install -m 644 '$(call SHESCAPE,$(BINDIR))/limine-eltorito-efi.bin' '$(DESTDIR)$(PREFIX)/share/limine/' || true
|
|
|
|
install -m 644 '$(call SHESCAPE,$(BINDIR))/limine-pxe.bin' '$(DESTDIR)$(PREFIX)/share/limine/' || true
|
|
|
|
install -m 644 '$(call SHESCAPE,$(BINDIR))/BOOTX64.EFI' '$(DESTDIR)$(PREFIX)/share/limine/' || true
|
|
|
|
install -m 644 '$(call SHESCAPE,$(BINDIR))/BOOTIA32.EFI' '$(DESTDIR)$(PREFIX)/share/limine/' || true
|
|
|
|
|
|
|
|
$(call MKESCAPE,$(BUILDDIR))/stage1: $(STAGE1_FILES) $(call MKESCAPE,$(BUILDDIR))/decompressor/decompressor.bin $(call MKESCAPE,$(BUILDDIR))/stage23-bios/stage2.bin.gz
|
|
|
|
mkdir -p '$(call SHESCAPE,$(BINDIR))'
|
2021-12-23 00:08:19 +03:00
|
|
|
cd stage1/hdd && nasm bootsect.asm -Werror -fbin -DBUILDDIR="'"'$(call NASMESCAPE,$(BUILDDIR))'"'" -o '$(call SHESCAPE,$(BINDIR))/limine-hdd.bin'
|
|
|
|
cd stage1/cd && nasm bootsect.asm -Werror -fbin -DBUILDDIR="'"'$(call NASMESCAPE,$(BUILDDIR))'"'" -o '$(call SHESCAPE,$(BINDIR))/limine-cd.bin'
|
|
|
|
cd stage1/pxe && nasm bootsect.asm -Werror -fbin -DBUILDDIR="'"'$(call NASMESCAPE,$(BUILDDIR))'"'" -o '$(call SHESCAPE,$(BINDIR))/limine-pxe.bin'
|
2021-11-28 21:00:49 +03:00
|
|
|
cp '$(call SHESCAPE,$(BUILDDIR))/stage23-bios/limine.sys' '$(call SHESCAPE,$(BINDIR))/'
|
|
|
|
touch '$(call SHESCAPE,$(BUILDDIR))/stage1'
|
2021-04-03 23:12:40 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: limine-bios
|
2021-04-03 23:12:40 +03:00
|
|
|
limine-bios: stage23-bios decompressor
|
2021-11-28 21:00:49 +03:00
|
|
|
$(MAKE) '$(call SHESCAPE,$(BUILDDIR))/stage1'
|
2022-01-02 14:45:15 +03:00
|
|
|
$(MAKE) limine-install
|
2021-11-28 21:00:49 +03:00
|
|
|
|
2021-12-08 21:22:09 +03:00
|
|
|
.PHONY: limine-eltorito-efi
|
|
|
|
limine-eltorito-efi:
|
2021-11-28 21:00:49 +03:00
|
|
|
mkdir -p '$(call SHESCAPE,$(BINDIR))'
|
2021-12-08 23:26:25 +03:00
|
|
|
dd if=/dev/zero of='$(call SHESCAPE,$(BINDIR))/limine-eltorito-efi.bin' bs=512 count=2880
|
|
|
|
( mformat -i '$(call SHESCAPE,$(BINDIR))/limine-eltorito-efi.bin' -f 1440 :: && \
|
|
|
|
mmd -D s -i '$(call SHESCAPE,$(BINDIR))/limine-eltorito-efi.bin' ::/EFI && \
|
|
|
|
mmd -D s -i '$(call SHESCAPE,$(BINDIR))/limine-eltorito-efi.bin' ::/EFI/BOOT && \
|
2022-01-02 14:45:15 +03:00
|
|
|
( ( [ -f '$(call SHESCAPE,$(BUILDDIR))/stage23-uefi64/BOOTX64.EFI' ] && \
|
|
|
|
mcopy -D o -i '$(call SHESCAPE,$(BINDIR))/limine-eltorito-efi.bin' '$(call SHESCAPE,$(BUILDDIR))/stage23-uefi64/BOOTX64.EFI' ::/EFI/BOOT ) || true ) && \
|
2021-11-28 21:00:49 +03:00
|
|
|
( ( [ -f '$(call SHESCAPE,$(BUILDDIR))/stage23-uefi32/BOOTIA32.EFI' ] && \
|
2021-12-08 23:26:25 +03:00
|
|
|
mcopy -D o -i '$(call SHESCAPE,$(BINDIR))/limine-eltorito-efi.bin' '$(call SHESCAPE,$(BUILDDIR))/stage23-uefi32/BOOTIA32.EFI' ::/EFI/BOOT ) || true ) \
|
|
|
|
) || rm -f '$(call SHESCAPE,$(BINDIR))/limine-eltorito-efi.bin'
|
2021-03-17 15:19:06 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: limine-uefi
|
2022-01-02 14:45:15 +03:00
|
|
|
limine-uefi: limine-uefi32 limine-uefi64
|
|
|
|
$(MAKE) limine-eltorito-efi
|
|
|
|
|
|
|
|
.PHONY: limine-uefi64
|
|
|
|
limine-uefi64: reduced-gnu-efi
|
|
|
|
$(MAKE) stage23-uefi64
|
2021-11-28 21:00:49 +03:00
|
|
|
mkdir -p '$(call SHESCAPE,$(BINDIR))'
|
2022-01-02 14:45:15 +03:00
|
|
|
cp '$(call SHESCAPE,$(BUILDDIR))/stage23-uefi64/BOOTX64.EFI' '$(call SHESCAPE,$(BINDIR))/'
|
2021-03-08 02:50:23 +03:00
|
|
|
|
2021-07-20 14:35:43 +03:00
|
|
|
.PHONY: limine-uefi32
|
2021-12-08 23:26:25 +03:00
|
|
|
limine-uefi32: reduced-gnu-efi
|
2021-07-20 14:35:43 +03:00
|
|
|
$(MAKE) stage23-uefi32
|
2021-11-28 21:00:49 +03:00
|
|
|
mkdir -p '$(call SHESCAPE,$(BINDIR))'
|
|
|
|
cp '$(call SHESCAPE,$(BUILDDIR))/stage23-uefi32/BOOTIA32.EFI' '$(call SHESCAPE,$(BINDIR))/'
|
2021-07-20 14:35:43 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: limine-bios-clean
|
2021-03-08 02:50:23 +03:00
|
|
|
limine-bios-clean: stage23-bios-clean decompressor-clean
|
2020-09-14 21:02:36 +03:00
|
|
|
|
2022-01-02 14:45:15 +03:00
|
|
|
.PHONY: limine-uefi64-clean
|
|
|
|
limine-uefi64-clean: stage23-uefi64-clean
|
2020-09-13 16:47:43 +03:00
|
|
|
|
2021-07-20 14:35:43 +03:00
|
|
|
.PHONY: limine-uefi32-clean
|
2021-07-20 15:46:19 +03:00
|
|
|
limine-uefi32-clean: stage23-uefi32-clean
|
2021-07-20 14:35:43 +03:00
|
|
|
|
2021-11-20 10:38:34 +03:00
|
|
|
.PHONY: regenerate
|
2021-12-08 23:26:25 +03:00
|
|
|
regenerate: reduced-gnu-efi stivale
|
2021-11-20 10:38:34 +03:00
|
|
|
|
2021-10-24 16:48:52 +03:00
|
|
|
.PHONY: dist
|
|
|
|
dist:
|
|
|
|
rm -rf "limine-$(LIMINE_VERSION)"
|
|
|
|
LIST="$$(ls -A)"; mkdir "limine-$(LIMINE_VERSION)" && cp -r $$LIST "limine-$(LIMINE_VERSION)/"
|
|
|
|
rm -rf "limine-$(LIMINE_VERSION)/"*.tar*
|
|
|
|
$(MAKE) -C "limine-$(LIMINE_VERSION)" repoclean
|
2021-11-20 10:38:34 +03:00
|
|
|
$(MAKE) -C "limine-$(LIMINE_VERSION)" regenerate
|
2021-12-08 23:26:25 +03:00
|
|
|
rm -rf "limine-$(LIMINE_VERSION)/reduced-gnu-efi/.git"
|
2021-10-24 16:48:52 +03:00
|
|
|
rm -rf "limine-$(LIMINE_VERSION)/stivale/.git"
|
|
|
|
rm -rf "limine-$(LIMINE_VERSION)/.git"
|
|
|
|
echo "$(LIMINE_VERSION)" > "limine-$(LIMINE_VERSION)/version"
|
|
|
|
tar -Jcf "limine-$(LIMINE_VERSION).tar.xz" "limine-$(LIMINE_VERSION)"
|
|
|
|
rm -rf "limine-$(LIMINE_VERSION)"
|
2021-04-15 03:42:39 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: distclean
|
2021-10-24 16:48:52 +03:00
|
|
|
distclean: clean test-clean
|
2021-11-20 10:32:06 +03:00
|
|
|
rm -rf build toolchain ovmf*
|
2021-10-24 16:48:52 +03:00
|
|
|
|
|
|
|
.PHONY: repoclean
|
|
|
|
repoclean: distclean
|
2021-12-08 23:26:25 +03:00
|
|
|
rm -rf stivale reduced-gnu-efi *.tar.xz
|
2020-10-04 01:01:05 +03:00
|
|
|
|
2021-01-15 07:14:20 +03:00
|
|
|
stivale:
|
|
|
|
git clone https://github.com/stivale/stivale.git
|
|
|
|
|
2021-12-08 23:26:25 +03:00
|
|
|
reduced-gnu-efi:
|
|
|
|
git clone https://github.com/limine-bootloader/reduced-gnu-efi.git
|
|
|
|
|
2022-01-02 14:45:15 +03:00
|
|
|
.PHONY: stage23-uefi64
|
|
|
|
stage23-uefi64: stivale
|
|
|
|
$(MAKE) -C stage23 all TARGET=uefi64 BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/stage23-uefi64'
|
2021-03-08 02:50:23 +03:00
|
|
|
|
2022-01-02 14:45:15 +03:00
|
|
|
.PHONY: stage23-uefi64-clean
|
|
|
|
stage23-uefi64-clean:
|
|
|
|
$(MAKE) -C stage23 clean TARGET=uefi64 BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/stage23-uefi64'
|
2021-03-08 02:50:23 +03:00
|
|
|
|
2021-07-20 14:35:43 +03:00
|
|
|
.PHONY: stage23-uefi32
|
|
|
|
stage23-uefi32: stivale
|
2021-11-28 21:00:49 +03:00
|
|
|
$(MAKE) -C stage23 all TARGET=uefi32 BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/stage23-uefi32'
|
2021-07-20 14:35:43 +03:00
|
|
|
|
|
|
|
.PHONY: stage23-uefi32-clean
|
|
|
|
stage23-uefi32-clean:
|
2021-11-28 21:00:49 +03:00
|
|
|
$(MAKE) -C stage23 clean TARGET=uefi32 BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/stage23-uefi32'
|
2021-07-20 14:35:43 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: stage23-bios
|
2021-03-08 02:50:23 +03:00
|
|
|
stage23-bios: stivale
|
2021-11-28 21:00:49 +03:00
|
|
|
$(MAKE) -C stage23 all TARGET=bios BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/stage23-bios'
|
2020-09-13 16:20:53 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: stage23-bios-clean
|
2021-03-08 02:50:23 +03:00
|
|
|
stage23-bios-clean:
|
2021-11-28 21:00:49 +03:00
|
|
|
$(MAKE) -C stage23 clean TARGET=bios BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/stage23-bios'
|
2020-09-14 20:32:11 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: decompressor
|
2021-03-02 12:23:43 +03:00
|
|
|
decompressor:
|
2021-11-28 21:00:49 +03:00
|
|
|
$(MAKE) -C decompressor all BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/decompressor'
|
2020-09-14 20:32:11 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: decompressor-clean
|
2020-09-14 20:32:11 +03:00
|
|
|
decompressor-clean:
|
2021-11-28 21:00:49 +03:00
|
|
|
$(MAKE) -C decompressor clean BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/decompressor'
|
2019-05-15 07:08:56 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: test-clean
|
2020-09-30 01:31:42 +03:00
|
|
|
test-clean:
|
|
|
|
$(MAKE) -C test clean
|
2021-02-25 03:47:48 +03:00
|
|
|
rm -rf test_image test.hdd test.iso
|
2020-09-30 01:31:42 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: toolchain
|
2020-09-15 13:16:31 +03:00
|
|
|
toolchain:
|
2021-11-28 14:25:37 +03:00
|
|
|
MAKE="$(MAKE)" build-aux/make_toolchain.sh "`pwd`/toolchain" -j$(NCPUS)
|
2020-09-14 20:32:11 +03:00
|
|
|
|
2021-07-20 14:35:43 +03:00
|
|
|
ovmf-x64:
|
|
|
|
mkdir -p ovmf-x64
|
|
|
|
cd ovmf-x64 && curl -o OVMF-X64.zip https://efi.akeo.ie/OVMF/OVMF-X64.zip && 7z x OVMF-X64.zip
|
2021-03-02 12:23:43 +03:00
|
|
|
|
2021-07-20 14:35:43 +03:00
|
|
|
ovmf-ia32:
|
|
|
|
mkdir -p ovmf-ia32
|
|
|
|
cd ovmf-ia32 && curl -o OVMF-IA32.zip https://efi.akeo.ie/OVMF/OVMF-IA32.zip && 7z x OVMF-IA32.zip
|
2021-03-02 12:23:43 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: test.hdd
|
2020-11-29 10:26:08 +03:00
|
|
|
test.hdd:
|
|
|
|
rm -f test.hdd
|
|
|
|
dd if=/dev/zero bs=1M count=0 seek=64 of=test.hdd
|
2020-12-06 18:43:38 +03:00
|
|
|
parted -s test.hdd mklabel gpt
|
2020-11-29 10:26:08 +03:00
|
|
|
parted -s test.hdd mkpart primary 2048s 100%
|
2020-04-15 09:48:35 +03:00
|
|
|
|
2021-12-14 08:47:28 +03:00
|
|
|
.PHONY: mbrtest.hdd
|
|
|
|
mbrtest.hdd:
|
|
|
|
rm -f mbrtest.hdd
|
|
|
|
dd if=/dev/zero bs=1M count=0 seek=64 of=mbrtest.hdd
|
|
|
|
echo -e "o\nn\np\n1\n2048\n\nt\n6\na\nw\n" | fdisk mbrtest.hdd -H 16 -S 63
|
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: echfs-test
|
2021-03-08 10:09:15 +03:00
|
|
|
echfs-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2021-11-20 10:47:22 +03:00
|
|
|
$(MAKE) limine-install
|
2020-04-15 09:48:35 +03:00
|
|
|
$(MAKE) -C test
|
2020-12-06 18:43:38 +03:00
|
|
|
echfs-utils -g -p0 test.hdd quick-format 512 > part_guid
|
2020-11-01 23:25:35 +03:00
|
|
|
sed "s/@GUID@/`cat part_guid`/g" < test/limine.cfg > limine.cfg.tmp
|
2020-12-06 18:43:38 +03:00
|
|
|
echfs-utils -g -p0 test.hdd import limine.cfg.tmp limine.cfg
|
2020-11-01 23:25:35 +03:00
|
|
|
rm -f limine.cfg.tmp part_guid
|
2020-12-06 18:43:38 +03:00
|
|
|
echfs-utils -g -p0 test.hdd import test/test.elf boot/test.elf
|
2020-12-27 21:32:18 +03:00
|
|
|
echfs-utils -g -p0 test.hdd import test/bg.bmp boot/bg.bmp
|
2021-11-20 10:32:06 +03:00
|
|
|
echfs-utils -g -p0 test.hdd import $(BINDIR)/limine.sys boot/limine.sys
|
|
|
|
$(BINDIR)/limine-install test.hdd
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
2020-05-01 18:19:29 +03:00
|
|
|
|
2021-11-26 15:09:09 +03:00
|
|
|
.PHONY: fwcfg-common fwcfg-test fwcfg-simple-test
|
|
|
|
fwcfg-common:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) limine-bios
|
|
|
|
$(MAKE) limine-install
|
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir -p test_image/boot
|
|
|
|
cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
xorriso -as mkisofs -b boot/limine-cd.bin -no-emul-boot -boot-load-size 4 -boot-info-table test_image/ -o test.iso
|
|
|
|
|
|
|
|
fwcfg-simple-test:
|
|
|
|
$(MAKE) fwcfg-common
|
|
|
|
qemu-system-x86_64 -net none -smp 4 -cdrom test.iso -debugcon stdio \
|
|
|
|
-fw_cfg opt/org.limine-bootloader.background,file=test/bg.bmp \
|
|
|
|
-fw_cfg opt/org.limine-bootloader.kernel,file=test/test.elf
|
|
|
|
|
|
|
|
fwcfg-test:
|
|
|
|
$(MAKE) fwcfg-common
|
|
|
|
qemu-system-x86_64 -net none -smp 4 -cdrom test.iso -debugcon stdio \
|
|
|
|
-fw_cfg opt/org.limine-bootloader.config,file=test/limine-fwcfg.cfg \
|
|
|
|
-fw_cfg opt/org.limine-bootloader.background,file=test/bg.bmp \
|
|
|
|
-fw_cfg opt/org.limine-bootloader.kernel,file=test/test.elf
|
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: ext2-test
|
2021-03-08 10:09:15 +03:00
|
|
|
ext2-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2021-11-20 10:47:22 +03:00
|
|
|
$(MAKE) limine-install
|
2020-05-01 18:19:29 +03:00
|
|
|
$(MAKE) -C test
|
2020-07-06 23:59:28 +03:00
|
|
|
rm -rf test_image/
|
2020-05-01 18:19:29 +03:00
|
|
|
mkdir test_image
|
2020-11-29 10:26:08 +03:00
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
2020-05-01 19:23:49 +03:00
|
|
|
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
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
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
|
2021-11-20 10:32:06 +03:00
|
|
|
$(BINDIR)/limine-install test.hdd
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
2021-03-13 07:07:18 +03:00
|
|
|
|
2021-05-11 07:46:42 +03:00
|
|
|
.PHONY: fat12-test
|
|
|
|
fat12-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2021-11-20 10:47:22 +03:00
|
|
|
$(MAKE) limine-install
|
2021-05-11 07:46:42 +03:00
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 12 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2021-05-11 07:46:42 +03:00
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2021-11-20 10:32:06 +03:00
|
|
|
$(BINDIR)/limine-install test.hdd
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
2021-05-11 07:46:42 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: fat16-test
|
2021-03-13 07:07:18 +03:00
|
|
|
fat16-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2021-11-20 10:47:22 +03:00
|
|
|
$(MAKE) limine-install
|
2021-03-13 07:07:18 +03:00
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 16 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2021-03-13 07:07:18 +03:00
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2021-11-20 10:32:06 +03:00
|
|
|
$(BINDIR)/limine-install test.hdd
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
2020-05-02 16:47:29 +03:00
|
|
|
|
2021-12-14 08:47:28 +03:00
|
|
|
.PHONY: legacy-fat16-test
|
|
|
|
legacy-fat16-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) mbrtest.hdd
|
|
|
|
fdisk -l mbrtest.hdd
|
|
|
|
$(MAKE) limine-bios
|
|
|
|
$(MAKE) limine-install
|
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show mbrtest.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 16 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
|
|
|
$(BINDIR)/limine-install mbrtest.hdd
|
|
|
|
qemu-system-i386 -cpu pentium2 -m 16M -M isapc -net none -hda mbrtest.hdd -debugcon stdio
|
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: fat32-test
|
2021-03-08 10:09:15 +03:00
|
|
|
fat32-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2021-11-20 10:47:22 +03:00
|
|
|
$(MAKE) limine-install
|
2020-05-02 16:47:29 +03:00
|
|
|
$(MAKE) -C test
|
2020-07-06 23:59:28 +03:00
|
|
|
rm -rf test_image/
|
2020-05-02 16:47:29 +03:00
|
|
|
mkdir test_image
|
2020-11-29 10:26:08 +03:00
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
2020-05-02 16:47:29 +03:00
|
|
|
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
|
2020-05-02 16:47:29 +03:00
|
|
|
sudo mkdir test_image/boot
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2020-05-02 16:47:29 +03:00
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2021-11-20 10:32:06 +03:00
|
|
|
$(BINDIR)/limine-install test.hdd
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
2021-02-21 05:45:24 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: iso9660-test
|
2021-03-08 10:09:15 +03:00
|
|
|
iso9660-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2021-02-21 05:45:24 +03:00
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir -p test_image/boot
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2021-03-28 19:37:53 +03:00
|
|
|
xorriso -as mkisofs -b boot/limine-cd.bin -no-emul-boot -boot-load-size 4 -boot-info-table test_image/ -o test.iso
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -cdrom test.iso -debugcon stdio
|
2021-03-13 17:53:16 +03:00
|
|
|
|
2021-09-03 11:12:56 +03:00
|
|
|
.PHONY: ntfs-test
|
|
|
|
ntfs-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-bios
|
2021-11-20 10:47:22 +03:00
|
|
|
$(MAKE) limine-install
|
2021-09-03 11:12:56 +03:00
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.ntfs `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
2021-11-20 10:32:06 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test/* test_image/boot/
|
2021-09-03 11:12:56 +03:00
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2021-11-20 10:32:06 +03:00
|
|
|
$(BINDIR)/limine-install test.hdd
|
2021-09-03 11:12:56 +03:00
|
|
|
qemu-system-x86_64 -net none -smp 4 -hda test.hdd -debugcon stdio
|
|
|
|
|
2021-05-05 21:24:30 +03:00
|
|
|
.PHONY: full-hybrid-test
|
|
|
|
full-hybrid-test:
|
2021-07-20 15:46:19 +03:00
|
|
|
$(MAKE) ovmf-x64
|
|
|
|
$(MAKE) ovmf-ia32
|
2021-05-05 21:24:30 +03:00
|
|
|
$(MAKE) test-clean
|
2021-12-08 21:22:09 +03:00
|
|
|
$(MAKE) all
|
2021-05-05 21:24:30 +03:00
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir -p test_image/boot
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2021-05-23 06:07:24 +03:00
|
|
|
xorriso -as mkisofs -b boot/limine-cd.bin -no-emul-boot -boot-load-size 4 -boot-info-table --efi-boot boot/limine-eltorito-efi.bin -efi-boot-part --efi-boot-image --protective-msdos-label test_image/ -o test.iso
|
2021-11-20 10:32:06 +03:00
|
|
|
$(BINDIR)/limine-install test.iso
|
2021-12-11 17:34:30 +03:00
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-x64/OVMF.fd -net none -smp 4 -cdrom test.iso -debugcon stdio
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-x64/OVMF.fd -net none -smp 4 -hda test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-ia32/OVMF.fd -net none -smp 4 -cdrom test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -bios ovmf-ia32/OVMF.fd -net none -smp 4 -hda test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -net none -smp 4 -cdrom test.iso -debugcon stdio
|
|
|
|
qemu-system-x86_64 -m 512M -M q35 -net none -smp 4 -hda test.iso -debugcon stdio
|
2021-05-05 21:24:30 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: pxe-test
|
2021-03-11 02:35:24 +03:00
|
|
|
pxe-test:
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) limine-bios
|
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir -p test_image/boot
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -smp 4 -netdev user,id=n0,tftp=./test_image,bootfile=boot/limine-pxe.bin -device rtl8139,netdev=n0,mac=00:00:00:11:11:11 -debugcon stdio
|
2021-03-11 02:35:24 +03:00
|
|
|
|
2021-04-11 10:56:48 +03:00
|
|
|
.PHONY: uefi-test
|
2021-03-08 10:09:15 +03:00
|
|
|
uefi-test:
|
2021-07-20 14:35:43 +03:00
|
|
|
$(MAKE) ovmf-x64
|
2021-03-08 10:09:15 +03:00
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
2022-01-02 14:45:15 +03:00
|
|
|
$(MAKE) limine-uefi64
|
2021-03-04 07:30:31 +03:00
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 32 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2021-03-04 07:30:31 +03:00
|
|
|
sudo mkdir -p test_image/EFI/BOOT
|
2021-11-20 10:32:06 +03:00
|
|
|
sudo cp $(BINDIR)/BOOTX64.EFI test_image/EFI/BOOT/
|
2021-03-04 07:30:31 +03:00
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -m 512M -M q35 -L ovmf -bios ovmf-x64/OVMF.fd -net none -smp 4 -hda test.hdd -debugcon stdio
|
2021-07-20 14:35:43 +03:00
|
|
|
|
|
|
|
.PHONY: uefi32-test
|
|
|
|
uefi32-test:
|
|
|
|
$(MAKE) ovmf-ia32
|
|
|
|
$(MAKE) test-clean
|
|
|
|
$(MAKE) test.hdd
|
|
|
|
$(MAKE) limine-uefi32
|
|
|
|
$(MAKE) -C test
|
|
|
|
rm -rf test_image/
|
|
|
|
mkdir test_image
|
|
|
|
sudo losetup -Pf --show test.hdd > loopback_dev
|
|
|
|
sudo partprobe `cat loopback_dev`
|
|
|
|
sudo mkfs.fat -F 32 `cat loopback_dev`p1
|
|
|
|
sudo mount `cat loopback_dev`p1 test_image
|
|
|
|
sudo mkdir test_image/boot
|
2021-12-06 02:19:08 +03:00
|
|
|
sudo cp -rv $(BINDIR)/* test_image/boot/
|
|
|
|
sudo cp -rv test/* test_image/boot/
|
2021-07-20 14:35:43 +03:00
|
|
|
sudo mkdir -p test_image/EFI/BOOT
|
2021-11-20 10:32:06 +03:00
|
|
|
sudo cp $(BINDIR)/BOOTIA32.EFI test_image/EFI/BOOT/
|
2021-07-20 14:35:43 +03:00
|
|
|
sync
|
|
|
|
sudo umount test_image/
|
|
|
|
sudo losetup -d `cat loopback_dev`
|
|
|
|
rm -rf test_image loopback_dev
|
2021-08-31 09:50:58 +03:00
|
|
|
qemu-system-x86_64 -m 512M -M q35 -L ovmf -bios ovmf-ia32/OVMF.fd -net none -smp 4 -hda test.hdd -debugcon stdio
|