summaryrefslogtreecommitdiffstats
path: root/support/scripts/check-bin-arch
diff options
context:
space:
mode:
authorThomas Petazzoni <thomas.petazzoni@free-electrons.com>2017-03-19 14:07:52 +0100
committerThomas Petazzoni <thomas.petazzoni@free-electrons.com>2017-03-20 22:22:22 +0100
commitbbb7f6c16cd5ff04ec9b78713f42ea53a940529f (patch)
tree1eeb922b2d832d22e7a978e9579e249be4bf765f /support/scripts/check-bin-arch
parentd04ea6e4e8d53405b55be5f5877823ed65e85e8b (diff)
downloadbuildroot-bbb7f6c16cd5ff04ec9b78713f42ea53a940529f.tar.gz
buildroot-bbb7f6c16cd5ff04ec9b78713f42ea53a940529f.zip
Makefile: add check of binaries architecture
As shown recently by the firejail example, it is easy to miss that a package builds and installs binaries without actually cross-compiling them: they are built for the host architecture instead of the target architecture. This commit adds a small helper script, check-bin-arch, called as a GLOBAL_INSTRUMENTATION_HOOKS at the end of the target installation of each package, to verify that the files installed by this package have been built for the correct architecture. Being called as a GLOBAL_INSTRUMENTATION_HOOKS allows the build to error out right after the installation of the faulty package, and therefore get autobuilder error detection properly assigned to this specific package. Example output with the firejail package enabled, when building for an ARM target: ERROR: architecture for ./usr/lib/firejail/libconnect.so is Advanced Micro Devices X86-64, should be ARM ERROR: architecture for ./usr/bin/firejail is Advanced Micro Devices X86-64, should be ARM ERROR: architecture for ./usr/lib/firejail/libtrace.so is Advanced Micro Devices X86-64, should be ARM ERROR: architecture for ./usr/lib/firejail/libtracelog.so is Advanced Micro Devices X86-64, should be ARM ERROR: architecture for ./usr/lib/firejail/ftee is Advanced Micro Devices X86-64, should be ARM ERROR: architecture for ./usr/lib/firejail/faudit is Advanced Micro Devices X86-64, should be ARM ERROR: architecture for ./usr/bin/firemon is Advanced Micro Devices X86-64, should be ARM ERROR: architecture for ./usr/bin/firecfg is Advanced Micro Devices X86-64, should be ARM Many thanks to Yann E. Morin and Arnout Vandecappelle for their reviews and suggestions. Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Diffstat (limited to 'support/scripts/check-bin-arch')
-rwxr-xr-xsupport/scripts/check-bin-arch52
1 files changed, 52 insertions, 0 deletions
diff --git a/support/scripts/check-bin-arch b/support/scripts/check-bin-arch
new file mode 100755
index 0000000000..2c619ad674
--- /dev/null
+++ b/support/scripts/check-bin-arch
@@ -0,0 +1,52 @@
+#!/bin/bash
+
+while getopts p:l:r:a: OPT ; do
+ case "${OPT}" in
+ p) package="${OPTARG}";;
+ l) pkg_list="${OPTARG}";;
+ r) readelf="${OPTARG}";;
+ a) arch_name="${OPTARG}";;
+ :) error "option '%s' expects a mandatory argument\n" "${OPTARG}";;
+ \?) error "unknown option '%s'\n" "${OPTARG}";;
+ esac
+done
+
+if test -z "${package}" -o -z "${pkg_list}" -o -z "${readelf}" -o -z "${arch_name}" ; then
+ echo "Usage: $0 -p <pkg> -l <pkg-file-list> -r <readelf> -a <arch name>"
+ exit 1
+fi
+
+exitcode=0
+
+pkg_files=$(sed -r -e "/^${package},(.+)$/!d; s//\1/;" ${pkg_list})
+
+for f in ${pkg_files} ; do
+ # Skip firmware files, they could be ELF files for other
+ # architectures
+ if [[ "${f}" =~ ^\./(usr/)?lib/firmware/.* ]]; then
+ continue
+ fi
+
+ # Get architecture using readelf. We pipe through 'head -1' so
+ # that when the file is a static library (.a), we only take
+ # into account the architecture of the first object file.
+ arch=$(LC_ALL=C ${readelf} -h "${TARGET_DIR}/${f}" 2>&1 | \
+ sed -r -e '/^ Machine: +(.+)/!d; s//\1/;' | head -1)
+
+ # If no architecture found, assume it was not an ELF file
+ if test "${arch}" = "" ; then
+ continue
+ fi
+
+ # Architecture is correct
+ if test "${arch}" = "${arch_name}" ; then
+ continue
+ fi
+
+ printf 'ERROR: architecture for %s is %s, should be %s\n' \
+ "${f}" "${arch}" "${arch_name}"
+
+ exitcode=1
+done
+
+exit ${exitcode}
OpenPOWER on IntegriCloud