3 # Copyright (C) 2016-2018 - Michael Jeanson <mjeanson@efficios.com>
5 # This program is free software: you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation, either version 3 of the License, or
8 # (at your option) any later version.
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with this program. If not, see <http://www.gnu.org/licenses/>.
20 cross_arch
=${cross_arch:-}
22 kgitrepo
=${kgitrepo:-}
23 mversion
=${mversion:-}
24 mgitrepo
=${mgitrepo:-}
29 # Kernel version compare functions
31 [ "$1" = "$(printf '%s\n%s' "$1" "$2" | sort -V | head -n1)" ]
35 [ "$1" = "$2" ] && return 1 || verlte
"$1" "$2"
39 [ "$1" = "$(printf '%s\n%s' "$1" "$2" | sort -V | tail -n1)" ]
43 [ "$1" = "$2" ] && return 1 || vergte
"$1" "$2"
47 git_clone_modules_sources
() {
48 mkdir
-p "$MODULES_GIT_DIR"
49 git clone
--depth=1 -b "${mversion}" "${mgitrepo}" "$MODULES_GIT_DIR"
52 # Checkout a shallow kernel tree of the specified tag
53 git_clone_linux_sources
() {
54 mkdir
-p "$LINUX_GIT_DIR"
55 git clone
--depth=1 -b "${ktag}" --reference "$LINUX_GIT_REF_REPO_DIR" "${kgitrepo}" "$LINUX_GIT_DIR"
59 # Export the kernel sources from the git repo
60 git_export_linux_sources
() {
62 git archive
"${ktag}" |
tar -x -C "$LINUX_SRCOBJ_DIR"
66 # Upload the tar archive to the object store
67 upload_archive_obj
() {
68 s3cmd
-c "$WORKSPACE/.s3cfg" put
"$WORKSPACE/$obj_name" "$obj_url_prefix/"
69 rm -f "$WORKSPACE/$obj_name"
73 extract_archive_obj
() {
74 tar -xf "$WORKSPACE/$obj_name" -C "$LINUX_OBJ_DIR"
75 rm -f "$WORKSPACE/$obj_name"
81 tar -cf "$WORKSPACE/$obj_name" -I pbzip2 .
85 # Find the most recent GCC version supported by the kernel sources
89 cd "$LINUX_SRCOBJ_DIR"
91 kversion
=$
(make -s kernelversion
)
95 for cc
in gcc-7 gcc-5 gcc-4.8
; do
96 if "${CROSS_COMPILE:-}${cc}" -I include
/ -D__LINUX_COMPILER_H -D__LINUX_COMPILER_TYPES_H -E include
/linux
/compiler-gcc.h
; then
104 if [ "x$selected_cc" = "x" ]; then
105 echo "Found no suitable compiler."
109 # Force gcc-4 for buggy kernel branches
110 if { vergte
"$kversion" "3.2" && verlt
"$kversion" "3.3"; } || \
111 { vergte
"$kversion" "3.4" && verlt
"$kversion" "3.5"; } || \
112 { vergte
"$kversion" "3.17" && verlt
"$kversion" "3.18"; }; then
118 if { vergte
"$kversion" "3.13" && verlt
"$kversion" "3.14"; }; then
124 if [ "$selected_cc" != "gcc-4.8" ]; then
125 # Older kernel Makefiles do not expect the compiler to default to PIE
127 KCFLAGS
="-fno-pie -no-pie"
129 export KAFLAGS KCFLAGS KCPPFLAGS
132 export CC
="${CROSS_COMPILE:-}${selected_cc}"
138 build_linux_kernel
() {
139 cd "$LINUX_SRCOBJ_DIR"
141 kversion
=$
(make -s kernelversion
)
143 # Generate kernel configuration
146 if [ "${cross_arch}" = "powerpc" ]; then
147 if vergte
"${kversion}" "4.10"; then
148 echo "Ubuntu removed big endian powerpc configuration from kernel >= 4.10. Don't try to build it."
152 fakeroot debian
/rules clean
153 fakeroot debian
/rules genconfigs
154 cp CONFIGS
/"${ubuntu_config}" .config
157 # Force 32bit build on i386, default is 64bit
158 if [ "$arch" = "i386" ]; then
162 # allyesconfig is mostly broken for kernels of the 2.6 series
163 if verlt
"$kversion" "3.0"; then
164 vanilla_config
="defconfig"
167 make "${vanilla_config}"
171 # silentoldconfig was renamed in 4.19
172 if vergte
"$kversion" "4.19"; then
173 update_conf_target
="syncconfig"
175 update_conf_target
="silentoldconfig"
178 # Fix 'defined(@array)' was removed from recent perl
179 if [ -f "kernel/timeconst.pl" ]; then
180 sed -i 's/defined(\@\(.*\))/@\1/' kernel
/timeconst.pl
183 # Fix syntax of inline assembly which is confused with C++11 raw strings on gcc >= 5
184 if [ "$CC" != "gcc-4.8" ]; then
185 if [ -f "arch/x86/kvm/svm.c" ]; then
186 sed -i 's/ R"/ R "/g; s/"R"/" R "/g' arch
/x86
/kvm
/svm.c
189 if [ -f "arch/x86/kvm/vmx.c" ]; then
190 sed -i 's/ R"/ R "/g; s/"R"/" R "/g' arch
/x86
/kvm
/vmx.c
194 # Fix a typo in v2.6.36.x
195 if [ -f "arch/x86/kernel/entry_64.S" ]; then
196 sed -i 's/END(do_hypervisor_callback)/END(xen_do_hypervisor_callback)/' arch
/x86
/kernel
/entry_64.S
199 # Fix kernel < 3.0 with gcc >= 4.7
200 if verlt
"$kversion" "3.0"; then
201 sed -i '/linux\/compiler.h/a #include <linux\/linkage.h> \/* For asmregparm *\/' arch
/x86
/include
/asm
/ptrace.h
202 sed -i 's/extern long syscall_trace_enter/extern asmregparm long syscall_trace_enter/' arch
/x86
/include
/asm
/ptrace.h
203 sed -i 's/extern void syscall_trace_leave/extern asmregparm void syscall_trace_leave/' arch
/x86
/include
/asm
/ptrace.h
204 echo "header-y += linkage.h" >> include
/linux
/Kbuild
208 sed -i "s/CONFIG_CC_STACKPROTECTOR_STRONG=y/# CONFIG_CC_STACKPROTECTOR_STRONG is not set/g" .config
210 # Don't try to sign modules
211 sed -i "s/CONFIG_MODULE_SIG=y/# CONFIG_MODULE_SIG is not set/g" .config
213 # Disable kernel stack frame correctness validation, introduced in 4.6.0 and currently fails
214 sed -i "s/CONFIG_STACK_VALIDATION=y/# CONFIG_STACK_VALIDATION is not set/g" .config
216 # Cause problems with inline assembly on i386
217 sed -i "s/CONFIG_DEBUG_SECTION_MISMATCH=y/# CONFIG_DEBUG_SECTION_MISMATCH is not set/g" .config
219 # IGBVF won't build with recent gcc on 2.6.38.x
220 if { vergte
"$kversion" "2.6.37" && verlt
"$kversion" "2.6.38"; }; then
221 sed -i "s/CONFIG_IGBVF=y/# CONFIG_IGBVF is not set/g" .config
224 # Set required options
226 echo "CONFIG_KPROBES=y";
227 echo "CONFIG_FTRACE=y";
228 echo "CONFIG_BLK_DEV_IO_TRACE=y";
229 echo "CONFIG_TRACEPOINTS=y";
230 echo "CONFIG_KALLSYMS_ALL=y";
236 make "$update_conf_target" CC
="$CC"
237 make -j"$NPROC" CC
="$CC"
239 krelease
=$
(make -s kernelrelease
)
241 # Save the kernel and modules
242 mkdir
-p "$LINUX_INSTOBJ_DIR/boot"
243 make INSTALL_MOD_PATH
="$LINUX_INSTOBJ_DIR" INSTALL_MOD_STRIP
=1 modules_install
244 make INSTALL_PATH
="$LINUX_INSTOBJ_DIR/boot" install
245 rm -f "$LINUX_INSTOBJ_DIR/lib/modules/${krelease}/source" "$LINUX_INSTOBJ_DIR/lib/modules/${krelease}/build"
246 ln -s ..
/..
/..
/..
/sources
"$LINUX_INSTOBJ_DIR/lib/modules/${krelease}/source"
247 ln -s ..
/..
/..
/..
/sources
"$LINUX_INSTOBJ_DIR/lib/modules/${krelease}/source"
251 extract_distro_headers
() {
253 # Enter linux source dir
254 cd "${LINUX_SRCOBJ_DIR}"
257 # For RT kernels, copy version file
258 if [ -s localversion-rt
]; then
259 cp -a localversion-rt
"${LINUX_HDROBJ_DIR}"
262 # Copy all Makefile related stuff
263 find .
-path './include/*' -prune \
264 -o -path './scripts/*' -prune -o -type f \
265 \
( -name 'Makefile*' -o -name 'Kconfig*' -o -name 'Kbuild*' -o \
266 -name '*.sh' -o -name '*.pl' -o -name '*.lds' \
) \
267 -print |
cpio -pd --preserve-modification-time "${LINUX_HDROBJ_DIR}"
269 # Copy base scripts and include dirs
270 cp -a scripts include
"${LINUX_HDROBJ_DIR}"
273 (find arch
-name include
-type d
-print0 | \
274 xargs -0 -n1 -i: find : -type f
) | \
275 cpio -pd --preserve-modification-time "${LINUX_HDROBJ_DIR}"
278 (find arch
-name scripts
-type d
-print0 | \
279 xargs -0 -n1 -i: find : -type f
) | \
280 cpio -pd --preserve-modification-time "${LINUX_HDROBJ_DIR}"
283 rm -f "${LINUX_HDROBJ_DIR}/scripts/*.o"
284 rm -f "${LINUX_HDROBJ_DIR}/scripts/*/*.o"
286 # On powerpc this object is required to link modules
287 if [ "${karch}" = "powerpc" ]; then
288 cp -a --parents arch
/powerpc
/lib
/crtsavres.
[So
] "${LINUX_HDROBJ_DIR}/"
291 # On arm64 between 4.13 and 1.15 this object is required to build with ftrace support
292 if [ "${karch}" = "arm64" ]; then
293 if [ -f "arch/arm64/kernel/ftrace-mod.S" ]; then
294 cp -a --parents arch
/arm64
/kernel
/ftrace-mod.
[So
] "${LINUX_HDROBJ_DIR}/"
298 # Newer kernels need objtool to build modules when CONFIG_STACK_VALIDATION=y
299 if [ -f tools
/objtool
/objtool
]; then
300 cp -a --parents tools
/objtool
/objtool
"${LINUX_HDROBJ_DIR}/"
303 if [ -f "arch/x86/kernel/macros.s" ]; then
304 cp -a --parents arch
/x86
/kernel
/macros.s
"${LINUX_HDROBJ_DIR}/"
307 # Copy modules related stuff, if available
308 if [ -s Module.symvers
]; then
309 cp Module.symvers
"${LINUX_HDROBJ_DIR}"
312 if [ -s System.map
]; then
313 cp System.map
"${LINUX_HDROBJ_DIR}"
316 if [ -s Module.markers
]; then
317 cp Module.markers
"${LINUX_HDROBJ_DIR}"
321 cp .config
"${LINUX_HDROBJ_DIR}"
323 # Make sure the Makefile and version.h have a matching timestamp so that
324 # external modules can be built
325 if [ -s "${LINUX_HDROBJ_DIR}/include/generated/uapi/linux/version.h" ]; then
326 touch -r "${LINUX_HDROBJ_DIR}/Makefile" "${LINUX_HDROBJ_DIR}/include/generated/uapi/linux/version.h"
327 elif [ -s "${LINUX_HDROBJ_DIR}/include/linux/version.h" ]; then
328 touch -r "${LINUX_HDROBJ_DIR}/Makefile" "${LINUX_HDROBJ_DIR}/include/linux/version.h"
330 echo "Missing version.h"
333 touch -r "${LINUX_HDROBJ_DIR}/.config" "${LINUX_HDROBJ_DIR}/include/generated/autoconf.h"
335 # Copy .config to include/config/auto.conf so "make prepare" is unnecessary.
336 cp "${LINUX_HDROBJ_DIR}/.config" "${LINUX_HDROBJ_DIR}/include/config/auto.conf"
338 # Finally clean the object files from the full source tree
341 # And regen the modules support files
342 make modules_prepare CC
="$CC"
344 # On powerpc this object is required to link modules
345 if [ "${karch}" = "powerpc" ]; then
346 make arch
/powerpc
/lib
/crtsavres.o CC
="$CC"
349 # On arm64 between 4.13 and 4.15 this object is required to build with ftrace support
350 if [ "${karch}" = "arm64" ]; then
351 if [ -f "arch/arm64/kernel/ftrace-mod.S" ]; then
352 make arch
/arm64
/kernel
/ftrace-mod.o CC
="$CC"
356 # Version specific tasks
359 # Add Ubuntu ABI number to kernel headers, this is normally done by the packaging code
360 ABINUM
="$(echo "$ktag" | grep -P -o 'Ubuntu-(lts-)?.*-\K\d+(?=\..*)')"
361 echo "#define UTS_UBUNTU_RELEASE_ABI $ABINUM" >> include
/generated
/utsrelease.h
362 echo "#define UTS_UBUNTU_RELEASE_ABI $ABINUM" >> "${LINUX_HDROBJ_DIR}/include/generated/utsrelease.h"
374 kversion
=$
(make -C "$LINUX_HDROBJ_DIR" -s kernelversion
)
376 # Enter lttng-modules source dir
377 cd "${MODULES_GIT_DIR}"
379 # kernels 3.10 to 3.10.13 and 3.11 to 3.11.2 introduce a deadlock in the
380 # timekeeping subsystem. We want those build to fail.
381 if { vergte
"$kversion" "3.10" && verlte
"$kversion" "3.10.13"; } || \
382 { vergte
"$kversion" "3.11" && verlte
"$kversion" "3.11.2"; }; then
387 KERNELDIR
="${kdir}" make -j"${NPROC}" V
=1 CC
="$CC"
391 # We expect this build to fail, if it doesn't, fail the job.
392 if [ "$?" -eq 0 ]; then
393 echo "This build should have failed."
397 # We have to publish at least one file or the build will fail
398 echo "This kernel is broken, there is a deadlock in the timekeeping subsystem." > "${outdir}/BROKEN.txt.ko"
402 KERNELDIR
="${kdir}" make clean
406 # Build modules against full kernel sources
407 KERNELDIR
="${kdir}" make -j"${NPROC}" V
=1 CC
="$CC"
409 # Install modules to build dir
410 KERNELDIR
="${kdir}" make INSTALL_MOD_PATH
="${outdir}" modules_install
413 KERNELDIR
="${kdir}" make clean
423 MODULES_GIT_DIR
="${WORKSPACE}/src/lttng-modules"
424 LINUX_GIT_DIR
="${WORKSPACE}/src/linux"
426 LINUX_OBJ_DIR
="${WORKSPACE}/linux"
427 LINUX_SRCOBJ_DIR
="${LINUX_OBJ_DIR}/sources"
428 LINUX_HDROBJ_DIR
="${LINUX_OBJ_DIR}/headers"
429 LINUX_INSTOBJ_DIR
="${LINUX_OBJ_DIR}/install"
431 MODULES_OUTPUT_KSRC_DIR
="${WORKSPACE}/build/lttng-modules-ksrc"
432 MODULES_OUTPUT_KHDR_DIR
="${WORKSPACE}/build/lttng-modules-khdr"
434 LINUX_GIT_REF_REPO_DIR
="$HOME/gitcache/linux-stable.git/"
436 OBJ_STORE_URL
="s3://jenkins"
440 # Create build directories
441 mkdir
-p "${LINUX_SRCOBJ_DIR}" "${LINUX_HDROBJ_DIR}" "${LINUX_INSTOBJ_DIR}" "${MODULES_OUTPUT_KSRC_DIR}" "${MODULES_OUTPUT_KHDR_DIR}"
443 git_clone_modules_sources
445 # Setup cross compile env if available
446 if [ "x${cross_arch}" != "x" ]; then
448 case "$cross_arch" in
451 cross_compile
="arm-linux-gnueabihf-"
452 vanilla_config
="allyesconfig"
453 ubuntu_config
="armhf-config.flavour.generic"
458 cross_compile
="aarch64-linux-gnu-"
459 vanilla_config
="allyesconfig"
460 ubuntu_config
="arm64-config.flavour.generic"
465 cross_compile
="powerpc-linux-gnu-"
466 vanilla_config
="ppc44x_defconfig"
467 ubuntu_config
="powerpc-config.flavour.powerpc-smp"
472 cross_compile
="powerpc64le-linux-gnu-"
473 vanilla_config
="pseries_le_defconfig"
474 ubuntu_config
="ppc64el-config.flavour.generic"
478 echo "Unsupported cross arch $cross_arch"
483 # Export variables used by Kbuild for cross compilation
484 export ARCH
="${karch}"
485 export CROSS_COMPILE
="${cross_compile}"
487 # Set arch specific values if we are not cross compiling
488 elif [ "x${arch}" != "x" ]; then
493 vanilla_config
="allyesconfig"
494 ubuntu_config
="i386-config.flavour.generic"
499 vanilla_config
="allyesconfig"
500 ubuntu_config
="amd64-config.flavour.generic"
505 vanilla_config
="allyesconfig"
506 ubuntu_config
="armhf-config.flavour.generic"
511 vanilla_config
="allyesconfig"
512 ubuntu_config
="arm64-config.flavour.generic"
517 vanilla_config
="allyesconfig"
518 ubuntu_config
="powerpc-config.flavour.powerpc-smp"
523 vanilla_config
="allyesconfig"
524 ubuntu_config
="ppc64el-config.flavour.generic"
528 echo "Unsupported arch $arch"
533 echo "Not arch or cross_arch specified"
539 # First get the kernel build from the object store, or build it, if it's
542 echo "# Setup endpoint
543 host_base = obj.internal.efficios.com
544 host_bucket = obj.internal.efficios.com
545 bucket_location = us-east-1
550 secret_key = echo123456
552 # Enable S3 v4 signature APIs
553 signature_v2 = False" > "$WORKSPACE/.s3cfg"
555 url_hash
="$(echo -n "$kgitrepo/$ktag/$arch/$cross_arch" | md5sum | awk '{ print $1 }')"
556 obj_name
="linux.tar.bz2"
557 obj_url_prefix
="$OBJ_STORE_URL/linux-build/$url_hash"
558 obj_url
="$obj_url_prefix/$obj_name"
561 s3cmd
-c "$WORKSPACE/.s3cfg" get
"$obj_url"
571 echo "File not found"
573 # Build all the things and upload
574 # then finish the module build...
576 git_clone_linux_sources
577 git_export_linux_sources
581 ## PREPARE FULL LINUX SOURCE TREE
584 ## EXTRACT DISTRO STYLE KERNEL HEADERS / DEVEL
585 extract_distro_headers
594 echo "Unknown error? Abort"
602 # Either we downloaded a pre-build kernel or we built it and uploaded
603 # the archive for future builds.
607 # Build modules against full kernel sources
608 build_modules
"${LINUX_SRCOBJ_DIR}" "${MODULES_OUTPUT_KSRC_DIR}"
610 # Build modules against kernel headers
611 build_modules
"${LINUX_HDROBJ_DIR}" "${MODULES_OUTPUT_KHDR_DIR}"
613 # Make sure some modules were actually built
614 tree
"${MODULES_OUTPUT_KSRC_DIR}"
615 if [ "x$(find "${MODULES_OUTPUT_KSRC_DIR}" -name '*.ko*' -printf yes -quit)" != "xyes" ]; then
616 echo "No modules built!"
620 tree
"${MODULES_OUTPUT_KHDR_DIR}"
621 if [ "x$(find "${MODULES_OUTPUT_KHDR_DIR}" -name '*.ko*' -printf yes -quit)" != "xyes" ]; then
622 echo "No modules built!"