X-Git-Url: https://git.proxmox.com/?p=pve-kernel.git;a=blobdiff_plain;f=Makefile;h=11f7cfa97ffb4f8e00a310d8ca4a1d1a4bcabbd0;hp=00a6dcca5ed9bf7fa75eb19b856886361d4a65ca;hb=c0514fa336bd49d68fd6b2682bf0b6b755c0687c;hpb=1e99f45be0fd4a6c95f996434defed04dd5db639 diff --git a/Makefile b/Makefile index 00a6dcc..11f7cfa 100644 --- a/Makefile +++ b/Makefile @@ -1,10 +1,15 @@ RELEASE=5.1 -# also update pve-kernel-meta.git if either of these change -KERNEL_VER=4.15.3 -KREL=1 +# also bump pve-kernel-meta if either of MAJ.MIN, PATCHLEVEL or KREL change +KERNEL_MAJ=4 +KERNEL_MIN=15 +KERNEL_PATCHLEVEL=17 +KREL=3 -PKGREL=1 +PKGREL=14 + +KERNEL_MAJMIN=$(KERNEL_MAJ).$(KERNEL_MIN) +KERNEL_VER=$(KERNEL_MAJMIN).$(KERNEL_PATCHLEVEL) EXTRAVERSION=-${KREL}-pve KVNAME=${KERNEL_VER}${EXTRAVERSION} @@ -33,16 +38,16 @@ endif BUILD_DIR=build KERNEL_SRC=ubuntu-bionic -KERNEL_SRC_SUBMODULE=submodules/ubuntu-bionic +KERNEL_SRC_SUBMODULE=submodules/$(KERNEL_SRC) KERNEL_CFG_ORG=config-${KERNEL_VER}.org -E1000EDIR=e1000e-3.3.6 +E1000EDIR=e1000e-3.4.1.1 E1000ESRC=${E1000EDIR}.tar.gz -IGBDIR=igb-5.3.5.10 +IGBDIR=igb-5.3.5.18 IGBSRC=${IGBDIR}.tar.gz -IXGBEDIR=ixgbe-5.3.3 +IXGBEDIR=ixgbe-5.3.7 IXGBESRC=${IXGBEDIR}.tar.gz ZFSONLINUX_SUBMODULE=submodules/zfsonlinux @@ -59,7 +64,7 @@ DIRS=KERNEL_SRC E1000EDIR IGBDIR IXGBEDIR SPLDIR ZFSDIR MODULES DST_DEB=${PACKAGE}_${KERNEL_VER}-${PKGREL}_${ARCH}.deb HDR_DEB=${HDRPACKAGE}_${KERNEL_VER}-${PKGREL}_${ARCH}.deb -LINUX_TOOLS_DEB=linux-tools-4.15_${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} @@ -83,7 +88,7 @@ ${DST_DEB}: ${BUILD_DIR}.prepared ${BUILD_DIR}.prepared: $(addsuffix .prepared,${KERNEL_SRC} ${MODULES} debian) cp -a fwlist-previous ${BUILD_DIR}/ - cp -a abi-previous ${BUILD_DIR}/ + cp -a abi-prev-* ${BUILD_DIR}/ cp -a abi-blacklist ${BUILD_DIR}/ touch $@ @@ -94,6 +99,7 @@ debian.prepared: 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 $@ @@ -106,7 +112,7 @@ ${KERNEL_SRC}.prepared: ${KERNEL_SRC_SUBMODULE} | submodule 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 - cd ${BUILD_DIR}/${KERNEL_SRC}; for patch in ../../patches/kernel/*.patch; do patch -p1 < $${patch}; done + 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}) @@ -118,14 +124,14 @@ ${E1000EDIR}.prepared: ${E1000ESRC} tar --strip-components=1 -C ${BUILD_DIR}/${MODULES}/${E1000EDIR} -xf ${E1000ESRC} cd ${BUILD_DIR}/${MODULES}/${E1000EDIR}; patch -p1 < ../../../patches/intel/intel-module-gcc6-compat.patch cd ${BUILD_DIR}/${MODULES}/${E1000EDIR}; patch -p1 < ../../../patches/intel/e1000e/e1000e_4.10_max-mtu.patch + cd ${BUILD_DIR}/${MODULES}/${E1000EDIR}; patch -p1 < ../../../patches/intel/e1000e/e1000e_4.15-new-timer.patch touch $@ ${IGBDIR}.prepared: ${IGBSRC} rm -rf ${BUILD_DIR}/${MODULES}/${IGBDIR} $@ mkdir -p ${BUILD_DIR}/${MODULES}/${IGBDIR} tar --strip-components=1 -C ${BUILD_DIR}/${MODULES}/${IGBDIR} -xf ${IGBSRC} - cd ${BUILD_DIR}/${MODULES}/${IGBDIR}; patch -p1 < ../../../patches/intel/igb/igb_4.10_max-mtu.patch - cd ${BUILD_DIR}/${MODULES}/${IGBDIR}; patch -p1 < ../../../patches/intel/igb/igb_4.12_compat.patch + cd ${BUILD_DIR}/${MODULES}/${IGBDIR}; patch -p1 < ../../../patches/intel/igb/igb_4.15_mtu.patch touch $@ ${IXGBEDIR}.prepared: ${IXGBESRC} @@ -146,6 +152,8 @@ $(ZFSDIR).prepared: ${ZFSSRC} mkdir -p ${BUILD_DIR}/${MODULES}/${ZFSDIR} cp -a ${ZFSSRC}/* ${BUILD_DIR}/${MODULES}/${ZFSDIR} cd ${BUILD_DIR}/${MODULES}/${ZFSDIR}; for patch in ../../../${ZFSSRC}/../zfs-patches/*.patch; do patch -p1 < $${patch}; done + # temporarily since patch does not know about permissions, remove after 0.7.7 was merged properly + chmod +x ${BUILD_DIR}/${MODULES}/${ZFSDIR}/scripts/enum-extract.pl touch $@ .PHONY: upload @@ -170,7 +178,26 @@ submodule: test -f "${ZFSONLINUX_SUBMODULE}/Makefile" || git submodule update --init ${ZFSONLINUX_SUBMODULE} (test -f "${ZFSSRC}/debian/changelog" && test -f "${SPLZRC}/debian/changelog") || (cd ${ZFSONLINUX_SUBMODULE}; git submodule update --init) +# 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