From cb7bb27a144083afe9b3f5955d8bc6def33eee9b Mon Sep 17 00:00:00 2001 From: Natanael Copa Date: Thu, 4 Mar 2010 15:15:37 +0000 Subject: alpine-mini: add wifi tools, firmware and openssl --- Makefile | 341 +++++++++++++++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 279 insertions(+), 62 deletions(-) mode change 100644 => 100755 Makefile (limited to 'Makefile') diff --git a/Makefile b/Makefile old mode 100644 new mode 100755 index 018ee9a..16c78a2 --- a/Makefile +++ b/Makefile @@ -1,85 +1,302 @@ +#!/usr/bin/make -f -PACKAGE := abuild -VERSION := 2.1 +PROFILE ?= alpine -prefix ?= /usr -sysconfdir ?= /etc -datadir ?= $(prefix)/share/$(PACKAGE) -apkcache ?= ~/.cache/apks +-include $(PROFILE).conf.mk -SCRIPTS := abuild devbuild mkalpine buildrepo abuild-keygen \ - abuild-sign newapkbuild -USR_BIN_FILES := $(SCRIPTS) abuild-tar -SAMPLES := sample.APKBUILD sample.initd sample.confd \ - sample.pre-install sample.post-install +BUILD_DATE := $(shell date +%y%m%d) +ALPINE_RELEASE ?= $(BUILD_DATE) +ALPINE_NAME ?= alpine-test +ALPINE_ARCH := x86 +DESTDIR ?= $(shell pwd)/isotmp.$(PROFILE) -SCRIPT_SOURCES := $(addsuffix .in,$(SCRIPTS)) +MKCRAMFS = mkcramfs +SUDO = sudo -DISTFILES=$(SCRIPT_SOURCES) $(SAMPLES) Makefile abuild.conf +ISO ?= $(ALPINE_NAME)-$(ALPINE_RELEASE)-$(ALPINE_ARCH).iso +ISO_LINK ?= $(ALPINE_NAME).iso +ISO_DIR := $(DESTDIR)/isofs +ISO_PKGDIR := $(ISO_DIR)/apks -GIT_REV := $(shell test -d .git && git describe || echo exported) -ifneq ($(GIT_REV), exported) -FULL_VERSION := $(patsubst $(PACKAGE)-%,%,$(GIT_REV)) -FULL_VERSION := $(patsubst v%,%,$(FULL_VERSION)) +APKS ?= $(shell sed 's/\#.*//; s/\*/\\*/g' $(PROFILE).packages) + +APK_OPTS := $(addprefix --repository ,$(APK_REPOS)) --keys-dir /etc/apk/keys + +find_apk_ver = $(shell apk search $(APK_OPTS) $(1) | sort | uniq) +find_apk_file = $(addsuffix .apk,$(call find_apk_ver,$(1))) +find_apk = $(addprefix $(ISO_PKGDIR)/,$(call find_apk_file,$(1))) + +# get apk does not support wildcards +get_apk = $(addsuffix .apk,$(shell apk fetch --simulate $(APK_OPTS) $(1) 2>&1 | sed 's:^Downloading :$(ISO_PKGDIR)/:')) + +KERNEL_FLAVOR ?= grsec +KERNEL_PKGNAME ?= linux-$(KERNEL_FLAVOR) +KERNEL_NAME := $(KERNEL_FLAVOR) +KERNEL_APK := $(call get_apk,$(KERNEL_PKGNAME)) + +KERNEL := $(word 3,$(subst -, ,$(notdir $(KERNEL_APK))))-$(word 2,$(subst -, ,$(notdir $(KERNEL_APK)))) + +ALPINEBASELAYOUT_APK := $(call find_apk,alpine-baselayout) +UCLIBC_APK := $(call get_apk,uclibc) +BUSYBOX_APK := $(call get_apk,busybox) +APK_TOOLS_APK := $(call get_apk,apk-tools) +STRACE_APK := $(call get_apk,strace) + +APKS_FILTER ?= | grep -v -- '-dev$$' | grep -v 'sources' + +APKS ?= '*' +APK_FILES := $(call find_apk,$(APKS)) + +all: isofs + +help: + @echo "Alpine ISO builder" + @echo + @echo "Type 'make iso' to build $(ISO)" + @echo + @echo "I will use the following sources files:" + @echo " 1. $(notdir $(KERNEL_APK)) (looks like $(KERNEL))" + @echo " 2. $(notdir $(MOD_APKS))" + @echo " 3. $(notdir $(ALPINEBASELAYOUT_APK))" + @echo " 4. $(notdir $(UCLIBC_APK))" + @echo " 5. $(notdir $(BUSYBOX_APK))" +ifeq ($(APK_BIN),) + @echo " 6. $(notdir $(APK_TOOLS_APK))" else -FULL_VERSION := $(VERSION) + @echo " 6. $(APK_BIN)" endif + @echo + @echo "ALPINE_NAME: $(ALPINE_NAME)" + @echo "ALPINE_RELEASE: $(ALPINE_RELEASE)" + @echo "KERNEL_FLAVOR: $(KERNEL_FLAVOR)" + @echo "KERNEL: $(KERNEL)" + @echo -CHMOD := chmod -SED := sed -TAR := tar +clean: + rm -rf $(MODLOOP) $(MODLOOP_DIR) $(MODLOOP_DIRSTAMP) \ + $(INITFS) $(INITFS_DIRSTAMP) $(INITFS_DIR) \ + $(ISO_DIR) $(ISO_REPOS_DIRSTAMP) -SED_REPLACE := -e 's:@VERSION@:$(FULL_VERSION):g' \ - -e 's:@prefix@:$(prefix):g' \ - -e 's:@sysconfdir@:$(sysconfdir):g' \ - -e 's:@datadir@:$(datadir):g' \ - -e 's:@apkcache@:$(apkcache):g' -SSL_LIBS := $(shell pkg-config --libs openssl) +$(APK_FILES): + @mkdir -p "$(dir $@)";\ + p="$(notdir $(basename $@))";\ + apk fetch $(APK_REPO) -R -v -o "$(dir $@)" $${p%-[0-9]*} +# apk fetch $(APK_OPTS) -R -v -o "$(dir $@)" \ +# `apk search -q $(APK_OPTS) $(APKS) | sort | uniq` -.SUFFIXES: .sh.in .in -.sh.in.sh: - ${SED} ${SED_REPLACE} ${SED_EXTRA} $< > $@ - ${CHMOD} +x $@ +# +# Modloop +# +MODLOOP := $(ISO_DIR)/boot/$(KERNEL_NAME).cmg +MODLOOP_DIR := $(DESTDIR)/modloop +MODLOOP_KERNELSTAMP := $(DESTDIR)/stamp.modloop.kernel +MODLOOP_DIRSTAMP := $(DESTDIR)/stamp.modloop +MODLOOP_EXTRA ?= $(addsuffix -$(KERNEL_FLAVOR), dahdi-linux iscsitarget xtables-addons) +MODLOOP_PKGS = $(KERNEL_PKGNAME) $(MODLOOP_EXTRA) -.in: - ${SED} ${SED_REPLACE} ${SED_EXTRA} $< > $@ - ${CHMOD} +x $@ +modloop: $(MODLOOP) -P=$(PACKAGE)-$(VERSION) +$(MODLOOP_KERNELSTAMP): + @echo "==> modloop: Unpacking kernel modules"; + @rm -rf $(MODLOOP_DIR) + @mkdir -p $(MODLOOP_DIR)/lib/modules/ + @for i in $(MODLOOP_PKGS); do \ + apk fetch $(APK_OPTS) --stdout $$i \ + | tar -C $(MODLOOP_DIR) -xz; \ + done + @cp $(MODLOOP_DIR)/usr/share/kernel/$(KERNEL_FLAVOR)/kernel.release $@ -all: $(USR_BIN_FILES) +MODLOOP_KERNEL_RELEASE = $(shell cat $(MODLOOP_KERNELSTAMP)) -clean: - @rm -f $(USR_BIN_FILES) +$(MODLOOP_DIRSTAMP): $(MODLOOP_KERNELSTAMP) + @rm -rf $(addprefix $(MODLOOP_DIR)/lib/modules/*/, source build) + @depmod $(MODLOOP_KERNEL_RELEASE) -b $(MODLOOP_DIR) + @touch $(MODLOOP_DIRSTAMP) -abuild-tar: abuild-tar.c - $(CC) -o $@ $(SSL_LIBS) $^ +$(MODLOOP): $(MODLOOP_DIRSTAMP) + @echo "==> modloop: building image $(notdir $(MODLOOP))" + @mkdir -p $(dir $(MODLOOP)) + @$(MKCRAMFS) $(MODLOOP_DIR)/lib $(MODLOOP) -help: - @echo "$(P) makefile" - @echo "usage: make install [ DESTDIR= ]" - @echo " make dist" - -install: $(USR_BIN_FILES) $(SAMPLES) abuild.conf functions.sh - mkdir -p $(DESTDIR)/$(prefix)/bin $(DESTDIR)/$(sysconfdir) \ - $(DESTDIR)/$(datadir) - for i in $(USR_BIN_FILES); do\ - install -m 755 $$i $(DESTDIR)/$(prefix)/bin/$$i;\ +clean-modloop: + @rm -rf $(MODLOOP_DIR) $(MODLOOP_DIRSTAMP) $(MODLOOP_PKGSTAMP) $(MODLOOP) + +# +# Initramfs rules +# + +# isolinux cannot handle - in filenames +#INITFS_NAME := initramfs-$(MODLOOP_KERNEL_RELEASE) +INITFS_NAME := $(KERNEL_FLAVOR).gz +INITFS := $(ISO_DIR)/boot/$(INITFS_NAME) + +INITFS_DIR := $(DESTDIR)/initfs +INITFS_TMP := $(DESTDIR)/tmp.initfs +INITFS_DIRSTAMP := $(DESTDIR)/stamp.initfs +INITFS_FEATURES := ata base bootchart cdrom cramfs ext3 floppy raid scsi usb +INITFS_PKGS := $(MODLOOP_PKGS) alpine-base acct + +initfs: $(INITFS) + +$(INITFS_DIRSTAMP): + @rm -rf $(INITFS_DIR) $(INITFS_TMP) + @mkdir -p $(INITFS_DIR) $(INITFS_TMP) + @for i in `apk fetch $(APK_OPTS) --simulate -R $(INITFS_PKGS) 2>&1\ + | sed 's:^Downloading ::; s:-[0-9].*::' | sort | uniq`; do \ + apk fetch $(APK_OPTS) --stdout $$i \ + | tar -C $(INITFS_DIR) -zx || exit 1; \ done - if [ -n "$(DESTDIR)" ] || [ ! -f "/$(sysconfdir)"/abuild.conf ]; then\ - cp abuild.conf $(DESTDIR)/$(sysconfdir)/; \ + @cp -r /etc/apk/keys $(INITFS_DIR)/etc/apk/ || true + @touch $@ + +#$(INITFS): $(shell mkinitfs -F "$(INITFS_FEATURES)" -l $(KERNEL)) +$(INITFS): $(INITFS_DIRSTAMP) $(MODLOOP_DIRSTAMP) + @mkinitfs -F "$(INITFS_FEATURES)" -t $(INITFS_TMP) \ + -b $(INITFS_DIR) -o $@ $(MODLOOP_KERNEL_RELEASE) + +clean-initfs: + @rm -rf $(INITFS) $(INITFS_DIRSTAMP) $(INITFS_DIR) + +# +# Vserver template rules +# +VSTEMPLATE := $(ISO_DIR)/vs-template.tar.bz2 +VSTEMPLATE_DIR := $(DESTDIR)/vs-template + +vstemplate: $(VSTEMPLATE) + @echo "==> vstemplate: built $(VSTEMPLATE)" + +#must be run as root or in fakeroot +$(VSTEMPLATE): + @rm -rf "$(VSTEMPLATE_DIR)" + @mkdir -p "$(VSTEMPLATE_DIR)" + @apk add $(APK_OPTS) --initdb --root $(VSTEMPLATE_DIR) \ + alpine-base + @cd $(VSTEMPLATE_DIR) && tar -jcf $@ * + +# +# ISO rules +# + +ISOLINUX_DIR := boot/isolinux +ISOLINUX := $(ISO_DIR)/$(ISOLINUX_DIR) +ISOLINUX_BIN := $(ISOLINUX)/isolinux.bin +ISOLINUX_CFG := $(ISOLINUX)/isolinux.cfg +SYSLINUX_CFG := $(ISO_DIR)/syslinux.cfg + +$(ISOLINUX_BIN): + @echo "==> iso: install isolinux" + @mkdir -p $(dir $(ISOLINUX_BIN)) + @if ! apk fetch $(APK_REPO) --stdout syslinux | tar -O -zx usr/share/syslinux/isolinux.bin > $@; then \ + rm -f $@ && exit 1;\ fi - cp $(SAMPLES) $(DESTDIR)/$(prefix)/share/abuild - cp functions.sh $(DESTDIR)/$(datadir)/ -dist: $(P).tar.bz2 +$(ISOLINUX_CFG): + @echo "==> iso: configure isolinux" + @mkdir -p $(dir $(ISOLINUX_BIN)) + @echo "timeout 20" >$(ISOLINUX_CFG) + @echo "prompt 1" >>$(ISOLINUX_CFG) + @echo "default $(KERNEL_NAME)" >>$(ISOLINUX_CFG) + @echo "label $(KERNEL_NAME)" >>$(ISOLINUX_CFG) + @echo " kernel /boot/$(KERNEL_NAME)" >>$(ISOLINUX_CFG) + @echo " append initrd=/boot/$(INITFS_NAME) alpine_dev=cdrom:iso9660 modules=loop,cramfs,sd-mod,usb-storage,floppy quiet" >>$(ISOLINUX_CFG) + +$(SYSLINUX_CFG): $(MODLOOP_DIRSTAMP) + @echo "==> iso: configure syslinux" + @echo "timeout 20" >$@ + @echo "prompt 1" >>$@ + @echo "default $(KERNEL_NAME)" >>$@ + @echo "label $(KERNEL_NAME)" >>$@ + @echo " kernel /boot/$(KERNEL_NAME)" >>$@ + @echo " append initrd=/boot/$(INITFS_NAME) alpine_dev=usbdisk:vfat modules=loop,cramfs,sd-mod,usb-storage quiet" >>$@ + +clean-syslinux: + @rm -f $(SYSLINUX_CFG) $(ISOLINUX_CFG) $(ISOLINUX_BIN) + +ISO_KERNEL := $(ISO_DIR)/boot/$(KERNEL_NAME) +ISO_REPOS_DIRSTAMP := $(DESTDIR)/stamp.isorepos +ISOFS_DIRSTAMP := $(DESTDIR)/stamp.isofs + +$(ISO_REPOS_DIRSTAMP): $(ISO_PKGDIR)/APKINDEX.tar.gz + @touch $(ISO_PKGDIR)/.boot_repository + @rm -f $(ISO_PKGDIR)/.SIGN.* + @touch $@ + +$(ISO_PKGDIR)/APKINDEX.tar.gz: $(APK_FILES) + @echo "==> iso: generating repository index" + @apk index --description "$(ALPINE_NAME) $(ALPINE_RELEASE)" \ + -o $@ $(ISO_PKGDIR)/*.apk + @abuild-sign $@ + +$(ISO_KERNEL): $(MODLOOP_DIRSTAMP) + @echo "==> iso: install kernel $(KERNEL)" + @mkdir -p $(dir $(ISO_KERNEL)) + @apk fetch $(APK_OPTS) --stdout $(KERNEL_PKGNAME) \ + | tar -C $(ISO_DIR) -xz boot + @rm -f $(ISO_DIR)/boot/$(KERNEL_NAME) + @ln -s vmlinuz-$(MODLOOP_KERNEL_RELEASE) $@ + @rm -rf $(ISO_DIR)/.[A-Z]* $(ISO_DIR)/.[a-z]* $(ISO_DIR)/lib + +$(ISOFS_DIRSTAMP): $(MODLOOP) $(INITFS) $(ISOLINUX_CFG) $(ISOLINUX_BIN) $(ISO_KERNEL) $(ISO_REPOS_DIRSTAMP) $(SYSLINUX_CFG) + @echo "$(ALPINE_NAME)-$(ALPINE_RELEASE) $(BUILD_DATE)" \ + > $(ISO_DIR)/.alpine-release + @touch $@ + +$(ISO): $(ISOFS_DIRSTAMP) + @echo "==> iso: building $(notdir $(ISO))" + @genisoimage -o $(ISO) -l -J -R \ + -b $(ISOLINUX_DIR)/isolinux.bin \ + -c $(ISOLINUX_DIR)/boot.cat \ + -no-emul-boot \ + -boot-load-size 4 \ + -boot-info-table \ + -quiet \ + -follow-links \ + $(ISO_OPTS) \ + $(ISO_DIR) + @ln -fs $@ $(ISO_LINK) + +isofs: $(ISOFS_DIRSTAMP) +iso: $(ISO) + +# +# SHA1 sum of ISO +# +ISO_SHA1 := $(ISO).sha1 + +$(ISO_SHA1): $(ISO) + @echo "==> Generating sha1 sum" + @sha1sum $(ISO) > $@ || rm -f $@ + +# +# USB image +# +USBIMG := $(ALPINE_NAME)-$(ALPINE_RELEASE)-$(ALPINE_ARCH).img +USBIMG_FREE ?= 8192 +USBIMG_SIZE = $(shell echo $$(( `du -s $(ISO_DIR) | awk '{print $$1}'` + $(USBIMG_FREE) )) ) +MBRPATH := /usr/share/syslinux/mbr.bin + +$(USBIMG): $(ISOFS_DIRSTAMP) + @echo "==> Generating $@" + @mformat -C -v 'ALPINE' -c 16 -h 64 -n 32 -i $(USBIMG) \ + -t $$(($(USBIMG_SIZE) / 1000)) :: + @syslinux $(USBIMG) + @mcopy -i $(USBIMG) $(ISO_DIR)/* $(ISO_DIR)/.[a-z]* :: + @mcopy -i $(USBIMG) /dev/zero ::/zero 2>/dev/null || true + @mdel -i $(USBIMG) ::/zero + +USBIMG_SHA1 := $(USBIMG).sha1 +$(USBIMG_SHA1): $(USBIMG) + @echo "==> Generating sha1 sum" + @sha1sum $(USBIMG) > $@ || rm -f $@ + +$(ALPINE_NAME).img: $(USBIMG) + @ln -sf $(USBIMG) $@ + +img: $(ALPINE_NAME).img + +sha1: $(ISO_SHA1) $(USBIMG_SHA1) -$(P).tar.bz2: $(DISTFILES) - rm -rf $(P) - mkdir -p $(P) - cp $(DISTFILES) $(P)/ - tar -cjf $@ $(P) - rm -rf $(P) +release: $(ISO_SHA1) -.PHONY: install dist -- cgit v1.2.3