From bd246ac340c82d3a8e701242d4d550c05914c53f7ebca7f125a372223640ec7e Mon Sep 17 00:00:00 2001 From: Dirk Mueller Date: Wed, 5 Apr 2017 11:45:54 +0000 Subject: [PATCH 1/2] Accepting request 484048 from home:ndas:branches:network - Enable HAVE_VF_VLAN_PROTO for SLE12SP3(bsc#1031705). [+0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch] - Enable HAVE_VF_VLAN_PROTO for SLE12SP3(bsc#1031705). [+0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch] OBS-URL: https://build.opensuse.org/request/show/484048 OBS-URL: https://build.opensuse.org/package/show/network/dpdk?expand=0&rev=42 --- ...ine-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch | 33 +++++++++++++++++++ dpdk-thunderx.changes | 6 ++++ dpdk-thunderx.spec | 2 ++ dpdk.changes | 6 ++++ dpdk.spec | 2 ++ 5 files changed, 49 insertions(+) create mode 100644 0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch diff --git a/0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch b/0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch new file mode 100644 index 0000000..ab2d733 --- /dev/null +++ b/0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch @@ -0,0 +1,33 @@ +From e6b63f9d941c8b27c4c1cbeab2c7cdbefb7747ba Mon Sep 17 00:00:00 2001 +From: Nirmoy Das +Date: Fri, 31 Mar 2017 11:40:42 +0200 +Subject: [PATCH] kni: define HAVE_VF_VLAN_PROTO for SLES12SP3 + +Add support for SLES12SP3, which uses kernel 4.4, +but backported features from newer kernels. + +Signed-off-by: Nirmoy Das +--- + lib/librte_eal/linuxapp/kni/ethtool/igb/kcompat.h | 6 ++++-- + 1 file changed, 4 insertions(+), 2 deletions(-) + +diff --git a/lib/librte_eal/linuxapp/kni/ethtool/igb/kcompat.h b/lib/librte_eal/linuxapp/kni/ethtool/igb/kcompat.h +index 84826b26e..3d22d8e69 100644 +--- a/lib/librte_eal/linuxapp/kni/ethtool/igb/kcompat.h ++++ b/lib/librte_eal/linuxapp/kni/ethtool/igb/kcompat.h +@@ -3929,8 +3929,10 @@ skb_set_hash(struct sk_buff *skb, __u32 hash, __always_unused int type) + #define vlan_tx_tag_present skb_vlan_tag_present + #endif + +-#if ( LINUX_VERSION_CODE >= KERNEL_VERSION(4,9,0) ) ++#if (( LINUX_VERSION_CODE >= KERNEL_VERSION(4,9,0) ) \ ++ || (defined(CONFIG_SUSE_KERNEL) && \ ++ (LINUX_VERSION_CODE >= KERNEL_VERSION(4,4,57)))) + #define HAVE_VF_VLAN_PROTO +-#endif /* >= 4.9.0 */ ++#endif /* >= 4.9.0, >= SLES12SP3 */ + + #endif /* _KCOMPAT_H_ */ +-- +2.12.0 + diff --git a/dpdk-thunderx.changes b/dpdk-thunderx.changes index e61f574..66a50a8 100644 --- a/dpdk-thunderx.changes +++ b/dpdk-thunderx.changes @@ -1,3 +1,9 @@ +------------------------------------------------------------------- +Thu Mar 30 16:50:07 CEST 2017 - ndas@suse.de + +- Enable HAVE_VF_VLAN_PROTO for SLE12SP3(bsc#1031705). + [+0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch] + ------------------------------------------------------------------- Mon Mar 20 15:32:12 CET 2017 - ndas@suse.de diff --git a/dpdk-thunderx.spec b/dpdk-thunderx.spec index 22d9c8a..3c136a3 100644 --- a/dpdk-thunderx.spec +++ b/dpdk-thunderx.spec @@ -58,6 +58,7 @@ Source1: preamble # However, the problem still exists and the fix has to find its way to the # upstream code. Patch1: 0001-enic-fix-Type-punning-and-strict-aliasing-warning.patch +Patch2: 0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch BuildRequires: doxygen BuildRequires: fdupes BuildRequires: gcc6 @@ -143,6 +144,7 @@ The DPDK Kernel NIC Interface (KNI) allows userspace applications access to the %prep %setup -q -n dpdk-stable-16.11.1 %patch1 -p1 -z .enic +%patch2 -p1 -z .kni # This fixes CROSS compilation (broken) in the mk file for ThunderX sed -i '/^CROSS /s/^/#/' mk/machine/thunderx/rte.vars.mk diff --git a/dpdk.changes b/dpdk.changes index e61f574..66a50a8 100644 --- a/dpdk.changes +++ b/dpdk.changes @@ -1,3 +1,9 @@ +------------------------------------------------------------------- +Thu Mar 30 16:50:07 CEST 2017 - ndas@suse.de + +- Enable HAVE_VF_VLAN_PROTO for SLE12SP3(bsc#1031705). + [+0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch] + ------------------------------------------------------------------- Mon Mar 20 15:32:12 CET 2017 - ndas@suse.de diff --git a/dpdk.spec b/dpdk.spec index 701b758..4276065 100644 --- a/dpdk.spec +++ b/dpdk.spec @@ -56,6 +56,7 @@ Source1: preamble # However, the problem still exists and the fix has to find its way to the # upstream code. Patch1: 0001-enic-fix-Type-punning-and-strict-aliasing-warning.patch +Patch2: 0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch BuildRequires: doxygen BuildRequires: fdupes BuildRequires: gcc6 @@ -141,6 +142,7 @@ The DPDK Kernel NIC Interface (KNI) allows userspace applications access to the %prep %setup -q -n dpdk-stable-16.11.1 %patch1 -p1 -z .enic +%patch2 -p1 -z .kni # This fixes CROSS compilation (broken) in the mk file for ThunderX sed -i '/^CROSS /s/^/#/' mk/machine/thunderx/rte.vars.mk From 76f4489889e807cba6742845e41fb5cf71eccad061d5e492ad6adab0109b6422 Mon Sep 17 00:00:00 2001 From: Markos Chandras Date: Wed, 5 Apr 2017 14:51:28 +0000 Subject: [PATCH 2/2] Accepting request 485838 from home:ndas:branches:network - Fix dpdk KMP build fails(bsc#1031750) - enable igb_uio kernel module(fate#322394) - update kernel version for SLES12SP3 4.4.59 for bsc#1031705 [*0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch] - Fix dpdk KMP build fails(bsc#1031750) - enable igb_uio kernel module(fate#322394) - update kernel version for SLES12SP3 4.4.59 for bsc#1031705 [*0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch] OBS-URL: https://build.opensuse.org/request/show/485838 OBS-URL: https://build.opensuse.org/package/show/network/dpdk?expand=0&rev=43 --- ...ine-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch | 2 +- dpdk-thunderx.changes | 8 ++ dpdk-thunderx.spec | 80 +++++++++++-------- dpdk.changes | 8 ++ dpdk.spec | 80 +++++++++++-------- 5 files changed, 107 insertions(+), 71 deletions(-) diff --git a/0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch b/0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch index ab2d733..0c811c4 100644 --- a/0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch +++ b/0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch @@ -22,7 +22,7 @@ index 84826b26e..3d22d8e69 100644 -#if ( LINUX_VERSION_CODE >= KERNEL_VERSION(4,9,0) ) +#if (( LINUX_VERSION_CODE >= KERNEL_VERSION(4,9,0) ) \ + || (defined(CONFIG_SUSE_KERNEL) && \ -+ (LINUX_VERSION_CODE >= KERNEL_VERSION(4,4,57)))) ++ (LINUX_VERSION_CODE >= KERNEL_VERSION(4,4,59)))) #define HAVE_VF_VLAN_PROTO -#endif /* >= 4.9.0 */ +#endif /* >= 4.9.0, >= SLES12SP3 */ diff --git a/dpdk-thunderx.changes b/dpdk-thunderx.changes index 66a50a8..c9548c9 100644 --- a/dpdk-thunderx.changes +++ b/dpdk-thunderx.changes @@ -1,3 +1,11 @@ +------------------------------------------------------------------- +Tue Apr 4 15:28:20 CEST 2017 - ndas@suse.de + +- Fix dpdk KMP build fails(bsc#1031750) +- enable igb_uio kernel module(fate#322394) +- update kernel version for SLES12SP3 4.4.59 for bsc#1031705 + [*0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch] + ------------------------------------------------------------------- Thu Mar 30 16:50:07 CEST 2017 - ndas@suse.de diff --git a/dpdk-thunderx.spec b/dpdk-thunderx.spec index 3c136a3..e9a7261 100644 --- a/dpdk-thunderx.spec +++ b/dpdk-thunderx.spec @@ -151,13 +151,40 @@ sed -i '/^CROSS /s/^/#/' mk/machine/thunderx/rte.vars.mk %build # set up a method for modifying the resulting .config file function setconf() { - if grep -q ^$1= %{target}/.config; then - sed -i "s:^$1=.*$:$1=$2:g" %{target}/.config + if grep -q ^$1= $3/.config; then + sed -i "s:^$1=.*$:$1=$2:g" $3/.config else - echo $1=$2 >> %{target}/.config + echo $1=$2 >> $3/.config fi } +function setdefaultconf() +{ + setconf CONFIG_RTE_MACHINE '"%{machine2}"' $1 + # Disable experimental features + setconf CONFIG_RTE_NEXT_ABI n $1 + + # Enable automatic driver loading from this path + setconf CONFIG_RTE_EAL_PMD_PATH '"%{pmddir}"' $1 + + setconf CONFIG_RTE_LIBRTE_BNX2X_PMD y $1 + setconf CONFIG_RTE_LIBRTE_PMD_PCAP y $1 + setconf CONFIG_RTE_LIBRTE_VHOST_NUMA y $1 + + setconf CONFIG_RTE_EAL_IGB_UIO n $1 + setconf CONFIG_RTE_KNI_KMOD n $1 + + %if %{with shared} + setconf CONFIG_RTE_BUILD_SHARED_LIB y $1 + %endif + + %ifarch aarch64 ppc64le + setconf CONFIG_RTE_LIBRTE_DISTRIBUTOR n $1 + %endif + %ifarch ppc64le + setconf CONFIG_RTE_LIBRTE_PMD_RING n $1 + %endif +} # In case dpdk-devel is installed, we should ignore its hints about the SDK directories unset RTE_SDK RTE_INCLUDE RTE_TARGET @@ -172,42 +199,20 @@ export EXTRA_CFLAGS="%{optflags} -Wformat -fPIC -Wno-error=array-bounds" # machines, but runtime checks in DPDK will catch those situations. make CC=gcc-6 V=1 O=%{target} T=%{target} %{?_smp_mflags} config - -setconf CONFIG_RTE_MACHINE '"%{machine2}"' -# Disable experimental features -setconf CONFIG_RTE_NEXT_ABI n - -# Enable automatic driver loading from this path -setconf CONFIG_RTE_EAL_PMD_PATH '"%{pmddir}"' - -setconf CONFIG_RTE_LIBRTE_BNX2X_PMD y -setconf CONFIG_RTE_LIBRTE_PMD_PCAP y -setconf CONFIG_RTE_LIBRTE_VHOST_NUMA y - -setconf CONFIG_RTE_EAL_IGB_UIO n -%ifnarch %{ix86} -setconf CONFIG_RTE_KNI_KMOD y -%else -setconf CONFIG_RTE_KNI_KMOD n -%endif - -%if %{with shared} -setconf CONFIG_RTE_BUILD_SHARED_LIB y -%endif - -%ifarch aarch64 ppc64le -setconf CONFIG_RTE_LIBRTE_DISTRIBUTOR n -%endif -%ifarch ppc64le -setconf CONFIG_RTE_LIBRTE_PMD_RING n -%endif +setdefaultconf %{target} %ifnarch %{ix86} export EXTRA_CFLAGS='-DVERSION=\"%{version}\"' for flavor in %{flavors_to_build}; do - cp -r %{target} %{target}-$flavor + export RTE_KERNELDIR=%{_prefix}/src/linux-obj/%{_target_cpu}/$flavor + make CC=gcc-6 V=1 O=%{target}-$flavor T=%{target} %{?_smp_mflags} config + setdefaultconf %{target}-$flavor + %ifnarch %{ix86} + setconf CONFIG_RTE_EAL_IGB_UIO y %{target}-$flavor + setconf CONFIG_RTE_KNI_KMOD y %{target}-$flavor + %endif cd %{target}-$flavor - make CC=gcc-6 KERNELDIR=%{_prefix}/src/linux-obj/%{_target_cpu}/$flavor %{?_smp_mflags} + make CC=gcc-6 V=1 %{?_smp_mflags} cd - done %endif @@ -229,7 +234,12 @@ export BRP_PESIGN_FILES="*.ko" for flavor in %{flavors_to_build}; do cd %{target}-$flavor - %make_install KERNELDIR=%{_prefix}/src/linux-obj/%{_target_cpu}/$flavor prefix=%{_usr} libdir=%{_libdir} + export RTE_KERNELDIR=%{_prefix}/src/linux-obj/%{_target_cpu}/$flavor + dir=/usr/src/linux-obj/%{_target_cpu}/$flavor + krel=$(make -s -C "$dir" kernelrelease) + mkdir -p %{buildroot}/lib/modules/$krel/extra/dpdk/ + #make install expects same kernel for build and target, lets copy it manually + install -m644 ../%{target}-$flavor/kmod/*.ko %{buildroot}/lib/modules/$krel/extra/dpdk/ cd - done %endif diff --git a/dpdk.changes b/dpdk.changes index 66a50a8..c9548c9 100644 --- a/dpdk.changes +++ b/dpdk.changes @@ -1,3 +1,11 @@ +------------------------------------------------------------------- +Tue Apr 4 15:28:20 CEST 2017 - ndas@suse.de + +- Fix dpdk KMP build fails(bsc#1031750) +- enable igb_uio kernel module(fate#322394) +- update kernel version for SLES12SP3 4.4.59 for bsc#1031705 + [*0002-kni-define-HAVE_VF_VLAN_PROTO-for-SLES12SP3.patch] + ------------------------------------------------------------------- Thu Mar 30 16:50:07 CEST 2017 - ndas@suse.de diff --git a/dpdk.spec b/dpdk.spec index 4276065..40880ef 100644 --- a/dpdk.spec +++ b/dpdk.spec @@ -149,13 +149,40 @@ sed -i '/^CROSS /s/^/#/' mk/machine/thunderx/rte.vars.mk %build # set up a method for modifying the resulting .config file function setconf() { - if grep -q ^$1= %{target}/.config; then - sed -i "s:^$1=.*$:$1=$2:g" %{target}/.config + if grep -q ^$1= $3/.config; then + sed -i "s:^$1=.*$:$1=$2:g" $3/.config else - echo $1=$2 >> %{target}/.config + echo $1=$2 >> $3/.config fi } +function setdefaultconf() +{ + setconf CONFIG_RTE_MACHINE '"%{machine2}"' $1 + # Disable experimental features + setconf CONFIG_RTE_NEXT_ABI n $1 + + # Enable automatic driver loading from this path + setconf CONFIG_RTE_EAL_PMD_PATH '"%{pmddir}"' $1 + + setconf CONFIG_RTE_LIBRTE_BNX2X_PMD y $1 + setconf CONFIG_RTE_LIBRTE_PMD_PCAP y $1 + setconf CONFIG_RTE_LIBRTE_VHOST_NUMA y $1 + + setconf CONFIG_RTE_EAL_IGB_UIO n $1 + setconf CONFIG_RTE_KNI_KMOD n $1 + + %if %{with shared} + setconf CONFIG_RTE_BUILD_SHARED_LIB y $1 + %endif + + %ifarch aarch64 ppc64le + setconf CONFIG_RTE_LIBRTE_DISTRIBUTOR n $1 + %endif + %ifarch ppc64le + setconf CONFIG_RTE_LIBRTE_PMD_RING n $1 + %endif +} # In case dpdk-devel is installed, we should ignore its hints about the SDK directories unset RTE_SDK RTE_INCLUDE RTE_TARGET @@ -170,42 +197,20 @@ export EXTRA_CFLAGS="%{optflags} -Wformat -fPIC -Wno-error=array-bounds" # machines, but runtime checks in DPDK will catch those situations. make CC=gcc-6 V=1 O=%{target} T=%{target} %{?_smp_mflags} config - -setconf CONFIG_RTE_MACHINE '"%{machine2}"' -# Disable experimental features -setconf CONFIG_RTE_NEXT_ABI n - -# Enable automatic driver loading from this path -setconf CONFIG_RTE_EAL_PMD_PATH '"%{pmddir}"' - -setconf CONFIG_RTE_LIBRTE_BNX2X_PMD y -setconf CONFIG_RTE_LIBRTE_PMD_PCAP y -setconf CONFIG_RTE_LIBRTE_VHOST_NUMA y - -setconf CONFIG_RTE_EAL_IGB_UIO n -%ifnarch %{ix86} -setconf CONFIG_RTE_KNI_KMOD y -%else -setconf CONFIG_RTE_KNI_KMOD n -%endif - -%if %{with shared} -setconf CONFIG_RTE_BUILD_SHARED_LIB y -%endif - -%ifarch aarch64 ppc64le -setconf CONFIG_RTE_LIBRTE_DISTRIBUTOR n -%endif -%ifarch ppc64le -setconf CONFIG_RTE_LIBRTE_PMD_RING n -%endif +setdefaultconf %{target} %ifnarch %{ix86} export EXTRA_CFLAGS='-DVERSION=\"%{version}\"' for flavor in %{flavors_to_build}; do - cp -r %{target} %{target}-$flavor + export RTE_KERNELDIR=%{_prefix}/src/linux-obj/%{_target_cpu}/$flavor + make CC=gcc-6 V=1 O=%{target}-$flavor T=%{target} %{?_smp_mflags} config + setdefaultconf %{target}-$flavor + %ifnarch %{ix86} + setconf CONFIG_RTE_EAL_IGB_UIO y %{target}-$flavor + setconf CONFIG_RTE_KNI_KMOD y %{target}-$flavor + %endif cd %{target}-$flavor - make CC=gcc-6 KERNELDIR=%{_prefix}/src/linux-obj/%{_target_cpu}/$flavor %{?_smp_mflags} + make CC=gcc-6 V=1 %{?_smp_mflags} cd - done %endif @@ -227,7 +232,12 @@ export BRP_PESIGN_FILES="*.ko" for flavor in %{flavors_to_build}; do cd %{target}-$flavor - %make_install KERNELDIR=%{_prefix}/src/linux-obj/%{_target_cpu}/$flavor prefix=%{_usr} libdir=%{_libdir} + export RTE_KERNELDIR=%{_prefix}/src/linux-obj/%{_target_cpu}/$flavor + dir=/usr/src/linux-obj/%{_target_cpu}/$flavor + krel=$(make -s -C "$dir" kernelrelease) + mkdir -p %{buildroot}/lib/modules/$krel/extra/dpdk/ + #make install expects same kernel for build and target, lets copy it manually + install -m644 ../%{target}-$flavor/kmod/*.ko %{buildroot}/lib/modules/$krel/extra/dpdk/ cd - done %endif