Makefile: PLATFORM_PKGS, rootfs install target, genfstab

This commit is contained in:
Andrea Rogers 2024-11-03 12:14:43 -06:00
commit 50b7b8e35f
3 changed files with 74 additions and 14 deletions

View file

@ -21,6 +21,12 @@ else ifeq ($(PLATFORM),uefi)
include mk/uefi.mk include mk/uefi.mk
endif endif
ifeq ($(ROOTFS_TYPE),btrfs)
include mk/btrfs.mk
else
include mk/simplefs.mk
endif
RUNLEVEL_BOOT_CMDS := $(foreach SERVICE,$(RUNLEVEL_BOOT),\ RUNLEVEL_BOOT_CMDS := $(foreach SERVICE,$(RUNLEVEL_BOOT),\
rc-update add $(SERVICE) boot &&) rc-update add $(SERVICE) boot &&)
RUNLEVEL_SYSINIT_CMDS := $(foreach SERVICE,$(RUNLEVEL_SYSINIT),\ RUNLEVEL_SYSINIT_CMDS := $(foreach SERVICE,$(RUNLEVEL_SYSINIT),\
@ -54,7 +60,9 @@ APK_BIN := $(APK_MODULE)/src/apk
ABUILD := $(BUSYBOX) ash $(CURDIR)/$(ABUILD_SCRIPT) -c -P $(CURDIR)/$(REPO) rootbld ABUILD := $(BUSYBOX) ash $(CURDIR)/$(ABUILD_SCRIPT) -c -P $(CURDIR)/$(REPO) rootbld
ACHROOT := $(ARCH_MODULE)/arch-chroot ACHROOT := $(ARCH_MODULE)/arch-chroot
GENFSTAB := $(ARCH_MODULE)/genfstab
ACHROOT_CMD := $(DOSU) $(ACHROOT) $(DESTROOT) /bin/sh -c '. /etc/profile' ACHROOT_CMD := $(DOSU) $(ACHROOT) $(DESTROOT) /bin/sh -c '. /etc/profile'
ACHROOTI_CMD := $(DOSU) $(ACHROOT) $(MOUNTPOINT) /bin/sh -c '. /etc/profile'
APK := LD_LIBRARY_PATH=$(APK_MODULE)/src $(APK_BIN) APK := LD_LIBRARY_PATH=$(APK_MODULE)/src $(APK_BIN)
BUTIL := . $(BASH_UTIL_MODULE) BUTIL := . $(BASH_UTIL_MODULE)
@ -70,6 +78,9 @@ $(ARCH_MODULE)/Makefile: .gitmodules
$(ACHROOT): $(ARCH_MODULE)/Makefile $(ACHROOT): $(ARCH_MODULE)/Makefile
$(MAKE) -j -C $(ARCH_MODULE) arch-chroot $(MAKE) -j -C $(ARCH_MODULE) arch-chroot
$(GENFSTAB): $(ARCH_MODULE)/Makefile
$(MAKE) -j -C $(ARCH_MODULE) genfstab
$(APK_MODULE)/Makefile: .gitmodules $(APK_MODULE)/Makefile: .gitmodules
$(GIMME_MODULE) -- $(APK_MODULE) $(GIMME_MODULE) -- $(APK_MODULE)
@ -103,9 +114,10 @@ $(DESTROOT):
$(DESTROOT)/.bootstrap-done: $(DESTROOT) $(APK_BIN) $(DESTROOT)/.bootstrap-done: $(DESTROOT) $(APK_BIN)
$(DOSU) $(APK) --arch $(ARCH) -X $(ALPINE_REPO) --root $(DESTROOT) \ $(DOSU) $(APK) --arch $(ARCH) -X $(ALPINE_REPO) --root $(DESTROOT) \
-U --allow-untrusted --initdb add alpine-keys $(PKGS) && touch $@ -U --allow-untrusted --initdb add alpine-keys && touch $@
$(DOSU) $(APK) --arch $(ARCH) -X $(ALPINE_REPO) --root $(DESTROOT) \ $(DOSU) $(APK) --arch $(ARCH) -X $(ALPINE_REPO) --root $(DESTROOT) \
add alpine-base btrfs-progs e2fsprogs $(PKGS) && touch $@ add alpine-base btrfs-progs e2fsprogs $(PLATFORM_PKGS) $(PKGS) \
&& touch $@
bootstrap: $(DESTROOT)/.bootstrap-done bootstrap: $(DESTROOT)/.bootstrap-done
@ -118,38 +130,78 @@ blkcheck: $(BASH_UTIL_MODULE)/Makefile
format: partition format: partition
$(DOSU) mkfs.vfat $(BLKDEV)$(P)1 $(DOSU) mkfs.vfat $(BLKDEV)$(P)1
$(DOSU) mkfs.$(ROOTFS_TYPE) $(BLKDEV)$(P)2 $(DOSU) mkfs.$(ROOTFS_TYPE) -f $(BLKDEV)$(P)2
$(BLKDEV)$(P)2: partition $(BLKDEV)$(P)2: partition
### INSTALLATION ### ### INSTALLATION ###
services: $(DESTROOT)/.bootstrap-done $(ACHROOT) $(DESTROOT)/.services-done: $(DESTROOT)/.bootstrap-done $(ACHROOT)
$(ACHROOT_CMD)' && $(RUNLEVEL_CMDS)' $(ACHROOT_CMD)' && $(RUNLEVEL_CMDS)'
$(DOSU) touch $@
fastest-repo: $(DESTROOT)/.bootstrap-done $(ACHROOT) services: $(DESTROOT)/.services-done
$(DESTROOT)/.fastrepo-done: $(DESTROOT)/.bootstrap-done $(ACHROOT)
$(ACHROOT_CMD)' && setup-apkrepos -f' $(ACHROOT_CMD)' && setup-apkrepos -f'
$(DOSU) touch $@
fastest-repo: $(DESTROOT)/.fastrepo-done
$(MOUNTPOINT): $(MOUNTPOINT):
mkdir -p $@ || $(DOSU) mkdir -p $@ mkdir -p $@ || $(DOSU) mkdir -p $@
mount: $(BLKDEV)$(P)2 $(MOUNTPOINT) $(MOUNTPOINT)/etc/fstab: $(GENFSTAB) mount
$(DOSU) mount $(BLKDEV)$(P)2 $(MOUNTPOINT) $(GENFSTAB) -U $(MOUNTPOINT) | $(DOSU) tee $@
$(DOSU) mkdir -p $(MOUNTPOINT)/boot
$(DOSU) mount $(BLKDEV)$(P)1 $(MOUNTPOINT)/boot
install: services fastest-repo fstab: $(MOUNTPOINT)/etc/fstab
mount: $(MOUNTPOINT)/.mount-done
$(MOUNTPOINT)/.install-done: fstab services fastest-repo
@[ -z "$(MOUNTPOINT)" ] && $(BUTIL)/logging.bash \
&& die 'ERROR: Must define MOUNTPOINT env variable!' \
|| :
$(DOSU) rsync -aAXHv \
--exclude=$(DESTROOT)'/dev/*' \
--exclude=$(DESTROOT)'/proc/*' \
--exclude=$(DESTROOT)'/sys/*' \
--exclude=$(DESTROOT)'/tmp/*' \
--exclude=$(DESTROOT)'/run/*' \
--exclude=$(DESTROOT)'/mnt/*' \
--exclude=$(DESTROOT)'/media/*' \
--exclude=$(DESTROOT)'/lost+found/' \
$(DESTROOT)/ $(MOUNTPOINT)
$(DOSU) touch $@
install: $(MOUNTPOINT)/.install-done
install-chroot: $(MOUNTPOINT)/.install-done $(ACHROOT)
$(ACHROOTI_CMD)' && sh'
chroot: $(DESTROOT)/.bootstrap-done $(ACHROOT)
$(ACHROOT_CMD)' && sh'
### CLEANLINESS ### ### CLEANLINESS ###
clean: clean: umount
git submodule deinit -f -- \ git submodule deinit -f -- \
$(APK_MODULE) $(ABUILD_MODULE) $(APORTS_MODULE) $(ARCH_MODULE) \ $(APK_MODULE) $(ABUILD_MODULE) $(APORTS_MODULE) $(ARCH_MODULE) \
$(BASH_UTIL_MODULE) $(BASH_UTIL_MODULE)
$(DOSU) umount mnt/boot || :
$(DOSU) umount mnt || :
$(DOSU) rm -rf destroot/* repo/* $(DOSU) rm -rf destroot/* repo/*
### MAKEY-MAKEY ### ### MAKEY-MAKEY ###
.PHONY: default-target tools bootstrap aports blkcheck format install \ .PHONY: default-target tools bootstrap aports blkcheck format install \
$(PLATFORM_PHONYS) $(PLATFORM_PHONYS) mount fstab chroot
### DOCS ################ Require Pandoc to be installed ############## DOCS ###
pandoc.css:
wget https://sqt.wtf/~targetdisk/pandoc.css
# Requires Pandoc to be installed
README.html: README.md pandoc.css
pandoc $< -s -c pandoc.css -o $@
README: README.html
xdg-open $<

View file

@ -6,6 +6,10 @@ else
endif endif
PLATFORM_PHONYS := partition kernel PLATFORM_PHONYS := partition kernel
PLATFORM_PKGS := linux-rpi
BOOTFS_PART := 1
ROOTFS_PART := 2
RUNLEVEL_BOOT ?= modules bootmisc hostname networking seedrng swap RUNLEVEL_BOOT ?= modules bootmisc hostname networking seedrng swap
RUNLEVEL_DEFAULT ?= crond RUNLEVEL_DEFAULT ?= crond

View file

@ -1,4 +1,8 @@
PLATFORM_PHONYS := partition kernel PLATFORM_PHONYS := partition kernel
PLATFORM_PKGS := linux-lts grub-efi efibootmgr
BOOTFS_PART := 1
ROOTFS_PART := 2
RUNLEVEL_BOOT ?= hwclock modules bootmisc hostname networking seedrng swap RUNLEVEL_BOOT ?= hwclock modules bootmisc hostname networking seedrng swap
RUNLEVEL_DEFAULT ?= acpid crond RUNLEVEL_DEFAULT ?= acpid crond