diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:45:59 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:45:59 +0000 |
commit | 19fcec84d8d7d21e796c7624e521b60d28ee21ed (patch) | |
tree | 42d26aa27d1e3f7c0b8bd3fd14e7d7082f5008dc /src/spdk/dpdk/.ci | |
parent | Initial commit. (diff) | |
download | ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.tar.xz ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.zip |
Adding upstream version 16.2.11+ds.upstream/16.2.11+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/spdk/dpdk/.ci')
-rwxr-xr-x | src/spdk/dpdk/.ci/linux-build.sh | 100 | ||||
-rwxr-xr-x | src/spdk/dpdk/.ci/linux-setup.sh | 9 |
2 files changed, 109 insertions, 0 deletions
diff --git a/src/spdk/dpdk/.ci/linux-build.sh b/src/spdk/dpdk/.ci/linux-build.sh new file mode 100755 index 000000000..d079801d7 --- /dev/null +++ b/src/spdk/dpdk/.ci/linux-build.sh @@ -0,0 +1,100 @@ +#!/bin/sh -xe + +on_error() { + if [ $? = 0 ]; then + exit + fi + FILES_TO_PRINT="build/meson-logs/testlog.txt build/.ninja_log build/meson-logs/meson-log.txt" + + for pr_file in $FILES_TO_PRINT; do + if [ -e "$pr_file" ]; then + cat "$pr_file" + fi + done +} +trap on_error EXIT + +install_libabigail() { + version=$1 + instdir=$2 + + wget -q "http://mirrors.kernel.org/sourceware/libabigail/${version}.tar.gz" + tar -xf ${version}.tar.gz + cd $version && autoreconf -vfi && cd - + mkdir $version/build + cd $version/build && ../configure --prefix=$instdir && cd - + make -C $version/build all install + rm -rf $version + rm ${version}.tar.gz +} + +if [ "$AARCH64" = "1" ]; then + # convert the arch specifier + OPTS="$OPTS --cross-file config/arm/arm64_armv8_linux_gcc" +fi + +if [ "$BUILD_DOCS" = "1" ]; then + OPTS="$OPTS -Denable_docs=true" +fi + +if [ "$BUILD_32BIT" = "1" ]; then + OPTS="$OPTS -Dc_args=-m32 -Dc_link_args=-m32" + export PKG_CONFIG_LIBDIR="/usr/lib32/pkgconfig" +fi + +if [ "$DEF_LIB" = "static" ]; then + OPTS="$OPTS -Dexamples=l2fwd,l3fwd" +else + OPTS="$OPTS -Dexamples=all" +fi + +OPTS="$OPTS --default-library=$DEF_LIB" +OPTS="$OPTS --buildtype=debugoptimized" +meson build --werror $OPTS +ninja -C build + +if [ "$AARCH64" != "1" ]; then + devtools/test-null.sh +fi + +if [ "$ABI_CHECKS" = "1" ]; then + LIBABIGAIL_VERSION=${LIBABIGAIL_VERSION:-libabigail-1.6} + + if [ "$(cat libabigail/VERSION 2>/dev/null)" != "$LIBABIGAIL_VERSION" ]; then + rm -rf libabigail + # if we change libabigail, invalidate existing abi cache + rm -rf reference + fi + + if [ ! -d libabigail ]; then + install_libabigail $LIBABIGAIL_VERSION $(pwd)/libabigail + echo $LIBABIGAIL_VERSION > libabigail/VERSION + fi + + export PATH=$(pwd)/libabigail/bin:$PATH + + REF_GIT_REPO=${REF_GIT_REPO:-https://dpdk.org/git/dpdk} + REF_GIT_TAG=${REF_GIT_TAG:-v19.11} + + if [ "$(cat reference/VERSION 2>/dev/null)" != "$REF_GIT_TAG" ]; then + rm -rf reference + fi + + if [ ! -d reference ]; then + refsrcdir=$(readlink -f $(pwd)/../dpdk-$REF_GIT_TAG) + git clone --single-branch -b $REF_GIT_TAG $REF_GIT_REPO $refsrcdir + meson --werror $OPTS $refsrcdir $refsrcdir/build + ninja -C $refsrcdir/build + DESTDIR=$(pwd)/reference ninja -C $refsrcdir/build install + devtools/gen-abi.sh reference + echo $REF_GIT_TAG > reference/VERSION + fi + + DESTDIR=$(pwd)/install ninja -C build install + devtools/gen-abi.sh install + devtools/check-abi.sh reference install ${ABI_CHECKS_WARN_ONLY:-} +fi + +if [ "$RUN_TESTS" = "1" ]; then + sudo meson test -C build --suite fast-tests -t 3 +fi diff --git a/src/spdk/dpdk/.ci/linux-setup.sh b/src/spdk/dpdk/.ci/linux-setup.sh new file mode 100755 index 000000000..5d3089cad --- /dev/null +++ b/src/spdk/dpdk/.ci/linux-setup.sh @@ -0,0 +1,9 @@ +#!/bin/sh -xe + +# need to install as 'root' since some of the unit tests won't run without it +sudo python3 -m pip install --upgrade 'meson==0.47.1' + +# setup hugepages. error ignored because having hugepage is not mandatory. +cat /proc/meminfo +sudo sh -c 'echo 1024 > /proc/sys/vm/nr_hugepages' || true +cat /proc/meminfo |