]>
Commit | Line | Data |
---|---|---|
75b315d4 | 1 | # also bump pve-kernel-meta if either of MAJ.MIN, PATCHLEVEL or KREL change |
3f2c044f | 2 | KERNEL_MAJ=5 |
625b5c77 | 3 | KERNEL_MIN=4 |
ebbe0c51 | 4 | KERNEL_PATCHLEVEL=140 |
8b4e1fa9 SI |
5 | # increment KREL if the ABI changes (abicheck target in debian/rules) |
6 | # rebuild packages with new KREL and run 'make abiupdate' | |
8603b9e2 | 7 | KREL=1 |
ba2f1a67 | 8 | |
ebbe0c51 | 9 | PKGREL=1 |
44403fcc | 10 | |
5fd5ec0e SI |
11 | KERNEL_MAJMIN=$(KERNEL_MAJ).$(KERNEL_MIN) |
12 | KERNEL_VER=$(KERNEL_MAJMIN).$(KERNEL_PATCHLEVEL) | |
13 | ||
66aed5b8 | 14 | EXTRAVERSION=-${KREL}-pve |
ba2f1a67 FG |
15 | KVNAME=${KERNEL_VER}${EXTRAVERSION} |
16 | PACKAGE=pve-kernel-${KVNAME} | |
17 | HDRPACKAGE=pve-headers-${KVNAME} | |
18 | ||
37d1225d | 19 | ARCH=$(shell dpkg-architecture -qDEB_BUILD_ARCH) |
6490543b TL |
20 | |
21 | # amd64/x86_64/x86 share the arch subdirectory in the kernel, 'x86' so we need | |
22 | # a mapping | |
23 | KERNEL_ARCH=x86 | |
24 | ifneq (${ARCH}, amd64) | |
25 | KERNEL_ARCH=${ARCH} | |
26 | endif | |
27 | ||
97d6ca37 | 28 | GITVERSION:=$(shell git rev-parse HEAD) |
ba2f1a67 | 29 | |
41f5ee98 FG |
30 | SKIPABI=0 |
31 | ||
66aed5b8 | 32 | BUILD_DIR=build |
ba2f1a67 | 33 | |
625b5c77 | 34 | KERNEL_SRC=ubuntu-focal |
5fd5ec0e | 35 | KERNEL_SRC_SUBMODULE=submodules/$(KERNEL_SRC) |
ba2f1a67 FG |
36 | KERNEL_CFG_ORG=config-${KERNEL_VER}.org |
37 | ||
2e38f6f9 | 38 | ZFSONLINUX_SUBMODULE=submodules/zfsonlinux |
66aed5b8 | 39 | ZFSDIR=pkg-zfs |
e96d2ab3 | 40 | |
66aed5b8 | 41 | MODULES=modules |
5fa6b6ae | 42 | MODULE_DIRS=${ZFSDIR} |
ba2f1a67 | 43 | |
66aed5b8 | 44 | # exported to debian/rules via debian/rules.d/dirs.mk |
5fa6b6ae | 45 | DIRS=KERNEL_SRC ZFSDIR MODULES |
66aed5b8 | 46 | |
ba2f1a67 FG |
47 | DST_DEB=${PACKAGE}_${KERNEL_VER}-${PKGREL}_${ARCH}.deb |
48 | HDR_DEB=${HDRPACKAGE}_${KERNEL_VER}-${PKGREL}_${ARCH}.deb | |
36eda89b | 49 | USR_HDR_DEB=pve-kernel-libc-dev_${KERNEL_VER}-${PKGREL}_${ARCH}.deb |
5fd5ec0e | 50 | LINUX_TOOLS_DEB=linux-tools-$(KERNEL_MAJMIN)_${KERNEL_VER}-${PKGREL}_${ARCH}.deb |
19ab15b7 | 51 | LINUX_TOOLS_DBG_DEB=linux-tools-$(KERNEL_MAJMIN)-dbgsym_${KERNEL_VER}-${PKGREL}_${ARCH}.deb |
ba2f1a67 | 52 | |
19ab15b7 | 53 | DEBS=${DST_DEB} ${HDR_DEB} ${USR_HDR_DEB} ${LINUX_TOOLS_DEB} ${LINUX_TOOLS_DBG_DEB} |
ba2f1a67 | 54 | |
2135c723 | 55 | all: deb |
bdfc6d28 | 56 | deb: ${DEBS} |
ba2f1a67 | 57 | |
e96d2ab3 FG |
58 | ${LINUX_TOOLS_DEB} ${HDR_DEB}: ${DST_DEB} |
59 | ${DST_DEB}: ${BUILD_DIR}.prepared | |
e96d2ab3 | 60 | cd ${BUILD_DIR}; dpkg-buildpackage --jobs=auto -b -uc -us |
ba2f1a67 | 61 | lintian ${DST_DEB} |
e96d2ab3 | 62 | #lintian ${HDR_DEB} |
ba2f1a67 FG |
63 | lintian ${LINUX_TOOLS_DEB} |
64 | ||
66aed5b8 | 65 | ${BUILD_DIR}.prepared: $(addsuffix .prepared,${KERNEL_SRC} ${MODULES} debian) |
e96d2ab3 | 66 | cp -a fwlist-previous ${BUILD_DIR}/ |
faa3d751 | 67 | cp -a abi-prev-* ${BUILD_DIR}/ |
e96d2ab3 | 68 | cp -a abi-blacklist ${BUILD_DIR}/ |
66aed5b8 FG |
69 | touch $@ |
70 | ||
71 | debian.prepared: debian | |
72 | rm -rf ${BUILD_DIR}/debian | |
73 | mkdir -p ${BUILD_DIR} | |
74 | cp -a debian ${BUILD_DIR}/debian | |
e96d2ab3 | 75 | echo "git clone git://git.proxmox.com/git/pve-kernel.git\\ngit checkout ${GITVERSION}" > ${BUILD_DIR}/debian/SOURCE |
66aed5b8 FG |
76 | @$(foreach dir, ${DIRS},echo "${dir}=${${dir}}" >> ${BUILD_DIR}/debian/rules.d/env.mk;) |
77 | echo "KVNAME=${KVNAME}" >> ${BUILD_DIR}/debian/rules.d/env.mk | |
5fd5ec0e | 78 | echo "KERNEL_MAJMIN=${KERNEL_MAJMIN}" >> ${BUILD_DIR}/debian/rules.d/env.mk |
66aed5b8 | 79 | cd ${BUILD_DIR}; debian/rules debian/control |
ba2f1a67 FG |
80 | touch $@ |
81 | ||
e96d2ab3 FG |
82 | ${KERNEL_SRC}.prepared: ${KERNEL_SRC_SUBMODULE} | submodule |
83 | rm -rf ${BUILD_DIR}/${KERNEL_SRC} $@ | |
84 | mkdir -p ${BUILD_DIR} | |
12aaf1a2 | 85 | cp -a ${KERNEL_SRC_SUBMODULE} ${BUILD_DIR}/${KERNEL_SRC} |
e96d2ab3 FG |
86 | # TODO: split for archs, track and diff in our repository? |
87 | 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} | |
88 | cp ${KERNEL_CFG_ORG} ${BUILD_DIR}/${KERNEL_SRC}/.config | |
89 | sed -i ${BUILD_DIR}/${KERNEL_SRC}/Makefile -e 's/^EXTRAVERSION.*$$/EXTRAVERSION=${EXTRAVERSION}/' | |
90 | rm -rf ${BUILD_DIR}/${KERNEL_SRC}/debian ${BUILD_DIR}/${KERNEL_SRC}/debian.master | |
c98ed5b4 | 91 | set -e; cd ${BUILD_DIR}/${KERNEL_SRC}; for patch in ../../patches/kernel/*.patch; do echo "applying patch '$$patch'" && patch -p1 < $${patch}; done |
ba2f1a67 FG |
92 | touch $@ |
93 | ||
e96d2ab3 FG |
94 | ${MODULES}.prepared: $(addsuffix .prepared,${MODULE_DIRS}) |
95 | touch $@ | |
96 | ||
62307a08 | 97 | ${ZFSDIR}.prepared: ${ZFSONLINUX_SUBMODULE} |
5fa6b6ae | 98 | rm -rf ${BUILD_DIR}/${MODULES}/${ZFSDIR} ${BUILD_DIR}/${MODULES}/tmp $@ |
62307a08 FG |
99 | mkdir -p ${BUILD_DIR}/${MODULES}/tmp |
100 | cp -a ${ZFSONLINUX_SUBMODULE}/* ${BUILD_DIR}/${MODULES}/tmp | |
101 | cd ${BUILD_DIR}/${MODULES}/tmp; make kernel | |
102 | rm -rf ${BUILD_DIR}/${MODULES}/tmp | |
5fa6b6ae | 103 | touch ${ZFSDIR}.prepared |
ba2f1a67 | 104 | |
ba2f1a67 FG |
105 | .PHONY: upload |
106 | upload: ${DEBS} | |
2552aa9d | 107 | tar cf - ${DEBS}|ssh -X repoman@repo.proxmox.com -- upload --product pve,pmg --dist buster --arch ${ARCH} |
ba2f1a67 FG |
108 | |
109 | .PHONY: distclean | |
110 | distclean: clean | |
e96d2ab3 | 111 | git submodule deinit --all |
ba2f1a67 | 112 | |
32054ef4 FG |
113 | # upgrade to current master |
114 | .PHONY: update_modules | |
a6dd515e | 115 | update_modules: submodule |
32054ef4 | 116 | git submodule foreach 'git pull --ff-only origin master' |
62307a08 | 117 | cd ${ZFSONLINUX_SUBMODULE}; git pull --ff-only origin master |
32054ef4 FG |
118 | |
119 | # make sure submodules were initialized | |
a6dd515e FG |
120 | .PHONY: submodule |
121 | submodule: | |
2e38f6f9 | 122 | test -f "${KERNEL_SRC_SUBMODULE}/README" || git submodule update --init ${KERNEL_SRC_SUBMODULE} |
b76c223c | 123 | test -f "${ZFSONLINUX_SUBMODULE}/Makefile" || git submodule update --init --recursive ${ZFSONLINUX_SUBMODULE} |
32054ef4 | 124 | |
b4ecde23 FG |
125 | # call after ABI bump with header deb in working directory |
126 | .PHONY: abiupdate | |
127 | abiupdate: abi-prev-${KVNAME} | |
128 | abi-prev-${KVNAME}: abi-tmp-${KVNAME} | |
129 | ifneq ($(strip $(shell git status --untracked-files=no --porcelain -z)),) | |
130 | @echo "working directory unclean, aborting!" | |
131 | @false | |
132 | else | |
133 | git rm "abi-prev-*" | |
134 | mv $< $@ | |
135 | git add $@ | |
136 | git commit -s -m "update ABI file for ${KVNAME}" -m "(generated with debian/scripts/abi-generate)" | |
137 | @echo "update abi-prev-${KVNAME} committed!" | |
138 | endif | |
139 | ||
140 | abi-tmp-${KVNAME}: | |
141 | @ test -e ${HDR_DEB} || (echo "need ${HDR_DEB} to extract ABI data!" && false) | |
142 | debian/scripts/abi-generate ${HDR_DEB} $@ ${KVNAME} 1 | |
32054ef4 | 143 | |
ba2f1a67 FG |
144 | .PHONY: clean |
145 | clean: | |
e96d2ab3 | 146 | rm -rf *~ build *.prepared ${KERNEL_CFG_ORG} |
9952c40c | 147 | rm -f *.deb *.changes *.buildinfo |