diff options
author | Christian Breunig <christian@breunig.cc> | 2024-07-25 18:23:00 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-07-25 18:23:00 +0200 |
commit | 02379d3dd5e3ed455c8ed33e403606001fe7cee3 (patch) | |
tree | 264c551f776917d401f491c11ba1b35f2943ae1f | |
parent | dfa18329b8bec91f7d0ab170316920af58102391 (diff) | |
parent | f33a22bcf36d52a1150ce048a9b60db774416c49 (diff) | |
download | vyos-build-02379d3dd5e3ed455c8ed33e403606001fe7cee3.tar.gz vyos-build-02379d3dd5e3ed455c8ed33e403606001fe7cee3.zip |
Merge pull request #665 from sempervictus/feature/mellanox_ofed_drivers
T6231: Mellanox OFED
-rw-r--r-- | packages/linux-kernel/.gitignore | 2 | ||||
-rw-r--r-- | packages/linux-kernel/Jenkinsfile | 3 | ||||
-rwxr-xr-x | packages/linux-kernel/build-mellanox-ofed.sh | 123 |
3 files changed, 128 insertions, 0 deletions
diff --git a/packages/linux-kernel/.gitignore b/packages/linux-kernel/.gitignore index 97e392e3..a3e9257c 100644 --- a/packages/linux-kernel/.gitignore +++ b/packages/linux-kernel/.gitignore @@ -23,3 +23,5 @@ vyos-intel-*/ vyos-linux-firmware*/ kernel-vars r8152-*.tar.bz2 +/MLNX_OFED_SRC* +/vyos-mellanox-ofed* diff --git a/packages/linux-kernel/Jenkinsfile b/packages/linux-kernel/Jenkinsfile index b7d10a19..986780e0 100644 --- a/packages/linux-kernel/Jenkinsfile +++ b/packages/linux-kernel/Jenkinsfile @@ -62,6 +62,9 @@ def pkgList = [ // Intel IXGBEVF ['name': 'ixgbevf', 'buildCmd': 'cd ..; ./build-intel-ixgbevf.sh'], + // Mellanox OFED + ['name': 'ofed', 'buildCmd': 'cd ..; ./build-mellanox-ofed.sh'], + // Jool ['name': 'jool', 'buildCmd': 'cd ..; ./build-jool.py'], diff --git a/packages/linux-kernel/build-mellanox-ofed.sh b/packages/linux-kernel/build-mellanox-ofed.sh new file mode 100755 index 00000000..0dffcfdb --- /dev/null +++ b/packages/linux-kernel/build-mellanox-ofed.sh @@ -0,0 +1,123 @@ +#!/bin/sh +DROP_DEV_DBG_DEBS=1 +DEB_DISTRO='debian12.1' +CWD=$(pwd) +KERNEL_VAR_FILE=${CWD}/kernel-vars + +if ! dpkg-architecture -iamd64; then + echo "Mellanox OFED is only buildable on amd64 platforms" + exit 0 +fi + +if [ ! -f ${KERNEL_VAR_FILE} ]; then + echo "Kernel variable file '${KERNEL_VAR_FILE}' does not exist, run ./build_kernel.sh first" + exit 1 +fi + +. ${KERNEL_VAR_FILE} + +url="https://www.mellanox.com/downloads/ofed/MLNX_OFED-24.04-0.6.6.0/MLNX_OFED_SRC-debian-24.04-0.6.6.0.tgz" + +cd ${CWD} + +DRIVER_FILE=$(basename ${url} | sed -e s/tar_0/tar/) +DRIVER_SHA1="003c1c022f9f6558d45750eacc0a64d06cf9cd42" + +DRIVER_DIR="${DRIVER_FILE%.tgz}" +DRIVER_NAME="ofed" +DRIVER_PRFX="MLNX_OFED" +DRIVER_VERSION=$(echo ${DRIVER_DIR} | awk -F${DRIVER_PRFX} '{print $2}' | sed 's/^-//;s|_SRC-debian-||') +DRIVER_VERSION_EXTRA="" + +# Build up Debian related variables required for packaging +DEBIAN_ARCH=$(dpkg --print-architecture) +DEBIAN_DIR="${CWD}/vyos-mellanox-${DRIVER_NAME}_${DRIVER_VERSION}_${DEBIAN_ARCH}" +DEBIAN_CONTROL="${DEBIAN_DIR}/DEBIAN/control" +DEBIAN_POSTINST="${CWD}/vyos-mellanox-ofed.postinst" + +# Fetch OFED driver source from Nvidia +if [ -e ${DRIVER_FILE} ]; then + rm -f ${DRIVER_FILE} +fi +curl -L -o ${DRIVER_FILE} ${url} +if [ "$?" -ne "0" ]; then + exit 1 +fi + +# Verify integrity +echo "${DRIVER_SHA1} ${DRIVER_FILE}" | sha1sum -c - +if [[ $? != 0 ]]; then + echo SHA1 checksum missmatch + exit 1 +fi + +# Unpack archive +if [ -d ${DRIVER_DIR} ]; then + rm -rf ${DRIVER_DIR} +fi +mkdir -p ${DRIVER_DIR} +tar -C ${DRIVER_DIR} --strip-components=1 -xf ${DRIVER_FILE} + +# Build/install debs +cd ${DRIVER_DIR} +if [ -z $KERNEL_DIR ]; then + echo "KERNEL_DIR not defined" + exit 1 +fi + +rm -f SOURCES/ibarr_0.1.3.orig.tar.gz +rm -f SOURCES/ibdump_6.0.0.orig.tar.gz +rm -f SOURCES/ibsim_0.12.orig.tar.gz +rm -f SOURCES/iser_24.04.OFED.24.04.0.6.6.1.orig.tar.gz +rm -f SOURCES/isert_24.04.OFED.24.04.0.6.6.1.orig.tar.gz +rm -f SOURCES/kernel-mft_4.28.0.92.orig.tar.gz +rm -f SOURCES/knem_1.1.4.90mlnx3.orig.tar.gz +rm -f SOURCES/libvma_9.8.60.orig.tar.gz +rm -f SOURCES/libxlio_3.30.5.orig.tar.gz +rm -f SOURCES/mlnx-ethtool_6.7.orig.tar.gz +rm -f SOURCES/mlnx-iproute2_6.7.0.orig.tar.gz +rm -f SOURCES/mlnx-nfsrdma_24.04.OFED.24.04.0.6.6.1.orig.tar.gz +rm -f SOURCES/mlnx-nvme_24.04.OFED.24.04.0.6.6.1.orig.tar.gz +rm -f SOURCES/mlx-steering-dump_1.0.0.orig.tar.gz +rm -f SOURCES/mpitests_3.2.23.orig.tar.gz +rm -f SOURCES/mstflint_4.16.1.orig.tar.gz +rm -f SOURCES/ofed-scripts_24.04.OFED.24.04.0.6.6.orig.tar.gz +rm -f SOURCES/openmpi_4.1.7a1.orig.tar.gz +rm -f SOURCES/openvswitch_2.17.8.orig.tar.gz +rm -f SOURCES/perftest_24.04.0.orig.tar.gz +rm -f SOURCES/rdma-core_2404mlnx51.orig.tar.gz +rm -f SOURCES/rshim_2.0.28.orig.tar.gz +rm -f SOURCES/sockperf_3.10.orig.tar.gz +rm -f SOURCES/srp_24.04.OFED.24.04.0.6.6.1.orig.tar.gz +rm -f SOURCES/ucx_1.17.0.orig.tar.gz + + +sudo ./install.pl \ + --basic --dpdk \ + --without-dkms \ + --without-mlnx-nvme-modules \ + --with-vma --vma-vpi --vma-eth \ + --guest --hypervisor \ + --builddir ${DEBIAN_DIR}/mlx \ + --distro ${DEB_DISTRO} \ + --kernel-sources ${KERNEL_DIR} \ + --kernel ${KERNEL_VERSION}${KERNEL_SUFFIX} + +if [ $DROP_DEV_DBG_DEBS -eq 1 ]; then + echo "I: Removing development and debug packages" + sudo rm $(find $CWD/$DRIVER_DIR/DEBS/$DEB_DISTRO -type f | grep -E '\-dev|\-dbg') +fi + +cp $(find $CWD/$DRIVER_DIR/DEBS/$DEB_DISTRO -type f | grep '\.deb$') "$CWD/" + +echo "I: Cleanup ${DRIVER_NAME} source" +cd ${CWD} +if [ -e ${DRIVER_FILE} ]; then + rm -f ${DRIVER_FILE} +fi +if [ -d ${DRIVER_DIR} ]; then + sudo rm -rf ${DRIVER_DIR} +fi +if [ -d ${DEBIAN_DIR} ]; then + sudo rm -rf ${DEBIAN_DIR} +fi |