1 # also bump pve-kernel-meta if either of MAJ.MIN, PATCHLEVEL or KREL change
5 # increment KREL if the ABI changes (abicheck target in debian/rules)
6 # rebuild packages with new KREL and run 'make abiupdate'
11 KERNEL_MAJMIN
=$(KERNEL_MAJ
).
$(KERNEL_MIN
)
12 KERNEL_VER
=$(KERNEL_MAJMIN
).
$(KERNEL_PATCHLEVEL
)
14 EXTRAVERSION
=-${KREL}-pve
15 KVNAME
=${KERNEL_VER}${EXTRAVERSION}
16 PACKAGE
=pve-kernel-
${KVNAME}
17 HDRPACKAGE
=pve-headers-
${KVNAME}
19 ARCH
=$(shell dpkg-architecture
-qDEB_BUILD_ARCH
)
21 # amd64/x86_64/x86 share the arch subdirectory in the kernel, 'x86' so we need
24 ifneq (${ARCH}, amd64
)
28 GITVERSION
:=$(shell git rev-parse HEAD
)
34 KERNEL_SRC
=ubuntu-hirsute
35 KERNEL_SRC_SUBMODULE
=submodules
/$(KERNEL_SRC
)
36 KERNEL_CFG_ORG
=config-
${KERNEL_VER}.org
38 ZFSONLINUX_SUBMODULE
=submodules
/zfsonlinux
44 # exported to debian/rules via debian/rules.d/dirs.mk
45 DIRS
=KERNEL_SRC ZFSDIR MODULES
47 DST_DEB
=${PACKAGE}_
${KERNEL_VER}-${PKGREL}_
${ARCH}.deb
48 HDR_DEB
=${HDRPACKAGE}_
${KERNEL_VER}-${PKGREL}_
${ARCH}.deb
49 USR_HDR_DEB
=pve-kernel-libc-dev_
${KERNEL_VER}-${PKGREL}_
${ARCH}.deb
50 LINUX_TOOLS_DEB
=linux-tools-
$(KERNEL_MAJMIN
)_
${KERNEL_VER}-${PKGREL}_
${ARCH}.deb
52 DEBS
=${DST_DEB} ${HDR_DEB} ${USR_HDR_DEB} ${LINUX_TOOLS_DEB}
57 ${LINUX_TOOLS_DEB} ${HDR_DEB}: ${DST_DEB}
58 ${DST_DEB}: ${BUILD_DIR}.prepared
59 cd
${BUILD_DIR}; dpkg-buildpackage
--jobs
=auto
-b
-uc
-us
62 lintian
${LINUX_TOOLS_DEB}
64 ${BUILD_DIR}.prepared
: $(addsuffix .prepared
,${KERNEL_SRC} ${MODULES} debian
)
65 cp
-a fwlist-previous
${BUILD_DIR}/
66 cp
-a abi-prev-
* ${BUILD_DIR}/
67 cp
-a abi-blacklist
${BUILD_DIR}/
70 debian.prepared
: debian
71 rm -rf
${BUILD_DIR}/debian
73 cp
-a debian
${BUILD_DIR}/debian
74 echo
"git clone git://git.proxmox.com/git/pve-kernel.git\\ngit checkout ${GITVERSION}" > ${BUILD_DIR}/debian
/SOURCE
75 @
$(foreach dir, ${DIRS},echo
"${dir}=${${dir}}" >> ${BUILD_DIR}/debian
/rules.d
/env.mk
;)
76 echo
"KVNAME=${KVNAME}" >> ${BUILD_DIR}/debian
/rules.d
/env.mk
77 echo
"KERNEL_MAJMIN=${KERNEL_MAJMIN}" >> ${BUILD_DIR}/debian
/rules.d
/env.mk
78 cd
${BUILD_DIR}; debian
/rules debian
/control
81 ${KERNEL_SRC}.prepared
: ${KERNEL_SRC_SUBMODULE} | submodule
82 rm -rf
${BUILD_DIR}/${KERNEL_SRC} $@
84 cp
-a
${KERNEL_SRC_SUBMODULE} ${BUILD_DIR}/${KERNEL_SRC}
85 # TODO: split for archs, track and diff in our repository?
86 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}
87 cp
${KERNEL_CFG_ORG} ${BUILD_DIR}/${KERNEL_SRC}/.config
88 sed
-i
${BUILD_DIR}/${KERNEL_SRC}/Makefile
-e
's/^EXTRAVERSION.*$$/EXTRAVERSION=${EXTRAVERSION}/'
89 rm -rf
${BUILD_DIR}/${KERNEL_SRC}/debian
${BUILD_DIR}/${KERNEL_SRC}/debian.master
90 set
-e
; cd
${BUILD_DIR}/${KERNEL_SRC}; for patch in ..
/..
/patches
/kernel
/*.patch
; do echo
"applying patch '$$patch'" && patch
-p1
< $${patch}; done
93 ${MODULES}.prepared
: $(addsuffix .prepared
,${MODULE_DIRS})
96 ${ZFSDIR}.prepared
: ${ZFSONLINUX_SUBMODULE}
97 rm -rf
${BUILD_DIR}/${MODULES}/${ZFSDIR} ${BUILD_DIR}/${MODULES}/tmp
$@
98 mkdir
-p
${BUILD_DIR}/${MODULES}/tmp
99 cp
-a
${ZFSONLINUX_SUBMODULE}/* ${BUILD_DIR}/${MODULES}/tmp
100 cd
${BUILD_DIR}/${MODULES}/tmp
; make kernel
101 rm -rf
${BUILD_DIR}/${MODULES}/tmp
102 touch
${ZFSDIR}.prepared
106 tar cf
- ${DEBS}|ssh
-X repoman@repo.proxmox.com
-- upload
--product pve
,pmg
,pbs
--dist bullseye
--arch
${ARCH}
110 git submodule deinit
--all
112 # upgrade to current master
113 .PHONY
: update_modules
114 update_modules
: submodule
115 git submodule
foreach 'git pull --ff-only origin master'
116 cd
${ZFSONLINUX_SUBMODULE}; git pull
--ff-only
origin master
118 # make sure submodules were initialized
121 test -f
"${KERNEL_SRC_SUBMODULE}/README" || git submodule update
--init
${KERNEL_SRC_SUBMODULE}
122 test -f
"${ZFSONLINUX_SUBMODULE}/Makefile" || git submodule update
--init
--recursive
${ZFSONLINUX_SUBMODULE}
124 # call after ABI bump with header deb in working directory
126 abiupdate
: abi-prev-
${KVNAME}
127 abi-prev-
${KVNAME}: abi-tmp-
${KVNAME}
128 ifneq ($(strip $(shell git status
--untracked-files
=no
--porcelain
-z
)),)
129 @echo
"working directory unclean, aborting!"
135 git commit
-s
-m
"update ABI file for ${KVNAME}" -m
"(generated with debian/scripts/abi-generate)"
136 @echo
"update abi-prev-${KVNAME} committed!"
140 @
test -e
${HDR_DEB} ||
(echo
"need ${HDR_DEB} to extract ABI data!" && false
)
141 debian
/scripts
/abi-generate
${HDR_DEB} $@
${KVNAME} 1
145 rm -rf
*~ build
*.prepared
${KERNEL_CFG_ORG}
146 rm -f
*.deb
*.changes
*.buildinfo