[dpdk-dev] [PATCH v2] examples/flow_filtering: add rte_fdir_conf initialization

2018-07-21 Thread Rosen Xu
Rte_fdir_conf of rte_eth_conf should be initialized before
port initialization. It is a workaround solution when work
with Intel I40e.

Fixes: 4a3ef59a10c8 ("examples/flow_filtering: add simple demo of flow API")
Cc: sta...@dpdk.org

Signed-off-by: Rosen Xu 

v2 updates:
===
 - Take more test on I40e
 - Add comments
---
 examples/flow_filtering/main.c | 11 +++
 1 file changed, 11 insertions(+)

diff --git a/examples/flow_filtering/main.c b/examples/flow_filtering/main.c
index f595034..73d646c 100644
--- a/examples/flow_filtering/main.c
+++ b/examples/flow_filtering/main.c
@@ -132,6 +132,17 @@
DEV_TX_OFFLOAD_SCTP_CKSUM  |
DEV_TX_OFFLOAD_TCP_TSO,
},
+   /*
+* Initialize fdir_conf of ete_eth_conf
+* it is a workaround solution when work with Intel I40e
+* and it is not the normal way
+*/
+   .fdir_conf = {
+   .mode = RTE_FDIR_MODE_PERFECT,
+   .pballoc = RTE_FDIR_PBALLOC_64K,
+   .status = RTE_FDIR_REPORT_STATUS,
+   .drop_queue = 127,
+   },
};
struct rte_eth_txconf txq_conf;
struct rte_eth_rxconf rxq_conf;
-- 
1.8.3.1



[dpdk-dev] [Bug 74] PMD: i40e_dcb_init_configure(): default dcb config fails. err = -53, aq_err = 3

2018-07-21 Thread bugzilla
https://bugs.dpdk.org/show_bug.cgi?id=74

Bug ID: 74
   Summary: PMD: i40e_dcb_init_configure(): default dcb config
fails. err = -53, aq_err = 3
   Product: DPDK
   Version: 16.07
  Hardware: x86
OS: Other
Status: CONFIRMED
  Severity: normal
  Priority: Normal
 Component: ethdev
  Assignee: dev@dpdk.org
  Reporter: 1126578...@qq.com
  Target Milestone: ---

PMD: i40e_dcb_init_configure(): default dcb config fails. err = -53, aq_err = 3

There is an error when the i40e_dcb_init_configure is running. But dpdk is
normal running, it seems no effect.

:

Linux localhost.localdomain 3.10.0-514.el7.x86_64 #1 SMP Tue Nov 22 16:42:41
UTC 2016 x86_64 x86_64 x86_64 GNU/Linux


driver: i40e
version: 2.4.6
firmware-version: 4.25 0x800013f2 0.0.0
expansion-rom-version: 
bus-info: :02:00.3
supports-statistics: yes
supports-test: yes
supports-eeprom-access: yes
supports-register-dump: yes
supports-priv-flags: yes

-- 
You are receiving this mail because:
You are the assignee for the bug.

Re: [dpdk-dev] [PATCH v3] net/tap: add queues when attaching from secondary process

2018-07-21 Thread Wiles, Keith



> On Jul 20, 2018, at 4:51 PM, Thomas Monjalon  wrote:
> 
> 20/07/2018 17:35, Wiles, Keith:
>>> On Jul 20, 2018, at 4:15 AM, Thomas Monjalon  wrote:
>>> +   /* FIXME: handle replies.nb_received > 1 */
>> 
>> I am not a big fan of having TODO or FIXME comments in the code.
> 
> What don't you like in such comments?

We should not have FIXME or TODO in the code it does not look like it is 
complete, if we need to fix something then fix it or put it on a todo list not 
in the code. The same thing for the TODO which to me means a future enhancement 
we just need to add it to a future todo list.

If the code in these sections have a limitation them describe the limitation 
and remove the FIXME and TODOs from the code.

> 
>> Can we remove them and just describe the problem and what would happen
>> or not happen if the condition occurs?
> 
> You mean describing the problem in the code?
> 
>> If we need to add this support in the future then we need to put these
>> in a enhancement tracker or someplace else.
> 
> The limitation is documented in the guide (limit of 8 queues).
> 
>>> +   reply = &replies.msgs[0];
> 
> [...]
>>> +   /* FIXME: split message if more queues than RTE_MP_MAX_FD_NUM */
>> 
>> Here too.
> 
> This limitation is related to the previous one (send only one message,
> receive only message).
> 
>>> +   RTE_ASSERT(reply.num_fds <= RTE_MP_MAX_FD_NUM);
>>> +
>>> +   /* Send reply */
>>> +   strcpy(reply.name, request->name);
>>> +   strcpy(reply_param->port_name, request_param->port_name);
>> 
>> Normally we use the snprintf or strlcpy() functions for the above should we 
>> do that here too?
> 
> Yes it looks to be a good idea.
> 
> 
>>> @@ -1946,8 +2056,18 @@ rte_pmd_tap_probe(struct rte_vdev_device *dev)
>>> TAP_LOG(ERR, "Failed to probe %s", name);
>>> return -1;
>>> }
>>> -   /* TODO: request info from primary to set up Rx and Tx */
>>> eth_dev->dev_ops = &ops;
>>> +   eth_dev->rx_pkt_burst = pmd_rx_burst;
>>> +   eth_dev->tx_pkt_burst = pmd_tx_burst;
>>> +
>>> +   if (!rte_eal_primary_proc_alive(NULL)) {
>>> +   TAP_LOG(ERR, "Primary process is missing");
>>> +   return -1;
>>> +   }
>>> +   ret = tap_mp_attach_queues(name, eth_dev);
>>> +   if (ret != 0)
>>> +   return -1;
>> 
>> Does the call above need to be wrapped using if secondary process or is this 
>> for both primary and secondary?
> 
> It is already in a "secondary only" block.
> 
>>> +   /* Register IPC feed callback */
>>> +   ret = rte_mp_action_register(TAP_MP_KEY, tap_mp_sync_queues);
>>> +   if (ret < 0 && rte_errno != EEXIST) {
>>> +   TAP_LOG(ERR, "%s: Failed to register IPC callback: %s",
>>> +   tuntap_name, strerror(rte_errno));
>>> +   goto leave;
>>> +   }
>> 
>> Same for this one as above?
> 
> This code path is executed only in primary or creation of port in secondary.
> I think it is fine.
> 
> However I am thinking it should be registered only once for all TAP ports.
> 
> 

