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