X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=debian%2Frules;h=365b4fa5ea1bb86397325399cf8ddcf1d44c821f;hb=2bebed59351ceefe53e7bca7a913fd6c549efed8;hp=96373e5bf1be39fc0b60c8abe6eb2e10f9d01f6b;hpb=758134b5b89beecc5a34a50b812d45cd31fef286;p=pve-kernel.git diff --git a/debian/rules b/debian/rules index 96373e5..365b4fa 100755 --- a/debian/rules +++ b/debian/rules @@ -14,8 +14,11 @@ include debian/rules.d/${DEB_BUILD_ARCH}.mk CHANGELOG_DATE:=$(shell dpkg-parsechangelog -SDate) PVE_KERNEL_PKG=pve-kernel-${KVNAME} +PVE_DEBUG_KERNEL_PKG=pve-kernel-${KVNAME}-dbgsym PVE_HEADER_PKG=pve-headers-${KVNAME} +PVE_USR_HEADER_PKG=pve-kernel-libc-dev LINUX_TOOLS_PKG=linux-tools-${KERNEL_MAJMIN} +KERNEL_SRC_COPY=${KERNEL_SRC}_tmp # TODO: split for archs, move to files? PVE_CONFIG_OPTS= \ @@ -26,22 +29,45 @@ PVE_CONFIG_OPTS= \ -m CONFIG_CEPH_FS \ -m CONFIG_BLK_DEV_NBD \ -m CONFIG_BLK_DEV_RBD \ +-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 \ +-e CONFIG_SYSFB_SIMPLEFB \ +-e CONFIG_DRM_SIMPLEDRM \ -d CONFIG_MODULE_SIG \ -d CONFIG_MEMCG_DISABLED \ -e CONFIG_MEMCG_SWAP_ENABLED \ +-e CONFIG_HYPERV \ +-m CONFIG_VFIO_IOMMU_TYPE1 \ +-m 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 \ @@ -52,6 +78,11 @@ PVE_CONFIG_OPTS= \ -d CONFIG_UNWINDER_ORC \ -d CONFIG_UNWINDER_GUESS \ -e CONFIG_UNWINDER_FRAME_POINTER \ +--set-str CONFIG_SYSTEM_TRUSTED_KEYS ""\ +--set-str CONFIG_SYSTEM_REVOCATION_KEYS ""\ +-d CONFIG_SECURITY_LOCKDOWN_LSM \ +-d CONFIG_SECURITY_LOCKDOWN_LSM_EARLY \ +--set-str CONFIG_LSM yama,integrity,apparmor \ -e CONFIG_PAGE_TABLE_ISOLATION debian/control: $(wildcard debian/*.in) @@ -67,7 +98,7 @@ debian/control: $(wildcard debian/*.in) 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 +108,7 @@ install: .install_mark .tools_install_mark .headers_install_mark binary: install debian/rules fwcheck abicheck - dh_strip -N${PVE_HEADER_PKG} + dh_strip -N${PVE_HEADER_PKG} -N${PVE_USR_HEADER_PKG} dh_makeshlibs dh_shlibdeps dh_installdeb @@ -85,9 +116,15 @@ binary: install dh_md5sums dh_builddeb -.compile_mark: ${KERNEL_SRC}/.config +.config_mark: cd ${KERNEL_SRC}; scripts/config ${PVE_CONFIG_OPTS} ${MAKE} -C ${KERNEL_SRC} oldconfig + # 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="PVE ${DEB_VERSION} (${CHANGELOG_DATE})" touch $@ @@ -99,17 +136,25 @@ binary: install 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 - ## 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/ # 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 -m 644 $(addprefix ${MODULES}/,zfs.ko zavl.ko znvpair.ko zunicode.ko zcommon.ko icp.ko zlua.ko spl.ko zzstd.ko) debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/zfs # remove firmware rm -rf debian/${PVE_KERNEL_PKG}/lib/firmware + +ifeq ($(filter pkg.pve-kernel.debug,$(DEB_BUILD_PROFILES)),) + echo "'pkg.pve-kernel.debug' build profile disabled, skipping -dbgsym creation" +else + echo "'pkg.pve-kernel.debug' build profile enabled, creating -dbgsym contents" + mkdir -p debian/${PVE_DEBUG_KERNEL_PKG}/usr/lib/debug/lib/modules/${KVNAME} + mkdir debian/${PVE_DEBUG_KERNEL_PKG}/usr/lib/debug/boot + install -m 644 ${KERNEL_SRC}/vmlinux debian/${PVE_DEBUG_KERNEL_PKG}/usr/lib/debug/boot/vmlinux-${KVNAME} + cp -r debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME} debian/${PVE_DEBUG_KERNEL_PKG}/usr/lib/debug/lib/modules/ + rm -f debian/${PVE_DEBUG_KERNEL_PKG}/usr/lib/debug/lib/modules/${KVNAME}/source + rm -f debian/${PVE_DEBUG_KERNEL_PKG}/usr/lib/debug/lib/modules/${KVNAME}/build + rm -f debian/${PVE_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 # finalize @@ -124,7 +169,7 @@ binary: install touch $@ .tools_compile_mark: .compile_mark - ${MAKE} -C ${KERNEL_SRC}/tools/perf prefix=/usr HAVE_NO_LIBBFD=1 HAVE_CPLUS_DEMANGLE_SUPPORT=1 NO_LIBPYTHON=1 NO_LIBPERL=1 NO_LIBCRYPTO=1 PYTHON=python2.7 + ${MAKE} -C ${KERNEL_SRC}/tools/perf prefix=/usr 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' @@ -142,12 +187,12 @@ binary: install done touch $@ -.headers_install_mark: .compile_mark .modules_compile_mark +.headers_prepare_mark: .config_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 \ + 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 \ @@ -160,50 +205,65 @@ binary: install -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}; \ + cd ${KERNEL_SRC_COPY}; \ ( \ 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} + touch $@ + +.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}/${PVE_HEADER_PKG} + mkdir -p ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG} + cp ${KERNEL_SRC}/.config ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG}/.config + ${MAKE} -C ${KERNEL_SRC_COPY} O=${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG} -j1 syncconfig modules_prepare prepare scripts + cd ${KERNEL_SRC_COPY}; cp -a include scripts ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME} + find ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG} -name \*.o.ur-\* -o -name '*.cmd' | xargs rm -f + rsync --ignore-existing -r -v -a $(addprefix ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG}/,arch include kernel scripts tools) ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}/ + rm -rf ${BUILD_DIR}/${KERNEL_SRC_COPY} + touch $@ + +.headers_install_mark: .compile_mark .modules_compile_mark .headers_compile_mark + cp ${KERNEL_SRC}/include/generated/compile.h debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}/include/generated/compile.h + install -m 0644 ${KERNEL_SRC}/Module.symvers 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 touch $@ -.modules_compile_mark: $(addprefix ${MODULES}/,igb.ko ixgbe.ko e1000e.ko spl.ko zfs.ko) +.usr_headers_install_mark: PKG_DIR = debian/${PVE_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}/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_compile_mark: ${MODULES}/zfs.ko + touch $@ -${MODULES}/zfs.ko: .compile_mark ${MODULES}/spl.ko +${MODULES}/zfs.ko: .compile_mark 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} + 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/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}/ + cp ${MODULES}/${ZFSDIR}/module/lua/zlua.ko ${MODULES}/ + cp ${MODULES}/${ZFSDIR}/module/spl/spl.ko ${MODULES}/ + cp ${MODULES}/${ZFSDIR}/module/zstd/zzstd.ko ${MODULES}/ fwlist-${KVNAME}: .compile_mark .modules_compile_mark debian/scripts/find-firmware.pl debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME} >fwlist.tmp