Regards,
Keith



Re: [dpdk-dev] Does lthread_cond_wait need a mutex?

2018-07-21 Thread Wiles, Keith



> On Jul 20, 2018, at 8:32 PM, wubenq...@ruijie.com.cn wrote:
> 
> Hi~
> I would be appreciate it if you could provide your lthread code for me. 
> And I found that DPDK lthreads does not provide lthread_cond_timedwait API 
> which I am looking for.
> Thanks.

I took the lthread code and renamed it and did a number of changes, so it will 
not be easy to drop into the lthread code as it is not just these functions 
that have to change. I am very hesitant to give that code out as it is still a 
work in progress and may not even work correctly in all cases.

I will have a look at the code and see what I can do, but I make no promises.

> 
> Regards,
> Wubenqing
>  

Regards,
Keith



[dpdk-dev] [PATCH v2] test: add unit tests for metrics library

2018-07-21 Thread Hari kumar Vemula
From: Hari Kumar Vemula 

Unit testcases are added for metrics library.

Signed-off-by: Hari Kumar Vemula 
Reviewed-by: Reshma Pattan 
Reviewed-by: Remy Horton 
---
v2: Removal of overstated array size based testcases as suggested
---
 test/test/Makefile   |   2 +
 test/test/test_metrics.c | 307 +++
 2 files changed, 309 insertions(+)
 create mode 100644 test/test/test_metrics.c

diff --git a/test/test/Makefile b/test/test/Makefile
index e6967bab6..30bc53087 100644
--- a/test/test/Makefile
+++ b/test/test/Makefile
@@ -183,6 +183,8 @@ SRCS-$(CONFIG_RTE_LIBRTE_CRYPTODEV) += 
test_cryptodev_blockcipher.c
 SRCS-$(CONFIG_RTE_LIBRTE_CRYPTODEV) += test_cryptodev.c
 SRCS-$(CONFIG_RTE_LIBRTE_CRYPTODEV) += test_cryptodev_asym.c
 
+SRCS-$(CONFIG_RTE_LIBRTE_METRICS) += test_metrics.c
+
 ifeq ($(CONFIG_RTE_COMPRESSDEV_TEST),y)
 SRCS-$(CONFIG_RTE_LIBRTE_COMPRESSDEV) += test_compressdev.c
 endif
