mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-07-13 21:50:33 +03:00
Merge pull request #29100 from abuibrahim/master
odp-dpdk: 1.12.0.0 -> 1.15.0.0
This commit is contained in:
commit
23a58b9b8a
7 changed files with 104 additions and 40 deletions
|
@ -20,45 +20,18 @@ stdenv.mkDerivation rec {
|
||||||
NIX_CFLAGS_COMPILE = [ "-march=core2" ];
|
NIX_CFLAGS_COMPILE = [ "-march=core2" ];
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
outputs = [ "out" "kmod" "examples" ];
|
outputs = [ "out" "kmod" ];
|
||||||
|
|
||||||
hardeningDisable = [ "pic" ];
|
hardeningDisable = [ "pic" ];
|
||||||
|
|
||||||
configurePhase = ''
|
configurePhase = ''
|
||||||
make T=x86_64-native-linuxapp-gcc config
|
make T=${RTE_TARGET} config
|
||||||
'';
|
|
||||||
|
|
||||||
buildPhase = ''
|
|
||||||
make T=x86_64-native-linuxapp-gcc install
|
|
||||||
make T=x86_64-native-linuxapp-gcc examples
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
install -m 0755 -d $out/lib
|
make install-runtime install-sdk DESTDIR=$out prefix= includedir=/include datadir=/
|
||||||
install -m 0644 ${RTE_TARGET}/lib/*.a $out/lib
|
make install-sdk DESTDIR=$out prefix= includedir=/include datadir=/
|
||||||
|
make install-kmod DESTDIR=$kmod
|
||||||
install -m 0755 -d $out/include
|
|
||||||
install -m 0644 ${RTE_TARGET}/include/*.h $out/include
|
|
||||||
|
|
||||||
install -m 0755 -d $out/include/generic
|
|
||||||
install -m 0644 ${RTE_TARGET}/include/generic/*.h $out/include/generic
|
|
||||||
|
|
||||||
install -m 0755 -d $out/include/exec-env
|
|
||||||
install -m 0644 ${RTE_TARGET}/include/exec-env/*.h $out/include/exec-env
|
|
||||||
|
|
||||||
install -m 0755 -d $out/${RTE_TARGET}
|
|
||||||
install -m 0644 ${RTE_TARGET}/.config $out/${RTE_TARGET}
|
|
||||||
|
|
||||||
install -m 0755 -d $out/${RTE_TARGET}/include
|
|
||||||
install -m 0644 ${RTE_TARGET}/include/rte_config.h $out/${RTE_TARGET}/include
|
|
||||||
|
|
||||||
cp -pr mk $out/
|
|
||||||
|
|
||||||
mkdir -p $kmod/lib/modules/${kernel.modDirVersion}/kernel/drivers/net
|
|
||||||
cp ${RTE_TARGET}/kmod/*.ko $kmod/lib/modules/${kernel.modDirVersion}/kernel/drivers/net
|
|
||||||
|
|
||||||
mkdir -p $examples/bin
|
|
||||||
find examples ${RTE_TARGET}/app -type f -executable -exec cp {} $examples/bin \;
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
meta = with stdenv.lib; {
|
||||||
|
|
32
pkgs/os-specific/linux/odp-dpdk/configure.patch
Normal file
32
pkgs/os-specific/linux/odp-dpdk/configure.patch
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 001ebfc2893b..7d19ebcd213f 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -215,7 +215,7 @@ AC_SUBST([testdir])
|
||||||
|
##########################################################################
|
||||||
|
AM_CONDITIONAL([netmap_support], [test x$netmap_support = xyes ])
|
||||||
|
AM_CONDITIONAL([PKTIO_DPDK], [test x$pktio_dpdk_support = xyes ])
|
||||||
|
-AM_CONDITIONAL([HAVE_PCAP], [test $have_pcap = yes])
|
||||||
|
+AM_CONDITIONAL([HAVE_PCAP], [test x$have_pcap = xyes])
|
||||||
|
AM_CONDITIONAL([DPDK_DEFAULT_DIR], [test "x${DPDK_DEFAULT_DIR}" = "x1"])
|
||||||
|
AM_CONDITIONAL([test_installdir], [test "$testdir" != ""])
|
||||||
|
AM_CONDITIONAL([cunit_support], [test x$cunit_support = xyes ])
|
||||||
|
@@ -320,18 +320,6 @@ ODP_CFLAGS="$ODP_CFLAGS -Wcast-align -Wnested-externs -Wcast-qual -Wformat-nonli
|
||||||
|
ODP_CFLAGS="$ODP_CFLAGS -Wformat-security -Wundef -Wwrite-strings"
|
||||||
|
ODP_CFLAGS="$ODP_CFLAGS -std=gnu99"
|
||||||
|
|
||||||
|
-dnl Use -Werror in the checks below since Clang emits a warning instead of
|
||||||
|
-dnl an error when it encounters an unknown warning option.
|
||||||
|
-AX_CHECK_COMPILE_FLAG([-Wimplicit-fallthrough=0],
|
||||||
|
- [ODP_CFLAGS="$ODP_CFLAGS -Wimplicit-fallthrough=0"],
|
||||||
|
- [], [-Werror])
|
||||||
|
-AX_CHECK_COMPILE_FLAG([-Wformat-truncation=0],
|
||||||
|
- [ODP_CFLAGS="$ODP_CFLAGS -Wformat-truncation=0"],
|
||||||
|
- [], [-Werror])
|
||||||
|
-AX_CHECK_COMPILE_FLAG([-Wformat-overflow=0],
|
||||||
|
- [ODP_CFLAGS="$ODP_CFLAGS -Wformat-overflow=0"],
|
||||||
|
- [], [-Werror])
|
||||||
|
-
|
||||||
|
# Extra flags for example to suppress certain warning types
|
||||||
|
ODP_CFLAGS="$ODP_CFLAGS $ODP_CFLAGS_EXTRA"
|
||||||
|
|
|
@ -2,12 +2,12 @@
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "odp-dpdk-${version}";
|
name = "odp-dpdk-${version}";
|
||||||
version = "1.12.0.0";
|
version = "1.15.0.0";
|
||||||
|
|
||||||
src = fetchgit {
|
src = fetchgit {
|
||||||
url = "https://git.linaro.org/lng/odp-dpdk.git";
|
url = "https://git.linaro.org/lng/odp-dpdk.git";
|
||||||
rev = "5e370e1113973feafb43a8e57d4c59be40e9aeab";
|
rev = "d8533b4e575d62c9f6f2caedd38d98a1a56fb8d3";
|
||||||
sha256 = "0rrakbxnbsqaj148xaz2hwxjvg3cmzlynfkvcp8w56sqyly75d0n";
|
sha256 = "1p09rw7dxxqcxxrdb8wbwp2imapyjvdbvap7s9km2i9hbd8ipdif";
|
||||||
};
|
};
|
||||||
|
|
||||||
nativeBuildInputs = [ autoreconfHook ];
|
nativeBuildInputs = [ autoreconfHook ];
|
||||||
|
@ -19,11 +19,15 @@ stdenv.mkDerivation rec {
|
||||||
dontDisableStatic = true;
|
dontDisableStatic = true;
|
||||||
|
|
||||||
configureFlags = [
|
configureFlags = [
|
||||||
"--with-platform=linux-dpdk"
|
|
||||||
"--disable-shared"
|
"--disable-shared"
|
||||||
"--with-sdk-install-path=${dpdk}/${RTE_TARGET}"
|
"--with-sdk-install-path=${dpdk}/${RTE_TARGET}"
|
||||||
];
|
];
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
./configure.patch
|
||||||
|
./odp_crypto.patch
|
||||||
|
];
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
meta = with stdenv.lib; {
|
||||||
description = "Open Data Plane optimized for DPDK";
|
description = "Open Data Plane optimized for DPDK";
|
||||||
homepage = http://www.opendataplane.org;
|
homepage = http://www.opendataplane.org;
|
||||||
|
|
18
pkgs/os-specific/linux/odp-dpdk/odp_crypto.patch
Normal file
18
pkgs/os-specific/linux/odp-dpdk/odp_crypto.patch
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
diff --git a/platform/linux-dpdk/odp_crypto.c b/platform/linux-dpdk/odp_crypto.c
|
||||||
|
index d95b157805dc..d13ad5bbde95 100644
|
||||||
|
--- a/platform/linux-dpdk/odp_crypto.c
|
||||||
|
+++ b/platform/linux-dpdk/odp_crypto.c
|
||||||
|
@@ -900,11 +900,12 @@ int odp_crypto_session_create(odp_crypto_session_param_t *param,
|
||||||
|
/* Setup session */
|
||||||
|
session = rte_cryptodev_sym_session_create(cdev_id, first_xform);
|
||||||
|
|
||||||
|
- if (session == NULL)
|
||||||
|
+ if (session == NULL) {
|
||||||
|
/* remove the crypto_session_entry_t */
|
||||||
|
memset(entry, 0, sizeof(*entry));
|
||||||
|
free_session(entry);
|
||||||
|
return -1;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
entry->rte_session = (intptr_t)session;
|
||||||
|
entry->cipher_xform = cipher_xform;
|
|
@ -36,5 +36,6 @@ stdenv.mkDerivation rec {
|
||||||
license = licenses.bsd3;
|
license = licenses.bsd3;
|
||||||
platforms = [ "x86_64-linux" ];
|
platforms = [ "x86_64-linux" ];
|
||||||
maintainers = [ maintainers.abuibrahim ];
|
maintainers = [ maintainers.abuibrahim ];
|
||||||
|
broken = true;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
34
pkgs/os-specific/linux/pktgen/Makefile.patch
Normal file
34
pkgs/os-specific/linux/pktgen/Makefile.patch
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
diff --git a/app/Makefile b/app/Makefile
|
||||||
|
index 5078b9a..99b208a 100644
|
||||||
|
--- a/app/Makefile
|
||||||
|
+++ b/app/Makefile
|
||||||
|
@@ -46,29 +46,10 @@ APP = pktgen
|
||||||
|
CFLAGS += -O3 -g $(WERROR_FLAGS) -fno-stack-protector
|
||||||
|
CFLAGS += -I$(RTE_SRCDIR) -I$(RTE_SRCDIR)/../lib/common
|
||||||
|
|
||||||
|
-dpdk_ver := $(RTE_SDK)/xusertools/dpdk-version.sh
|
||||||
|
-pktgen_ver := $(RTE_SRCDIR)/../tools/dpdk-version.sh
|
||||||
|
-ver_cmd := $(if $(wildcard $(dpdk_ver)),$(dpdk_ver),$(pktgen_ver))
|
||||||
|
-# $(info ver_cmd=$(ver_cmd))
|
||||||
|
-
|
||||||
|
-yy := $(shell $(ver_cmd) -yy)
|
||||||
|
-# mm := $(shell $(ver_cmd) -mm)
|
||||||
|
-
|
||||||
|
-# $(info yy=$(yy))
|
||||||
|
-
|
||||||
|
-ifeq ($(yy),17)
|
||||||
|
COMMON_PRE := $(RTE_SRCDIR)/../lib/common
|
||||||
|
LUA_PRE := $(RTE_SRCDIR)/../lib/lua/src
|
||||||
|
CLI_PRE := $(RTE_SRCDIR)/../lib/cli
|
||||||
|
GUI_PRE := $(RTE_SRCDIR)/../gui/gui
|
||||||
|
-else
|
||||||
|
-ifeq ($(yy),16)
|
||||||
|
-COMMON_PRE := $(RTE_SRCDIR)/../lib/common/lib/common
|
||||||
|
-LUA_PRE := $(RTE_SRCDIR)/../lib/lua/src/lib/lua/src
|
||||||
|
-CLI_PRE := $(RTE_SRCDIR)/../lib/cli/lib/cli
|
||||||
|
-GUI_PRE := $(RTE_SRCDIR)/../gui
|
||||||
|
-endif
|
||||||
|
-endif
|
||||||
|
|
||||||
|
COMMON_LIB := $(COMMON_PRE)/$(RTE_TARGET)
|
||||||
|
LUA_LIB := $(LUA_PRE)/$(RTE_TARGET)
|
|
@ -5,11 +5,11 @@
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "pktgen-${version}";
|
name = "pktgen-${version}";
|
||||||
version = "3.1.0";
|
version = "3.4.0";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "http://dpdk.org/browse/apps/pktgen-dpdk/snapshot/pktgen-v${version}.tar.gz";
|
url = "http://dpdk.org/browse/apps/pktgen-dpdk/snapshot/pktgen-${version}.tar.gz";
|
||||||
sha256 = "1a1dl8h8p76wlcjlvn736mz4nc2nc5c3764rlydiz86wl45mb0nb";
|
sha256 = "0fcyb56d4mkvchi5i8s3m210f5c3xa8zbjb08ranpa1a2k1kzfg5";
|
||||||
};
|
};
|
||||||
|
|
||||||
nativeBuildInputs = stdenv.lib.optionals withGtk [ pkgconfig ];
|
nativeBuildInputs = stdenv.lib.optionals withGtk [ pkgconfig ];
|
||||||
|
@ -24,6 +24,8 @@ stdenv.mkDerivation rec {
|
||||||
|
|
||||||
NIX_CFLAGS_COMPILE = [ "-march=core2" ];
|
NIX_CFLAGS_COMPILE = [ "-march=core2" ];
|
||||||
|
|
||||||
|
patches = [ ./Makefile.patch ];
|
||||||
|
|
||||||
postPatch = ''
|
postPatch = ''
|
||||||
substituteInPlace lib/lua/src/luaconf.h --replace /usr/local $out
|
substituteInPlace lib/lua/src/luaconf.h --replace /usr/local $out
|
||||||
substituteInPlace lib/common/lscpu.h --replace /usr/bin/lscpu ${utillinux}/bin/lscpu
|
substituteInPlace lib/common/lscpu.h --replace /usr/bin/lscpu ${utillinux}/bin/lscpu
|
||||||
|
@ -31,7 +33,7 @@ stdenv.mkDerivation rec {
|
||||||
|
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
install -d $out/bin
|
install -d $out/bin
|
||||||
install -m 0755 app/app/${RTE_TARGET}/app/pktgen $out/bin
|
install -m 0755 app/${RTE_TARGET}/pktgen $out/bin
|
||||||
install -d $out/lib/lua/5.3
|
install -d $out/lib/lua/5.3
|
||||||
install -m 0644 Pktgen.lua $out/lib/lua/5.3
|
install -m 0644 Pktgen.lua $out/lib/lua/5.3
|
||||||
'';
|
'';
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue