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