X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=debian%2Frules;h=60e0265df5e8f4754c4c93299a34bb55566a9aa4;hb=HEAD;hp=e7cedbfd05738774d0da83b53f4b962503ba798b;hpb=7a315510b5fed311211aba13fd60b9f25e9b60c1;p=pve-kernel.git diff --git a/debian/rules b/debian/rules index e7cedbf..f19a5b8 100755 --- a/debian/rules +++ b/debian/rules @@ -9,16 +9,25 @@ BUILD_DIR=$(shell pwd) include /usr/share/dpkg/default.mk include debian/rules.d/env.mk -include debian/rules.d/${DEB_BUILD_ARCH}.mk +include debian/rules.d/$(DEB_BUILD_ARCH).mk + +MAKEFLAGS += $(subst parallel=,-j,$(filter parallel=%,${DEB_BUILD_OPTIONS})) CHANGELOG_DATE:=$(shell dpkg-parsechangelog -SDate) +CHANGELOG_DATE_UTC_ISO := $(shell date -u -d '$(CHANGELOG_DATE)' +%Y-%m-%dT%H:%MZ) -PVE_KERNEL_PKG=pve-kernel-${KVNAME} -PVE_HEADER_PKG=pve-headers-${KVNAME} -LINUX_TOOLS_PKG=linux-tools-4.15 +PMX_KERNEL_PKG=proxmox-kernel-$(KVNAME) +PMX_KERNEL_SERIES_PKG=proxmox-kernel-$(KERNEL_MAJMIN) +PMX_DEBUG_KERNEL_PKG=proxmox-kernel-$(KVNAME)-dbgsym +PMX_HEADER_PKG=proxmox-headers-$(KVNAME) +PMX_USR_HEADER_PKG=proxmox-kernel-libc-dev +PMX_KERNEL_SIGNING_TEMPLATE_PKG=proxmox-kernel-${KVNAME}-signed-template +PMX_KERNEL_SIGNED_VERSION := $(shell echo ${DEB_VERSION} | sed -e 's/-/+/') +LINUX_TOOLS_PKG=linux-tools-$(KERNEL_MAJMIN) +KERNEL_SRC_COPY=$(KERNEL_SRC)_tmp # TODO: split for archs, move to files? -PVE_CONFIG_OPTS= \ +PMX_CONFIG_OPTS= \ -m INTEL_MEI_WDT \ -d CONFIG_SND_PCM_OSS \ -e CONFIG_TRANSPARENT_HUGEPAGE_MADVISE \ @@ -26,48 +35,105 @@ PVE_CONFIG_OPTS= \ -m CONFIG_CEPH_FS \ -m CONFIG_BLK_DEV_NBD \ -m CONFIG_BLK_DEV_RBD \ +-m CONFIG_BLK_DEV_UBLK \ +-d CONFIG_SND_PCSP \ -m CONFIG_BCACHE \ -m CONFIG_JFS_FS \ -m CONFIG_HFS_FS \ -m CONFIG_HFSPLUS_FS \ +-e CIFS_SMB_DIRECT \ +-e CONFIG_SQUASHFS_DECOMP_MULTI_PERCPU \ -e CONFIG_BRIDGE \ -e CONFIG_BRIDGE_NETFILTER \ -e CONFIG_BLK_DEV_SD \ -e CONFIG_BLK_DEV_SR \ -e CONFIG_BLK_DEV_DM \ --e CONFIG_BLK_DEV_NVME \ +-m CONFIG_BLK_DEV_NVME \ +-e CONFIG_NLS_ISO8859_1 \ -d CONFIG_INPUT_EVBUG \ -d CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND \ +-d CONFIG_CPU_FREQ_DEFAULT_GOV_SCHEDUTIL \ -e CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE \ --d CONFIG_MODULE_SIG \ +-e CONFIG_SYSFB_SIMPLEFB \ +-e CONFIG_DRM_SIMPLEDRM \ +-e CONFIG_MODULE_SIG \ +-e CONFIG_MODULE_SIG_ALL \ +-e CONFIG_MODULE_SIG_FORMAT \ +--set-str CONFIG_MODULE_SIG_HASH sha512 \ +--set-str CONFIG_MODULE_SIG_KEY certs/signing_key.pem \ +-e CONFIG_MODULE_SIG_KEY_TYPE_RSA \ +-e CONFIG_MODULE_SIG_SHA512 \ -d CONFIG_MEMCG_DISABLED \ -e CONFIG_MEMCG_SWAP_ENABLED \ +-e CONFIG_HYPERV \ +-m CONFIG_VFIO_IOMMU_TYPE1 \ +-e CONFIG_VFIO_VIRQFD \ +-m CONFIG_VFIO \ +-m CONFIG_VFIO_PCI \ +-m CONFIG_USB_XHCI_HCD \ +-m CONFIG_USB_XHCI_PCI \ +-m CONFIG_USB_EHCI_HCD \ +-m CONFIG_USB_EHCI_PCI \ +-m CONFIG_USB_EHCI_HCD_PLATFORM \ +-m CONFIG_USB_OHCI_HCD \ +-m CONFIG_USB_OHCI_HCD_PCI \ +-m CONFIG_USB_OHCI_HCD_PLATFORM \ +-d CONFIG_USB_OHCI_HCD_SSB \ +-m CONFIG_USB_UHCI_HCD \ +-d CONFIG_USB_SL811_HCD_ISO \ -e CONFIG_MEMCG_KMEM \ -d CONFIG_DEFAULT_CFQ \ -e CONFIG_DEFAULT_DEADLINE \ -e CONFIG_MODVERSIONS \ +-e CONFIG_ZSTD_COMPRESS \ -d CONFIG_DEFAULT_SECURITY_DAC \ -e CONFIG_DEFAULT_SECURITY_APPARMOR \ --set-str CONFIG_DEFAULT_SECURITY apparmor \ +-e CONFIG_MODULE_ALLOW_BTF_MISMATCH \ -d CONFIG_UNWINDER_ORC \ -d CONFIG_UNWINDER_GUESS \ -e CONFIG_UNWINDER_FRAME_POINTER \ --e CONFIG_PAGE_TABLE_ISOLATION +--set-str CONFIG_SYSTEM_TRUSTED_KEYS ""\ +--set-str CONFIG_SYSTEM_REVOCATION_KEYS ""\ +-e CONFIG_SECURITY_LOCKDOWN_LSM \ +-e CONFIG_SECURITY_LOCKDOWN_LSM_EARLY \ +--set-str CONFIG_LSM lockdown,yama,integrity,apparmor \ +-e CONFIG_PAGE_TABLE_ISOLATION \ +-e CONFIG_ARCH_HAS_CPU_FINALIZE_INIT \ +-d CONFIG_GDS_FORCE_MITIGATION \ +-d CONFIG_WQ_CPU_INTENSIVE_REPORT \ +-d CONFIG_N_GSM \ +-d UBSAN_BOUNDS \ debian/control: $(wildcard debian/*.in) - sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/pve-kernel.prerm.in > debian/${PVE_KERNEL_PKG}.prerm - sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/pve-kernel.postrm.in > debian/${PVE_KERNEL_PKG}.postrm - sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/pve-kernel.postinst.in > debian/${PVE_KERNEL_PKG}.postinst - sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/pve-headers.postinst.in > debian/${PVE_HEADER_PKG}.postinst - chmod +x debian/${PVE_KERNEL_PKG}.prerm - chmod +x debian/${PVE_KERNEL_PKG}.postrm - chmod +x debian/${PVE_KERNEL_PKG}.postinst - chmod +x debian/${PVE_HEADER_PKG}.postinst - sed -e 's/@KVNAME@/${KVNAME}/g' < debian/control.in > debian/control + sed -e 's/@@KVNAME@@/$(KVNAME)/g' < debian/proxmox-kernel.prerm.in > debian/$(PMX_KERNEL_PKG).prerm + sed -e 's/@@KVNAME@@/$(KVNAME)/g' < debian/proxmox-kernel.postrm.in > debian/$(PMX_KERNEL_PKG).postrm + sed -e 's/@@KVNAME@@/$(KVNAME)/g' < debian/proxmox-kernel.postinst.in > debian/$(PMX_KERNEL_PKG).postinst + sed -e 's/@@KVNAME@@/$(KVNAME)/g' < debian/proxmox-headers.postinst.in > debian/$(PMX_HEADER_PKG).postinst + sed -e 's/@@KVMAJMIN@@/$(KERNEL_MAJMIN)/g' -e 's/@@KVNAME@@/$(KVNAME)/g' < debian/proxmox-kernel-meta.postrm.in > debian/$(PMX_KERNEL_SERIES_PKG).postrm + sed -e 's/@@KVMAJMIN@@/$(KERNEL_MAJMIN)/g' -e 's/@@KVNAME@@/$(KVNAME)/g' < debian/proxmox-kernel-meta.postinst.in > debian/$(PMX_KERNEL_SERIES_PKG).postinst + chmod +x debian/$(PMX_KERNEL_PKG).prerm + chmod +x debian/$(PMX_KERNEL_PKG).postrm + chmod +x debian/$(PMX_KERNEL_PKG).postinst + chmod +x debian/$(PMX_KERNEL_SERIES_PKG).postrm + chmod +x debian/$(PMX_KERNEL_SERIES_PKG).postinst + chmod +x debian/$(PMX_HEADER_PKG).postinst + sed -e 's/@KVNAME@/$(KVNAME)/g' -e 's/@KVMAJMIN@/$(KERNEL_MAJMIN)/g' < debian/control.in > debian/control + + # signing-template + sed -e '1 s/proxmox-kernel/proxmox-kernel-signed/' -e '1 s/${DEB_VERSION}/${PMX_KERNEL_SIGNED_VERSION}/' < debian/changelog > debian/signing-template/changelog + sed -e 's/@KVNAME@/${KVNAME}/g' -e 's/@KVMAJMIN@/$(KERNEL_MAJMIN)/g' -e 's/@UNSIGNED_VERSION@/${DEB_VERSION}/g' < debian/signing-template/control.in > debian/signing-template/control + sed -e 's/@KVNAME@/${KVNAME}/g' < debian/signing-template/files.json.in > debian/signing-template/files.json + sed -e 's/@KVNAME@/${KVNAME}/g' -e 's/@PKG_VERSION@/${DEB_VERSION}/' < debian/signing-template/rules.in > debian/signing-template/rules + sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/proxmox-kernel.prerm.in > debian/signing-template/prerm + sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/proxmox-kernel.postrm.in > debian/signing-template/postrm + sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/proxmox-kernel.postinst.in > debian/signing-template/postinst + rm debian/signing-template/*.in + cp debian/SOURCE debian/signing-template/ build: .compile_mark .tools_compile_mark .modules_compile_mark -install: .install_mark .tools_install_mark .headers_install_mark +install: .install_mark .tools_install_mark .headers_install_mark .usr_headers_install_mark dh_installdocs -A debian/copyright debian/SOURCE dh_installchangelogs dh_installman @@ -77,7 +143,7 @@ install: .install_mark .tools_install_mark .headers_install_mark binary: install debian/rules fwcheck abicheck - dh_strip + dh_strip -N$(PMX_HEADER_PKG) -N$(PMX_USR_HEADER_PKG) dh_makeshlibs dh_shlibdeps dh_installdeb @@ -85,62 +151,107 @@ binary: install dh_md5sums dh_builddeb -.compile_mark: ${KERNEL_SRC}/.config - cd ${KERNEL_SRC}; scripts/config ${PVE_CONFIG_OPTS} - ${MAKE} -C ${KERNEL_SRC} oldconfig - ${MAKE} -C ${KERNEL_SRC} KBUILD_BUILD_VERSION_TIMESTAMP="PVE ${DEB_VERSION} (${CHANGELOG_DATE})" +.config_mark: + cd $(KERNEL_SRC); scripts/config $(PMX_CONFIG_OPTS) + $(MAKE) -C $(KERNEL_SRC) olddefconfig + # copy to allow building in parallel to kernel/module compilation without interference + rm -rf $(KERNEL_SRC_COPY) + cp -ar $(KERNEL_SRC) $(KERNEL_SRC_COPY) + touch $@ + +.compile_mark: .config_mark + $(MAKE) -C $(KERNEL_SRC) KBUILD_BUILD_VERSION_TIMESTAMP="PMX $(DEB_VERSION) ($(CHANGELOG_DATE_UTC_ISO))" touch $@ .install_mark: .compile_mark .modules_compile_mark - rm -rf debian/${PVE_KERNEL_PKG} - mkdir -p debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME} - mkdir debian/${PVE_KERNEL_PKG}/boot - install -m 644 ${KERNEL_SRC}/.config debian/${PVE_KERNEL_PKG}/boot/config-${KVNAME} - install -m 644 ${KERNEL_SRC}/System.map debian/${PVE_KERNEL_PKG}/boot/System.map-${KVNAME} - install -m 644 ${KERNEL_SRC}/${KERNEL_IMAGE_PATH} debian/${PVE_KERNEL_PKG}/boot/${KERNEL_INSTALL_FILE}-${KVNAME} - ${MAKE} -C ${KERNEL_SRC} INSTALL_MOD_PATH=${BUILD_DIR}/debian/${PVE_KERNEL_PKG}/ modules_install -# disabled for now, incompatbile with 4.15 -# ## install latest ibg driver -# install -m 644 ${MODULES}/igb.ko debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/kernel/drivers/net/ethernet/intel/igb/ -# # install latest ixgbe driver -# install -m 644 ${MODULES}/ixgbe.ko debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/kernel/drivers/net/ethernet/intel/ixgbe/ -# # install latest e1000e driver -# install -m 644 ${MODULES}/e1000e.ko debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/kernel/drivers/net/ethernet/intel/e1000e/ + rm -rf debian/$(PMX_KERNEL_PKG) + mkdir -p debian/$(PMX_KERNEL_PKG)/lib/modules/$(KVNAME) + mkdir debian/$(PMX_KERNEL_PKG)/boot + install -m 644 $(KERNEL_SRC)/.config debian/$(PMX_KERNEL_PKG)/boot/config-$(KVNAME) + install -m 644 $(KERNEL_SRC)/System.map debian/$(PMX_KERNEL_PKG)/boot/System.map-$(KVNAME) + install -m 644 $(KERNEL_SRC)/$(KERNEL_IMAGE_PATH) debian/$(PMX_KERNEL_PKG)/boot/$(KERNEL_INSTALL_FILE)-$(KVNAME) + $(MAKE) -C $(KERNEL_SRC) INSTALL_MOD_PATH=$(BUILD_DIR)/debian/$(PMX_KERNEL_PKG)/ modules_install # install zfs drivers - install -d -m 0755 debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/zfs - install -m 644 $(addprefix ${MODULES}/,spl.ko splat.ko zfs.ko zavl.ko znvpair.ko zunicode.ko zcommon.ko zpios.ko icp.ko) debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/zfs + install -d -m 0755 debian/$(PMX_KERNEL_PKG)/lib/modules/$(KVNAME)/zfs + install -m 644 $(MODULES)/zfs.ko $(MODULES)/spl.ko debian/$(PMX_KERNEL_PKG)/lib/modules/$(KVNAME)/zfs # remove firmware - rm -rf debian/${PVE_KERNEL_PKG}/lib/firmware + rm -rf debian/$(PMX_KERNEL_PKG)/lib/firmware + +ifeq ($(filter pkg.proxmox-kernel.debug,$(DEB_BUILD_PROFILES)),) + echo "'pkg.proxmox-kernel.debug' build profile disabled, skipping -dbgsym creation" +else + echo "'pkg.proxmox-kernel.debug' build profile enabled, creating -dbgsym contents" + mkdir -p debian/$(PMX_DEBUG_KERNEL_PKG)/usr/lib/debug/lib/modules/$(KVNAME) + mkdir debian/$(PMX_DEBUG_KERNEL_PKG)/usr/lib/debug/boot + install -m 644 $(KERNEL_SRC)/vmlinux debian/$(PMX_DEBUG_KERNEL_PKG)/usr/lib/debug/boot/vmlinux-$(KVNAME) + cp -r debian/$(PMX_KERNEL_PKG)/lib/modules/$(KVNAME) debian/$(PMX_DEBUG_KERNEL_PKG)/usr/lib/debug/lib/modules/ + rm -f debian/$(PMX_DEBUG_KERNEL_PKG)/usr/lib/debug/lib/modules/$(KVNAME)/source + rm -f debian/$(PMX_DEBUG_KERNEL_PKG)/usr/lib/debug/lib/modules/$(KVNAME)/build + rm -f debian/$(PMX_DEBUG_KERNEL_PKG)/usr/lib/debug/lib/modules/$(KVNAME)/modules.* +endif + # strip debug info - find debian/${PVE_KERNEL_PKG}/lib/modules -name \*.ko -print | while read f ; do strip --strip-debug "$$f"; done + find debian/$(PMX_KERNEL_PKG)/lib/modules -name \*.ko -print | while read f ; do strip --strip-debug "$$f"; done + + # sign modules using ephemeral, embedded key + if grep -q CONFIG_MODULE_SIG=y ubuntu-kernel/.config ; then \ + find debian/$(PMX_KERNEL_PKG)/lib/modules -name \*.ko -print | while read f ; do \ + ./ubuntu-kernel/scripts/sign-file sha512 ./ubuntu-kernel/certs/signing_key.pem ubuntu-kernel/certs/signing_key.x509 "$$f" ; \ + done; \ + rm ./ubuntu-kernel/certs/signing_key.pem ; \ + fi # finalize - /sbin/depmod -b debian/${PVE_KERNEL_PKG}/ ${KVNAME} + /sbin/depmod -b debian/$(PMX_KERNEL_PKG)/ $(KVNAME) # Autogenerate blacklist for watchdog devices (see README) - install -m 0755 -d debian/${PVE_KERNEL_PKG}/lib/modprobe.d - ls debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/kernel/drivers/watchdog/ > watchdog-blacklist.tmp + install -m 0755 -d debian/$(PMX_KERNEL_PKG)/lib/modprobe.d + ls debian/$(PMX_KERNEL_PKG)/lib/modules/$(KVNAME)/kernel/drivers/watchdog/ > watchdog-blacklist.tmp echo ipmi_watchdog.ko >> watchdog-blacklist.tmp - cat watchdog-blacklist.tmp|sed -e 's/^/blacklist /' -e 's/.ko$$//'|sort -u > debian/${PVE_KERNEL_PKG}/lib/modprobe.d/blacklist_${PVE_KERNEL_PKG}.conf - rm -f debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/source - rm -f debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/build + cat watchdog-blacklist.tmp|sed -e 's/^/blacklist /' -e 's/.ko$$//'|sort -u > debian/$(PMX_KERNEL_PKG)/lib/modprobe.d/blacklist_$(PMX_KERNEL_PKG).conf + rm -f debian/$(PMX_KERNEL_PKG)/lib/modules/$(KVNAME)/source + rm -f debian/$(PMX_KERNEL_PKG)/lib/modules/$(KVNAME)/build + + # copy signing template contents + rm -rf debian/${PMX_KERNEL_SIGNING_TEMPLATE_PKG} + mkdir -p debian/${PMX_KERNEL_SIGNING_TEMPLATE_PKG}/usr/share/code-signing/${PMX_KERNEL_SIGNING_TEMPLATE_PKG}/source-template/debian + cp -R debian/copyright \ + debian/signing-template/rules \ + debian/signing-template/control \ + debian/signing-template/source \ + debian/signing-template/changelog \ + debian/signing-template/prerm \ + debian/signing-template/postrm \ + debian/signing-template/postinst \ + debian/signing-template/SOURCE \ + debian/${PMX_KERNEL_SIGNING_TEMPLATE_PKG}/usr/share/code-signing/${PMX_KERNEL_SIGNING_TEMPLATE_PKG}/source-template/debian + cp debian/signing-template/files.json debian/${PMX_KERNEL_SIGNING_TEMPLATE_PKG}/usr/share/code-signing/${PMX_KERNEL_SIGNING_TEMPLATE_PKG}/ + touch $@ .tools_compile_mark: .compile_mark - ${MAKE} -C ${KERNEL_SRC}/tools/perf prefix=/usr HAVE_CPLUS_DEMANGLE=1 NO_LIBPYTHON=1 NO_LIBPERL=1 NO_LIBCRYPTO=1 PYTHON=python2.7 - ${MAKE} -C ${KERNEL_SRC}/tools/perf man + $(MAKE) -C $(KERNEL_SRC)/tools/perf prefix=/usr NO_LIBTRACEEVENT=1 HAVE_NO_LIBBFD=1 HAVE_CPLUS_DEMANGLE_SUPPORT=1 NO_LIBPYTHON=1 NO_LIBPERL=1 NO_LIBCRYPTO=1 PYTHON=python3 + echo "checking GPL-2 only perf binary for library linkage with incompatible licenses.." + ! ldd $(KERNEL_SRC)/tools/perf/perf | grep -q -E '\blibbfd' + ! ldd $(KERNEL_SRC)/tools/perf/perf | grep -q -E '\blibcrypto' + $(MAKE) -C $(KERNEL_SRC)/tools/perf NO_LIBTRACEEVENT=1 man touch $@ .tools_install_mark: .tools_compile_mark - rm -rf debian/${LINUX_TOOLS_PKG} - mkdir -p debian/${LINUX_TOOLS_PKG}/usr/bin - install -m 755 ${BUILD_DIR}/${KERNEL_SRC}/tools/perf/perf debian/${LINUX_TOOLS_PKG}/usr/bin/perf_4.15 + rm -rf debian/$(LINUX_TOOLS_PKG) + mkdir -p debian/$(LINUX_TOOLS_PKG)/usr/bin + mkdir -p debian/$(LINUX_TOOLS_PKG)/usr/share/man/man1 + install -m 755 $(BUILD_DIR)/$(KERNEL_SRC)/tools/perf/perf debian/$(LINUX_TOOLS_PKG)/usr/bin/perf_$(KERNEL_MAJMIN) + for i in $(BUILD_DIR)/$(KERNEL_SRC)/tools/perf/Documentation/*.1; do \ + fname="$${i##*/}"; manname="$${fname%.1}"; \ + install -m644 "$$i" "debian/$(LINUX_TOOLS_PKG)/usr/share/man/man1/$${manname}_$(KERNEL_MAJMIN).1"; \ + done touch $@ -.headers_install_mark: .compile_mark .modules_compile_mark - rm -rf debian/${PVE_HEADER_PKG} - mkdir -p debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME} - install -m 0644 ${KERNEL_SRC}/.config debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME} - install -m 0644 ${KERNEL_SRC}/Module.symvers debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME} - cd ${KERNEL_SRC}; find . -path './debian/*' -prune \ +.headers_prepare_mark: .config_mark + rm -rf debian/$(PMX_HEADER_PKG) + mkdir -p debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME) + install -m 0644 $(KERNEL_SRC)/.config debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME) + make -C $(KERNEL_SRC_COPY) mrproper + cd $(KERNEL_SRC_COPY); find . -path './debian/*' -prune \ -o -path './include/*' -prune \ -o -path './Documentation' -prune \ -o -path './scripts' -prune \ @@ -152,74 +263,80 @@ binary: install -o -name '*.sh' \ -o -name '*.pl' \ \) \ - -print | cpio -pd --preserve-modification-time ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME} - cd ${KERNEL_SRC}; cp -a include scripts ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME} - cd ${KERNEL_SRC}; \ + -print | cpio -pd --preserve-modification-time $(BUILD_DIR)/debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME) + cd $(KERNEL_SRC_COPY); \ ( \ - find arch/${KERNEL_HEADER_ARCH} -name include -type d -print | \ + find arch/$(KERNEL_HEADER_ARCH) -name include -type d -print | \ xargs -n1 -i: find : -type f \ ) | \ - cpio -pd --preserve-modification-time ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME} - mkdir -p debian/${PVE_HEADER_PKG}/lib/modules/${KVNAME} - ln -sf /usr/src/linux-headers-${KVNAME} debian/${PVE_HEADER_PKG}/lib/modules/${KVNAME}/build + cpio -pd --preserve-modification-time $(BUILD_DIR)/debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME) touch $@ -# intel out-of-tree drivers disabled for now - incompatible with 4.15 -#.modules_compile_mark: $(addprefix ${MODULES}/,igb.ko ixgbe.ko e1000e.ko spl.ko zfs.ko) -.modules_compile_mark: $(addprefix ${MODULES}/,spl.ko zfs.ko) +.headers_compile_mark: .headers_prepare_mark + # set output to subdir of source to reduce number of hardcoded paths in output files + rm -rf $(BUILD_DIR)/$(KERNEL_SRC_COPY)/$(PMX_HEADER_PKG) + mkdir -p $(BUILD_DIR)/$(KERNEL_SRC_COPY)/$(PMX_HEADER_PKG) + cp $(KERNEL_SRC)/.config $(BUILD_DIR)/$(KERNEL_SRC_COPY)/$(PMX_HEADER_PKG)/.config + $(MAKE) -C $(KERNEL_SRC_COPY) O=$(BUILD_DIR)/$(KERNEL_SRC_COPY)/$(PMX_HEADER_PKG) -j1 syncconfig modules_prepare prepare scripts + cd $(KERNEL_SRC_COPY); cp -a include scripts $(BUILD_DIR)/debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME) + find $(BUILD_DIR)/$(KERNEL_SRC_COPY)/$(PMX_HEADER_PKG) -name \*.o.ur-\* -o -name '*.cmd' | xargs rm -f + rsync --ignore-existing -r -v -a $(addprefix $(BUILD_DIR)/$(KERNEL_SRC_COPY)/$(PMX_HEADER_PKG)/,arch include kernel scripts tools) $(BUILD_DIR)/debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME)/ + rm -rf $(BUILD_DIR)/$(KERNEL_SRC_COPY) touch $@ -${MODULES}/spl.ko: .compile_mark - cd ${MODULES}/${SPLDIR}; ./autogen.sh - cd ${MODULES}/${SPLDIR}; ./configure --with-config=kernel --with-linux=${BUILD_DIR}/${KERNEL_SRC} --with-linux-obj=${BUILD_DIR}/${KERNEL_SRC} - ${MAKE} -C ${MODULES}/${SPLDIR} - cp ${MODULES}/${SPLDIR}/module/splat/splat.ko ${MODULES}/ - cp ${MODULES}/${SPLDIR}/module/spl/spl.ko ${MODULES}/ - -${MODULES}/zfs.ko: .compile_mark ${MODULES}/spl.ko - cd ${MODULES}/${ZFSDIR}; ./autogen.sh - cd ${MODULES}/${ZFSDIR}; ./configure --with-spl=${BUILD_DIR}/${MODULES}/${SPLDIR} --with-spl-obj=${BUILD_DIR}/${MODULES}/${SPLDIR} --with-config=kernel --with-linux=${BUILD_DIR}/${KERNEL_SRC} --with-linux-obj=${BUILD_DIR}/${KERNEL_SRC} - ${MAKE} -C ${MODULES}/${ZFSDIR} - cp ${MODULES}/${ZFSDIR}/module/avl/zavl.ko ${MODULES}/ - cp ${MODULES}/${ZFSDIR}/module/nvpair/znvpair.ko ${MODULES}/ - cp ${MODULES}/${ZFSDIR}/module/unicode/zunicode.ko ${MODULES}/ - cp ${MODULES}/${ZFSDIR}/module/zcommon/zcommon.ko ${MODULES}/ - cp ${MODULES}/${ZFSDIR}/module/zpios/zpios.ko ${MODULES}/ - cp ${MODULES}/${ZFSDIR}/module/icp/icp.ko ${MODULES}/ - cp ${MODULES}/${ZFSDIR}/module/zfs/zfs.ko ${MODULES}/ - -${MODULES}/igb.ko: .compile_mark - ${MAKE} -C ${MODULES}/${IGBDIR}/src BUILD_KERNEL=${KVNAME} KSRC=${BUILD_DIR}/${KERNEL_SRC} - cp ${MODULES}/${IGBDIR}/src/igb.ko ${MODULES}/ - -${MODULES}/ixgbe.ko: .compile_mark - ${MAKE} -C ${MODULES}/${IXGBEDIR}/src CFLAGS_EXTRA="-DIXGBE_NO_LRO" BUILD_KERNEL=${KVNAME} KSRC=${BUILD_DIR}/${KERNEL_SRC} - cp ${MODULES}/${IXGBEDIR}/src/ixgbe.ko ${MODULES}/ - -${MODULES}/e1000e.ko: .compile_mark - ${MAKE} -C ${MODULES}/${E1000EDIR}/src BUILD_KERNEL=${KVNAME} KSRC=${BUILD_DIR}/${KERNEL_SRC} - cp ${MODULES}/${E1000EDIR}/src/e1000e.ko ${MODULES}/ - -fwlist-${KVNAME}: .compile_mark .modules_compile_mark - debian/scripts/find-firmware.pl debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME} >fwlist.tmp +.headers_install_mark: .compile_mark .modules_compile_mark .headers_compile_mark + cp $(KERNEL_SRC)/include/generated/compile.h debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME)/include/generated/compile.h + install -m 0644 $(KERNEL_SRC)/Module.symvers debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME) + mkdir -p debian/$(PMX_HEADER_PKG)/lib/modules/$(KVNAME) + ln -sf /usr/src/linux-headers-$(KVNAME) debian/$(PMX_HEADER_PKG)/lib/modules/$(KVNAME)/build + touch $@ + +.usr_headers_install_mark: PKG_DIR = debian/$(PMX_USR_HEADER_PKG) +.usr_headers_install_mark: OUT_DIR = $(PKG_DIR)/usr +.usr_headers_install_mark: .config_mark + rm -rf '$(PKG_DIR)' + mkdir -p '$(PKG_DIR)' + $(MAKE) -C $(KERNEL_SRC) headers_install ARCH=$(KERNEL_HEADER_ARCH) INSTALL_HDR_PATH='$(CURDIR)'/$(OUT_DIR) + rm -rf $(OUT_DIR)/include/drm $(OUT_DIR)/include/scsi + find $(OUT_DIR)/include \( -name .install -o -name ..install.cmd \) -execdir rm {} + + +# Move include/asm to arch-specific directory + mkdir -p $(OUT_DIR)/include/$(DEB_HOST_MULTIARCH) + mv $(OUT_DIR)/include/asm $(OUT_DIR)/include/$(DEB_HOST_MULTIARCH)/ + test ! -d $(OUT_DIR)/include/arch || \ + mv $(OUT_DIR)/include/arch $(OUT_DIR)/include/$(DEB_HOST_MULTIARCH)/ + touch $@ + +.modules_compile_mark: $(MODULES)/zfs.ko + touch $@ + +$(MODULES)/zfs.ko: .compile_mark + cd $(MODULES)/$(ZFSDIR); ./autogen.sh + cd $(MODULES)/$(ZFSDIR); ./configure --with-config=kernel --with-linux=$(BUILD_DIR)/$(KERNEL_SRC) --with-linux-obj=$(BUILD_DIR)/$(KERNEL_SRC) + $(MAKE) -C $(MODULES)/$(ZFSDIR) + cp $(MODULES)/$(ZFSDIR)/module/zfs.ko $(MODULES)/ + cp $(MODULES)/$(ZFSDIR)/module/spl.ko $(MODULES)/ + +fwlist-$(KVNAME): .compile_mark .modules_compile_mark + debian/scripts/find-firmware.pl debian/$(PMX_KERNEL_PKG)/lib/modules/$(KVNAME) >fwlist.tmp mv fwlist.tmp $@ .PHONY: fwcheck -fwcheck: fwlist-${KVNAME} fwlist-previous +fwcheck: fwlist-$(KVNAME) fwlist-previous @echo "checking fwlist for changes since last built firmware package.." - @echo "if this check fails, add fwlist-${KVNAME} to the pve-firmware repository and upload a new firmware package together with the ${KVNAME} kernel" + @echo "if this check fails, add fwlist-$(KVNAME) to the pve-firmware repository and upload a new firmware package together with the $(KVNAME) kernel" sort fwlist-previous | uniq > fwlist-previous.sorted - sort fwlist-${KVNAME} | uniq > fwlist-${KVNAME}.sorted - diff -up -N fwlist-previous.sorted fwlist-${KVNAME}.sorted > fwlist.diff - rm fwlist.diff fwlist-previous.sorted fwlist-${KVNAME}.sorted + sort fwlist-$(KVNAME) | uniq > fwlist-$(KVNAME).sorted + diff -up -N fwlist-previous.sorted fwlist-$(KVNAME).sorted > fwlist.diff + rm fwlist.diff fwlist-previous.sorted fwlist-$(KVNAME).sorted @echo "done, no need to rebuild pve-firmware" -abi-${KVNAME}: .compile_mark - debian/scripts/abi-generate debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}/Module.symvers abi-${KVNAME} ${KVNAME} +abi-$(KVNAME): .compile_mark + debian/scripts/abi-generate debian/$(PMX_HEADER_PKG)/usr/src/linux-headers-$(KVNAME)/Module.symvers abi-$(KVNAME) $(KVNAME) .PHONY: abicheck -abicheck: debian/scripts/abi-check abi-${KVNAME} abi-prev-* abi-blacklist - debian/scripts/abi-check abi-${KVNAME} abi-prev-* ${SKIPABI} +abicheck: debian/scripts/abi-check abi-$(KVNAME) abi-prev-* abi-blacklist + debian/scripts/abi-check abi-$(KVNAME) abi-prev-* $(SKIPABI) .PHONY: clean