"${ZFSONLINUX_SUBMODULE}/upstream/README.markdown" does not exists
anymore, if it'd be ".../README.md", but actually lets just switch
over to a recursive initialization and be done with it..
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
		
	
			
		
			
				
	
	
		
			146 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
# also bump pve-kernel-meta if either of MAJ.MIN, PATCHLEVEL or KREL change
 | 
						|
KERNEL_MAJ=5
 | 
						|
KERNEL_MIN=0
 | 
						|
KERNEL_PATCHLEVEL=8
 | 
						|
# increment KREL if the ABI changes (abicheck target in debian/rules)
 | 
						|
# rebuild packages with new KREL and run 'make abiupdate'
 | 
						|
KREL=1
 | 
						|
 | 
						|
PKGREL=1
 | 
						|
 | 
						|
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-disco
 | 
						|
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
 | 
						|
LINUX_TOOLS_DEB=linux-tools-$(KERNEL_MAJMIN)_${KERNEL_VER}-${PKGREL}_${ARCH}.deb
 | 
						|
 | 
						|
DEBS=${DST_DEB} ${HDR_DEB} ${LINUX_TOOLS_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 --dist buster --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
 |