]> git.proxmox.com Git - pve-kernel.git/blob - debian/rules
fix #2814: config: disable lockdown
[pve-kernel.git] / debian / rules
1 #!/usr/bin/make -f
2 # -*- makefile -*-
3
4 # Uncomment this to turn on verbose mode.
5 #export DH_VERBOSE=1
6
7 # TODO: check for headers not being installed
8 BUILD_DIR=$(shell pwd)
9
10 include /usr/share/dpkg/default.mk
11 include debian/rules.d/env.mk
12 include debian/rules.d/${DEB_BUILD_ARCH}.mk
13
14 CHANGELOG_DATE:=$(shell dpkg-parsechangelog -SDate)
15
16 PVE_KERNEL_PKG=pve-kernel-${KVNAME}
17 PVE_HEADER_PKG=pve-headers-${KVNAME}
18 PVE_USR_HEADER_PKG=pve-kernel-libc-dev
19 LINUX_TOOLS_PKG=linux-tools-${KERNEL_MAJMIN}
20 KERNEL_SRC_COPY=${KERNEL_SRC}_tmp
21
22 # TODO: split for archs, move to files?
23 PVE_CONFIG_OPTS= \
24 -m INTEL_MEI_WDT \
25 -d CONFIG_SND_PCM_OSS \
26 -e CONFIG_TRANSPARENT_HUGEPAGE_MADVISE \
27 -d CONFIG_TRANSPARENT_HUGEPAGE_ALWAYS \
28 -m CONFIG_CEPH_FS \
29 -m CONFIG_BLK_DEV_NBD \
30 -m CONFIG_BLK_DEV_RBD \
31 -d CONFIG_SND_PCSP \
32 -m CONFIG_BCACHE \
33 -m CONFIG_JFS_FS \
34 -m CONFIG_HFS_FS \
35 -m CONFIG_HFSPLUS_FS \
36 -e CIFS_SMB_DIRECT \
37 -e CONFIG_BRIDGE \
38 -e CONFIG_BRIDGE_NETFILTER \
39 -e CONFIG_BLK_DEV_SD \
40 -e CONFIG_BLK_DEV_SR \
41 -e CONFIG_BLK_DEV_DM \
42 -e CONFIG_BLK_DEV_NVME \
43 -e CONFIG_NLS_ISO8859_1 \
44 -d CONFIG_INPUT_EVBUG \
45 -d CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND \
46 -e CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE \
47 -d CONFIG_MODULE_SIG \
48 -d CONFIG_MEMCG_DISABLED \
49 -e CONFIG_MEMCG_SWAP_ENABLED \
50 -e CONFIG_HYPERV \
51 -m CONFIG_VFIO_IOMMU_TYPE1 \
52 -m CONFIG_VFIO_VIRQFD \
53 -m CONFIG_VFIO \
54 -m CONFIG_VFIO_PCI \
55 -m CONFIG_USB_XHCI_HCD \
56 -m CONFIG_USB_XHCI_PCI \
57 -m CONFIG_USB_EHCI_HCD \
58 -m CONFIG_USB_EHCI_PCI \
59 -m CONFIG_USB_EHCI_HCD_PLATFORM \
60 -m CONFIG_USB_OHCI_HCD \
61 -m CONFIG_USB_OHCI_HCD_PCI \
62 -m CONFIG_USB_OHCI_HCD_PLATFORM \
63 -d CONFIG_USB_OHCI_HCD_SSB \
64 -m CONFIG_USB_UHCI_HCD \
65 -d CONFIG_USB_SL811_HCD_ISO \
66 -e CONFIG_MEMCG_KMEM \
67 -d CONFIG_DEFAULT_CFQ \
68 -e CONFIG_DEFAULT_DEADLINE \
69 -e CONFIG_MODVERSIONS \
70 -d CONFIG_DEFAULT_SECURITY_DAC \
71 -e CONFIG_DEFAULT_SECURITY_APPARMOR \
72 --set-str CONFIG_DEFAULT_SECURITY apparmor \
73 -d CONFIG_UNWINDER_ORC \
74 -d CONFIG_UNWINDER_GUESS \
75 -e CONFIG_UNWINDER_FRAME_POINTER \
76 -d CONFIG_SECURITY_LOCKDOWN_LSM \
77 -d CONFIG_SECURITY_LOCKDOWN_LSM_EARLY \
78 --set-str CONFIG_LSM yama,integrity,apparmor \
79 -e CONFIG_PAGE_TABLE_ISOLATION
80
81 debian/control: $(wildcard debian/*.in)
82 sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/pve-kernel.prerm.in > debian/${PVE_KERNEL_PKG}.prerm
83 sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/pve-kernel.postrm.in > debian/${PVE_KERNEL_PKG}.postrm
84 sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/pve-kernel.postinst.in > debian/${PVE_KERNEL_PKG}.postinst
85 sed -e 's/@@KVNAME@@/${KVNAME}/g' < debian/pve-headers.postinst.in > debian/${PVE_HEADER_PKG}.postinst
86 chmod +x debian/${PVE_KERNEL_PKG}.prerm
87 chmod +x debian/${PVE_KERNEL_PKG}.postrm
88 chmod +x debian/${PVE_KERNEL_PKG}.postinst
89 chmod +x debian/${PVE_HEADER_PKG}.postinst
90 sed -e 's/@KVNAME@/${KVNAME}/g' -e 's/@KVMAJMIN@/${KERNEL_MAJMIN}/g' < debian/control.in > debian/control
91
92 build: .compile_mark .tools_compile_mark .modules_compile_mark
93
94 install: .install_mark .tools_install_mark .headers_install_mark .usr_headers_install_mark
95 dh_installdocs -A debian/copyright debian/SOURCE
96 dh_installchangelogs
97 dh_installman
98 dh_strip_nondeterminism
99 dh_compress
100 dh_fixperms
101
102 binary: install
103 debian/rules fwcheck abicheck
104 dh_strip -N${PVE_HEADER_PKG} -N${PVE_USR_HEADER_PKG}
105 dh_makeshlibs
106 dh_shlibdeps
107 dh_installdeb
108 dh_gencontrol
109 dh_md5sums
110 dh_builddeb
111
112 .config_mark:
113 cd ${KERNEL_SRC}; scripts/config ${PVE_CONFIG_OPTS}
114 ${MAKE} -C ${KERNEL_SRC} oldconfig
115 touch $@
116
117 .compile_mark: .config_mark
118 ${MAKE} -C ${KERNEL_SRC} KBUILD_BUILD_VERSION_TIMESTAMP="PVE ${DEB_VERSION} (${CHANGELOG_DATE})"
119 touch $@
120
121 .install_mark: .compile_mark .modules_compile_mark
122 rm -rf debian/${PVE_KERNEL_PKG}
123 mkdir -p debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}
124 mkdir debian/${PVE_KERNEL_PKG}/boot
125 install -m 644 ${KERNEL_SRC}/.config debian/${PVE_KERNEL_PKG}/boot/config-${KVNAME}
126 install -m 644 ${KERNEL_SRC}/System.map debian/${PVE_KERNEL_PKG}/boot/System.map-${KVNAME}
127 install -m 644 ${KERNEL_SRC}/${KERNEL_IMAGE_PATH} debian/${PVE_KERNEL_PKG}/boot/${KERNEL_INSTALL_FILE}-${KVNAME}
128 ${MAKE} -C ${KERNEL_SRC} INSTALL_MOD_PATH=${BUILD_DIR}/debian/${PVE_KERNEL_PKG}/ modules_install
129 # install zfs drivers
130 install -d -m 0755 debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/zfs
131 install -m 644 $(addprefix ${MODULES}/,zfs.ko zavl.ko znvpair.ko zunicode.ko zcommon.ko icp.ko zlua.ko spl.ko) debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/zfs
132 # remove firmware
133 rm -rf debian/${PVE_KERNEL_PKG}/lib/firmware
134 # strip debug info
135 find debian/${PVE_KERNEL_PKG}/lib/modules -name \*.ko -print | while read f ; do strip --strip-debug "$$f"; done
136 # finalize
137 /sbin/depmod -b debian/${PVE_KERNEL_PKG}/ ${KVNAME}
138 # Autogenerate blacklist for watchdog devices (see README)
139 install -m 0755 -d debian/${PVE_KERNEL_PKG}/lib/modprobe.d
140 ls debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/kernel/drivers/watchdog/ > watchdog-blacklist.tmp
141 echo ipmi_watchdog.ko >> watchdog-blacklist.tmp
142 cat watchdog-blacklist.tmp|sed -e 's/^/blacklist /' -e 's/.ko$$//'|sort -u > debian/${PVE_KERNEL_PKG}/lib/modprobe.d/blacklist_${PVE_KERNEL_PKG}.conf
143 rm -f debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/source
144 rm -f debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME}/build
145 touch $@
146
147 .tools_compile_mark: .compile_mark
148 ${MAKE} -C ${KERNEL_SRC}/tools/perf prefix=/usr HAVE_NO_LIBBFD=1 HAVE_CPLUS_DEMANGLE_SUPPORT=1 NO_LIBPYTHON=1 NO_LIBPERL=1 NO_LIBCRYPTO=1 PYTHON=python2.7
149 echo "checking GPL-2 only perf binary for library linkage with incompatible licenses.."
150 ! ldd ${KERNEL_SRC}/tools/perf/perf | grep -q -E '\blibbfd'
151 ! ldd ${KERNEL_SRC}/tools/perf/perf | grep -q -E '\blibcrypto'
152 ${MAKE} -C ${KERNEL_SRC}/tools/perf man
153 touch $@
154
155 .tools_install_mark: .tools_compile_mark
156 rm -rf debian/${LINUX_TOOLS_PKG}
157 mkdir -p debian/${LINUX_TOOLS_PKG}/usr/bin
158 mkdir -p debian/${LINUX_TOOLS_PKG}/usr/share/man/man1
159 install -m 755 ${BUILD_DIR}/${KERNEL_SRC}/tools/perf/perf debian/${LINUX_TOOLS_PKG}/usr/bin/perf_$(KERNEL_MAJMIN)
160 for i in ${BUILD_DIR}/${KERNEL_SRC}/tools/perf/Documentation/*.1; do \
161 fname="$${i##*/}"; manname="$${fname%.1}"; \
162 install -m644 "$$i" "debian/${LINUX_TOOLS_PKG}/usr/share/man/man1/$${manname}_$(KERNEL_MAJMIN).1"; \
163 done
164 touch $@
165
166 .headers_prepare_mark: .config_mark
167 rm -rf debian/${PVE_HEADER_PKG}
168 mkdir -p debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}
169 install -m 0644 ${KERNEL_SRC}/.config debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}
170 # copy to allow building in parallel to kernel/module compilation without interference
171 rm -rf ${KERNEL_SRC_COPY}
172 cp -ar ${KERNEL_SRC} ${KERNEL_SRC_COPY}
173 make -C ${KERNEL_SRC_COPY} mrproper
174 cd ${KERNEL_SRC_COPY}; find . -path './debian/*' -prune \
175 -o -path './include/*' -prune \
176 -o -path './Documentation' -prune \
177 -o -path './scripts' -prune \
178 -o -type f \
179 \( \
180 -name 'Makefile*' \
181 -o -name 'Kconfig*' \
182 -o -name 'Kbuild*' \
183 -o -name '*.sh' \
184 -o -name '*.pl' \
185 \) \
186 -print | cpio -pd --preserve-modification-time ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}
187 cd ${KERNEL_SRC_COPY}; cp -a include scripts ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}
188 cd ${KERNEL_SRC_COPY}; \
189 ( \
190 find arch/${KERNEL_HEADER_ARCH} -name include -type d -print | \
191 xargs -n1 -i: find : -type f \
192 ) | \
193 cpio -pd --preserve-modification-time ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}
194 touch $@
195
196 .headers_compile_mark: .headers_prepare_mark
197 # set output to subdir of source to reduce number of hardcoded paths in output files
198 rm -rf ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG}
199 mkdir -p ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG}
200 cp ${KERNEL_SRC}/.config ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG}/.config
201 ${MAKE} -C ${KERNEL_SRC_COPY} O=${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG} -j1 syncconfig prepare scripts
202 find ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG} -name \*.o.ur-\* | xargs rm -f
203 rsync --ignore-existing -r -v -a $(addprefix ${BUILD_DIR}/${KERNEL_SRC_COPY}/${PVE_HEADER_PKG}/,arch include kernel scripts tools) ${BUILD_DIR}/debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}/
204 rm -rf ${BUILD_DIR}/${KERNEL_SRC_COPY}
205 touch $@
206
207 .headers_install_mark: .compile_mark .modules_compile_mark .headers_compile_mark
208 cp ${KERNEL_SRC}/include/generated/compile.h debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}/include/generated/compile.h
209 install -m 0644 ${KERNEL_SRC}/Module.symvers debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}
210 mkdir -p debian/${PVE_HEADER_PKG}/lib/modules/${KVNAME}
211 ln -sf /usr/src/linux-headers-${KVNAME} debian/${PVE_HEADER_PKG}/lib/modules/${KVNAME}/build
212 touch $@
213
214 .usr_headers_install_mark: PKG_DIR = debian/${PVE_USR_HEADER_PKG}
215 .usr_headers_install_mark: OUT_DIR = ${PKG_DIR}/usr
216 .usr_headers_install_mark: .config_mark
217 rm -rf '${PKG_DIR}'
218 mkdir -p '${PKG_DIR}'
219 $(MAKE) -C ${KERNEL_SRC} headers_check ARCH=$(KERNEL_HEADER_ARCH)
220 $(MAKE) -C ${KERNEL_SRC} headers_install ARCH=$(KERNEL_HEADER_ARCH) INSTALL_HDR_PATH='$(CURDIR)'/$(OUT_DIR)
221 rm -rf $(OUT_DIR)/include/drm $(OUT_DIR)/include/scsi
222 find $(OUT_DIR)/include \( -name .install -o -name ..install.cmd \) -execdir rm {} +
223
224 # Move include/asm to arch-specific directory
225 mkdir -p $(OUT_DIR)/include/$(DEB_HOST_MULTIARCH)
226 mv $(OUT_DIR)/include/asm $(OUT_DIR)/include/$(DEB_HOST_MULTIARCH)/
227 test ! -d $(OUT_DIR)/include/arch || \
228 mv $(OUT_DIR)/include/arch $(OUT_DIR)/include/$(DEB_HOST_MULTIARCH)/
229 touch $@
230
231 .modules_compile_mark: ${MODULES}/zfs.ko
232 touch $@
233
234 ${MODULES}/zfs.ko: .compile_mark
235 cd ${MODULES}/${ZFSDIR}; ./autogen.sh
236 cd ${MODULES}/${ZFSDIR}; ./configure --with-config=kernel --with-linux=${BUILD_DIR}/${KERNEL_SRC} --with-linux-obj=${BUILD_DIR}/${KERNEL_SRC}
237 ${MAKE} -C ${MODULES}/${ZFSDIR}
238 cp ${MODULES}/${ZFSDIR}/module/avl/zavl.ko ${MODULES}/
239 cp ${MODULES}/${ZFSDIR}/module/nvpair/znvpair.ko ${MODULES}/
240 cp ${MODULES}/${ZFSDIR}/module/unicode/zunicode.ko ${MODULES}/
241 cp ${MODULES}/${ZFSDIR}/module/zcommon/zcommon.ko ${MODULES}/
242 cp ${MODULES}/${ZFSDIR}/module/icp/icp.ko ${MODULES}/
243 cp ${MODULES}/${ZFSDIR}/module/zfs/zfs.ko ${MODULES}/
244 cp ${MODULES}/${ZFSDIR}/module/lua/zlua.ko ${MODULES}/
245 cp ${MODULES}/${ZFSDIR}/module/spl/spl.ko ${MODULES}/
246
247 fwlist-${KVNAME}: .compile_mark .modules_compile_mark
248 debian/scripts/find-firmware.pl debian/${PVE_KERNEL_PKG}/lib/modules/${KVNAME} >fwlist.tmp
249 mv fwlist.tmp $@
250
251 .PHONY: fwcheck
252 fwcheck: fwlist-${KVNAME} fwlist-previous
253 @echo "checking fwlist for changes since last built firmware package.."
254 @echo "if this check fails, add fwlist-${KVNAME} to the pve-firmware repository and upload a new firmware package together with the ${KVNAME} kernel"
255 sort fwlist-previous | uniq > fwlist-previous.sorted
256 sort fwlist-${KVNAME} | uniq > fwlist-${KVNAME}.sorted
257 diff -up -N fwlist-previous.sorted fwlist-${KVNAME}.sorted > fwlist.diff
258 rm fwlist.diff fwlist-previous.sorted fwlist-${KVNAME}.sorted
259 @echo "done, no need to rebuild pve-firmware"
260
261
262 abi-${KVNAME}: .compile_mark
263 debian/scripts/abi-generate debian/${PVE_HEADER_PKG}/usr/src/linux-headers-${KVNAME}/Module.symvers abi-${KVNAME} ${KVNAME}
264
265 .PHONY: abicheck
266 abicheck: debian/scripts/abi-check abi-${KVNAME} abi-prev-* abi-blacklist
267 debian/scripts/abi-check abi-${KVNAME} abi-prev-* ${SKIPABI}
268
269 .PHONY: clean