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