19b148a675
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
148 lines
5.0 KiB
Makefile
148 lines
5.0 KiB
Makefile
# also bump pve-kernel-meta if either of MAJ.MIN, PATCHLEVEL or KREL change
|
|
KERNEL_MAJ=5
|
|
KERNEL_MIN=15
|
|
KERNEL_PATCHLEVEL=107
|
|
# increment KREL if the ABI changes (abicheck target in debian/rules)
|
|
# rebuild packages with new KREL and run 'make abiupdate'
|
|
KREL=2
|
|
|
|
PKGREL=2
|
|
|
|
KERNEL_MAJMIN=$(KERNEL_MAJ).$(KERNEL_MIN)
|
|
KERNEL_VER=$(KERNEL_MAJMIN).$(KERNEL_PATCHLEVEL)
|
|
|
|
EXTRAVERSION=-$(KREL)-pve
|
|
KVNAME=$(KERNEL_VER)$(EXTRAVERSION)
|
|
PACKAGE=pve-kernel-$(KVNAME)
|
|
HDRPACKAGE=pve-headers-$(KVNAME)
|
|
|
|
ARCH=$(shell dpkg-architecture -qDEB_BUILD_ARCH)
|
|
|
|
# amd64/x86_64/x86 share the arch subdirectory in the kernel, 'x86' so we need
|
|
# a mapping
|
|
KERNEL_ARCH=x86
|
|
ifneq ($(ARCH), amd64)
|
|
KERNEL_ARCH=$(ARCH)
|
|
endif
|
|
|
|
GITVERSION:=$(shell git rev-parse HEAD)
|
|
|
|
SKIPABI=0
|
|
|
|
BUILD_DIR=build
|
|
|
|
KERNEL_SRC=ubuntu-kernel
|
|
KERNEL_SRC_SUBMODULE=submodules/$(KERNEL_SRC)
|
|
KERNEL_CFG_ORG=config-$(KERNEL_VER).org
|
|
|
|
ZFSONLINUX_SUBMODULE=submodules/zfsonlinux
|
|
ZFSDIR=pkg-zfs
|
|
|
|
MODULES=modules
|
|
MODULE_DIRS=$(ZFSDIR)
|
|
|
|
# exported to debian/rules via debian/rules.d/dirs.mk
|
|
DIRS=KERNEL_SRC ZFSDIR MODULES
|
|
|
|
DST_DEB=$(PACKAGE)_$(KERNEL_VER)-$(PKGREL)_$(ARCH).deb
|
|
HDR_DEB=$(HDRPACKAGE)_$(KERNEL_VER)-$(PKGREL)_$(ARCH).deb
|
|
USR_HDR_DEB=pve-kernel-libc-dev_$(KERNEL_VER)-$(PKGREL)_$(ARCH).deb
|
|
LINUX_TOOLS_DEB=linux-tools-$(KERNEL_MAJMIN)_$(KERNEL_VER)-$(PKGREL)_$(ARCH).deb
|
|
LINUX_TOOLS_DBG_DEB=linux-tools-$(KERNEL_MAJMIN)-dbgsym_$(KERNEL_VER)-$(PKGREL)_$(ARCH).deb
|
|
|
|
DEBS=$(DST_DEB) $(HDR_DEB) $(USR_HDR_DEB) $(LINUX_TOOLS_DEB) $(LINUX_TOOLS_DBG_DEB)
|
|
|
|
all: deb
|
|
deb: $(DEBS)
|
|
|
|
$(LINUX_TOOLS_DEB) $(HDR_DEB): $(DST_DEB)
|
|
$(DST_DEB): $(BUILD_DIR).prepared
|
|
cd $(BUILD_DIR); dpkg-buildpackage --jobs=auto -b -uc -us
|
|
lintian $(DST_DEB)
|
|
#lintian $(HDR_DEB)
|
|
lintian $(LINUX_TOOLS_DEB)
|
|
|
|
$(BUILD_DIR).prepared: $(addsuffix .prepared,$(KERNEL_SRC) $(MODULES) debian)
|
|
cp -a fwlist-previous $(BUILD_DIR)/
|
|
cp -a abi-prev-* $(BUILD_DIR)/
|
|
cp -a abi-blacklist $(BUILD_DIR)/
|
|
touch $@
|
|
|
|
debian.prepared: debian
|
|
rm -rf $(BUILD_DIR)/debian
|
|
mkdir -p $(BUILD_DIR)
|
|
cp -a debian $(BUILD_DIR)/debian
|
|
echo "git clone git://git.proxmox.com/git/pve-kernel.git\\ngit checkout $(GITVERSION)" > $(BUILD_DIR)/debian/SOURCE
|
|
@$(foreach dir, $(DIRS),echo "$(dir)=$($(dir))" >> $(BUILD_DIR)/debian/rules.d/env.mk;)
|
|
echo "KVNAME=$(KVNAME)" >> $(BUILD_DIR)/debian/rules.d/env.mk
|
|
echo "KERNEL_MAJMIN=$(KERNEL_MAJMIN)" >> $(BUILD_DIR)/debian/rules.d/env.mk
|
|
cd $(BUILD_DIR); debian/rules debian/control
|
|
touch $@
|
|
|
|
$(KERNEL_SRC).prepared: $(KERNEL_SRC_SUBMODULE) | submodule
|
|
rm -rf $(BUILD_DIR)/$(KERNEL_SRC) $@
|
|
mkdir -p $(BUILD_DIR)
|
|
cp -a $(KERNEL_SRC_SUBMODULE) $(BUILD_DIR)/$(KERNEL_SRC)
|
|
# TODO: split for archs, track and diff in our repository?
|
|
cat $(BUILD_DIR)/$(KERNEL_SRC)/debian.master/config/config.common.ubuntu $(BUILD_DIR)/$(KERNEL_SRC)/debian.master/config/$(ARCH)/config.common.$(ARCH) $(BUILD_DIR)/$(KERNEL_SRC)/debian.master/config/$(ARCH)/config.flavour.generic > $(KERNEL_CFG_ORG)
|
|
cp $(KERNEL_CFG_ORG) $(BUILD_DIR)/$(KERNEL_SRC)/.config
|
|
sed -i $(BUILD_DIR)/$(KERNEL_SRC)/Makefile -e 's/^EXTRAVERSION.*$$/EXTRAVERSION=$(EXTRAVERSION)/'
|
|
rm -rf $(BUILD_DIR)/$(KERNEL_SRC)/debian $(BUILD_DIR)/$(KERNEL_SRC)/debian.master
|
|
set -e; cd $(BUILD_DIR)/$(KERNEL_SRC); for patch in ../../patches/kernel/*.patch; do echo "applying patch '$$patch'" && patch -p1 < "$${patch}"; done
|
|
touch $@
|
|
|
|
$(MODULES).prepared: $(addsuffix .prepared,$(MODULE_DIRS))
|
|
touch $@
|
|
|
|
$(ZFSDIR).prepared: $(ZFSONLINUX_SUBMODULE)
|
|
rm -rf $(BUILD_DIR)/$(MODULES)/$(ZFSDIR) $(BUILD_DIR)/$(MODULES)/tmp $@
|
|
mkdir -p $(BUILD_DIR)/$(MODULES)/tmp
|
|
cp -a $(ZFSONLINUX_SUBMODULE)/* $(BUILD_DIR)/$(MODULES)/tmp
|
|
cd $(BUILD_DIR)/$(MODULES)/tmp; make kernel
|
|
rm -rf $(BUILD_DIR)/$(MODULES)/tmp
|
|
touch $(ZFSDIR).prepared
|
|
|
|
.PHONY: upload
|
|
upload: $(DEBS)
|
|
tar cf - $(DEBS)|ssh -X repoman@repo.proxmox.com -- upload --product pve,pmg,pbs --dist bullseye --arch $(ARCH)
|
|
|
|
.PHONY: distclean
|
|
distclean: clean
|
|
git submodule deinit --all
|
|
|
|
# upgrade to current master
|
|
.PHONY: update_modules
|
|
update_modules: submodule
|
|
git submodule foreach 'git pull --ff-only origin master'
|
|
cd $(ZFSONLINUX_SUBMODULE); git pull --ff-only origin master
|
|
|
|
# make sure submodules were initialized
|
|
.PHONY: submodule
|
|
submodule:
|
|
test -f "$(KERNEL_SRC_SUBMODULE)/README" || git submodule update --init $(KERNEL_SRC_SUBMODULE)
|
|
test -f "$(ZFSONLINUX_SUBMODULE)/Makefile" || git submodule update --init --recursive $(ZFSONLINUX_SUBMODULE)
|
|
|
|
# call after ABI bump with header deb in working directory
|
|
.PHONY: abiupdate
|
|
abiupdate: abi-prev-$(KVNAME)
|
|
abi-prev-$(KVNAME): abi-tmp-$(KVNAME)
|
|
ifneq ($(strip $(shell git status --untracked-files=no --porcelain -z)),)
|
|
@echo "working directory unclean, aborting!"
|
|
@false
|
|
else
|
|
git rm "abi-prev-*"
|
|
mv $< $@
|
|
git add $@
|
|
git commit -s -m "update ABI file for $(KVNAME)" -m "(generated with debian/scripts/abi-generate)"
|
|
@echo "update abi-prev-$(KVNAME) committed!"
|
|
endif
|
|
|
|
abi-tmp-$(KVNAME):
|
|
@ test -e $(HDR_DEB) || (echo "need $(HDR_DEB) to extract ABI data!" && false)
|
|
debian/scripts/abi-generate $(HDR_DEB) $@ $(KVNAME) 1
|
|
|
|
.PHONY: clean
|
|
clean:
|
|
rm -rf *~ build *.prepared $(KERNEL_CFG_ORG)
|
|
rm -f *.deb *.changes *.buildinfo
|