]> git.proxmox.com Git - pve-kernel.git/blame - Makefile
backport protection against userspace-userspace spectreRSB
[pve-kernel.git] / Makefile
CommitLineData
3572537f 1RELEASE=5.1
ba2f1a67 2
75b315d4 3# also bump pve-kernel-meta if either of MAJ.MIN, PATCHLEVEL or KREL change
5fd5ec0e
SI
4KERNEL_MAJ=4
5KERNEL_MIN=15
75af7c34 6KERNEL_PATCHLEVEL=18
8b4e1fa9
SI
7# increment KREL if the ABI changes (abicheck target in debian/rules)
8# rebuild packages with new KREL and run 'make abiupdate'
2b76f08c 9KREL=3
ba2f1a67 10
2b76f08c 11PKGREL=22
44403fcc 12
5fd5ec0e
SI
13KERNEL_MAJMIN=$(KERNEL_MAJ).$(KERNEL_MIN)
14KERNEL_VER=$(KERNEL_MAJMIN).$(KERNEL_PATCHLEVEL)
15
66aed5b8 16EXTRAVERSION=-${KREL}-pve
ba2f1a67
FG
17KVNAME=${KERNEL_VER}${EXTRAVERSION}
18PACKAGE=pve-kernel-${KVNAME}
19HDRPACKAGE=pve-headers-${KVNAME}
20
37d1225d 21ARCH=$(shell dpkg-architecture -qDEB_BUILD_ARCH)
6490543b
TL
22
23# amd64/x86_64/x86 share the arch subdirectory in the kernel, 'x86' so we need
24# a mapping
25KERNEL_ARCH=x86
26ifneq (${ARCH}, amd64)
27KERNEL_ARCH=${ARCH}
28endif
29
97d6ca37 30GITVERSION:=$(shell git rev-parse HEAD)
ba2f1a67 31
41f5ee98
FG
32SKIPABI=0
33
7f4d14b0
FG
34ifeq ($(CC), cc)
35GCC=gcc
36else
37GCC=$(CC)
38endif
39
66aed5b8 40BUILD_DIR=build
ba2f1a67 41
1e99f45b 42KERNEL_SRC=ubuntu-bionic
5fd5ec0e 43KERNEL_SRC_SUBMODULE=submodules/$(KERNEL_SRC)
ba2f1a67
FG
44KERNEL_CFG_ORG=config-${KERNEL_VER}.org
45
f6149693 46E1000EDIR=e1000e-3.4.1.1
97229657
TL
47E1000ESRC=${E1000EDIR}.tar.gz
48
f6149693 49IGBDIR=igb-5.3.5.18
97229657
TL
50IGBSRC=${IGBDIR}.tar.gz
51
2e38f6f9 52ZFSONLINUX_SUBMODULE=submodules/zfsonlinux
66aed5b8 53SPLDIR=pkg-spl
2e38f6f9 54SPLSRC=${ZFSONLINUX_SUBMODULE}/spl-debian
66aed5b8 55ZFSDIR=pkg-zfs
2e38f6f9 56ZFSSRC=${ZFSONLINUX_SUBMODULE}/zfs-debian
e96d2ab3 57
66aed5b8 58MODULES=modules
b5e86998 59MODULE_DIRS=${E1000EDIR} ${IGBDIR} ${SPLDIR} ${ZFSDIR}
ba2f1a67 60
66aed5b8 61# exported to debian/rules via debian/rules.d/dirs.mk
b5e86998 62DIRS=KERNEL_SRC E1000EDIR IGBDIR SPLDIR ZFSDIR MODULES
66aed5b8 63
ba2f1a67
FG
64DST_DEB=${PACKAGE}_${KERNEL_VER}-${PKGREL}_${ARCH}.deb
65HDR_DEB=${HDRPACKAGE}_${KERNEL_VER}-${PKGREL}_${ARCH}.deb
5fd5ec0e 66LINUX_TOOLS_DEB=linux-tools-$(KERNEL_MAJMIN)_${KERNEL_VER}-${PKGREL}_${ARCH}.deb
ba2f1a67 67
e96d2ab3 68DEBS=${DST_DEB} ${HDR_DEB} ${LINUX_TOOLS_DEB}
ba2f1a67 69
bdfc6d28
FG
70all: check_gcc deb
71deb: ${DEBS}
ba2f1a67 72
7f4d14b0
FG
73check_gcc:
74 $(GCC) --version|grep "6\.3" || false
75 @$(GCC) -Werror -mindirect-branch=thunk-extern -mindirect-branch-register -c -x c /dev/null -o check_gcc.o \
76 || ( rm -f check_gcc.o; \
77 echo "Please install gcc-6 packages with indirect thunk / RETPOLINE support"; \
78 false)
79 @rm -f check_gcc.o
ba2f1a67 80
e96d2ab3
FG
81${LINUX_TOOLS_DEB} ${HDR_DEB}: ${DST_DEB}
82${DST_DEB}: ${BUILD_DIR}.prepared
e96d2ab3 83 cd ${BUILD_DIR}; dpkg-buildpackage --jobs=auto -b -uc -us
ba2f1a67 84 lintian ${DST_DEB}
e96d2ab3 85 #lintian ${HDR_DEB}
ba2f1a67
FG
86 lintian ${LINUX_TOOLS_DEB}
87
66aed5b8 88${BUILD_DIR}.prepared: $(addsuffix .prepared,${KERNEL_SRC} ${MODULES} debian)
e96d2ab3 89 cp -a fwlist-previous ${BUILD_DIR}/
faa3d751 90 cp -a abi-prev-* ${BUILD_DIR}/
e96d2ab3 91 cp -a abi-blacklist ${BUILD_DIR}/
66aed5b8
FG
92 touch $@
93
94debian.prepared: debian
95 rm -rf ${BUILD_DIR}/debian
96 mkdir -p ${BUILD_DIR}
97 cp -a debian ${BUILD_DIR}/debian
e96d2ab3 98 echo "git clone git://git.proxmox.com/git/pve-kernel.git\\ngit checkout ${GITVERSION}" > ${BUILD_DIR}/debian/SOURCE
66aed5b8
FG
99 @$(foreach dir, ${DIRS},echo "${dir}=${${dir}}" >> ${BUILD_DIR}/debian/rules.d/env.mk;)
100 echo "KVNAME=${KVNAME}" >> ${BUILD_DIR}/debian/rules.d/env.mk
5fd5ec0e 101 echo "KERNEL_MAJMIN=${KERNEL_MAJMIN}" >> ${BUILD_DIR}/debian/rules.d/env.mk
66aed5b8 102 cd ${BUILD_DIR}; debian/rules debian/control
ba2f1a67
FG
103 touch $@
104
e96d2ab3
FG
105${KERNEL_SRC}.prepared: ${KERNEL_SRC_SUBMODULE} | submodule
106 rm -rf ${BUILD_DIR}/${KERNEL_SRC} $@
107 mkdir -p ${BUILD_DIR}
12aaf1a2 108 cp -a ${KERNEL_SRC_SUBMODULE} ${BUILD_DIR}/${KERNEL_SRC}
e96d2ab3
FG
109# TODO: split for archs, track and diff in our repository?
110 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}
111 cp ${KERNEL_CFG_ORG} ${BUILD_DIR}/${KERNEL_SRC}/.config
112 sed -i ${BUILD_DIR}/${KERNEL_SRC}/Makefile -e 's/^EXTRAVERSION.*$$/EXTRAVERSION=${EXTRAVERSION}/'
113 rm -rf ${BUILD_DIR}/${KERNEL_SRC}/debian ${BUILD_DIR}/${KERNEL_SRC}/debian.master
5d6c3ffa 114 cd ${BUILD_DIR}/${KERNEL_SRC}; for patch in ../../patches/kernel/*.patch; do echo "applying patch '$$patch'" && patch -p1 < $${patch}; done
ba2f1a67
FG
115 touch $@
116
e96d2ab3
FG
117${MODULES}.prepared: $(addsuffix .prepared,${MODULE_DIRS})
118 touch $@
119
120${E1000EDIR}.prepared: ${E1000ESRC}
121 rm -rf ${BUILD_DIR}/${MODULES}/${E1000EDIR} $@
122 mkdir -p ${BUILD_DIR}/${MODULES}/${E1000EDIR}
123 tar --strip-components=1 -C ${BUILD_DIR}/${MODULES}/${E1000EDIR} -xf ${E1000ESRC}
124 cd ${BUILD_DIR}/${MODULES}/${E1000EDIR}; patch -p1 < ../../../patches/intel/intel-module-gcc6-compat.patch
125 cd ${BUILD_DIR}/${MODULES}/${E1000EDIR}; patch -p1 < ../../../patches/intel/e1000e/e1000e_4.10_max-mtu.patch
51597363 126 cd ${BUILD_DIR}/${MODULES}/${E1000EDIR}; patch -p1 < ../../../patches/intel/e1000e/e1000e_4.15-new-timer.patch
e96d2ab3
FG
127 touch $@
128
129${IGBDIR}.prepared: ${IGBSRC}
130 rm -rf ${BUILD_DIR}/${MODULES}/${IGBDIR} $@
131 mkdir -p ${BUILD_DIR}/${MODULES}/${IGBDIR}
132 tar --strip-components=1 -C ${BUILD_DIR}/${MODULES}/${IGBDIR} -xf ${IGBSRC}
e8834e95 133 cd ${BUILD_DIR}/${MODULES}/${IGBDIR}; patch -p1 < ../../../patches/intel/igb/igb_4.15_mtu.patch
e96d2ab3
FG
134 touch $@
135
e96d2ab3
FG
136$(SPLDIR).prepared: ${SPLSRC}
137 rm -rf ${BUILD_DIR}/${MODULES}/${SPLDIR} $@
138 mkdir -p ${BUILD_DIR}/${MODULES}/${SPLDIR}
139 cp -a ${SPLSRC}/* ${BUILD_DIR}/${MODULES}/${SPLDIR}
140 cd ${BUILD_DIR}/${MODULES}/${SPLDIR}; for patch in ../../../${SPLSRC}/../spl-patches/*.patch; do patch -p1 < $${patch}; done
141 touch $@
142
143$(ZFSDIR).prepared: ${ZFSSRC}
144 rm -rf ${BUILD_DIR}/${MODULES}/${ZFSDIR} $@
145 mkdir -p ${BUILD_DIR}/${MODULES}/${ZFSDIR}
146 cp -a ${ZFSSRC}/* ${BUILD_DIR}/${MODULES}/${ZFSDIR}
147 cd ${BUILD_DIR}/${MODULES}/${ZFSDIR}; for patch in ../../../${ZFSSRC}/../zfs-patches/*.patch; do patch -p1 < $${patch}; done
aac51341
FG
148 # temporarily since patch does not know about permissions, remove after 0.7.7 was merged properly
149 chmod +x ${BUILD_DIR}/${MODULES}/${ZFSDIR}/scripts/enum-extract.pl
e96d2ab3 150 touch $@
ba2f1a67 151
ba2f1a67
FG
152.PHONY: upload
153upload: ${DEBS}
beb9b869 154 tar cf - ${DEBS}|ssh -X repoman@repo.proxmox.com -- upload --product pve,pmg --dist stretch --arch ${ARCH}
ba2f1a67
FG
155
156.PHONY: distclean
157distclean: clean
e96d2ab3 158 git submodule deinit --all
ba2f1a67 159
32054ef4
FG
160# upgrade to current master
161.PHONY: update_modules
a6dd515e 162update_modules: submodule
32054ef4 163 git submodule foreach 'git pull --ff-only origin master'
2e38f6f9
FG
164 cd ${ZFSSRC}; git pull --ff-only origin master
165 cd ${SPLSRC}; git pull --ff-only origin master
32054ef4
FG
166
167# make sure submodules were initialized
a6dd515e
FG
168.PHONY: submodule
169submodule:
2e38f6f9
FG
170 test -f "${KERNEL_SRC_SUBMODULE}/README" || git submodule update --init ${KERNEL_SRC_SUBMODULE}
171 test -f "${ZFSONLINUX_SUBMODULE}/Makefile" || git submodule update --init ${ZFSONLINUX_SUBMODULE}
172 (test -f "${ZFSSRC}/debian/changelog" && test -f "${SPLZRC}/debian/changelog") || (cd ${ZFSONLINUX_SUBMODULE}; git submodule update --init)
32054ef4 173
b4ecde23
FG
174# call after ABI bump with header deb in working directory
175.PHONY: abiupdate
176abiupdate: abi-prev-${KVNAME}
177abi-prev-${KVNAME}: abi-tmp-${KVNAME}
178ifneq ($(strip $(shell git status --untracked-files=no --porcelain -z)),)
179 @echo "working directory unclean, aborting!"
180 @false
181else
182 git rm "abi-prev-*"
183 mv $< $@
184 git add $@
185 git commit -s -m "update ABI file for ${KVNAME}" -m "(generated with debian/scripts/abi-generate)"
186 @echo "update abi-prev-${KVNAME} committed!"
187endif
188
189abi-tmp-${KVNAME}:
190 @ test -e ${HDR_DEB} || (echo "need ${HDR_DEB} to extract ABI data!" && false)
191 debian/scripts/abi-generate ${HDR_DEB} $@ ${KVNAME} 1
32054ef4 192
ba2f1a67
FG
193.PHONY: clean
194clean:
e96d2ab3 195 rm -rf *~ build *.prepared ${KERNEL_CFG_ORG}
9952c40c 196 rm -f *.deb *.changes *.buildinfo