rulimine/GNUmakefile.in

634 lines
22 KiB
Makefile
Raw Normal View History

2022-01-16 08:09:36 +03:00
PREFIX ?= @prefix@
2021-08-07 08:26:34 +03:00
DESTDIR ?=
2022-01-16 08:09:36 +03:00
BUILDDIR ?= @abs_builddir@
2021-12-08 19:41:19 +03:00
override BINDIR := $(BUILDDIR)/bin
2021-11-20 10:32:06 +03:00
2022-01-16 08:09:36 +03:00
SRCDIR ?= @abs_srcdir@
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:14:34 +03:00
MKESCAPE = $(subst $(SPACE),\ ,$(1))
SHESCAPE = $(subst ','\'',$(1))
2021-12-23 00:08:19 +03:00
NASMESCAPE = $(subst ','"'$(COMMA) \"'\"$(COMMA) '"',$(1))
2022-01-16 08:09:36 +03:00
override PATH := $(BUILDDIR)/toolchain/bin:$(PATH)
2021-12-08 19:41:19 +03:00
export PATH
2022-01-16 08:09:36 +03:00
override LIMINE_VERSION := @limine_version@
2021-12-08 19:41:19 +03:00
export LIMINE_VERSION
2021-10-24 16:48:52 +03:00
2022-01-16 08:09:36 +03:00
override LIMINE_COPYRIGHT := $(shell grep Copyright '$(call SHESCAPE,$(SRCDIR))/LICENSE.md')
2021-12-08 19:41:19 +03:00
export LIMINE_COPYRIGHT
2021-10-24 16:48:52 +03:00
2022-01-17 00:41:37 +03:00
WERROR ?= @werror@
export WERROR
2022-01-16 08:09:36 +03:00
ifeq ($(origin CC), default)
CC := @CC@
endif
2022-01-17 00:41:37 +03:00
export CC
CFLAGS ?= @CFLAGS@
export CFLAGS
LIMINE_CFLAGS ?= @LIMINE_CFLAGS@
LIMINE_LDFLAGS ?= @LIMINE_LDFLAGS@
export LIMINE_CFLAGS
export LIMINE_LDFLAGS
2022-01-16 08:09:36 +03:00
TOOLCHAIN ?= @TOOLCHAIN@
2022-01-17 00:41:37 +03:00
LIMINE_CC ?= @LIMINE_CC@
LIMINE_LD ?= @LIMINE_LD@
LIMINE_AR ?= @LIMINE_AR@
LIMINE_AS ?= @LIMINE_AS@
2022-01-17 00:41:37 +03:00
LIMINE_OBJCOPY ?= @LIMINE_OBJCOPY@
LIMINE_OBJDUMP ?= @LIMINE_OBJDUMP@
LIMINE_READELF ?= @LIMINE_READELF@
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_CC) ; ), )
override LIMINE_CC := $(CC)
2022-01-16 08:09:36 +03:00
endif
2022-01-17 00:41:37 +03:00
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_LD) ; ), )
2022-01-22 05:10:25 +03:00
override LIMINE_LD := gld
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_LD) ; ), )
2022-01-21 04:24:36 +03:00
override LIMINE_LD := ld.bfd
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_LD) ; ), )
2022-01-22 05:10:25 +03:00
override LIMINE_LD := /usr/local/bin/ld
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_LD) ; ), )
2022-01-17 00:41:37 +03:00
override LIMINE_LD := ld
2022-01-16 08:09:36 +03:00
endif
2022-01-21 04:24:36 +03:00
endif
2022-01-22 05:10:25 +03:00
endif
endif
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_AR) ; ), )
override LIMINE_AR := gar
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_AR) ; ), )
override LIMINE_AR := /usr/local/bin/ar
2022-01-17 00:41:37 +03:00
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_AR) ; ), )
override LIMINE_AR := ar
2022-01-16 08:09:36 +03:00
endif
2022-01-22 05:10:25 +03:00
endif
endif
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_AS) ; ), )
override LIMINE_AS := gas
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_AS) ; ), )
override LIMINE_AS := /usr/local/bin/as
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_AS) ; ), )
override LIMINE_AS := as
endif
2022-01-22 05:10:25 +03:00
endif
endif
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_OBJCOPY) ; ), )
override LIMINE_OBJCOPY := gobjcopy
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_OBJCOPY) ; ), )
override LIMINE_OBJCOPY := /usr/local/bin/objcopy
2022-01-17 00:41:37 +03:00
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_OBJCOPY) ; ), )
override LIMINE_OBJCOPY := objcopy
2022-01-16 08:09:36 +03:00
endif
2022-01-22 05:10:25 +03:00
endif
endif
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_OBJDUMP) ; ), )
override LIMINE_OBJDUMP := gobjdump
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_OBJDUMP) ; ), )
override LIMINE_OBJDUMP := /usr/local/bin/objdump
2022-01-17 00:41:37 +03:00
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_OBJDUMP) ; ), )
override LIMINE_OBJDUMP := objdump
endif
2022-01-22 05:10:25 +03:00
endif
endif
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_READELF) ; ), )
override LIMINE_READELF := greadelf
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_READELF) ; ), )
override LIMINE_READELF := /usr/local/bin/readelf
2022-01-17 00:41:37 +03:00
ifeq ($(shell PATH='$(call SHESCAPE,$(PATH))' command -v $(LIMINE_READELF) ; ), )
override LIMINE_READELF := readelf
2022-01-16 08:09:36 +03:00
endif
2022-01-22 05:10:25 +03:00
endif
endif
2022-01-16 08:09:36 +03:00
2022-01-17 00:41:37 +03:00
export LIMINE_CC
export LIMINE_LD
export LIMINE_AR
export LIMINE_AS
2022-01-17 00:41:37 +03:00
export LIMINE_OBJCOPY
export LIMINE_OBJDUMP
export LIMINE_READELF
override USING_CLANG := $(shell PATH='$(call SHESCAPE,$(PATH))' $(LIMINE_CC) --version | grep clang >/dev/null && echo 1)
2022-01-02 14:45:15 +03:00
export USING_CLANG
ifeq ($(USING_CLANG), 1)
2022-01-17 00:41:37 +03:00
override ORIG_LIMINE_CC := $(LIMINE_CC)
override LIMINE_CC += --target=x86_64-elf
2021-08-07 08:26:34 +03:00
endif
2022-01-17 00:41:37 +03:00
override CC_MACHINE := $(shell PATH='$(call SHESCAPE,$(PATH))' $(LIMINE_CC) -dumpmachine | dd bs=6 count=1 2>/dev/null)
2021-07-26 19:27:05 +03:00
ifneq ($(MAKECMDGOALS), clean)
ifneq ($(MAKECMDGOALS), distclean)
ifneq ($(MAKECMDGOALS), maintainer-clean)
ifneq ($(MAKECMDGOALS), uninstall)
ifneq ($(MAKECMDGOALS), dist)
ifneq ($(MAKECMDGOALS), limine-install)
ifneq ($(MAKECMDGOALS), limine-eltorito-efi)
ifneq ($(MAKECMDGOALS), install)
ifneq ($(MAKECMDGOALS), install-data)
ifneq ($(MAKECMDGOALS), install-strip)
2022-01-22 05:10:25 +03:00
override USING_GNU_LD := $(shell PATH='$(call SHESCAPE,$(PATH))' $(LIMINE_LD) --version | grep 'GNU Binutils' >/dev/null && echo 1)
ifneq ($(USING_GNU_LD), 1)
$(error The specified LIMINE_LD linker ($(LIMINE_LD)) is not the GNU linker)
endif
2022-01-22 05:10:25 +03:00
override USING_GNU_AR := $(shell PATH='$(call SHESCAPE,$(PATH))' $(LIMINE_AR) --version | grep 'GNU Binutils' >/dev/null && echo 1)
ifneq ($(USING_GNU_AR), 1)
$(error The specified LIMINE_AR archiver ($(LIMINE_AR)) is not the GNU archiver)
endif
override USING_GNU_AS := $(shell PATH='$(call SHESCAPE,$(PATH))' $(LIMINE_AS) --version | grep 'GNU Binutils' >/dev/null && echo 1)
ifneq ($(USING_GNU_AS), 1)
$(error The specified LIMINE_AS assembler ($(LIMINE_AS)) is not the GNU assembler)
endif
override USING_GNU_OBJCOPY := $(shell PATH='$(call SHESCAPE,$(PATH))' $(LIMINE_OBJCOPY) --version | grep 'GNU Binutils' >/dev/null && echo 1)
ifneq ($(USING_GNU_OBJCOPY), 1)
$(error The specified LIMINE_OBJCOPY ($(LIMINE_OBJCOPY)) is not GNU objcopy)
endif
2022-01-22 05:10:25 +03:00
override USING_GNU_OBJDUMP := $(shell PATH='$(call SHESCAPE,$(PATH))' $(LIMINE_OBJDUMP) --version | grep 'GNU Binutils' >/dev/null && echo 1)
ifneq ($(USING_GNU_OBJDUMP), 1)
$(error The specified LIMINE_OBJDUMP ($(LIMINE_OBJDUMP)) is not GNU objdump)
endif
override USING_GNU_READELF := $(shell PATH='$(call SHESCAPE,$(PATH))' $(LIMINE_READELF) --version | grep 'GNU Binutils' >/dev/null && echo 1)
ifneq ($(USING_GNU_READELF), 1)
$(error The specified LIMINE_READELF ($(LIMINE_READELF)) is not GNU readelf)
endif
2021-07-26 19:27:05 +03:00
ifneq ($(CC_MACHINE), x86_64)
ifneq ($(CC_MACHINE), amd64-)
$(error No suitable x86_64 C compiler found, please install an x86_64 C toolchain or run "./make_toolchain.sh")
endif
endif
endif
endif
endif
endif
endif
endif
endif
endif
endif
endif
2020-07-06 23:59:28 +03:00
2022-01-02 14:45:15 +03:00
ifeq ($(USING_CLANG), 1)
2022-01-17 00:41:37 +03:00
override LIMINE_CC := $(ORIG_LIMINE_CC)
2021-12-22 03:44:33 +03:00
endif
2022-01-22 05:10:25 +03:00
override STAGE1_FILES := $(shell find '$(call SHESCAPE,$(SRCDIR))/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
.PHONY: limine-install
limine-install:
mkdir -p '$(call SHESCAPE,$(BINDIR))'
2022-01-16 08:09:36 +03:00
cp '$(call SHESCAPE,$(SRCDIR))/limine-install/'* '$(call SHESCAPE,$(SRCDIR))/limine-install/.gitignore' '$(call SHESCAPE,$(BINDIR))/'
2022-01-17 00:41:37 +03:00
$(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
2022-01-16 08:09:36 +03:00
rm -rf '$(call SHESCAPE,$(BINDIR))' '$(call SHESCAPE,$(BUILDDIR))/stage1.stamp'
2022-01-18 00:36:47 +03:00
.PHONY: install-data
install-data:
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
2022-01-18 00:36:47 +03:00
.PHONY: install-strip
install-strip: install-data
install -d '$(DESTDIR)$(PREFIX)/bin'
install -s '$(call SHESCAPE,$(BINDIR))/limine-install' '$(DESTDIR)$(PREFIX)/bin/' || true
.PHONY: install
install: install-data
install -d '$(DESTDIR)$(PREFIX)/bin'
install '$(call SHESCAPE,$(BINDIR))/limine-install' '$(DESTDIR)$(PREFIX)/bin/' || true
2022-01-16 22:08:53 +03:00
.PHONY: uninstall
uninstall:
rm -f '$(DESTDIR)$(PREFIX)/bin/limine-install'
rm -f '$(DESTDIR)$(PREFIX)/share/limine'
2022-01-16 08:09:36 +03:00
$(call MKESCAPE,$(BUILDDIR))/stage1.stamp: $(STAGE1_FILES) $(call MKESCAPE,$(BUILDDIR))/decompressor-build/decompressor.bin $(call MKESCAPE,$(BUILDDIR))/stage23-bios/stage2.bin.gz
mkdir -p '$(call SHESCAPE,$(BINDIR))'
2022-01-17 00:41:37 +03:00
cd '$(call SHESCAPE,$(SRCDIR))/stage1/hdd' && nasm bootsect.asm @werror@ -fbin -DBUILDDIR="'"'$(call NASMESCAPE,$(BUILDDIR))'"'" -o '$(call SHESCAPE,$(BINDIR))/limine-hdd.bin'
cd '$(call SHESCAPE,$(SRCDIR))/stage1/cd' && nasm bootsect.asm @werror@ -fbin -DBUILDDIR="'"'$(call NASMESCAPE,$(BUILDDIR))'"'" -o '$(call SHESCAPE,$(BINDIR))/limine-cd.bin'
cd '$(call SHESCAPE,$(SRCDIR))/stage1/pxe' && nasm bootsect.asm @werror@ -fbin -DBUILDDIR="'"'$(call NASMESCAPE,$(BUILDDIR))'"'" -o '$(call SHESCAPE,$(BINDIR))/limine-pxe.bin'
cp '$(call SHESCAPE,$(BUILDDIR))/stage23-bios/limine.sys' '$(call SHESCAPE,$(BINDIR))/'
2022-01-16 08:09:36 +03:00
touch '$(call SHESCAPE,$(BUILDDIR))/stage1.stamp'
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
2022-01-16 08:09:36 +03:00
$(MAKE) '$(call SHESCAPE,$(BUILDDIR))/stage1.stamp'
2022-01-02 14:45:15 +03:00
$(MAKE) limine-install
2021-12-08 21:22:09 +03:00
.PHONY: limine-eltorito-efi
limine-eltorito-efi:
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 ) && \
( ( [ -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
2022-01-16 08:09:36 +03:00
limine-uefi64: $(call MKESCAPE,$(SRCDIR))/reduced-gnu-efi
2022-01-02 14:45:15 +03:00
$(MAKE) stage23-uefi64
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
2022-01-16 08:09:36 +03:00
limine-uefi32: $(call MKESCAPE,$(SRCDIR))/reduced-gnu-efi
2021-07-20 14:35:43 +03:00
$(MAKE) stage23-uefi32
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-10-24 16:48:52 +03:00
.PHONY: dist
dist:
2022-01-16 08:09:36 +03:00
rm -rf '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)"
mkdir -p '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)"
cp -r '$(call SHESCAPE,$(SRCDIR))'/.git '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)"/
cd '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)" && git checkout .
cd '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)" && NOCONFIGURE=yes ./autogen.sh
2022-01-16 08:09:36 +03:00
rm -rf '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)/reduced-gnu-efi/.git"
rm -rf '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)/stivale/.git"
rm -rf '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)/.git"
rm -rf '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)/autom4te.cache"
echo "$(LIMINE_VERSION)" > '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)/version"
cd '$(call SHESCAPE,$(BUILDDIR))' && tar -Jcf "limine-$(LIMINE_VERSION).tar.xz" "limine-$(LIMINE_VERSION)"
rm -rf '$(call SHESCAPE,$(BUILDDIR))'/"limine-$(LIMINE_VERSION)"
2021-04-15 03:42:39 +03:00
2021-04-11 10:56:48 +03:00
.PHONY: distclean
2022-01-16 08:09:36 +03:00
distclean: clean
rm -rf toolchain ovmf* config.log config.status GNUmakefile
2022-01-16 08:09:36 +03:00
.PHONY: maintainer-clean
maintainer-clean: distclean
cd '$(call SHESCAPE,$(SRCDIR))' && rm -rf stivale reduced-gnu-efi configure *'~' autom4te.cache *.tar.xz
2021-12-08 23:26:25 +03:00
2022-01-02 14:45:15 +03:00
.PHONY: stage23-uefi64
2022-01-16 08:09:36 +03:00
stage23-uefi64: $(call MKESCAPE,$(SRCDIR))/stivale
$(MAKE) -C '$(call SHESCAPE,$(SRCDIR))/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:
2022-01-16 08:09:36 +03:00
$(MAKE) -C '$(call SHESCAPE,$(SRCDIR))/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
2022-01-16 08:09:36 +03:00
stage23-uefi32: $(call MKESCAPE,$(SRCDIR))/stivale
$(MAKE) -C '$(call SHESCAPE,$(SRCDIR))/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:
2022-01-16 08:09:36 +03:00
$(MAKE) -C '$(call SHESCAPE,$(SRCDIR))/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
2022-01-16 08:09:36 +03:00
stage23-bios: $(call MKESCAPE,$(SRCDIR))/stivale
$(MAKE) -C '$(call SHESCAPE,$(SRCDIR))/stage23' all TARGET=bios BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/stage23-bios'
2021-04-11 10:56:48 +03:00
.PHONY: stage23-bios-clean
2021-03-08 02:50:23 +03:00
stage23-bios-clean:
2022-01-16 08:09:36 +03:00
$(MAKE) -C '$(call SHESCAPE,$(SRCDIR))/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:
2022-01-16 08:09:36 +03:00
$(MAKE) -C '$(call SHESCAPE,$(SRCDIR))/decompressor' all BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/decompressor-build'
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:
2022-01-16 08:09:36 +03:00
$(MAKE) -C '$(call SHESCAPE,$(SRCDIR))/decompressor' clean BUILDDIR='$(call SHESCAPE,$(BUILDDIR))/decompressor-build'
2019-05-15 07:08:56 +03:00
2021-04-11 10:56:48 +03:00
.PHONY: test-clean
test-clean:
$(MAKE) -C test clean
2021-02-25 03:47:48 +03:00
rm -rf test_image test.hdd test.iso
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
test.hdd:
rm -f test.hdd
dd if=/dev/zero bs=1M count=0 seek=64 of=test.hdd
parted -s test.hdd mklabel gpt
parted -s test.hdd mkpart primary 2048s 100%
.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
echfs-test:
$(MAKE) test-clean
$(MAKE) test.hdd
$(MAKE) limine-bios
$(MAKE) limine-install
$(MAKE) -C test
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
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
echfs-utils -g -p0 test.hdd import test/test.elf boot/test.elf
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
ext2-test:
$(MAKE) test-clean
$(MAKE) test.hdd
$(MAKE) limine-bios
$(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
sudo losetup -Pf --show test.hdd > 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
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
$(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
$(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
.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
fat32-test:
$(MAKE) test-clean
$(MAKE) test.hdd
$(MAKE) limine-bios
$(MAKE) limine-install
$(MAKE) -C test
2020-07-06 23:59:28 +03:00
rm -rf test_image/
mkdir test_image
sudo losetup -Pf --show test.hdd > 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
2021-12-06 02:19:08 +03:00
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
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
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/
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-09-03 11:12:56 +03:00
.PHONY: ntfs-test
ntfs-test:
$(MAKE) test-clean
$(MAKE) test.hdd
$(MAKE) limine-bios
$(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/
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
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
uefi-test:
2021-07-20 14:35:43 +03:00
$(MAKE) ovmf-x64
$(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