diff --git a/test/test/test_metrics.c b/test/test/test_metrics.c
new file mode 100644
index 0..d01f381cd
--- /dev/null
+++ b/test/test/test_metrics.c
@@ -0,0 +1,307 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright(c) 2018 Intel Corporation
+ */
+
+#include 
+#include 
+
+#include 
+#include 
+#include 
+
+#include "test.h"
+
+#define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
+#defineREG_METRIC_COUNT6
+#defineMETRIC_LESSER_COUNT 3
+#defineKEY 1
+#defineVALUE   1
+
+/* Initializes metric module. This function must be called
+ * from a primary process before metrics are used
+ */
+static int
+test_metrics_init(void)
+{
+   rte_metrics_init(rte_socket_id());
+   return TEST_SUCCESS;
+}
+
+ /* Test Case to check failures when memzone init is not done */
+static int
+test_metrics_without_init(void)
+{
+   int err = 0;
+   const uint64_t  value[REG_METRIC_COUNT] = {0};
+   const char * const mnames[] = {
+   "mean_bits_in", "mean_bits_out",
+   "peak_bits_in", "peak_bits_out",
+   };
+
+   /* Failure Test: Checking for memzone initialization */
+   err = rte_metrics_reg_name(NULL);
+   TEST_ASSERT(err == -EIO, "%s, %d", __func__, __LINE__);
+
+   err = rte_metrics_reg_names(&mnames[0], 1);
+   TEST_ASSERT(err == -EIO, "%s, %d", __func__, __LINE__);
+
+   err = rte_metrics_update_value(RTE_METRICS_GLOBAL, KEY, VALUE);
+   TEST_ASSERT(err == -EIO, "%s, %d", __func__, __LINE__);
+
+   err = rte_metrics_update_values(RTE_METRICS_GLOBAL, KEY, &value[0], 4);
+   TEST_ASSERT(err == -EIO, "%s, %d", __func__, __LINE__);
+
+   err = rte_metrics_get_names(NULL, 0);
+   TEST_ASSERT(err == 0, "%s, %d", __func__, __LINE__);
+
+   err = rte_metrics_get_values(RTE_METRICS_GLOBAL, NULL, 0);
+   TEST_ASSERT(err == 0, "%s, %d", __func__, __LINE__);
+
+   return TEST_SUCCESS;
+}
+
+/* Test Case to validate registering a single metric */
+static int
+test_metrics_reg_name_with_validname(void)
+{
+   int err = 0;
+
+   /* Test to register the new metric name */
+   err = rte_metrics_reg_name("peak_bits_out");
+   TEST_ASSERT(err >= 0, "%s, %d", __func__, __LINE__);
+
+   /* Test to register the same metric name */
+   err = rte_metrics_reg_name("peak_bits_out");
+   TEST_ASSERT(err >= 0, "%s, %d", __func__, __LINE__);
+
+   /* Test case to validate registering a invalid metric */
+   err = rte_metrics_reg_name(NULL);
+   TEST_ASSERT(err == -EINVAL, "%s, %d", __func__, __LINE__);
+
+   return TEST_SUCCESS;
+}
+
+/* Test case to validate registering a list of valid  metric names */
+static int
+test_metrics_reg_names(void)
+{
+   int err = 0;
+   const char * const mnames[] = {
+   "mean_bits_in", "mean_bits_out",
+   "peak_bits_in", "peak_bits_out",
+   };
+
+   /* Success Test: valid array and count size */
+   err = rte_metrics_reg_names(&mnames[0], ARRAY_SIZE(mnames));
+   TEST_ASSERT(err >= 0, "%s, %d", __func__, __LINE__);
+
+   return TEST_SUCCESS;
+}
+
+/* Test case to validate update a metric */
+static int
+test_metrics_update_value(void)
+{
+   int err = 0;
+
+   /* Successful Test: Valid port_id, key and value */
+   err = rte_metrics_update_value(RTE_METRICS_GLOBAL, KEY, VALUE);
+   TEST_ASSERT(err >= 0, "%s, %d", __func__, __LINE__);
+
+   /* Successful Test: Valid port_id otherthan RTE_METRICS_GLOBAL, key
+* and value
+*/
+   err = rte_metrics_update_value(9, KEY, VALUE);
+   TEST_ASSERT(err >= 0, "%s, %d", __func__, __LINE__);
+
+   /* Failed Test: Invalid port_id with lower value */
+   err = rte_metrics_update_value(-2, KEY, VALUE);
+   TEST_ASSERT(err == -EINVAL, "%s, %d", __func__, __LINE__);
+
+   /* Failed Test: Invalid port_id with higher value */
+   err = rte_metrics_update_value(39, KEY, VALUE);
+   TEST_ASSERT(err == -EINVAL, "%s, %d", __func__, __LI

[dpdk-dev] [PATCH v3 0/5] compress: add ZLIB compression PMD

2018-07-21 Thread Shally Verma
This patch series add software zlib library (http://zlib.net/)
based compression PMD in DPDK compress drivers.

Application must need to install zlib prior to enabling
this PMD to avail compression/decompression services.
Currently driver only tested for deflate, stateless
compression and decompression.

Changes in v3:
- added comp_feature_flags to compressdev_capabilities
- removed stream_create as stateful not supported
- changed compression strategy to DEFAULT_STRATEGY
- Simplified core processing logic
- fix doc build error
- other v2 feedbacks

TBDs
- No change to current qp enqueue_err stats update.
- PMD increment enqd_err stats, if it fails to push op
  into completion queue. This logic to be revisited based on
  further discussion

Changes in v2:
- removed unused variables
- corrected capability to reflect current support
- add lookup for internally maintained mempool during device_configure
- optimized core compression/decompression logic in enq/deq APIs
- updated documentation with correct feature support

v1 includes:
- build changes to build zlib PMD
- zlib PMD implementation
- zlib PMD documentation
- meson build support

This patchset is dependent upon compressdev API.


Ashish Gupta (2):
  compress/zlib: add ZLIB PMD
  compress/zlib: add device PMD ops

Shally Verma (1):
  doc: add ZLIB PMD guide

Sunila Sahu (2):
  compress/zlib: create private xform
  compress/zlib: support burst enqueue/dequeue

 MAINTAINERS|   5 +
 config/common_base |   5 +
 doc/guides/compressdevs/features/zlib.ini  |  11 +
 doc/guides/compressdevs/index.rst  |   1 +
 doc/guides/compressdevs/zlib.rst   |  69 
 drivers/compress/Makefile  |   1 +
 drivers/compress/meson.build   |   2 +-
 drivers/compress/zlib/Makefile |  29 ++
 drivers/compress/zlib/meson.build  |  14 +
 drivers/compress/zlib/rte_pmd_zlib_version.map |   3 +
 drivers/compress/zlib/zlib_pmd.c   | 425 +
 drivers/compress/zlib/zlib_pmd_ops.c   | 308 ++
 drivers/compress/zlib/zlib_pmd_private.h   |  71 +
 mk/rte.app.mk  |   2 +
 14 files changed, 945 insertions(+), 1 deletion(-)
 create mode 100644 doc/guides/compressdevs/features/zlib.ini
 create mode 100644 doc/guides/compressdevs/zlib.rst
 create mode 100644 drivers/compress/zlib/Makefile
 create mode 100644 drivers/compress/zlib/meson.build
 create mode 100644 drivers/compress/zlib/rte_pmd_zlib_version.map
 create mode 100644 drivers/compress/zlib/zlib_pmd.c
 create mode 100644 drivers/compress/zlib/zlib_pmd_ops.c
 create mode 100644 drivers/compress/zlib/zlib_pmd_private.h

-- 
2.9.5



[dpdk-dev] [PATCH v3 1/5] compress/zlib: add ZLIB PMD

2018-07-21 Thread Shally Verma
From: Ashish Gupta 

Add initial PMD setup routines in compressdev
framework. ZLIB PMD appears as virtual compression
device. User would need to install zlib prior to
enabling this PMD.

Signed-off-by: Sunila Sahu 
Signed-off-by: Shally Verma 
Signed-off-by: Ashish Gupta 
---
 MAINTAINERS|  3 +
 config/common_base |  5 ++
 drivers/compress/Makefile  |  1 +
 drivers/compress/meson.build   |  2 +-
 drivers/compress/zlib/Makefile | 28 +
 drivers/compress/zlib/meson.build  | 14 +
 drivers/compress/zlib/rte_pmd_zlib_version.map |  3 +
 drivers/compress/zlib/zlib_pmd.c   | 78 ++
 drivers/compress/zlib/zlib_pmd_private.h   | 32 +++
 mk/rte.app.mk  |  2 +
 10 files changed, 167 insertions(+), 1 deletion(-)

diff --git a/MAINTAINERS b/MAINTAINERS
index 7b2414d..ca27c6f 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -872,6 +872,9 @@ M: Fiona Trahe 
 F: drivers/compress/qat/
 F: drivers/common/qat/
 
+ZLIB
+M: Sunila Sahu 
+F: drivers/compress/zlib/
 
 Eventdev Drivers
 
diff --git a/config/common_base b/config/common_base
index a061c21..d9b238c 100644
--- a/config/common_base
+++ b/config/common_base
@@ -582,6 +582,11 @@ CONFIG_RTE_COMPRESSDEV_TEST=n
 CONFIG_RTE_LIBRTE_PMD_ISAL=n
 
 #
+# Compile PMD for ZLIB compression device
+#
+CONFIG_RTE_LIBRTE_PMD_ZLIB=n
+
+#
 # Compile generic event device library
 #
 CONFIG_RTE_LIBRTE_EVENTDEV=y
diff --git a/drivers/compress/Makefile b/drivers/compress/Makefile
index 592497f..1f159a5 100644
--- a/drivers/compress/Makefile
+++ b/drivers/compress/Makefile
@@ -4,5 +4,6 @@
 include $(RTE_SDK)/mk/rte.vars.mk
 
 DIRS-$(CONFIG_RTE_LIBRTE_PMD_ISAL) += isal
+DIRS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib
 
 include $(RTE_SDK)/mk/rte.subdir.mk
diff --git a/drivers/compress/meson.build b/drivers/compress/meson.build
index 2352ad5..d2ca8fc 100644
--- a/drivers/compress/meson.build
+++ b/drivers/compress/meson.build
@@ -1,7 +1,7 @@
 # SPDX-License-Identifier: BSD-3-Clause
 # Copyright(c) 2018 Intel Corporation
 
-drivers = ['isal', 'qat']
+drivers = ['isal', 'qat', 'zlib']
 
 std_deps = ['compressdev'] # compressdev pulls in all other needed deps
 config_flag_fmt = 'RTE_LIBRTE_@0@_PMD'
diff --git a/drivers/compress/zlib/Makefile b/drivers/compress/zlib/Makefile
new file mode 100644
index 000..bd322c9
--- /dev/null
+++ b/drivers/compress/zlib/Makefile
@@ -0,0 +1,28 @@
+# SPDX-License-Identifier: BSD-3-Clause
+# Copyright(c) 2018 Cavium Networks
+
+include $(RTE_SDK)/mk/rte.vars.mk
+
+# library name
+LIB = librte_pmd_zlib.a
+
+# build flags
+CFLAGS += -O3
+CFLAGS += $(WERROR_FLAGS)
+CFLAGS += -DALLOW_EXPERIMENTAL_API
+
+# library version
+LIBABIVER := 1
+
+# versioning export map
+EXPORT_MAP := rte_pmd_zlib_version.map
+
+# external library dependencies
+LDLIBS += -lrte_eal -lrte_mbuf -lrte_mempool -lrte_ring -lz
+LDLIBS += -lrte_compressdev
+LDLIBS += -lrte_bus_vdev
+
+# library source files
+SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd.c
+
+include $(RTE_SDK)/mk/rte.lib.mk
diff --git a/drivers/compress/zlib/meson.build 
b/drivers/compress/zlib/meson.build
new file mode 100644
index 000..3f0a77b
--- /dev/null
+++ b/drivers/compress/zlib/meson.build
@@ -0,0 +1,14 @@
+# SPDX-License-Identifier: BSD-3-Clause
+# Copyright(c) 2018 Cavium Networks
+
+dep = dependency('zlib', required: false)
+if not dep.found()
+   build = false
+endif
+
+deps += 'bus_vdev'
+sources = files('zlib_pmd.c')
+ext_deps += dep
+pkgconfig_extra_libs += '-lz'
+
+allow_experimental_apis = true
diff --git a/drivers/compress/zlib/rte_pmd_zlib_version.map 
b/drivers/compress/zlib/rte_pmd_zlib_version.map
new file mode 100644
index 000..ad6e191
--- /dev/null
+++ b/drivers/compress/zlib/rte_pmd_zlib_version.map
@@ -0,0 +1,3 @@
+DPDK_18.08 {
+   local: *;
+};
diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c
new file mode 100644
index 000..39d3628
--- /dev/null
+++ b/drivers/compress/zlib/zlib_pmd.c
@@ -0,0 +1,78 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright(c) 2018 Cavium Networks
+ */
+
+#include 
+#include 
+
+#include "zlib_pmd_private.h"
+
+static int
+zlib_create(const char *name,
+   struct rte_vdev_device *vdev,
+   struct rte_compressdev_pmd_init_params *init_params)
+{
+   struct rte_compressdev *dev;
+
+   dev = rte_compressdev_pmd_create(name, &vdev->device,
+   sizeof(struct zlib_private), init_params);
+   if (dev == NULL) {
+   ZLIB_PMD_ERR("driver %s: create failed", init_params->name);
+   return -ENODEV;
+   }
+
+   return 0;
+}
+
+static int
+zlib_probe(struct rte_vdev_device *vdev)
+{
+   struct rte_compressdev_pmd_init_params init_params = {
+   "",
+   rte_socket_id()
+   };
+   const cha

[dpdk-dev] [PATCH v3 2/5] compress/zlib: add device PMD ops

2018-07-21 Thread Shally Verma
From: Ashish Gupta 

Implement device configure and queue pair
setup PMD ops

Signed-off-by: Sunila Sahu 
Signed-off-by: Shally Verma 
Signed-off-by: Ashish Gupta 
---
 drivers/compress/zlib/Makefile   |   1 +
 drivers/compress/zlib/meson.build|   2 +-
 drivers/compress/zlib/zlib_pmd.c |   2 +
 drivers/compress/zlib/zlib_pmd_ops.c | 238 +++
 drivers/compress/zlib/zlib_pmd_private.h |  35 +
 5 files changed, 277 insertions(+), 1 deletion(-)

diff --git a/drivers/compress/zlib/Makefile b/drivers/compress/zlib/Makefile
index bd322c9..5cf8de6 100644
--- a/drivers/compress/zlib/Makefile
+++ b/drivers/compress/zlib/Makefile
@@ -24,5 +24,6 @@ LDLIBS += -lrte_bus_vdev
 
 # library source files
 SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd.c
+SRCS-$(CONFIG_RTE_LIBRTE_PMD_ZLIB) += zlib_pmd_ops.c
 
 include $(RTE_SDK)/mk/rte.lib.mk
diff --git a/drivers/compress/zlib/meson.build 
b/drivers/compress/zlib/meson.build
index 3f0a77b..7748de2 100644
--- a/drivers/compress/zlib/meson.build
+++ b/drivers/compress/zlib/meson.build
@@ -7,7 +7,7 @@ if not dep.found()
 endif
 
 deps += 'bus_vdev'
-sources = files('zlib_pmd.c')
+sources = files('zlib_pmd.c', 'zlib_pmd_ops.c')
 ext_deps += dep
 pkgconfig_extra_libs += '-lz'
 
diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c
index 39d3628..9363808 100644
--- a/drivers/compress/zlib/zlib_pmd.c
+++ b/drivers/compress/zlib/zlib_pmd.c
@@ -21,6 +21,8 @@ zlib_create(const char *name,
return -ENODEV;
}
 
+   dev->dev_ops = rte_zlib_pmd_ops;
+
return 0;
 }
 
diff --git a/drivers/compress/zlib/zlib_pmd_ops.c 
b/drivers/compress/zlib/zlib_pmd_ops.c
new file mode 100644
index 000..645c5b1
--- /dev/null
+++ b/drivers/compress/zlib/zlib_pmd_ops.c
@@ -0,0 +1,238 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright(c) 2018 Cavium Networks
+ */
+
+#include 
+
+#include 
+#include 
+
+#include "zlib_pmd_private.h"
+
+static const struct rte_compressdev_capabilities zlib_pmd_capabilities[] = {
+   {   /* Deflate */
+   .algo = RTE_COMP_ALGO_DEFLATE,
+   .comp_feature_flags = (RTE_COMP_FF_NONCOMPRESSED_BLOCKS |
+   RTE_COMP_FF_HUFFMAN_FIXED |
+   RTE_COMP_FF_HUFFMAN_DYNAMIC |
+   RTE_COMP_FF_OOP_SGL_IN_SGL_OUT),
+   .window_size = {
+   .min = 8,
+   .max = 15,
+   .increment = 1
+   },
+   },
+
+   RTE_COMP_END_OF_CAPABILITIES_LIST()
+
+};
+
+/** Configure device */
+static int
+zlib_pmd_config(struct rte_compressdev *dev,
+   struct rte_compressdev_config *config)
+{
+   struct rte_mempool *mp;
+   char mp_name[RTE_MEMPOOL_NAMESIZE];
+   struct zlib_private *internals = dev->data->dev_private;
+
+   snprintf(mp_name, RTE_MEMPOOL_NAMESIZE,
+   "stream_mp_%u", dev->data->dev_id);
+   mp = internals->mp;
+   if (mp == NULL) {
+   mp = rte_mempool_create(mp_name,
+   config->max_nb_priv_xforms +
+   config->max_nb_streams,
+   sizeof(struct zlib_priv_xform),
+   0, 0, NULL, NULL, NULL,
+   NULL, config->socket_id,
+   0);
+   if (mp == NULL) {
+   ZLIB_PMD_ERR("Cannot create private xform pool on "
+   "socket %d\n", config->socket_id);
+   return -ENOMEM;
+   }
+   internals->mp = mp;
+   }
+   return 0;
+}
+
+/** Start device */
+static int
+zlib_pmd_start(__rte_unused struct rte_compressdev *dev)
+{
+   return 0;
+}
+
+/** Stop device */
+static void
+zlib_pmd_stop(__rte_unused struct rte_compressdev *dev)
+{
+}
+
+/** Close device */
+static int
+zlib_pmd_close(struct rte_compressdev *dev)
+{
+   struct zlib_private *internals = dev->data->dev_private;
+   rte_mempool_free(internals->mp);
+   internals->mp = NULL;
+   return 0;
+}
+
+/** Get device statistics */
+static void
+zlib_pmd_stats_get(struct rte_compressdev *dev,
+   struct rte_compressdev_stats *stats)
+{
+   int qp_id;
+
+   for (qp_id = 0; qp_id < dev->data->nb_queue_pairs; qp_id++) {
+   struct zlib_qp *qp = dev->data->queue_pairs[qp_id];
+
+   stats->enqueued_count += qp->qp_stats.enqueued_count;
+   stats->dequeued_count += qp->qp_stats.dequeued_count;
+
+   stats->enqueue_err_count += qp->qp_stats.enqueue_err_count;
+   stats->dequeue_err_count += qp->qp_stats.dequeue_err_count;
+   }
+}
+
+/** Reset device statistics */
+static void
+zlib_pmd_stats_reset(struct rte_compressdev *dev)
+{
+   int qp_id;
+
+   for (qp_id = 0; qp_i

[dpdk-dev] [PATCH v3 4/5] compress/zlib: support burst enqueue/dequeue

2018-07-21 Thread Shally Verma
From: Sunila Sahu 

Signed-off-by: Sunila Sahu 
Signed-off-by: Shally Verma 
Signed-off-by: Ashish Gupta 
---
 drivers/compress/zlib/zlib_pmd.c | 254 ++-
 1 file changed, 253 insertions(+), 1 deletion(-)

diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c
index 9a464ee..44baa67 100644
--- a/drivers/compress/zlib/zlib_pmd.c
+++ b/drivers/compress/zlib/zlib_pmd.c
@@ -7,7 +7,213 @@
 
 #include "zlib_pmd_private.h"
 
-/** Parse comp xform and set private xform/stream parameters */
+/** Compute next mbuf in the list, assign data buffer and length,
+ *  returns 0 if mbuf is NULL
+ */
+#define COMPUTE_BUF(mbuf, data, len)   \
+   ((mbuf = mbuf->next) ?  \
+   (data = rte_pktmbuf_mtod(mbuf, uint8_t *)), \
+   (len = rte_pktmbuf_data_len(mbuf)) : 0)
+
+static void
+process_zlib_deflate(struct rte_comp_op *op, z_stream *strm)
+{
+   int ret, flush, fin_flush;
+   struct rte_mbuf *mbuf_src = op->m_src;
+   struct rte_mbuf *mbuf_dst = op->m_dst;
+
+   switch (op->flush_flag) {
+   case RTE_COMP_FLUSH_FULL:
+   case RTE_COMP_FLUSH_FINAL:
+   fin_flush = Z_FINISH;
+   break;
+   default:
+   op->status = RTE_COMP_OP_STATUS_INVALID_ARGS;
+   ZLIB_PMD_ERR("Invalid flush value\n");
+   }
+
+   if (unlikely(!strm)) {
+   op->status = RTE_COMP_OP_STATUS_INVALID_ARGS;
+   ZLIB_PMD_ERR("Invalid z_stream\n");
+   return;
+   }
+   /* Update z_stream with the inputs provided by application */
+   strm->next_in = rte_pktmbuf_mtod_offset(mbuf_src, uint8_t *,
+   op->src.offset);
+
+   strm->avail_in = rte_pktmbuf_data_len(mbuf_src) - op->src.offset;
+
+   strm->next_out = rte_pktmbuf_mtod_offset(mbuf_dst, uint8_t *,
+   op->dst.offset);
+
+   strm->avail_out = rte_pktmbuf_data_len(mbuf_dst) - op->dst.offset;
+
+   /* Set flush value to NO_FLUSH unless it is last mbuf */
+   flush = Z_NO_FLUSH;
+   /* Initialize status to SUCCESS */
+   op->status = RTE_COMP_OP_STATUS_SUCCESS;
+
+   do {
+   /* Set flush value to Z_FINISH for last block */
+   if ((op->src.length - strm->total_in) <= strm->avail_in) {
+   strm->avail_in = (op->src.length - strm->total_in);
+   flush = fin_flush;
+   }
+   do {
+   ret = deflate(strm, flush);
+   if (unlikely(ret == Z_STREAM_ERROR)) {
+   /* error return, do not process further */
+   op->status =  RTE_COMP_OP_STATUS_ERROR;
+   goto def_end;
+   }
+   /* Break if Z_STREAM_END is encountered */
+   if (ret == Z_STREAM_END)
+   goto def_end;
+
+   /* Keep looping until input mbuf is consumed.
+* Exit if destination mbuf gets exhausted.
+*/
+   } while ((strm->avail_out == 0) &&
+   COMPUTE_BUF(mbuf_dst, strm->next_out, strm->avail_out));
+
+   if (!strm->avail_out) {
+   /* there is no space for compressed output */
+   op->status = RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED;
+   break;
+   }
+
+   /* Update source buffer to next mbuf
+* Exit if input buffers are fully consumed
+*/
+   } while (COMPUTE_BUF(mbuf_src, strm->next_in, strm->avail_in));
+
+def_end:
+   /* Update op stats */
+   switch (op->status) {
+   case RTE_COMP_OP_STATUS_SUCCESS:
+   op->consumed += strm->total_in;
+   case RTE_COMP_OP_STATUS_OUT_OF_SPACE_TERMINATED:
+   op->produced += strm->total_out;
+   break;
+   default:
+   ZLIB_PMD_ERR("stats not updated for status:%d\n",
+   op->status);
+   }
+
+   deflateReset(strm);
+}
+
+static void
+process_zlib_inflate(struct rte_comp_op *op, z_stream *strm)
+{
+   int ret, flush;
+   struct rte_mbuf *mbuf_src = op->m_src;
+   struct rte_mbuf *mbuf_dst = op->m_dst;
+
+   if (unlikely(!strm)) {
+   op->status = RTE_COMP_OP_STATUS_INVALID_ARGS;
+   ZLIB_PMD_ERR("Invalid z_stream\n");
+   return;
+   }
+   strm->next_in = rte_pktmbuf_mtod_offset(mbuf_src, uint8_t *,
+   op->src.offset);
+
+   strm->avail_in = rte_pktmbuf_data_len(mbuf_src) - op->src.offset;
+
+   strm->next_out = rte_pktmbuf_mtod_offset(mbuf_dst, uint8_t *,
+   op->dst.offset);
+
+   strm->avail_out = rte_pktmbuf_data_len(mbuf_dst) - op->dst.offset;
+
+   /** Ignoring flush value provided from application for de

[dpdk-dev] [PATCH v3 3/5] compress/zlib: create private xform

2018-07-21 Thread Shally Verma
From: Sunila Sahu 

Create non-shareable private xform for stateless
operation processing

Signed-off-by: Sunila Sahu 
Signed-off-by: Shally Verma 
Signed-off-by: Ashish Gupta 
---
 drivers/compress/zlib/zlib_pmd.c | 93 
 drivers/compress/zlib/zlib_pmd_ops.c | 74 -
 drivers/compress/zlib/zlib_pmd_private.h |  4 ++
 3 files changed, 169 insertions(+), 2 deletions(-)

diff --git a/drivers/compress/zlib/zlib_pmd.c b/drivers/compress/zlib/zlib_pmd.c
index 9363808..9a464ee 100644
--- a/drivers/compress/zlib/zlib_pmd.c
+++ b/drivers/compress/zlib/zlib_pmd.c
@@ -7,6 +7,99 @@
 
 #include "zlib_pmd_private.h"
 
+/** Parse comp xform and set private xform/stream parameters */
+int
+zlib_set_stream_parameters(const struct rte_comp_xform *xform,
+   struct zlib_stream *stream)
+{
+   int strategy, level, wbits;
+   z_stream *strm = &stream->strm;
+
+   /* allocate deflate state */
+   strm->zalloc = Z_NULL;
+   strm->zfree = Z_NULL;
+   strm->opaque = Z_NULL;
+
+   switch (xform->type) {
+   case RTE_COMP_COMPRESS:
+   /** Compression window bits */
+   switch (xform->compress.algo) {
+   case RTE_COMP_ALGO_DEFLATE:
+   wbits = -(xform->compress.window_size);
+   break;
+   default:
+   ZLIB_PMD_ERR("Compression algorithm not supported\n");
+   return -1;
+   }
+   /** Compression Level */
+   switch (xform->compress.level) {
+   case RTE_COMP_LEVEL_PMD_DEFAULT:
+   level = Z_DEFAULT_COMPRESSION;
+   break;
+   case RTE_COMP_LEVEL_NONE:
+   level = Z_NO_COMPRESSION;
+   break;
+   case RTE_COMP_LEVEL_MIN:
+   level = Z_BEST_SPEED;
+   break;
+   case RTE_COMP_LEVEL_MAX:
+   level = Z_BEST_COMPRESSION;
+   break;
+   default:
+   level = xform->compress.level;
+   if (level < RTE_COMP_LEVEL_MIN ||
+   level > RTE_COMP_LEVEL_MAX) {
+   ZLIB_PMD_ERR("Compression level %d "
+   "not supported\n",
+   level);
+   return -1;
+   }
+   }
+   /** Compression strategy */
+   switch (xform->compress.deflate.huffman) {
+   case RTE_COMP_HUFFMAN_DEFAULT:
+   strategy = Z_DEFAULT_STRATEGY;
+   break;
+   case RTE_COMP_HUFFMAN_FIXED:
+   strategy = Z_FIXED;
+   break;
+   case RTE_COMP_HUFFMAN_DYNAMIC:
+   strategy = Z_DEFAULT_STRATEGY;
+   break;
+   default:
+   ZLIB_PMD_ERR("Compression strategy not supported\n");
+   return -1;
+   }
+   if (deflateInit2(strm, level,
+   Z_DEFLATED, wbits,
+   DEF_MEM_LEVEL, strategy) != Z_OK) {
+   ZLIB_PMD_ERR("Deflate init failed\n");
+   return -1;
+   }
+   break;
+
+   case RTE_COMP_DECOMPRESS:
+   /** window bits */
+   switch (xform->decompress.algo) {
+   case RTE_COMP_ALGO_DEFLATE:
+   wbits = -(xform->decompress.window_size);
+   break;
+   default:
+   ZLIB_PMD_ERR("Compression algorithm not supported\n");
+   return -1;
+   }
+
+   if (inflateInit2(strm, wbits) != Z_OK) {
+   ZLIB_PMD_ERR("Inflate init failed\n");
+   return -1;
+   }
+   break;
+   default:
+   return -1;
+   }
+   return 0;
+}
+
 static int
 zlib_create(const char *name,
struct rte_vdev_device *vdev,
diff --git a/drivers/compress/zlib/zlib_pmd_ops.c 
b/drivers/compress/zlib/zlib_pmd_ops.c
index 645c5b1..2fb6a85 100644
--- a/drivers/compress/zlib/zlib_pmd_ops.c
+++ b/drivers/compress/zlib/zlib_pmd_ops.c
@@ -214,6 +214,76 @@ zlib_pmd_qp_setup(struct rte_compressdev *dev, uint16_t 
qp_id,
return -1;
 }
 
+/** Configure stream */
+static int
+zlib_pmd_stream_create(struct rte_compressdev *dev,
+   const struct rte_comp_xform *xform,
+   void **zstream)
+{
+   int ret = 0;
+   struct zlib_stream *stream;
+   struct zlib_private *internals = dev->data->dev_private;
+
+   if (xform == NULL) {
+  

[dpdk-dev] [PATCH v3 5/5] doc: add ZLIB PMD guide

2018-07-21 Thread Shally Verma
Add zlib pmd feature support and user guide with
build and run instructions

Signed-off-by: Sunila Sahu 
Signed-off-by: Shally Verma 
Signed-off-by: Ashish Gupta 
---
 MAINTAINERS   |  2 +
 doc/guides/compressdevs/features/zlib.ini | 11 +
 doc/guides/compressdevs/index.rst |  1 +
 doc/guides/compressdevs/zlib.rst  | 69 +++
 4 files changed, 83 insertions(+)

diff --git a/MAINTAINERS b/MAINTAINERS
index ca27c6f..7e3c450 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -875,6 +875,8 @@ F: drivers/common/qat/
 ZLIB
 M: Sunila Sahu 
 F: drivers/compress/zlib/
+F: doc/guides/compressdevs/zlib.rst
+F: doc/guides/compressdevs/features/zlib.ini
 
 Eventdev Drivers
 
diff --git a/doc/guides/compressdevs/features/zlib.ini 
b/doc/guides/compressdevs/features/zlib.ini
new file mode 100644
index 000..c794643
--- /dev/null
+++ b/doc/guides/compressdevs/features/zlib.ini
@@ -0,0 +1,11 @@
+;
+; Refer to default.ini for the full list of available PMD features.
+;
+; Supported features of 'ZLIB' compression driver.
+;
+[Features]
+Pass-through   = Y
+Deflate= Y
+Fixed  = Y
+Dynamic= Y
+OOP SGL In SGL Out  = Y
diff --git a/doc/guides/compressdevs/index.rst 
b/doc/guides/compressdevs/index.rst
index 4228768..6ba6641 100644
--- a/doc/guides/compressdevs/index.rst
+++ b/doc/guides/compressdevs/index.rst
@@ -12,3 +12,4 @@ Compression Device Drivers
 overview
 isal
 qat_comp
+zlib
diff --git a/doc/guides/compressdevs/zlib.rst b/doc/guides/compressdevs/zlib.rst
new file mode 100644
index 000..c020792
--- /dev/null
+++ b/doc/guides/compressdevs/zlib.rst
@@ -0,0 +1,69 @@
+..  SPDX-License-Identifier: BSD-3-Clause
+Copyright(c) 2018 Cavium Networks.
+
+ZLIB Compression Poll Mode Driver
+==
+
+The ZLIB PMD (**librte_pmd_zlib**) provides poll mode compression &
+decompression driver based on SW zlib library,
+
+Features
+
+
+ZLIB PMD has support for:
+
+Compression/Decompression algorithm:
+
+* DEFLATE
+
+Huffman code type:
+
+* FIXED
+* DYNAMIC
+
+Window size support:
+
+* Min - 256 bytes
+* Max - 32K
+
+Limitations
+---
+
+* Stateful  not supported.
+
+Installation
+
+
+* To build DPDK with ZLIB library, the user is required to download the 
``libz`` library.
+* Use following command for installation.
+
+* For Fedora users::
+ sudo yum install zlib-devel
+* For Ubuntu users::
+ sudo apt-get install zlib1g-dev
+
+* Once downloaded, the user needs to build the library.
+
+* To build from sources
+  download zlib sources from http://zlib.net/ and do following before building 
DPDK::
+
+make
+sudo make install
+
+Initialization
+--
+
+In order to enable this virtual compression PMD, user must:
+
+* Set ``CONFIG_RTE_LIBRTE_PMD_ZLIB=y`` in config/common_base.
+
+To use the PMD in an application, user must:
+
+* Call ``rte_vdev_init("compress_zlib")`` within the application.
+
+* Use ``--vdev="compress_zlib"`` in the EAL options, which will call 
``rte_vdev_init()`` internally.
+
+The following parameter (optional) can be provided in the previous two calls:
+
+* ``socket_id:`` Specify the socket where the memory for the device is going 
to be allocated
+  (by default, socket_id will be the socket where the core that is creating 
the PMD is running on).
-- 
2.9.5



[dpdk-dev] Patch compilation failure

2018-07-21 Thread Fu, Qiaobin
Dear DPDK developers,

When I submitted a DPDK patch (http://patchwork.dpdk.org/patch/43090/), 
however, there is a compilation issue 
(http://mails.dpdk.org/archives/test-report/2018-July/060307.html).

When I tried to compile it in our local machine using the Target: 
x86_64-native-linuxapp-gcc-shared, it shows that

make[1]: *** No rule to make target 
‘~/dpdk/config/defconfig_x86_64-native-linuxapp-gcc-shared’

I checked the latest DPDK code, and it indeed doesn’t include the above target 
rule. I did some research online, however, I didn’t figure this out. Could you 
please help this?

Thanks,
Qiaobin

Re: [dpdk-dev] [PATCH v2] examples/flow_filtering: add rte_fdir_conf initialization

2018-07-21 Thread Ori Kam



> -Original Message-
> From: Rosen Xu [mailto:rosen...@intel.com]
> Sent: Saturday, July 21, 2018 10:50 AM
> To: dev@dpdk.org
> Cc: rosen...@intel.com; ferruh.yi...@intel.com; Ori Kam
> ; walter.e.gilm...@intel.com; qi.z.zh...@intel.com;
> sta...@dpdk.org
> Subject: [PATCH v2] examples/flow_filtering: add rte_fdir_conf initialization
> 
> Rte_fdir_conf of rte_eth_conf should be initialized before
> port initialization. It is a workaround solution when work
> with Intel I40e.
> 
> Fixes: 4a3ef59a10c8 ("examples/flow_filtering: add simple demo of flow
> API")
> Cc: sta...@dpdk.org
> 
> Signed-off-by: Rosen Xu 
> 
> v2 updates:
> ===
>  - Take more test on I40e
>  - Add comments
> ---
>  examples/flow_filtering/main.c | 11 +++
>  1 file changed, 11 insertions(+)
> 
> diff --git a/examples/flow_filtering/main.c b/examples/flow_filtering/main.c
> index f595034..73d646c 100644
> --- a/examples/flow_filtering/main.c
> +++ b/examples/flow_filtering/main.c
> @@ -132,6 +132,17 @@
>   DEV_TX_OFFLOAD_SCTP_CKSUM  |
>   DEV_TX_OFFLOAD_TCP_TSO,
>   },
> + /*
> +  * Initialize fdir_conf of ete_eth_conf
> +  * it is a workaround solution when work with Intel I40e
> +  * and it is not the normal way
> +  */
> + .fdir_conf = {
> + .mode = RTE_FDIR_MODE_PERFECT,
> + .pballoc = RTE_FDIR_PBALLOC_64K,
> + .status = RTE_FDIR_REPORT_STATUS,
> + .drop_queue = 127,
> + },
>   };
>   struct rte_eth_txconf txq_conf;
>   struct rte_eth_rxconf rxq_conf;
> --
> 1.8.3.1

Just small comment I think work should be replaced with working.
Both in the commit log and code comment.

Acked-by: Ori Kam 

Thanks,
Ori