Fix iavf driver build failure 57/124657/2
authorTodd Malsbary <todd.malsbary@intel.com>
Fri, 1 Oct 2021 20:51:00 +0000 (13:51 -0700)
committerTodd Malsbary <todd.malsbary@intel.com>
Fri, 1 Oct 2021 22:56:48 +0000 (15:56 -0700)
With kernel 4.15.0-159, Ubuntu added the skb_frag_off functions to the
kernel headers.

Issue-ID: MULTICLOUD-1396
Signed-off-by: Todd Malsbary <todd.malsbary@intel.com>
Change-Id: I283d6ea394ac4685be842339acd2a89548295b4f

kud/deployment_infra/installers/Dockerfile.iavf-driver-installer
kud/deployment_infra/installers/entrypoint-iavf-driver-installer.sh
kud/deployment_infra/installers/skb-frag-off.patch [new file with mode: 0644]

index 9882c2f..8d4593a 100644 (file)
@@ -19,6 +19,7 @@ RUN apt-get update && \
     rm -rf /var/lib/apt/lists/*
 
 COPY _common.sh /
+COPY skb-frag-off.patch /
 COPY entrypoint-iavf-driver-installer.sh /entrypoint.sh
 
 CMD /entrypoint.sh
index 6cfc373..d47e3b9 100755 (executable)
@@ -2,6 +2,7 @@
 
 #set -x
 source _common.sh
+SCRIPT_DIR=$(readlink -f "$(dirname "${BASH_SOURCE[0]}")")
 
 IAVF_DRIVER_VERSION="${IAVF_DRIVER_VERSION:-4.0.2}"
 IAVF_DRIVER_DOWNLOAD_URL_DEFAULT="https://downloadmirror.intel.com/30305/eng/iavf-${IAVF_DRIVER_VERSION}.tar.gz"
@@ -27,10 +28,15 @@ download_iavf_src() {
     pushd "${IAVF_INSTALL_DIR_CONTAINER}" > /dev/null
     curl -L -sS "${IAVF_DRIVER_DOWNLOAD_URL}" -o "${IAVF_DRIVER_ARCHIVE}"
     tar xf "${IAVF_DRIVER_ARCHIVE}" --strip-components=1
+    info "Patching IAVF source ... "
+    # Ubuntu 18.04 added the skb_frag_off definitions to the kernel
+    # headers beginning with 4.15.0-159
+    patch -p1 < "${SCRIPT_DIR}/skb-frag-off.patch"
     popd > /dev/null
 }
 
 build_iavf_src() {
+
     info "Building IAVF source ... "
     pushd "${IAVF_INSTALL_DIR_CONTAINER}/src" > /dev/null
     KSRC=${KERNEL_SRC_DIR} SYSTEM_MAP_FILE="${ROOT_MOUNT_DIR}/boot/System.map-$(uname -r)" INSTALL_MOD_PATH="${ROOT_MOUNT_DIR}" make install
diff --git a/kud/deployment_infra/installers/skb-frag-off.patch b/kud/deployment_infra/installers/skb-frag-off.patch
new file mode 100644 (file)
index 0000000..935828e
--- /dev/null
@@ -0,0 +1,14 @@
+diff --git a/src/kcompat.h b/src/kcompat.h
+index 21e9818..97abc2f 100644
+--- a/src/kcompat.h
++++ b/src/kcompat.h
+@@ -7074,7 +7074,8 @@ devlink_flash_update_status_notify(struct devlink __always_unused *devlink,
+ /*****************************************************************************/
+ #if (LINUX_VERSION_CODE < KERNEL_VERSION(5,4,0))
+ #if (!(RHEL_RELEASE_CODE >= RHEL_RELEASE_VERSION(8,2)) && \
+-     !(SLE_VERSION_CODE >= SLE_VERSION(15,2,0)))
++     !(SLE_VERSION_CODE >= SLE_VERSION(15,2,0)) && \
++     !(UBUNTU_VERSION_CODE >= UBUNTU_VERSION(4,15,0,159)))
+ static inline unsigned int skb_frag_off(const skb_frag_t *frag)
+ {
+        return frag->page_offset;