Re: [dpdk-dev] [PATCH] doc: two typos in documentation

2021-08-05 Thread Thomas Monjalon
04/08/2021 20:26, Henry Nadeau:
> -:start-after: Building correct configruration for vdmq. 8<
> +:start-after: Building correct configuration for vdmq. 8<

While at it, "vmdq" should be "VMDq" I think (to be checked).






Re: [dpdk-dev] [PATCH v2] net/virtio: fix repeated memory free of vq

2021-08-05 Thread Gaoxiang Liu





On 08/04/2021 07:45, Gaoxiang Liu wrote:
When virtio_init_queue returns error, the memory of vq is freed.
But the value of hw->vqs[queue_idx] does not restore.
If hw->vqs[queue_idx] != NULL, the memory of vq is freed again
in virtio_free_queues.

Fixes: 69c80d4ef89b ("net/virtio: allocate queue at init stage")
Cc: sta...@dpdk.org

Signed-off-by: Gaoxiang Liu 

v2:
fix spelling warning
---
drivers/net/virtio/virtio_ethdev.c | 1 +
1 file changed, 1 insertion(+)

diff --git a/drivers/net/virtio/virtio_ethdev.c 
b/drivers/net/virtio/virtio_ethdev.c
index 056830566..fc72d71cb 100644
--- a/drivers/net/virtio/virtio_ethdev.c
+++ b/drivers/net/virtio/virtio_ethdev.c
@@ -631,6 +631,7 @@ virtio_init_queue(struct rte_eth_dev *dev, uint16_t 
queue_idx)
 rte_memzone_free(mz);
free_vq:
 rte_free(vq);
+ hw->vqs[queue_idx] = NULL;

 return ret;
}
--
2.32.0


[dpdk-dev] [PATCH] doc: announce change in crypto raw data vector

2021-08-05 Thread Hemant Agrawal
The current crypto raw data vectors need to be extended to support
out of place processing. It is proposed to add additional desl_sgl
to provide details for destination sgl.
The same is also extended to support rte_security usecases, where
we need total data length to know how much additional memory space
is available in buffer other than data length so that driver/HW
can write expanded size data after encryption.

Signed-off-by: Gagandeep Singh 
Signed-off-by: Hemant Agrawal 
---
 doc/guides/rel_notes/deprecation.rst | 12 
 1 file changed, 12 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst 
b/doc/guides/rel_notes/deprecation.rst
index f4a4d00db2..c19a306c93 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -193,3 +193,15 @@ Deprecation Notices
   reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and other
   information from the crypto/security operation. This field will be used to
   communicate events such as soft expiry with IPsec in lookaside mode.
+
+* cryptodev: The structure ``rte_crypto_sym_vec`` would be updated to add
+  ``dest_sgl`` to support out of place processing. This field will be null for
+  inplace processing. This change is targeted for DPDK 21.11
+
+* cryptodev: The structure ``rte_crypto_vec`` would be updated to add
+  ``tot_len`` to support total buffer length. This is required for security
+  cases like IPsec and PDCP encryption offload to know how much additional
+  memory space is available in buffer other than data length so that driver/HW
+  can write expanded size data after encryption. This change is targeted for
+  DPDK 21.11
+
-- 
2.17.1



Re: [dpdk-dev] [PATCH] doc: announce SA config option struct changes

2021-08-05 Thread Nicolau, Radu



On 7/31/2021 6:44 PM, Akhil Goyal wrote:

From: Archana Muniganti 

Propose new fields to support offloads like
- IPsec inner checksum(L3/L4)
- IPsec tunnel header verification
- TSO
- etc
in the structure ``rte_security_ipsec_sa_options``.

Signed-off-by: Archana Muniganti 
Signed-off-by: Tejasree Kondoj 
Acked-by: Akhil Goyal 
---
Proposal for changes are floated as per below links.
https://mails.dpdk.org/archives/dev/2021-June/212977.html
https://mails.dpdk.org/archives/dev/2021-July/213484.html
https://mails.dpdk.org/archives/dev/2021-July/214521.html

Cc: Radu Nicolau 

Acked-by: Radu Nicolau 


Re: [dpdk-dev] [PATCH] doc: announce change in crypto adapter metadata

2021-08-05 Thread Kinsella, Ray



On 04/08/2021 19:17, Akhil Goyal wrote:
>> Subject: [PATCH] doc: announce change in crypto adapter metadata
>>
>> In crypto adapter metadata, first 8 bytes of request info is a space
>> holder for response info. For better clarity, reserved field should be
>> removed from request info. New space for response info can be made by
>> changing type of event crypto metadata to structure from union.
>>
>> Signed-off-by: Shijith Thotton 
> Acked-by: Akhil Goyal 
> 
Acked-by: Ray Kinsella 


[dpdk-dev] [PATCH v3] doc: mtr: add API walk through

2021-08-05 Thread jerinj
From: Jerin Jacob 

Added a diagram to document meter library components
and added text for steps performed by the application to
configure the traffic meter and policing library.

Signed-off-by: Jerin Jacob 
---
v2: Fix long lines in svg file to avoid patch apply issue
v3: Fix all Thomas's comment at
http://patches.dpdk.org/project/dpdk/patch/20210804113410.3604616-1-jer...@marvell.com/

 doc/guides/prog_guide/img/meter.svg   | 1600 +
 .../traffic_metering_and_policing.rst |   29 +
 lib/ethdev/rte_mtr.h  |4 +-
 3 files changed, 1631 insertions(+), 2 deletions(-)
 create mode 100644 doc/guides/prog_guide/img/meter.svg

diff --git a/doc/guides/prog_guide/img/meter.svg 
b/doc/guides/prog_guide/img/meter.svg
new file mode 100644
index 00..7214c5dc2b
--- /dev/null
+++ b/doc/guides/prog_guide/img/meter.svg
@@ -0,0 +1,1600 @@
+
+
+
+
+http://purl.org/dc/elements/1.1/"; 
xmlns:cc="http://creativecommons.org/ns#";
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#";
+   xmlns:svg="http://www.w3.org/2000/svg"; xmlns="http://www.w3.org/2000/svg";
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd";
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"; width="233mm" 
height="198mm"
+   viewBox="0 0 233 198" version="1.1" id="svg8" inkscape:version="0.92.4 
(5da689c313,
+   2019-01-14)" sodipodi:docname="meter_new.svg">
+  
+
+  
+ 
+
+  
+ 
+
+  
+ 
+
+  
+ 
+
+  
+ 
+
+  
+ 
+  
+ 
+  
+ 
+  
+ 
+  
+ 
+  
+ 
+  
+
+   
+  
+
+  
+image/svg+xml http://purl.org/dc/dcmitype/StillImage"; />
+
+  
+
+   
+
+  
+
+   
+
+   
+
+   
+
+   
+
+   
+  RTE_FLOW_ITEM
+  
+  RTE_FLOW_ACTION_TYPE_METER
+
+  
+  
+  
+  RED
+  
+  YELLOW
+  
+  GREEN
+  
+  RTE_FLOW_ACTION
+  
+  RTE_FLOW_ACTION
+  
+  RTE_FLOW_ACTION
+  
+  RED
+  
+  YELLOW
+  
+  GREEN
+  
+  RTE_FLOW_ACTION
+  
+  RTE_FLOW_ACTION
+  
+  RTE_FLOW_ACTION
+  
+  
+  CIR
+  
+  CBS
+  
+  EBS
+  
+  PIR
+  
+  PBS
+  
+  EIR
+  
+  
+  
+  CIR
+  
+  CBS
+  
+  EBS
+  
+  PIR
+  
+  PBS
+  
+  EIR
+  
+  
+  RED
+  
+  YELLOW
+  
+  GREEN
+  
+  RTE_FLOW_ACTION
+  
+  RTE_FLOW_ACTION
+  
+  RTE_FLOW_ACTION
+  
+  
+  
+  CIR
+  
+  CBS
+  
+  EBS
+  
+  PIR
+  
+  PBS
+  
+  EIR
+  
+  
+  RED
+  
+  YELLOW
+  
+  GREEN
+  
+  RTE_FLOW_ACTION_METER
+  
+  RTE_FLOW_ACTION
+  
+  RTE_FLOW_ACTION
+  
+  
+  
+  
+  
+  
+  
+  
+  
+  
+  
+
+  
+
diff --git a/doc/guides/prog_guide/traffic_metering_and_policing.rst 
b/doc/guides/prog_guide/traffic_metering_and_policing.rst
index c0537e653c..0fe013522f 100644
--- a/doc/guides/prog_guide/traffic_metering_and_policing.rst
+++ b/doc/guides/prog_guide/traffic_metering_and_policing.rst
@@ -20,6 +20,7 @@ The main features are:
   and RFC 4115 Two Rate Three Color Marker (trTCM)
 * Policer actions (per meter output color): recolor, drop
 * Statistics (per policer output color)
+* Chaining the meter objects

 Configuration steps
 ---
@@ -64,3 +65,31 @@ The processing done for each input packet hitting an MTR 
object is:
 * Statistics: The set of counters maintained for each MTR object is
   configurable and subject to the implementation support. This set includes
   the number of packets and bytes dropped or passed for each output color.
+
+API Walk-through
+
+
+.. figure:: img/meter.*
+
+   Meter components
+
+This section will introduce the reader to the critical APIs to use
+the traffic meter and policing library.
+
+In general, the following steps are performed by the application to configure
+the traffic meter and policing library.
+
+#. Application gets the meter driver capabilities using 
``rte_mtr_capabilities_get()``.
+#. Application identifies the profile(s) needed for metering and creates it 
with
+   ``rte_mtr_meter_profile_add()``.
+#. Application identifies the policies needed and creates it with 
``rte_mtr_meter_policy_add()``.
+#. A meter object consists of a profile and a policy. Use above created 
objects to create
+   meter object using ``rte_mtr_create()``. Application uses
+   ``struct rte_mtr_params::meter_profile_id`` and ``struct 
rte_mtr_params::meter_policy_id``
+   to specify the profile (created in step 2) and policy (created in step 3).
+#. Once the meter object is created, the application shall use 
``rte_flow_create(

Re: [dpdk-dev] [PATCH] doc: announce SA config option struct changes

2021-08-05 Thread Hemant Agrawal
Acked-by: Hemant Agrawal 


Re: [dpdk-dev] [PATCH] doc: announce change in crypto adapter metadata

2021-08-05 Thread Jerin Jacob
On Thu, Aug 5, 2021 at 3:42 PM Kinsella, Ray  wrote:
>
>
>
> On 04/08/2021 19:17, Akhil Goyal wrote:
> >> Subject: [PATCH] doc: announce change in crypto adapter metadata
> >>
> >> In crypto adapter metadata, first 8 bytes of request info is a space
> >> holder for response info. For better clarity, reserved field should be
> >> removed from request info. New space for response info can be made by
> >> changing type of event crypto metadata to structure from union.
> >>
> >> Signed-off-by: Shijith Thotton 
> > Acked-by: Akhil Goyal 
> >
> Acked-by: Ray Kinsella 

+ @Gujjar, Abhinandan S

Acked-by: Jerin Jacob 


[dpdk-dev] [PATCH 1/2] doc: announce ipsec rte_ipsec_sa_prm structure changes

2021-08-05 Thread Radu Nicolau
Signed-off-by: Radu Nicolau 
---
 doc/guides/rel_notes/deprecation.rst | 3 +++
 1 file changed, 3 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst 
b/doc/guides/rel_notes/deprecation.rst
index f4a4d00db2..b87fa54e67 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -193,3 +193,6 @@ Deprecation Notices
   reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and other
   information from the crypto/security operation. This field will be used to
   communicate events such as soft expiry with IPsec in lookaside mode.
+  
+  * ipsec: The structure ``rte_ipsec_sa_prm`` will be extended with a new 
+  field ``hdr_l3_len`` to configure tunnel l3 header lenght.
-- 
2.25.1



[dpdk-dev] [PATCH 2/2] doc: announce rte_security_ipsec_xform structure changes

2021-08-05 Thread Radu Nicolau
Signed-off-by: Radu Nicolau 
---
 doc/guides/rel_notes/deprecation.rst | 5 +
 1 file changed, 5 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst 
b/doc/guides/rel_notes/deprecation.rst
index b87fa54e67..a3493b4dfb 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -196,3 +196,8 @@ Deprecation Notices
   
   * ipsec: The structure ``rte_ipsec_sa_prm`` will be extended with a new 
   field ``hdr_l3_len`` to configure tunnel l3 header lenght.
+  
+  * security: The structure ``rte_security_ipsec_xform`` will be extended with 
+  multiple fields: udp structure that will hold the source and destination 
port 
+  for UDP encapsulation, mss to specify the IPsec payload Maximum Segment 
Size, 
+  esn structure for Extended Sequence Number.
-- 
2.25.1



Re: [dpdk-dev] [dpdk-announce] release candidate 21.08-rc3

2021-08-05 Thread Jiang, YuX
> -Original Message-
> From: Thomas Monjalon 
> Sent: Wednesday, August 4, 2021 8:48 PM
> To: Jiang, YuX 
> Cc: dev (dev@dpdk.org) ; Devlin, Michelle
> ; Mcnamara, John
> ; Yigit, Ferruh ; Zhang,
> Qi Z 
> Subject: Re: [dpdk-dev] [dpdk-announce] release candidate 21.08-rc3
> 
> 04/08/2021 13:38, Jiang, YuX:
> > Hi Thomas and all,
> > Update the test status for Intel part. Till now dpdk21.08-rc3 test is 
> > finished.
> No critical issue is found.
> > One bug about https://bugs.dpdk.org/show_bug.cgi?id=768 is found,
> Nvidia's Dev. is working on it.
> 
> No, there is no work on NVIDIA side, because it seems to reveal an issue on
> Intel driver side, as I said in the mail thread.
> 
Ok. Thanks Thomas, we will check it on Intel side.


Re: [dpdk-dev] [PATCH 1/2] doc: announce ipsec rte_ipsec_sa_prm structure changes

2021-08-05 Thread Ananyev, Konstantin



> 
> Signed-off-by: Radu Nicolau 
> ---
>  doc/guides/rel_notes/deprecation.rst | 3 +++
>  1 file changed, 3 insertions(+)
> 
> diff --git a/doc/guides/rel_notes/deprecation.rst 
> b/doc/guides/rel_notes/deprecation.rst
> index f4a4d00db2..b87fa54e67 100644
> --- a/doc/guides/rel_notes/deprecation.rst
> +++ b/doc/guides/rel_notes/deprecation.rst
> @@ -193,3 +193,6 @@ Deprecation Notices
>reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and other
>information from the crypto/security operation. This field will be used to
>communicate events such as soft expiry with IPsec in lookaside mode.
> +
> +  * ipsec: The structure ``rte_ipsec_sa_prm`` will be extended with a new
> +  field ``hdr_l3_len`` to configure tunnel l3 header lenght.
> --

Acked-by: Konstantin Ananyev 

> 2.25.1



Re: [dpdk-dev] [PATCH 2/2] doc: announce rte_security_ipsec_xform structure changes

2021-08-05 Thread Ananyev, Konstantin


> Signed-off-by: Radu Nicolau 
> ---
>  doc/guides/rel_notes/deprecation.rst | 5 +
>  1 file changed, 5 insertions(+)
> 
> diff --git a/doc/guides/rel_notes/deprecation.rst 
> b/doc/guides/rel_notes/deprecation.rst
> index b87fa54e67..a3493b4dfb 100644
> --- a/doc/guides/rel_notes/deprecation.rst
> +++ b/doc/guides/rel_notes/deprecation.rst
> @@ -196,3 +196,8 @@ Deprecation Notices
> 
>* ipsec: The structure ``rte_ipsec_sa_prm`` will be extended with a new
>field ``hdr_l3_len`` to configure tunnel l3 header lenght.
> +
> +  * security: The structure ``rte_security_ipsec_xform`` will be extended 
> with
> +  multiple fields: udp structure that will hold the source and destination 
> port
> +  for UDP encapsulation, mss to specify the IPsec payload Maximum Segment 
> Size,
> +  esn structure for Extended Sequence Number.
> --

Acked-by: Konstantin Ananyev 

> 2.25.1



Re: [dpdk-dev] [WARNING: UNSCANNABLE EXTRACTION FAILED][WARNING: UNSCANNABLE EXTRACTION FAILED] [PATCH v3] doc: mtr: add API walk through

2021-08-05 Thread Dumitrescu, Cristian
HI Jerin,

Thanks for your patch!

Initially, it looked like an easy job to review it, but there is actually an 
elephant in the room on how to chain the meters, see below.

> -Original Message-
> From: jer...@marvell.com 
> Sent: Thursday, August 5, 2021 11:11 AM
> To: Dumitrescu, Cristian ; Thomas Monjalon
> ; Yigit, Ferruh ; Andrew
> Rybchenko 
> Cc: dev@dpdk.org; arybche...@solarflare.com; l...@nvidia.com;
> ajit.khapa...@broadcom.com; Singh, Jasvinder
> ; ma...@nvidia.com; Jerin Jacob
> 
> Subject: [WARNING: UNSCANNABLE EXTRACTION FAILED][WARNING:
> UNSCANNABLE EXTRACTION FAILED][dpdk-dev] [PATCH v3] doc: mtr: add
> API walk through
> 
> From: Jerin Jacob 
> 
> Added a diagram to document meter library components
> and added text for steps performed by the application to
> configure the traffic meter and policing library.
> 
> Signed-off-by: Jerin Jacob 
> ---
> v2: Fix long lines in svg file to avoid patch apply issue
> v3: Fix all Thomas's comment at
> http://patches.dpdk.org/project/dpdk/patch/20210804113410.3604616-1-
> jer...@marvell.com/
> 
>  doc/guides/prog_guide/img/meter.svg   | 1600 +
>  .../traffic_metering_and_policing.rst |   29 +
>  lib/ethdev/rte_mtr.h  |4 +-
>  3 files changed, 1631 insertions(+), 2 deletions(-)
>  create mode 100644 doc/guides/prog_guide/img/meter.svg
> 
> diff --git a/doc/guides/prog_guide/img/meter.svg
> b/doc/guides/prog_guide/img/meter.svg
> new file mode 100644
> index 00..7214c5dc2b
> --- /dev/null
> +++ b/doc/guides/prog_guide/img/meter.svg



Just to avoid confusion with the rte_meter API (from the lib/meter library), 
may change the name to rte_mtr_meter_chaining.svg ?


> diff --git a/doc/guides/prog_guide/traffic_metering_and_policing.rst
> b/doc/guides/prog_guide/traffic_metering_and_policing.rst
> index c0537e653c..0fe013522f 100644
> --- a/doc/guides/prog_guide/traffic_metering_and_policing.rst
> +++ b/doc/guides/prog_guide/traffic_metering_and_policing.rst
> @@ -20,6 +20,7 @@ The main features are:
>and RFC 4115 Two Rate Three Color Marker (trTCM)
>  * Policer actions (per meter output color): recolor, drop
>  * Statistics (per policer output color)
> +* Chaining the meter objects

How about:
Chaining multiple meter objects.

> 
>  Configuration steps
>  ---
> @@ -64,3 +65,31 @@ The processing done for each input packet hitting an
> MTR object is:
>  * Statistics: The set of counters maintained for each MTR object is
>configurable and subject to the implementation support. This set includes
>the number of packets and bytes dropped or passed for each output color.
> +
> +API Walk-through
> +
> +
> +.. figure:: img/meter.*
> +
> +   Meter components
> +
> +This section will introduce the reader to the critical APIs to use
> +the traffic meter and policing library.
> +
> +In general, the following steps are performed by the application to
> configure
> +the traffic meter and policing library.
> +
> +#. Application gets the meter driver capabilities using
> ``rte_mtr_capabilities_get()``.
> +#. Application identifies the profile(s) needed for metering and creates it
> with
> +   ``rte_mtr_meter_profile_add()``.

How about:
The application creates the required meter profiles by using the 
rte_mtr_meter_profile_add() API function.

> +#. Application identifies the policies needed and creates it with
> ``rte_mtr_meter_policy_add()``.

How about:
The application creates the required meter policies by using the 
rte_mtr_meter_policy_add() API function.

> +#. A meter object consists of a profile and a policy. Use above created
> objects to create
> +   meter object using ``rte_mtr_create()``. Application uses
> +   ``struct rte_mtr_params::meter_profile_id`` and ``struct
> rte_mtr_params::meter_policy_id``
> +   to specify the profile (created in step 2) and policy (created in step 3).

It is mainly the meter object configuration that consists of a profile and a 
policy, but not exactly the meter object itself.

How about:
The application creates a meter object using the rte_mtr_create() API 
function. One of the previously created meter profile and meter policy are 
provided as arguments at this step.

> +#. Once the meter object is created, the application shall use
> ``rte_flow_create()`` API to
> +   instantiate the meter object using ``RTE_FLOW_ACTION_TYPE_METER``
> action.

The instantiate word might not be the best word here, as it typically indicates 
creating an object as opposed linking it to some other entity.

How about:
The application enables the meter object execution as part of the flow 
action processing by calling the rte_flow_create() API function with one of the 
flow action set to ``RTE_FLOW_ACTION_TYPE_METER`` and the associated meter 
object ID set to this meter object.


> +#. The API allows chaining the meter objects to create complex metering
> topology
> +   by specifyi

[dpdk-dev] [PATCH 1/2] rib: announce experimental tag removal of the rib API

2021-08-05 Thread Vladimir Medvedkin
This patch announces the experimental tag removal of all rib APIs,
which have been experimental for 2 years.
API will be promoted to stable in DPDK 21.11

Signed-off-by: Vladimir Medvedkin 
---
 doc/guides/rel_notes/deprecation.rst | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst 
b/doc/guides/rel_notes/deprecation.rst
index f4a4d00..afb599a 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -193,3 +193,5 @@ Deprecation Notices
   reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and other
   information from the crypto/security operation. This field will be used to
   communicate events such as soft expiry with IPsec in lookaside mode.
+
+* rib: The ``rib`` library will be promoted from experimental to stable.
-- 
2.7.4



[dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Vladimir Medvedkin
This patch announces the experimental tag removal of all fib APIs,
which have been experimental for 2 years.
API will be promoted to stable in DPDK 21.11

Signed-off-by: Vladimir Medvedkin 
---
 doc/guides/rel_notes/deprecation.rst | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst 
b/doc/guides/rel_notes/deprecation.rst
index afb599a..58826a8 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -195,3 +195,5 @@ Deprecation Notices
   communicate events such as soft expiry with IPsec in lookaside mode.
 
 * rib: The ``rib`` library will be promoted from experimental to stable.
+
+* fib: The ``fib`` library will be promoted from experimental to stable.
-- 
2.7.4



[dpdk-dev] [Bug 779] cryptodev_virtio_autotest crash

2021-08-05 Thread bugzilla
https://bugs.dpdk.org/show_bug.cgi?id=779

Bug ID: 779
   Summary: cryptodev_virtio_autotest crash
   Product: DPDK
   Version: 21.05
  Hardware: All
OS: All
Status: UNCONFIRMED
  Severity: normal
  Priority: Normal
 Component: cryptodev
  Assignee: dev@dpdk.org
  Reporter: ciara.po...@intel.com
  Target Milestone: ---

Created attachment 169
  --> https://bugs.dpdk.org/attachment.cgi?id=169&action=edit
Screenshot of where the autotest crashes. Unresponsive at this point.

When running the cryptodev_virtio_autotest, there is a seg fault and the app
crashes. This is seen when executing the ESN testsuite (see attached
screenshot).

>From basic debugging myself, the problem seems to occur for the first ESN
testcase auth_encrypt_AES128CBC_HMAC_SHA1_esn_check() when trying to process
the crypto request.

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

Re: [dpdk-dev] [EXT] [PATCH 2/2] doc: announce rte_security_ipsec_xform structure changes

2021-08-05 Thread Anoob Joseph
> Subject: [EXT] [PATCH 2/2] doc: announce rte_security_ipsec_xform
> structure changes
> 
> External Email
> 
> --
> Signed-off-by: Radu Nicolau 
> ---
>  doc/guides/rel_notes/deprecation.rst | 5 +
>  1 file changed, 5 insertions(+)
> 
> diff --git a/doc/guides/rel_notes/deprecation.rst
> b/doc/guides/rel_notes/deprecation.rst
> index b87fa54e67..a3493b4dfb 100644
> --- a/doc/guides/rel_notes/deprecation.rst
> +++ b/doc/guides/rel_notes/deprecation.rst
> @@ -196,3 +196,8 @@ Deprecation Notices
> 
>* ipsec: The structure ``rte_ipsec_sa_prm`` will be extended with a new
>field ``hdr_l3_len`` to configure tunnel l3 header lenght.
> +
> +  * security: The structure ``rte_security_ipsec_xform`` will be
> + extended with  multiple fields: udp structure that will hold the
> + source and destination port  for UDP encapsulation, mss to specify the
> + IPsec payload Maximum Segment Size,  esn structure for Extended
> Sequence Number.
> --

Acked-by: Anoob Joseph 



Re: [dpdk-dev] [PATCH] net/mlx5: fix Windows port spawn

2021-08-05 Thread Thomas Monjalon
05/08/2021 11:55, Gregory Etelson:
> mlx5_dev_check_sibling_config() API was updated to allow newly spawned
> port locate existing sibling devices.
> PMD port initialization for Windows OS was not updated for the new
> API prototype.
> The patch fixes mlx5_dev_check_sibling_config call for Windows OS.
> 
> Fixes: e9d420dfc2d0 ("net/mlx5: fix find sibling devices")
> 
> Signed-off-by: Gregory Etelson 
> Acked-by: Viacheslav Ovsiienko 

Adding the compilation log:
drivers/net/mlx5/windows/mlx5_os.c:457:50: error:
too few arguments to function call, expected 3, have 2
err = mlx5_dev_check_sibling_config(priv, config);

Changing title to "net/mlx5: fix build on Windows"

I missed the original CI failure in patchwork, sorry.

Applied, thanks.




Re: [dpdk-dev] [WARNING: UNSCANNABLE EXTRACTION FAILED][WARNING: UNSCANNABLE EXTRACTION FAILED] [PATCH v3] doc: mtr: add API walk through

2021-08-05 Thread Jerin Jacob
On Thu, Aug 5, 2021 at 4:36 PM Dumitrescu, Cristian
 wrote:
>
> HI Jerin,
>
> Thanks for your patch!
>
> Initially, it looked like an easy job to review it, but there is actually an 
> elephant in the room on how to chain the meters, see below.

Yes. That's why I send this patch to finalize how to chain the meter.
It was hard for me to follow that's why added a digram.


>
> > -Original Message-
> > From: jer...@marvell.com 
> > Sent: Thursday, August 5, 2021 11:11 AM
> > To: Dumitrescu, Cristian ; Thomas Monjalon
> > ; Yigit, Ferruh ; Andrew
> > Rybchenko 
> > Cc: dev@dpdk.org; arybche...@solarflare.com; l...@nvidia.com;
> > ajit.khapa...@broadcom.com; Singh, Jasvinder
> > ; ma...@nvidia.com; Jerin Jacob
> > 
> > Subject: [WARNING: UNSCANNABLE EXTRACTION FAILED][WARNING:
> > UNSCANNABLE EXTRACTION FAILED][dpdk-dev] [PATCH v3] doc: mtr: add
> > API walk through
> >
> > From: Jerin Jacob 
> >
> > Added a diagram to document meter library components
> > and added text for steps performed by the application to
> > configure the traffic meter and policing library.
> >
> > Signed-off-by: Jerin Jacob 
> > ---
> > v2: Fix long lines in svg file to avoid patch apply issue
> > v3: Fix all Thomas's comment at
> > http://patches.dpdk.org/project/dpdk/patch/20210804113410.3604616-1-
> > jer...@marvell.com/
> >
> >  doc/guides/prog_guide/img/meter.svg   | 1600 +
> >  .../traffic_metering_and_policing.rst |   29 +
> >  lib/ethdev/rte_mtr.h  |4 +-
> >  3 files changed, 1631 insertions(+), 2 deletions(-)
> >  create mode 100644 doc/guides/prog_guide/img/meter.svg
> >
> > diff --git a/doc/guides/prog_guide/img/meter.svg
> > b/doc/guides/prog_guide/img/meter.svg
> > new file mode 100644
> > index 00..7214c5dc2b
> > --- /dev/null
> > +++ b/doc/guides/prog_guide/img/meter.svg
>
> 
>
> Just to avoid confusion with the rte_meter API (from the lib/meter library), 
> may change the name to rte_mtr_meter_chaining.svg ?

Will do.

>
>
> > diff --git a/doc/guides/prog_guide/traffic_metering_and_policing.rst
> > b/doc/guides/prog_guide/traffic_metering_and_policing.rst
> > index c0537e653c..0fe013522f 100644
> > --- a/doc/guides/prog_guide/traffic_metering_and_policing.rst
> > +++ b/doc/guides/prog_guide/traffic_metering_and_policing.rst
> > @@ -20,6 +20,7 @@ The main features are:
> >and RFC 4115 Two Rate Three Color Marker (trTCM)
> >  * Policer actions (per meter output color): recolor, drop
> >  * Statistics (per policer output color)
> > +* Chaining the meter objects
>
> How about:
> Chaining multiple meter objects.

Ack

>
> >
> >  Configuration steps
> >  ---
> > @@ -64,3 +65,31 @@ The processing done for each input packet hitting an
> > MTR object is:
> >  * Statistics: The set of counters maintained for each MTR object is
> >configurable and subject to the implementation support. This set includes
> >the number of packets and bytes dropped or passed for each output color.
> > +
> > +API Walk-through
> > +
> > +
> > +.. figure:: img/meter.*
> > +
> > +   Meter components
> > +
> > +This section will introduce the reader to the critical APIs to use
> > +the traffic meter and policing library.
> > +
> > +In general, the following steps are performed by the application to
> > configure
> > +the traffic meter and policing library.
> > +
> > +#. Application gets the meter driver capabilities using
> > ``rte_mtr_capabilities_get()``.
> > +#. Application identifies the profile(s) needed for metering and creates it
> > with
> > +   ``rte_mtr_meter_profile_add()``.
>
> How about:
> The application creates the required meter profiles by using the 
> rte_mtr_meter_profile_add() API function.


Ack.

>
> > +#. Application identifies the policies needed and creates it with
> > ``rte_mtr_meter_policy_add()``.
>
> How about:
> The application creates the required meter policies by using the 
> rte_mtr_meter_policy_add() API function.


Ack


>
> > +#. A meter object consists of a profile and a policy. Use above created
> > objects to create
> > +   meter object using ``rte_mtr_create()``. Application uses
> > +   ``struct rte_mtr_params::meter_profile_id`` and ``struct
> > rte_mtr_params::meter_policy_id``
> > +   to specify the profile (created in step 2) and policy (created in step 
> > 3).
>
> It is mainly the meter object configuration that consists of a profile and a 
> policy, but not exactly the meter object itself.
>
> How about:
> The application creates a meter object using the rte_mtr_create() API 
> function. One of the previously created meter profile and meter policy are 
> provided as arguments at this step.

Sure. I just though to add exact struct field so that it easy for end
users to know.

How about your version + struct name.

The application creates a meter object using the rte_mtr_create() API function.
One of the previously created meter profile (`struct
rte_mtr_params

Re: [dpdk-dev] [PATCH v13 4/6] dmadev: introduce DMA device library implementation

2021-08-05 Thread Walsh, Conor
> This patch introduce DMA device library implementation which includes
> configuration and I/O with the DMA devices.
> 
> Signed-off-by: Chengwen Feng 
> Acked-by: Bruce Richardson 
> Acked-by: Morten Brørup 
> ---
>  config/rte_config.h  |   3 +
>  lib/dmadev/meson.build   |   1 +
>  lib/dmadev/rte_dmadev.c  | 563
> +++
>  lib/dmadev/rte_dmadev.h  | 118 -
>  lib/dmadev/rte_dmadev_core.h |   2 +
>  lib/dmadev/version.map   |   1 +
>  6 files changed, 676 insertions(+), 12 deletions(-)
>  create mode 100644 lib/dmadev/rte_dmadev.c
> 
> diff --git a/config/rte_config.h b/config/rte_config.h
> index 590903c..331a431 100644
> --- a/config/rte_config.h
> +++ b/config/rte_config.h
> @@ -81,6 +81,9 @@
>  /* rawdev defines */
>  #define RTE_RAWDEV_MAX_DEVS 64
> 
> +/* dmadev defines */
> +#define RTE_DMADEV_MAX_DEVS 64
> +
>  /* ip_fragmentation defines */
>  #define RTE_LIBRTE_IP_FRAG_MAX_FRAG 4
>  #undef RTE_LIBRTE_IP_FRAG_TBL_STAT
> diff --git a/lib/dmadev/meson.build b/lib/dmadev/meson.build
> index 833baf7..d2fc85e 100644
> --- a/lib/dmadev/meson.build
> +++ b/lib/dmadev/meson.build
> @@ -1,6 +1,7 @@
>  # SPDX-License-Identifier: BSD-3-Clause
>  # Copyright(c) 2021 HiSilicon Limited.
> 
> +sources = files('rte_dmadev.c')
>  headers = files('rte_dmadev.h')
>  indirect_headers += files('rte_dmadev_core.h')
>  driver_sdk_headers += files('rte_dmadev_pmd.h')
> diff --git a/lib/dmadev/rte_dmadev.c b/lib/dmadev/rte_dmadev.c
> new file mode 100644
> index 000..b4f5498
> --- /dev/null
> +++ b/lib/dmadev/rte_dmadev.c
> @@ -0,0 +1,563 @@
> +/* SPDX-License-Identifier: BSD-3-Clause
> + * Copyright(c) 2021 HiSilicon Limited.
> + * Copyright(c) 2021 Intel Corporation.
> + */
> +
> +#include 
> +#include 
> +#include 
> +#include 
> +#include 
> +#include 
> +
> +#include 
> +#include 
> +#include 
> +#include 
> +#include 
> +#include 
> +#include 
> +#include 
> +#include 
> +#include 
> +
> +#include "rte_dmadev.h"
> +#include "rte_dmadev_pmd.h"
> +
> +struct rte_dmadev rte_dmadevices[RTE_DMADEV_MAX_DEVS];
> +
> +static const char *mz_rte_dmadev_data = "rte_dmadev_data";
> +/* Shared memory between primary and secondary processes. */
> +static struct {
> + struct rte_dmadev_data data[RTE_DMADEV_MAX_DEVS];
> +} *dmadev_shared_data;
> +
> +RTE_LOG_REGISTER_DEFAULT(rte_dmadev_logtype, INFO);
> +#define RTE_DMADEV_LOG(level, ...) \
> + rte_log(RTE_LOG_ ## level, rte_dmadev_logtype, "" __VA_ARGS__)
> +
> +/* Macros to check for valid device id */
> +#define RTE_DMADEV_VALID_DEV_ID_OR_ERR_RET(dev_id, retval) do { \
> + if (!rte_dmadev_is_valid_dev(dev_id)) { \
> + RTE_DMADEV_LOG(ERR, "Invalid dev_id=%u\n", dev_id); \
> + return retval; \
> + } \
> +} while (0)
> +
> +static int
> +dmadev_check_name(const char *name)
> +{
> + size_t name_len;
> +
> + if (name == NULL) {
> + RTE_DMADEV_LOG(ERR, "Name can't be NULL\n");
> + return -EINVAL;
> + }
> +
> + name_len = strnlen(name, RTE_DMADEV_NAME_MAX_LEN);
> + if (name_len == 0) {
> + RTE_DMADEV_LOG(ERR, "Zero length DMA device
> name\n");
> + return -EINVAL;
> + }
> + if (name_len >= RTE_DMADEV_NAME_MAX_LEN) {
> + RTE_DMADEV_LOG(ERR, "DMA device name is too long\n");
> + return -EINVAL;
> + }
> +
> + return 0;
> +}
> +
> +static uint16_t
> +dmadev_find_free_dev(void)
> +{
> + uint16_t i;
> +
> + for (i = 0; i < RTE_DMADEV_MAX_DEVS; i++) {
> + if (dmadev_shared_data->data[i].dev_name[0] == '\0')
> + return i;
> + }
> +
> + return RTE_DMADEV_MAX_DEVS;
> +}
> +
> +static struct rte_dmadev*
> +dmadev_find(const char *name)
> +{
> + uint16_t i;
> +
> + for (i = 0; i < RTE_DMADEV_MAX_DEVS; i++) {
> + if ((rte_dmadevices[i].state == RTE_DMADEV_ATTACHED)
> &&
> + (!strcmp(name, rte_dmadevices[i].data->dev_name)))
> + return &rte_dmadevices[i];
> + }
> +
> + return NULL;
> +}
> +
> +static int
> +dmadev_shared_data_prepare(void)
> +{
> + const struct rte_memzone *mz;
> +
> + if (dmadev_shared_data == NULL) {
> + if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
> + /* Allocate port data and ownership shared memory.
> */
> + mz = rte_memzone_reserve(mz_rte_dmadev_data,
> +  sizeof(*dmadev_shared_data),
> +  rte_socket_id(), 0);
> + } else
> + mz = rte_memzone_lookup(mz_rte_dmadev_data);
> + if (mz == NULL)
> + return -ENOMEM;
> +
> + dmadev_shared_data = mz->addr;
> + if (rte_eal_process_type() == RTE_PROC_PRIMARY)
> + memset(dmadev_shared_data->data, 0,
> +sizeof(dmadev_shared_data->data));
> +  

Re: [dpdk-dev] DPDK meson build failed on Windows

2021-08-05 Thread William Tu
On Wed, Aug 4, 2021 at 11:45 AM Dmitry Kozlyuk  wrote:
>
> Hi again,
>
> This is exactly the error with 0.58 that I was talking about. Try 0.57.2.
>
> On Wed, Aug 4, 2021, 21:32 William Tu  wrote:
>>
>> Hi,
>> I got DPDK compiled on Windows, but suddenly I got this error when
>> compiling DPDK on windows again. (And I don't know why it worked
>> before...)
>> [3/183] "clang" @lib/rte_eal-21.dll.rsp
>> FAILED: lib/rte_eal-21.dll
>> "clang" @lib/rte_eal-21.dll.rsp
>> clang: error: no such file or directory: 'librte_kvargs.lib'
>>
>> Tested on main branch 45633c460c.
>> I also tried meson 0.55.0 but still failed. Any suggestions for
>> debugging or fixing it?
Thanks!
I tested again and now I can get meson 0.55.0 works for me.
meson 0.59.0 fails consistently.
William


Re: [dpdk-dev] [PATCH v13 4/6] dmadev: introduce DMA device library implementation

2021-08-05 Thread fengchengwen
On 2021/8/5 20:56, Walsh, Conor wrote:
>> This patch introduce DMA device library implementation which includes
>> configuration and I/O with the DMA devices.

[snip]

>>
>>  /**
>>   * @warning
>> @@ -952,10 +1029,27 @@ rte_dmadev_completed(uint16_t dev_id,
>> uint16_t vchan, const uint16_t nb_cpls,
>>   *   status array are also set.
>>   */
> 
> Hi Chenwen,
> 
> When completed status is called with status set to NULL the drivers will 
> segfault.
> Users may have a valid use case where they pass NULL as status so it needs to 
> be
> checked and handled appropriately.
> Could you handle this within dmadev similar to what I've added below?
> If added the doxygen comment will also need to be updated to specify NULL as 
> a valid input.

Hi Conor,

The status must be an array pointer, so below status_tmp will not work well.

This API is slow path (vs completed API), and is designed to obtain detailed
status information, so application should pass valid status parameters.

> 
> Thanks,
> Conor.
> 
>>  __rte_experimental
>> -uint16_t
>> +static inline uint16_t
>>  rte_dmadev_completed_status(uint16_t dev_id, uint16_t vchan,
>>  const uint16_t nb_cpls, uint16_t *last_idx,
>> -enum rte_dma_status_code *status);
>> +enum rte_dma_status_code *status)
>> +{
>> +struct rte_dmadev *dev = &rte_dmadevices[dev_id];
>> +uint16_t idx;
>enum rte_dma_status_code *status_tmp;
>> +
>> +#ifdef RTE_DMADEV_DEBUG
>> +if (!rte_dmadev_is_valid_dev(dev_id) ||
>> +vchan >= dev->data->dev_conf.max_vchans ||
>> +nb_cpls == 0 || status == NULL)
>> +return 0;
>> +RTE_FUNC_PTR_OR_ERR_RET(*dev->completed_status, 0);
>> +#endif
>> +
>> +if (last_idx == NULL)
>> +last_idx = &idx;
>if (status == NULL)
>  status = &status_tmp;
>> +
>> +return (*dev->completed_status)(dev, vchan, nb_cpls, last_idx,
>> status);
>> +}
>>
>>  #ifdef __cplusplus
>>  }
>> diff --git a/lib/dmadev/rte_dmadev_core.h
>> b/lib/dmadev/rte_dmadev_core.h
>> index 599ab15..9272725 100644
>> --- a/lib/dmadev/rte_dmadev_core.h
>> +++ b/lib/dmadev/rte_dmadev_core.h
>> @@ -177,4 +177,6 @@ struct rte_dmadev {
>>  uint64_t reserved[2]; /**< Reserved for future fields. */
>>  } __rte_cache_aligned;
>>
>> +extern struct rte_dmadev rte_dmadevices[];
>> +
>>  #endif /* _RTE_DMADEV_CORE_H_ */
>> diff --git a/lib/dmadev/version.map b/lib/dmadev/version.map
>> index 408b93c..86c5e75 100644
>> --- a/lib/dmadev/version.map
>> +++ b/lib/dmadev/version.map
>> @@ -27,6 +27,7 @@ EXPERIMENTAL {
>>  INTERNAL {
>>  global:
>>
>> +rte_dmadevices;
>>  rte_dmadev_get_device_by_name;
>>  rte_dmadev_pmd_allocate;
>>  rte_dmadev_pmd_release;
>> --
>> 2.8.1
> 


Re: [dpdk-dev] [PATCH v13 5/6] doc: add DMA device library guide

2021-08-05 Thread fengchengwen
On 2021/8/3 22:55, Jerin Jacob wrote:
> On Tue, Aug 3, 2021 at 5:03 PM Chengwen Feng  wrote:
>>
>> This patch adds dmadev library guide.
>>
>> Signed-off-by: Chengwen Feng 
>> ---
>>  doc/guides/prog_guide/dmadev.rst| 126 +++
> 
> 
> doc build has following warning in my machine
> 
> ninja: Entering directory `build'
> [2789/2813] Generating html_guides with a custom command
> /export/dpdk.org/doc/guides/prog_guide/dmadev.rst:24: WARNING: Figure
> caption must be a paragraph or empty comment.
will fix in v14

> 
> .. figure:: img/dmadev_i1.*
> 
>The model of the DMA framework built on
> 
>  * The DMA controller could have multiple hardware DMA channels (aka. hardware
>DMA queues), each hardware DMA channel should be represented by a dmadev.
>  * The dmadev could create multiple virtual DMA channels, each virtual DMA
>channel represents a different transfer context. The DMA operation request
>must be submitted to the virtual DMA channel. e.g. Application could create
>virtual DMA channel 0 for memory-to-memory transfer scenario, and create
>virtual DMA channel 1 for memory-to-device transfer scenario.
> [2813/2813] Linking target app/dpdk-test-pipeline
> 
>> new file mode 100644
>> index 000..b305beb
>> --- /dev/null
>> +++ b/doc/guides/prog_guide/img/dmadev_i1.svg
> 
> why _i1 in the name?

OK, maybe dmadev.svg is enough.

> 
> 
>> @@ -0,0 +1,278 @@
>> +
>> +
> 
> You could add an SPDX license and your company copyright as well.
> See other .svg files.

OK

> 
> 
> Rest looks good to me.
> 
> 
>> +

[snip]

>>
> .
> 


Re: [dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Medvedkin, Vladimir

Hi Jan,

The RIB is always used as a control plane struct intended to maintain 
the correct content of the dataplane struct, such as DIR24_8 for 
example. So it is always used on _add()/_delete(). For simplicity you 
can consider it as an LPM's rule_info. But instead of keeping routes in 
a plane array as it is in LPM, FIB uses RIB which is more suitable 
binary tree.



On 05/08/2021 15:14, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:08:13 +0200
Vladimir Medvedkin  wrote:


This patch announces the experimental tag removal of all fib APIs,
which have been experimental for 2 years.
API will be promoted to stable in DPDK 21.11


Hi Vladimir,

I have a question related to FIB. I am just learning how to use it and
I found that each FIB always creates a new RIB internally. There is no doc
about this topic...

If I understand correctly, the underlying RIB is only used when
dummy_lookup() and dummy_modify() are used. But they are only used when the
configured mode is RTE_FIB_DUMMY. Is there any reason to create the RIB with
RTE_FIB_DIR24_8?

The issue with this is that each RIB allocates a new mempool internally which
can waste quite a lot of never used memory that would be unused with DIR24_8
implementation.

Regards
Jan




Signed-off-by: Vladimir Medvedkin 
---
  doc/guides/rel_notes/deprecation.rst | 2 ++
  1 file changed, 2 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst
b/doc/guides/rel_notes/deprecation.rst
index afb599a..58826a8 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -195,3 +195,5 @@ Deprecation Notices
communicate events such as soft expiry with IPsec in lookaside
mode.
  * rib: The ``rib`` library will be promoted from experimental to
stable. +
+* fib: The ``fib`` library will be promoted from experimental to
stable.


--
Regards,
Vladimir


Re: [dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Jan Viktorin
On Thu, 5 Aug 2021 15:27:15 +0200
"Medvedkin, Vladimir"  wrote:

> Hi Jan,
> 
> The RIB is always used as a control plane struct intended to maintain 
> the correct content of the dataplane struct, such as DIR24_8 for 
> example. So it is always used on _add()/_delete(). For simplicity you 
> can consider it as an LPM's rule_info. But instead of keeping routes
> in a plane array as it is in LPM, FIB uses RIB which is more suitable 
> binary tree.

OK. I thought that I can have a single RIB, use it for maintaining
routes and based on this single RIB, I can build a FIB for the data
plane. And when the single RIB is updated (which can take quite a lot
of time) I build a new FIB and locklessly give it to the dataplane.
Such approach is not considered?

Jan

> 
> 
> On 05/08/2021 15:14, Jan Viktorin wrote:
> > On Thu, 5 Aug 2021 15:08:13 +0200
> > Vladimir Medvedkin  wrote:
> >   
> >> This patch announces the experimental tag removal of all fib APIs,
> >> which have been experimental for 2 years.
> >> API will be promoted to stable in DPDK 21.11  
> > 
> > Hi Vladimir,
> > 
> > I have a question related to FIB. I am just learning how to use it
> > and I found that each FIB always creates a new RIB internally.
> > There is no doc about this topic...
> > 
> > If I understand correctly, the underlying RIB is only used when
> > dummy_lookup() and dummy_modify() are used. But they are only used
> > when the configured mode is RTE_FIB_DUMMY. Is there any reason to
> > create the RIB with RTE_FIB_DIR24_8?
> > 
> > The issue with this is that each RIB allocates a new mempool
> > internally which can waste quite a lot of never used memory that
> > would be unused with DIR24_8 implementation.
> > 
> > Regards
> > Jan
> >   
> >>
> >>
> >> Signed-off-by: Vladimir Medvedkin 
> >> ---
> >>   doc/guides/rel_notes/deprecation.rst | 2 ++
> >>   1 file changed, 2 insertions(+)
> >>
> >> diff --git a/doc/guides/rel_notes/deprecation.rst
> >> b/doc/guides/rel_notes/deprecation.rst
> >> index afb599a..58826a8 100644
> >> --- a/doc/guides/rel_notes/deprecation.rst
> >> +++ b/doc/guides/rel_notes/deprecation.rst
> >> @@ -195,3 +195,5 @@ Deprecation Notices
> >> communicate events such as soft expiry with IPsec in lookaside
> >> mode.
> >>   * rib: The ``rib`` library will be promoted from experimental to
> >> stable. +
> >> +* fib: The ``fib`` library will be promoted from experimental to
> >> stable.  
> 



Re: [dpdk-dev] [PATCH v13 4/6] dmadev: introduce DMA device library implementation

2021-08-05 Thread Conor Walsh



On 05/08/2021 14:12, fengchengwen wrote:

On 2021/8/5 20:56, Walsh, Conor wrote:

This patch introduce DMA device library implementation which includes
configuration and I/O with the DMA devices.

[snip]


  /**
   * @warning
@@ -952,10 +1029,27 @@ rte_dmadev_completed(uint16_t dev_id,
uint16_t vchan, const uint16_t nb_cpls,
   *   status array are also set.
   */

Hi Chenwen,

When completed status is called with status set to NULL the drivers will 
segfault.
Users may have a valid use case where they pass NULL as status so it needs to be
checked and handled appropriately.
Could you handle this within dmadev similar to what I've added below?
If added the doxygen comment will also need to be updated to specify NULL as a 
valid input.

Hi Conor,

The status must be an array pointer, so below status_tmp will not work well.

This API is slow path (vs completed API), and is designed to obtain detailed
status information, so application should pass valid status parameters.


Thanks for your quick reply.

That is true that it is designed to be slower and return detailed status 
info but should we not handle it more gracefully than segfaulting.


I don't have too strong of an opinion either way so it's ok to ignore.

/Conor.





Thanks,
Conor.


  __rte_experimental
-uint16_t
+static inline uint16_t
  rte_dmadev_completed_status(uint16_t dev_id, uint16_t vchan,
const uint16_t nb_cpls, uint16_t *last_idx,
-   enum rte_dma_status_code *status);
+   enum rte_dma_status_code *status)
+{
+   struct rte_dmadev *dev = &rte_dmadevices[dev_id];
+   uint16_t idx;

enum rte_dma_status_code *status_tmp;

+
+#ifdef RTE_DMADEV_DEBUG
+   if (!rte_dmadev_is_valid_dev(dev_id) ||
+   vchan >= dev->data->dev_conf.max_vchans ||
+   nb_cpls == 0 || status == NULL)
+   return 0;
+   RTE_FUNC_PTR_OR_ERR_RET(*dev->completed_status, 0);
+#endif
+
+   if (last_idx == NULL)
+   last_idx = &idx;

if (status == NULL)
  status = &status_tmp;

+
+   return (*dev->completed_status)(dev, vchan, nb_cpls, last_idx,
status);
+}

  #ifdef __cplusplus
  }
diff --git a/lib/dmadev/rte_dmadev_core.h
b/lib/dmadev/rte_dmadev_core.h
index 599ab15..9272725 100644
--- a/lib/dmadev/rte_dmadev_core.h
+++ b/lib/dmadev/rte_dmadev_core.h
@@ -177,4 +177,6 @@ struct rte_dmadev {
uint64_t reserved[2]; /**< Reserved for future fields. */
  } __rte_cache_aligned;

+extern struct rte_dmadev rte_dmadevices[];
+
  #endif /* _RTE_DMADEV_CORE_H_ */
diff --git a/lib/dmadev/version.map b/lib/dmadev/version.map
index 408b93c..86c5e75 100644
--- a/lib/dmadev/version.map
+++ b/lib/dmadev/version.map
@@ -27,6 +27,7 @@ EXPERIMENTAL {
  INTERNAL {
  global:

+   rte_dmadevices;
rte_dmadev_get_device_by_name;
rte_dmadev_pmd_allocate;
rte_dmadev_pmd_release;
--
2.8.1


Re: [dpdk-dev] [PATCH] doc: announce change in crypto raw data vector

2021-08-05 Thread Zhang, Roy Fan
Hi Hemant,

> -Original Message-
> From: Hemant Agrawal 
> Sent: Thursday, August 5, 2021 9:06 AM
> To: dev@dpdk.org; gak...@marvell.com
> Cc: ano...@marvell.com; Nicolau, Radu ; Doherty,
> Declan ; ma...@nvidia.com; Ananyev,
> Konstantin ; tho...@monjalon.net; Zhang,
> Roy Fan ; asoma...@amd.com;
> ruifeng.w...@arm.com; ajit.khapa...@broadcom.com; De Lara Guarch,
> Pablo ; Trahe, Fiona
> ; adwiv...@marvell.com;
> jianjay.z...@huawei.com; Gagandeep Singh 
> Subject: [PATCH] doc: announce change in crypto raw data vector
> 
> The current crypto raw data vectors need to be extended to support
> out of place processing. It is proposed to add additional desl_sgl
> to provide details for destination sgl.
> The same is also extended to support rte_security usecases, where
> we need total data length to know how much additional memory space
> is available in buffer other than data length so that driver/HW
> can write expanded size data after encryption.
> 
> Signed-off-by: Gagandeep Singh 
> Signed-off-by: Hemant Agrawal 
> ---
>  doc/guides/rel_notes/deprecation.rst | 12 
>  1 file changed, 12 insertions(+)
> 
> diff --git a/doc/guides/rel_notes/deprecation.rst
> b/doc/guides/rel_notes/deprecation.rst
> index f4a4d00db2..c19a306c93 100644
> --- a/doc/guides/rel_notes/deprecation.rst
> +++ b/doc/guides/rel_notes/deprecation.rst
> @@ -193,3 +193,15 @@ Deprecation Notices
>reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and other
>information from the crypto/security operation. This field will be used to
>communicate events such as soft expiry with IPsec in lookaside mode.
> +
> +* cryptodev: The structure ``rte_crypto_sym_vec`` would be updated to
> add
> +  ``dest_sgl`` to support out of place processing. This field will be null 
> for
> +  inplace processing. This change is targeted for DPDK 21.11
> +
> +* cryptodev: The structure ``rte_crypto_vec`` would be updated to add
> +  ``tot_len`` to support total buffer length. This is required for security
> +  cases like IPsec and PDCP encryption offload to know how much additional
> +  memory space is available in buffer other than data length so that
> driver/HW
> +  can write expanded size data after encryption. This change is targeted for
> +  DPDK 21.11
> +
> --
> 2.17.1

To add ``dest_sgl`` to ``rte_crypto_sym_vec`` I suppose it is better to rename 
``sgl`` to ``src_sgl`` in this deprecating notice too?

Regards,
Fan


Re: [dpdk-dev] [PATCH] doc: announce change in crypto raw data vector

2021-08-05 Thread Hemant Agrawal
> > -Original Message-
> > From: Hemant Agrawal 
> > Sent: Thursday, August 5, 2021 9:06 AM
> > To: dev@dpdk.org; gak...@marvell.com
> > Cc: ano...@marvell.com; Nicolau, Radu ;
> > Doherty, Declan ; ma...@nvidia.com;
> Ananyev,
> > Konstantin ; tho...@monjalon.net;
> Zhang,
> > Roy Fan ; asoma...@amd.com;
> > ruifeng.w...@arm.com; ajit.khapa...@broadcom.com; De Lara Guarch,
> > Pablo ; Trahe, Fiona
> > ; adwiv...@marvell.com;
> > jianjay.z...@huawei.com; Gagandeep Singh 
> > Subject: [PATCH] doc: announce change in crypto raw data vector
> >
> > The current crypto raw data vectors need to be extended to support out
> > of place processing. It is proposed to add additional desl_sgl to
> > provide details for destination sgl.
> > The same is also extended to support rte_security usecases, where we
> > need total data length to know how much additional memory space is
> > available in buffer other than data length so that driver/HW can write
> > expanded size data after encryption.
> >
> > Signed-off-by: Gagandeep Singh 
> > Signed-off-by: Hemant Agrawal 
> > ---
> >  doc/guides/rel_notes/deprecation.rst | 12 
> >  1 file changed, 12 insertions(+)
> >
> > diff --git a/doc/guides/rel_notes/deprecation.rst
> > b/doc/guides/rel_notes/deprecation.rst
> > index f4a4d00db2..c19a306c93 100644
> > --- a/doc/guides/rel_notes/deprecation.rst
> > +++ b/doc/guides/rel_notes/deprecation.rst
> > @@ -193,3 +193,15 @@ Deprecation Notices
> >reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and
> other
> >information from the crypto/security operation. This field will be used 
> > to
> >communicate events such as soft expiry with IPsec in lookaside mode.
> > +
> > +* cryptodev: The structure ``rte_crypto_sym_vec`` would be updated to
> > add
> > +  ``dest_sgl`` to support out of place processing. This field will be
> > + null for  inplace processing. This change is targeted for DPDK 21.11
> > +
> > +* cryptodev: The structure ``rte_crypto_vec`` would be updated to add
> > +  ``tot_len`` to support total buffer length. This is required for
> > +security
> > +  cases like IPsec and PDCP encryption offload to know how much
> > +additional
> > +  memory space is available in buffer other than data length so that
> > driver/HW
> > +  can write expanded size data after encryption. This change is
> > + targeted for  DPDK 21.11
> > +
> > --
> > 2.17.1
> 
> To add ``dest_sgl`` to ``rte_crypto_sym_vec`` I suppose it is better to rename
> ``sgl`` to ``src_sgl`` in this deprecating notice too?
[Hemant] I was just trying to minimize the changes. But it can be done. 

> 
> Regards,
> Fan


Re: [dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Walsh, Conor
> This patch announces the experimental tag removal of all fib APIs,
> which have been experimental for 2 years.
> API will be promoted to stable in DPDK 21.11
> 
> Signed-off-by: Vladimir Medvedkin 
> ---
>  doc/guides/rel_notes/deprecation.rst | 2 ++
>  1 file changed, 2 insertions(+)

Acked-by: Conor Walsh 


Re: [dpdk-dev] [PATCH] maintainers: update for net mlx4/mlx5

2021-08-05 Thread Matan Azrad



From: Slava Ovsiienko
> From: Shahaf Shuler 
> 
> For net/mlx4:
>   - removing Shahaf Shuler
>   - add Viacheslav Ovsiienko
> 
> For net/mlx5:
>   - removing Shahaf Shuler
> 
> Signed-off-by: Viacheslav Ovsiienko 
Acked-by: Matan Azrad 

> ---
>  MAINTAINERS | 3 +--
>  1 file changed, 1 insertion(+), 2 deletions(-)
> 
> diff --git a/MAINTAINERS b/MAINTAINERS
> index 266f5ac1da..20e76ab9f8 100644
> --- a/MAINTAINERS
> +++ b/MAINTAINERS
> @@ -798,7 +798,7 @@ F: doc/guides/nics/octeontx_ep.rst
> 
>  Mellanox mlx4
>  M: Matan Azrad 
> -M: Shahaf Shuler 
> +M: Viacheslav Ovsiienko 
>  T: git://dpdk.org/next/dpdk-next-net-mlx
>  F: drivers/net/mlx4/
>  F: doc/guides/nics/mlx4.rst
> @@ -806,7 +806,6 @@ F: doc/guides/nics/features/mlx4.ini
> 
>  Mellanox mlx5
>  M: Matan Azrad 
> -M: Shahaf Shuler 
>  M: Viacheslav Ovsiienko 
>  T: git://dpdk.org/next/dpdk-next-net-mlx
>  F: drivers/common/mlx5/
> --
> 2.18.1



[dpdk-dev] [PATCH] net/mlx5: fix Windows port spawn

2021-08-05 Thread Gregory Etelson
mlx5_dev_check_sibling_config() API was updated to allow newly spawned
port locate existing sibling devices.
PMD port initialization for Windows OS was not updated for the new
API prototype.
The patch fixes mlx5_dev_check_sibling_config call for Windows OS.

Fixes: e9d420dfc2d0 ("net/mlx5: fix find sibling devices")

Signed-off-by: Gregory Etelson 
Acked-by: Viacheslav Ovsiienko 
---
 drivers/net/mlx5/windows/mlx5_os.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/net/mlx5/windows/mlx5_os.c 
b/drivers/net/mlx5/windows/mlx5_os.c
index 5518bc3e76..7e1df1c751 100644
--- a/drivers/net/mlx5/windows/mlx5_os.c
+++ b/drivers/net/mlx5/windows/mlx5_os.c
@@ -454,7 +454,7 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev,
}
/* Override some values set by hardware configuration. */
mlx5_args(config, dpdk_dev->devargs);
-   err = mlx5_dev_check_sibling_config(priv, config);
+   err = mlx5_dev_check_sibling_config(priv, config, dpdk_dev);
if (err)
goto error;
DRV_LOG(DEBUG, "counters are not supported");
-- 
2.32.0



Re: [dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Medvedkin, Vladimir




On 05/08/2021 15:32, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:27:15 +0200
"Medvedkin, Vladimir"  wrote:


Hi Jan,

The RIB is always used as a control plane struct intended to maintain
the correct content of the dataplane struct, such as DIR24_8 for
example. So it is always used on _add()/_delete(). For simplicity you
can consider it as an LPM's rule_info. But instead of keeping routes
in a plane array as it is in LPM, FIB uses RIB which is more suitable
binary tree.


OK. I thought that I can have a single RIB, use it for maintaining
routes and based on this single RIB, I can build a FIB for the data
plane. And when the single RIB is updated (which can take quite a lot
of time) I build a new FIB and locklessly give it to the dataplane.
Such approach is not considered?

Jan



I'm not sure I understood completely your use case. Do you want to 
rebuild the entire FIB from scratch every time the RIB changes?





On 05/08/2021 15:14, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:08:13 +0200
Vladimir Medvedkin  wrote:
   

This patch announces the experimental tag removal of all fib APIs,
which have been experimental for 2 years.
API will be promoted to stable in DPDK 21.11


Hi Vladimir,

I have a question related to FIB. I am just learning how to use it
and I found that each FIB always creates a new RIB internally.
There is no doc about this topic...

If I understand correctly, the underlying RIB is only used when
dummy_lookup() and dummy_modify() are used. But they are only used
when the configured mode is RTE_FIB_DUMMY. Is there any reason to
create the RIB with RTE_FIB_DIR24_8?

The issue with this is that each RIB allocates a new mempool
internally which can waste quite a lot of never used memory that
would be unused with DIR24_8 implementation.

Regards
Jan
   



Signed-off-by: Vladimir Medvedkin 
---
   doc/guides/rel_notes/deprecation.rst | 2 ++
   1 file changed, 2 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst
b/doc/guides/rel_notes/deprecation.rst
index afb599a..58826a8 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -195,3 +195,5 @@ Deprecation Notices
 communicate events such as soft expiry with IPsec in lookaside
mode.
   * rib: The ``rib`` library will be promoted from experimental to
stable. +
+* fib: The ``fib`` library will be promoted from experimental to
stable.






--
Regards,
Vladimir


Re: [dpdk-dev] [PATCH v2] doc: announce restructuring of crypto session structs

2021-08-05 Thread Zhang, Roy Fan
Hi Akhil,

> -Original Message-
> From: Akhil Goyal 
> Sent: Tuesday, August 3, 2021 1:01 PM
> To: dev@dpdk.org
> Cc: ano...@marvell.com; Nicolau, Radu ; Doherty,
> Declan ; hemant.agra...@nxp.com;
> ma...@nvidia.com; Ananyev, Konstantin ;
> tho...@monjalon.net; Zhang, Roy Fan ;
> asoma...@amd.com; ruifeng.w...@arm.com;
> ajit.khapa...@broadcom.com; De Lara Guarch, Pablo
> ; Trahe, Fiona ;
> adwiv...@marvell.com; michae...@marvell.com;
> rnagadhee...@marvell.com; jianjay.z...@huawei.com; Akhil Goyal
> 
> Subject: [PATCH v2] doc: announce restructuring of crypto session structs
> 
> The structures rte_cryptodev_sym_session and
> rte_cryptodev_asym_session are not used by the
> application directly. The application just need
> an opaque pointer which it can attach to rte_crypto_op
> while enqueue.
> Hence, these structures can be internal to library
> hidden from the user.
> 
> Signed-off-by: Akhil Goyal 
> ---
> v2: fixed trailing whitespace.
> 
>  doc/guides/rel_notes/deprecation.rst | 5 +
>  1 file changed, 5 insertions(+)
> 
> diff --git a/doc/guides/rel_notes/deprecation.rst
> b/doc/guides/rel_notes/deprecation.rst
> index f81bd87f10..c540c90f8e 100644
> --- a/doc/guides/rel_notes/deprecation.rst
> +++ b/doc/guides/rel_notes/deprecation.rst
> @@ -151,6 +151,11 @@ Deprecation Notices
>  * cryptodev: The APIs for interfacing between library and PMD will be
> marked
>as internal APIs in DPDK 21.11.
> 
> +* cryptodev: Hide structures ``rte_cryptodev_sym_session`` and
> +  ``rte_cryptodev_asym_session`` to remove unnecessary indirection
> between
> +  session and the private data of session. An opaque pointer can be exposed
> +  directly to application which can be attached to the ``rte_crypto_op``.
> +
>  * security: The functions ``rte_security_set_pkt_metadata`` and
>``rte_security_get_userdata`` will be made inline functions and additional
>flags will be added in structure ``rte_security_ctx`` in DPDK 21.11.
> --
> 2.25.1

Have you considered how crypto scheduler PMD can support multiple crypto 
devices' opaque data pointers after the change? Of course it is doable by 
adding dedicated APIs to the scheduler PMD - shall I assume you will work on it?

Regards,
Fan


[dpdk-dev] [PATCH v2] doc: announce change in crypto raw data vector

2021-08-05 Thread Hemant Agrawal
The current crypto raw data vectors need to be extended to support
out of place processing. It is proposed to add additional desl_sgl
to provide details for destination sgl.
The same is also extended to support rte_security usecases, where
we need total data length to know how much additional memory space
is available in buffer other than data length so that driver/HW
can write expanded size data after encryption.

Signed-off-by: Gagandeep Singh 
Signed-off-by: Hemant Agrawal 
---
 doc/guides/rel_notes/deprecation.rst | 12 
 1 file changed, 12 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst 
b/doc/guides/rel_notes/deprecation.rst
index f4a4d00db2..c19a306c93 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -193,3 +193,15 @@ Deprecation Notices
   reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and other
   information from the crypto/security operation. This field will be used to
   communicate events such as soft expiry with IPsec in lookaside mode.
+
+* cryptodev: The structure ``rte_crypto_sym_vec`` would be updated to add
+  ``dest_sgl`` to support out of place processing. This field will be null for
+  inplace processing. This change is targeted for DPDK 21.11
+
+* cryptodev: The structure ``rte_crypto_vec`` would be updated to add
+  ``tot_len`` to support total buffer length. This is required for security
+  cases like IPsec and PDCP encryption offload to know how much additional
+  memory space is available in buffer other than data length so that driver/HW
+  can write expanded size data after encryption. This change is targeted for
+  DPDK 21.11
+
-- 
2.17.1



Re: [dpdk-dev] [EXT] [PATCH v2] doc: announce change in crypto raw data vector

2021-08-05 Thread Akhil Goyal
> The current crypto raw data vectors need to be extended to support
> out of place processing. It is proposed to add additional desl_sgl
> to provide details for destination sgl.
> The same is also extended to support rte_security usecases, where
> we need total data length to know how much additional memory space
> is available in buffer other than data length so that driver/HW
> can write expanded size data after encryption.
> 
> Signed-off-by: Gagandeep Singh 
> Signed-off-by: Hemant Agrawal 
> ---
>  doc/guides/rel_notes/deprecation.rst | 12 
>  1 file changed, 12 insertions(+)
> 
> diff --git a/doc/guides/rel_notes/deprecation.rst
> b/doc/guides/rel_notes/deprecation.rst
> index f4a4d00db2..c19a306c93 100644
> --- a/doc/guides/rel_notes/deprecation.rst
> +++ b/doc/guides/rel_notes/deprecation.rst
> @@ -193,3 +193,15 @@ Deprecation Notices
>reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and other
>information from the crypto/security operation. This field will be used to
>communicate events such as soft expiry with IPsec in lookaside mode.
> +
> +* cryptodev: The structure ``rte_crypto_sym_vec`` would be updated to add
> +  ``dest_sgl`` to support out of place processing. This field will be null 
> for
> +  inplace processing. This change is targeted for DPDK 21.11
> +
> +* cryptodev: The structure ``rte_crypto_vec`` would be updated to add
> +  ``tot_len`` to support total buffer length. This is required for security
> +  cases like IPsec and PDCP encryption offload to know how much additional
> +  memory space is available in buffer other than data length so that
> driver/HW
> +  can write expanded size data after encryption. This change is targeted for
> +  DPDK 21.11
> +
Acked-by: Akhil Goyal 


Re: [dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Jan Viktorin
On Thu, 5 Aug 2021 15:57:14 +0200
"Medvedkin, Vladimir"  wrote:

> On 05/08/2021 15:32, Jan Viktorin wrote:
> > On Thu, 5 Aug 2021 15:27:15 +0200
> > "Medvedkin, Vladimir"  wrote:
> >   
> >> Hi Jan,
> >>
> >> The RIB is always used as a control plane struct intended to
> >> maintain the correct content of the dataplane struct, such as
> >> DIR24_8 for example. So it is always used on _add()/_delete(). For
> >> simplicity you can consider it as an LPM's rule_info. But instead
> >> of keeping routes in a plane array as it is in LPM, FIB uses RIB
> >> which is more suitable binary tree.  
> > 
> > OK. I thought that I can have a single RIB, use it for maintaining
> > routes and based on this single RIB, I can build a FIB for the data
> > plane. And when the single RIB is updated (which can take quite a
> > lot of time) I build a new FIB and locklessly give it to the
> > dataplane. Such approach is not considered?
> > 
> > Jan
> >   
> 
> I'm not sure I understood completely your use case. Do you want to 
> rebuild the entire FIB from scratch every time the RIB changes?

The idea was to maintain a single RIB and two FIBs. One FIB is active
and under heavy load and when a route change arrives, it is first
written to RIB. When RIB is ready, it is used to quickly
construct/update the second inactive FIB. Then I swap with the current
active FIB. The old one can be edited/updated/recreated and new one is
active.

I've got one place where all routes are placed (RIB). And two FIBs that
contain only routes that are relevant. (Well, yes, not all routes in RIB
might be relevant, this depends on other conditions.)

Jan

> 
> >>
> >>
> >> On 05/08/2021 15:14, Jan Viktorin wrote:  
> >>> On Thu, 5 Aug 2021 15:08:13 +0200
> >>> Vladimir Medvedkin  wrote:
> >>>  
>  This patch announces the experimental tag removal of all fib
>  APIs, which have been experimental for 2 years.
>  API will be promoted to stable in DPDK 21.11  
> >>>
> >>> Hi Vladimir,
> >>>
> >>> I have a question related to FIB. I am just learning how to use it
> >>> and I found that each FIB always creates a new RIB internally.
> >>> There is no doc about this topic...
> >>>
> >>> If I understand correctly, the underlying RIB is only used when
> >>> dummy_lookup() and dummy_modify() are used. But they are only used
> >>> when the configured mode is RTE_FIB_DUMMY. Is there any reason to
> >>> create the RIB with RTE_FIB_DIR24_8?
> >>>
> >>> The issue with this is that each RIB allocates a new mempool
> >>> internally which can waste quite a lot of never used memory that
> >>> would be unused with DIR24_8 implementation.
> >>>
> >>> Regards
> >>> Jan
> >>>  
> 
> 
>  Signed-off-by: Vladimir Medvedkin 
>  ---
> doc/guides/rel_notes/deprecation.rst | 2 ++
> 1 file changed, 2 insertions(+)
> 
>  diff --git a/doc/guides/rel_notes/deprecation.rst
>  b/doc/guides/rel_notes/deprecation.rst
>  index afb599a..58826a8 100644
>  --- a/doc/guides/rel_notes/deprecation.rst
>  +++ b/doc/guides/rel_notes/deprecation.rst
>  @@ -195,3 +195,5 @@ Deprecation Notices
>   communicate events such as soft expiry with IPsec in
>  lookaside mode.
> * rib: The ``rib`` library will be promoted from experimental
>  to stable. +
>  +* fib: The ``fib`` library will be promoted from experimental to
>  stable.  
> >>  
> >   
> 



Re: [dpdk-dev] [PATCH v2] doc: announce restructuring of crypto session structs

2021-08-05 Thread Akhil Goyal
Hi Fan,
> Hi Akhil,
> 
> > The structures rte_cryptodev_sym_session and
> > rte_cryptodev_asym_session are not used by the
> > application directly. The application just need
> > an opaque pointer which it can attach to rte_crypto_op
> > while enqueue.
> > Hence, these structures can be internal to library
> > hidden from the user.
> >
> > Signed-off-by: Akhil Goyal 
> > ---
> > v2: fixed trailing whitespace.
> >
> >  doc/guides/rel_notes/deprecation.rst | 5 +
> >  1 file changed, 5 insertions(+)
> >
> > diff --git a/doc/guides/rel_notes/deprecation.rst
> > b/doc/guides/rel_notes/deprecation.rst
> > index f81bd87f10..c540c90f8e 100644
> > --- a/doc/guides/rel_notes/deprecation.rst
> > +++ b/doc/guides/rel_notes/deprecation.rst
> > @@ -151,6 +151,11 @@ Deprecation Notices
> >  * cryptodev: The APIs for interfacing between library and PMD will be
> > marked
> >as internal APIs in DPDK 21.11.
> >
> > +* cryptodev: Hide structures ``rte_cryptodev_sym_session`` and
> > +  ``rte_cryptodev_asym_session`` to remove unnecessary indirection
> > between
> > +  session and the private data of session. An opaque pointer can be
> exposed
> > +  directly to application which can be attached to the ``rte_crypto_op``.
> > +
> >  * security: The functions ``rte_security_set_pkt_metadata`` and
> >``rte_security_get_userdata`` will be made inline functions and 
> > additional
> >flags will be added in structure ``rte_security_ctx`` in DPDK 21.11.
> > --
> > 2.25.1
> 
> Have you considered how crypto scheduler PMD can support multiple crypto
> devices' opaque data pointers after the change? Of course it is doable by
> adding dedicated APIs to the scheduler PMD - shall I assume you will work on
> it?

I haven't considered about the scheduler PMD yet. Would need your help in 
aligning that.
The deprecation notice is to allow us change in 21.11 timeframe.

Thanks,
Akhil


[dpdk-dev] [PATCH] eal/windows: add sys/queue.h.

2021-08-05 Thread William Tu
When compiling OVS, lib/dpdk.c, found the missing header.
In file included from ../lib/dpdk.c:27:
C:\temp\dpdk\include\rte_log.h:24:10: fatal error: 'sys/queue.h' file
not found
^
1 warning and 1 error generated.

Signed-off-by: William Tu 
---
 lib/eal/windows/include/meson.build | 4 
 lib/eal/windows/include/sys/meson.build | 6 ++
 2 files changed, 10 insertions(+)
 create mode 100644 lib/eal/windows/include/sys/meson.build

diff --git a/lib/eal/windows/include/meson.build 
b/lib/eal/windows/include/meson.build
index b3534b025f..875cc1cf0d 100644
--- a/lib/eal/windows/include/meson.build
+++ b/lib/eal/windows/include/meson.build
@@ -8,3 +8,7 @@ headers += files(
 'rte_virt2phys.h',
 'rte_windows.h',
 )
+
+sys_headers = []
+subdir('sys')
+install_headers(sys_headers, subdir: 'sys')
diff --git a/lib/eal/windows/include/sys/meson.build 
b/lib/eal/windows/include/sys/meson.build
new file mode 100644
index 00..6896cbf678
--- /dev/null
+++ b/lib/eal/windows/include/sys/meson.build
@@ -0,0 +1,6 @@
+# SPDX-License-Identifier: BSD-3-Clause
+# Copyright 2021 VMware, Inc
+
+sys_headers += files(
+'queue.h',
+)
-- 
2.32.0.windows.2



Re: [dpdk-dev] [PATCH v2] doc: announce changes to eventdev library

2021-08-05 Thread Thomas Monjalon
03/08/2021 06:12, Jerin Jacob:
> On Tue, Aug 3, 2021 at 2:46 AM  wrote:
> >
> > From: Pavan Nikhilesh 
> >
> > Make driver layer as internal, remove unnecessary rte_ prefix for
> > structures and functions that are not a part of public API.
> > Promote experimental trace and vector APIs to stable.
> > Add reserved field to `rte_event_timer` structure.
> >
> > Signed-off-by: Pavan Nikhilesh 
> 
> Acked-by: Jerin Jacob 
> 
> 
> ++ Eventdev driver Maintainers.
> 
> This list is based on items identified for 21.11 ABI improvement at
> https://docs.google.com/spreadsheets/d/1betlC000ua5SsSiJIcC54mCCCJnW6voH5Dqv9UxeyfE/edit#gid=0

Acked-by: Hemant Agrawal 
Acked-by: Mattias Rönnblom 
Acked-by: Jay Jayatheerthan 
Acked-by: Abhinandan Gujjar 


> > +* eventdev: The file ``rte_eventdev_pmd.h`` will be renamed to 
> > ``eventdev_driver.h``
> > +  to make the driver interface as internal and the structures 
> > ``rte_eventdev_data``,
> > +  ``rte_eventdev`` and ``rte_eventdevs`` will be moved to a new file named
> > +  ``rte_eventdev_core.h`` in DPDK 21.11.
> > +  The ``rte_`` prefix for internal structures and functions will be 
> > removed across the
> > +  library.

If a function is used outside of the library (in drivers),
it is better to keep rte_ prefix to avoid possible clash
with some driver dependencies.

> > +  The experimental eventdev trace APIs and 
> > ``rte_event_vector_pool_create``,
> > +  ``rte_event_eth_rx_adapter_vector_limits_get`` will be promoted to 
> > stable.
> > +  An 8byte reserved field will be added to the structure 
> > ``rte_event_timer`` to
> > +  support future extensions.

Applied, thanks.




Re: [dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Medvedkin, Vladimir




On 05/08/2021 16:07, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:57:14 +0200
"Medvedkin, Vladimir"  wrote:


On 05/08/2021 15:32, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:27:15 +0200
"Medvedkin, Vladimir"  wrote:
   

Hi Jan,

The RIB is always used as a control plane struct intended to
maintain the correct content of the dataplane struct, such as
DIR24_8 for example. So it is always used on _add()/_delete(). For
simplicity you can consider it as an LPM's rule_info. But instead
of keeping routes in a plane array as it is in LPM, FIB uses RIB
which is more suitable binary tree.


OK. I thought that I can have a single RIB, use it for maintaining
routes and based on this single RIB, I can build a FIB for the data
plane. And when the single RIB is updated (which can take quite a
lot of time) I build a new FIB and locklessly give it to the
dataplane. Such approach is not considered?

Jan
   


I'm not sure I understood completely your use case. Do you want to
rebuild the entire FIB from scratch every time the RIB changes?


The idea was to maintain a single RIB and two FIBs. One FIB is active
and under heavy load and when a route change arrives, it is first
written to RIB. When RIB is ready, it is used to quickly
construct/update the second inactive FIB. Then I swap with the current
active FIB. The old one can be edited/updated/recreated and new one is
active.

I've got one place where all routes are placed (RIB). And two FIBs that
contain only routes that are relevant. (Well, yes, not all routes in RIB
might be relevant, this depends on other conditions.)

Jan



This technique is used for data structures that do not support 
incremental updates. However FIB supports incremental updates.


You can keep a separate rib struct and reflect changes to the fib.

Also, using rte_fib_get_rib() you can get the corresponding RIB struct 
and work with it directly using rib API. However you need to be 
cautious, all adding/deletion and next hop changing must be done using 
fib API.







On 05/08/2021 15:14, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:08:13 +0200
Vladimir Medvedkin  wrote:
  

This patch announces the experimental tag removal of all fib
APIs, which have been experimental for 2 years.
API will be promoted to stable in DPDK 21.11


Hi Vladimir,

I have a question related to FIB. I am just learning how to use it
and I found that each FIB always creates a new RIB internally.
There is no doc about this topic...

If I understand correctly, the underlying RIB is only used when
dummy_lookup() and dummy_modify() are used. But they are only used
when the configured mode is RTE_FIB_DUMMY. Is there any reason to
create the RIB with RTE_FIB_DIR24_8?

The issue with this is that each RIB allocates a new mempool
internally which can waste quite a lot of never used memory that
would be unused with DIR24_8 implementation.

Regards
Jan
  



Signed-off-by: Vladimir Medvedkin 
---
doc/guides/rel_notes/deprecation.rst | 2 ++
1 file changed, 2 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst
b/doc/guides/rel_notes/deprecation.rst
index afb599a..58826a8 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -195,3 +195,5 @@ Deprecation Notices
  communicate events such as soft expiry with IPsec in
lookaside mode.
* rib: The ``rib`` library will be promoted from experimental
to stable. +
+* fib: The ``fib`` library will be promoted from experimental to
stable.
  
   






--
Regards,
Vladimir


Re: [dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Jan Viktorin
On Thu, 5 Aug 2021 16:29:50 +0200
"Medvedkin, Vladimir"  wrote:

> On 05/08/2021 16:07, Jan Viktorin wrote:
> > On Thu, 5 Aug 2021 15:57:14 +0200
> > "Medvedkin, Vladimir"  wrote:
> >   
> >> On 05/08/2021 15:32, Jan Viktorin wrote:  
> >>> On Thu, 5 Aug 2021 15:27:15 +0200
> >>> "Medvedkin, Vladimir"  wrote:
> >>>  
>  Hi Jan,
> 
>  The RIB is always used as a control plane struct intended to
>  maintain the correct content of the dataplane struct, such as
>  DIR24_8 for example. So it is always used on _add()/_delete().
>  For simplicity you can consider it as an LPM's rule_info. But
>  instead of keeping routes in a plane array as it is in LPM, FIB
>  uses RIB which is more suitable binary tree.  
> >>>
> >>> OK. I thought that I can have a single RIB, use it for maintaining
> >>> routes and based on this single RIB, I can build a FIB for the
> >>> data plane. And when the single RIB is updated (which can take
> >>> quite a lot of time) I build a new FIB and locklessly give it to
> >>> the dataplane. Such approach is not considered?
> >>>
> >>> Jan
> >>>  
> >>
> >> I'm not sure I understood completely your use case. Do you want to
> >> rebuild the entire FIB from scratch every time the RIB changes?  
> > 
> > The idea was to maintain a single RIB and two FIBs. One FIB is
> > active and under heavy load and when a route change arrives, it is
> > first written to RIB. When RIB is ready, it is used to quickly
> > construct/update the second inactive FIB. Then I swap with the
> > current active FIB. The old one can be edited/updated/recreated and
> > new one is active.
> > 
> > I've got one place where all routes are placed (RIB). And two FIBs
> > that contain only routes that are relevant. (Well, yes, not all
> > routes in RIB might be relevant, this depends on other conditions.)
> > 
> > Jan
> >   
> 
> This technique is used for data structures that do not support 
> incremental updates. However FIB supports incremental updates.
> 
> You can keep a separate rib struct and reflect changes to the fib.

But reflecting the changes is sometimes really more difficult than just
rebuilding from scratch.

> 
> Also, using rte_fib_get_rib() you can get the corresponding RIB
> struct and work with it directly using rib API. However you need to

But than I've got two RIBs that I have to keep in sync with each other
which is quite difficult.

> be cautious, all adding/deletion and next hop changing must be done
> using fib API.

Because, otherwise the DIR24_8 is not in sync, right?

Jan

> 
> >>  
> 
> 
>  On 05/08/2021 15:14, Jan Viktorin wrote:  
> > On Thu, 5 Aug 2021 15:08:13 +0200
> > Vladimir Medvedkin  wrote:
> > 
> >> This patch announces the experimental tag removal of all fib
> >> APIs, which have been experimental for 2 years.
> >> API will be promoted to stable in DPDK 21.11  
> >
> > Hi Vladimir,
> >
> > I have a question related to FIB. I am just learning how to use
> > it and I found that each FIB always creates a new RIB
> > internally. There is no doc about this topic...
> >
> > If I understand correctly, the underlying RIB is only used when
> > dummy_lookup() and dummy_modify() are used. But they are only
> > used when the configured mode is RTE_FIB_DUMMY. Is there any
> > reason to create the RIB with RTE_FIB_DIR24_8?
> >
> > The issue with this is that each RIB allocates a new mempool
> > internally which can waste quite a lot of never used memory that
> > would be unused with DIR24_8 implementation.
> >
> > Regards
> > Jan
> > 
> >>
> >>
> >> Signed-off-by: Vladimir Medvedkin
> >>  ---
> >> doc/guides/rel_notes/deprecation.rst | 2 ++
> >> 1 file changed, 2 insertions(+)
> >>
> >> diff --git a/doc/guides/rel_notes/deprecation.rst
> >> b/doc/guides/rel_notes/deprecation.rst
> >> index afb599a..58826a8 100644
> >> --- a/doc/guides/rel_notes/deprecation.rst
> >> +++ b/doc/guides/rel_notes/deprecation.rst
> >> @@ -195,3 +195,5 @@ Deprecation Notices
> >>   communicate events such as soft expiry with IPsec in
> >> lookaside mode.
> >> * rib: The ``rib`` library will be promoted from
> >> experimental to stable. +
> >> +* fib: The ``fib`` library will be promoted from experimental
> >> to stable.  
>  
> >>>  
> >>  
> >   
> 



[dpdk-dev] [PATCH] eal/windows: expose symbol rte_version

2021-08-05 Thread William Tu
When OVS inits, it calls rte_version to get the DPDK's version.
The patch fixes the error below by exposing rte_version symbol.
libopenvswitch.a(dpdk.c.obj) : error LNK2019: unresolved external symbol
rte_version referenced in function dpdk_init

Signed-off-by: William Tu 
---
 lib/eal/version.map | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/lib/eal/version.map b/lib/eal/version.map
index 887012d02a..3de59910cd 100644
--- a/lib/eal/version.map
+++ b/lib/eal/version.map
@@ -198,7 +198,7 @@ DPDK_21 {
rte_uuid_is_null; # WINDOWS_NO_EXPORT
rte_uuid_parse; # WINDOWS_NO_EXPORT
rte_uuid_unparse; # WINDOWS_NO_EXPORT
-   rte_version; # WINDOWS_NO_EXPORT
+   rte_version;
rte_vfio_clear_group; # WINDOWS_NO_EXPORT
rte_vfio_container_create; # WINDOWS_NO_EXPORT
rte_vfio_container_destroy; # WINDOWS_NO_EXPORT
-- 
2.32.0.windows.2



Re: [dpdk-dev] [PATCH 2/2] fib: announce experimental tag removal of the fib API

2021-08-05 Thread Medvedkin, Vladimir




On 05/08/2021 16:34, Jan Viktorin wrote:

On Thu, 5 Aug 2021 16:29:50 +0200
"Medvedkin, Vladimir"  wrote:


On 05/08/2021 16:07, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:57:14 +0200
"Medvedkin, Vladimir"  wrote:
   

On 05/08/2021 15:32, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:27:15 +0200
"Medvedkin, Vladimir"  wrote:
  

Hi Jan,

The RIB is always used as a control plane struct intended to
maintain the correct content of the dataplane struct, such as
DIR24_8 for example. So it is always used on _add()/_delete().
For simplicity you can consider it as an LPM's rule_info. But
instead of keeping routes in a plane array as it is in LPM, FIB
uses RIB which is more suitable binary tree.


OK. I thought that I can have a single RIB, use it for maintaining
routes and based on this single RIB, I can build a FIB for the
data plane. And when the single RIB is updated (which can take
quite a lot of time) I build a new FIB and locklessly give it to
the dataplane. Such approach is not considered?

Jan
  


I'm not sure I understood completely your use case. Do you want to
rebuild the entire FIB from scratch every time the RIB changes?


The idea was to maintain a single RIB and two FIBs. One FIB is
active and under heavy load and when a route change arrives, it is
first written to RIB. When RIB is ready, it is used to quickly
construct/update the second inactive FIB. Then I swap with the
current active FIB. The old one can be edited/updated/recreated and
new one is active.

I've got one place where all routes are placed (RIB). And two FIBs
that contain only routes that are relevant. (Well, yes, not all
routes in RIB might be relevant, this depends on other conditions.)

Jan
   


This technique is used for data structures that do not support
incremental updates. However FIB supports incremental updates.

You can keep a separate rib struct and reflect changes to the fib.


But reflecting the changes is sometimes really more difficult than just
rebuilding from scratch.



Why? Could you provide an example?



Also, using rte_fib_get_rib() you can get the corresponding RIB
struct and work with it directly using rib API. However you need to


But than I've got two RIBs that I have to keep in sync with each other
which is quite difficult.



In this case you'll only have a single rib embedded into the fib


be cautious, all adding/deletion and next hop changing must be done
using fib API.


Because, otherwise the DIR24_8 is not in sync, right?



Yes


Jan



  



On 05/08/2021 15:14, Jan Viktorin wrote:

On Thu, 5 Aug 2021 15:08:13 +0200
Vladimir Medvedkin  wrote:
 

This patch announces the experimental tag removal of all fib
APIs, which have been experimental for 2 years.
API will be promoted to stable in DPDK 21.11


Hi Vladimir,

I have a question related to FIB. I am just learning how to use
it and I found that each FIB always creates a new RIB
internally. There is no doc about this topic...

If I understand correctly, the underlying RIB is only used when
dummy_lookup() and dummy_modify() are used. But they are only
used when the configured mode is RTE_FIB_DUMMY. Is there any
reason to create the RIB with RTE_FIB_DIR24_8?

The issue with this is that each RIB allocates a new mempool
internally which can waste quite a lot of never used memory that
would be unused with DIR24_8 implementation.

Regards
Jan
 



Signed-off-by: Vladimir Medvedkin
 ---
 doc/guides/rel_notes/deprecation.rst | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst
b/doc/guides/rel_notes/deprecation.rst
index afb599a..58826a8 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -195,3 +195,5 @@ Deprecation Notices
   communicate events such as soft expiry with IPsec in
lookaside mode.
 * rib: The ``rib`` library will be promoted from
experimental to stable. +
+* fib: The ``fib`` library will be promoted from experimental
to stable.
 
  
  
   






--
Regards,
Vladimir


Re: [dpdk-dev] [PATCH v2] doc: announce restructuring of crypto session structs

2021-08-05 Thread Zhang, Roy Fan
Hi Akhil,

No problem. Glad to help. If you have code ready to share please let me know.

Regards,
Fan

> -Original Message-
> From: Akhil Goyal 
> Sent: Thursday, August 5, 2021 3:10 PM
> To: Zhang, Roy Fan ; dev@dpdk.org
> Cc: Anoob Joseph ; Nicolau, Radu
> ; Doherty, Declan ;
> hemant.agra...@nxp.com; ma...@nvidia.com; Ananyev, Konstantin
> ; tho...@monjalon.net;
> asoma...@amd.com; ruifeng.w...@arm.com;
> ajit.khapa...@broadcom.com; De Lara Guarch, Pablo
> ; Trahe, Fiona ;
> Ankur Dwivedi ; Michael Shamis
> ; Nagadheeraj Rottela
> ; jianjay.z...@huawei.com
> Subject: RE: [PATCH v2] doc: announce restructuring of crypto session structs
> 
> Hi Fan,
> > Hi Akhil,
> >
> > > The structures rte_cryptodev_sym_session and
> > > rte_cryptodev_asym_session are not used by the
> > > application directly. The application just need
> > > an opaque pointer which it can attach to rte_crypto_op
> > > while enqueue.
> > > Hence, these structures can be internal to library
> > > hidden from the user.
> > >
> > > Signed-off-by: Akhil Goyal 
> > > ---
> > > v2: fixed trailing whitespace.
> > >
> > >  doc/guides/rel_notes/deprecation.rst | 5 +
> > >  1 file changed, 5 insertions(+)
> > >
> > > diff --git a/doc/guides/rel_notes/deprecation.rst
> > > b/doc/guides/rel_notes/deprecation.rst
> > > index f81bd87f10..c540c90f8e 100644
> > > --- a/doc/guides/rel_notes/deprecation.rst
> > > +++ b/doc/guides/rel_notes/deprecation.rst
> > > @@ -151,6 +151,11 @@ Deprecation Notices
> > >  * cryptodev: The APIs for interfacing between library and PMD will be
> > > marked
> > >as internal APIs in DPDK 21.11.
> > >
> > > +* cryptodev: Hide structures ``rte_cryptodev_sym_session`` and
> > > +  ``rte_cryptodev_asym_session`` to remove unnecessary indirection
> > > between
> > > +  session and the private data of session. An opaque pointer can be
> > exposed
> > > +  directly to application which can be attached to the ``rte_crypto_op``.
> > > +
> > >  * security: The functions ``rte_security_set_pkt_metadata`` and
> > >``rte_security_get_userdata`` will be made inline functions and
> additional
> > >flags will be added in structure ``rte_security_ctx`` in DPDK 21.11.
> > > --
> > > 2.25.1
> >
> > Have you considered how crypto scheduler PMD can support multiple
> crypto
> > devices' opaque data pointers after the change? Of course it is doable by
> > adding dedicated APIs to the scheduler PMD - shall I assume you will work
> on
> > it?
> 
> I haven't considered about the scheduler PMD yet. Would need your help in
> aligning that.
> The deprecation notice is to allow us change in 21.11 timeframe.
> 
> Thanks,
> Akhil


[dpdk-dev] [Bug 780] Phoenix American Financial Services

2021-08-05 Thread bugzilla
https://bugs.dpdk.org/show_bug.cgi?id=780

Bug ID: 780
   Summary: Phoenix American Financial Services
   Product: DPDK
   Version: 21.08
  Hardware: All
OS: All
Status: UNCONFIRMED
  Severity: normal
  Priority: Normal
 Component: examples
  Assignee: dev@dpdk.org
  Reporter: robertleemax...@gmail.com
  Target Milestone: ---

Phoenix American Financial Services provides leading-edge fund administration,
accounting and technology for the alternative assets industry. Visit site:
https://www.phxa.com/fund-accounting/

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

Re: [dpdk-dev] [PATCH v2] doc: announce restructuring of crypto session structs

2021-08-05 Thread Akhil Goyal
> Hi Akhil,
> 
> No problem. Glad to help. If you have code ready to share please let me
> know.
> 
I haven't started work on this yet. There are a few items in ABI improvements,
If you could pick some of them, it would be helpful.
I am currently working on PMD interface.
- Security and crypto session structs are next inline.
If you can spend some time, you could work on
rte_cryptodev and rte_cryptodev_data split and hide.


Re: [dpdk-dev] [PATCH] net: announce changes in TCP header

2021-08-05 Thread Thomas Monjalon
Nobody rejected this change but there is not enough ack
to make it an accepted announce of change.

02/08/2021 12:42, Gregory Etelson:
> Announce change to add a union that will provide byte and bitfield
> access to TCP flags.
> 
> Signed-off-by: Gregory Etelson 
> ---
> +* net: structure ``rte_tcp_hdr`` will have a union that will provide
> +  byte access to existing ``tcp_flags`` and add a bitfield for TCP flags.





[dpdk-dev] [Bug 780] Phoenix American Financial Services

2021-08-05 Thread bugzilla
https://bugs.dpdk.org/show_bug.cgi?id=780

Ajit Khaparde (ajit.khapa...@broadcom.com) changed:

   What|Removed |Added

 Status|UNCONFIRMED |RESOLVED
 CC||ajit.khapa...@broadcom.com
 Resolution|--- |INVALID

--- Comment #1 from Ajit Khaparde (ajit.khapa...@broadcom.com) ---
SPAM

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

[dpdk-dev] Windows community call: MoM 2021-08-04

2021-08-05 Thread Dmitry Kozlyuk
# About

The meeting takes place in MS Teams every two weeks on Wednesday 15:00 UTC.
Ask Harini Ramakrishnan  for invitation.


# Attendees

* Microsoft:
  - Khoa To
  - Narcisa Ana Maria Vasile (Naty)
  - Omar Cordona
  - Tyler Retzlaff
* NVIDIA:
  - Dmitry Kozlyuk (DmitryK)
  - Tal Shnaiderman
* VMWare:
  - Cheng-Chung William Tu (VMWare)
  - Sergey Madaminov (VMWare)
* Mark Cheatham (Boulder Imaging)
* Nick Connolly (Datapath)
* Pallavi Kadam (Intel)
* Yan Vugenfirer (Daynix)


# Agenda

* Patch status review
* Porting OvS build system to meson status report
* Windows 21.11 roadmap planning
* Misc


# Patch review

1. eal: Add EAL API for threading v13

DmitryK to finish the review and ack.
Naty to follow up with Thomas if the series can be merged without
the next one once acked because the code is used in unit tests at
least.

2. Enable the internal EAL thread API v2

Naty to send v3.

3. [v2] eal/windows: ensure all enabled CPUs are counted v2

DmitryK acked, but suggested a shorted working.
Naty to track the patch (maybe send v3 following suggestion).

4. windows/virt2phys: fix paging issue v2 (DmitryK)

Tyler to do a security-centered review and/or ping DmitryM.


# Porting OvS build system to meson (William Tu)

Status: OvS compiles with some features disabled, with a lot of warnings.
Issues:

* vhost-user is Linux-specific.
  [Omar] Microsoft is working on functional equivalent.
* rte_version* not exported.
  AI William to send patches.
* rte_open_logstream() implementation relies on Linux-specific fopencookie().
  We need a more generic facility to redirect logs.
  AI William and DmitryK to discuss.
* meson not finding DPDK with pkg-config, maybe meson bug.
  AI William and DmitryK to investigate.

[Omar] What are the use cases for OvS on Windows?
[William]:
1. VMWare NSX on Windows;
2. AF_XDP replacement (fast data path);
   [Omar] Windows now has its own experimental AF_XDP
3. Kubernetes containers scenario.


# Windows 21.11 roadmap

AI DmitryK to send a roadmap patch, below are brief notes.

1. Harini, Omar, and Tyler will work on establishing the process of signing
and publishing netuio and virt2phys. Likely some form of external signing
will be used, i.e. not by Microsoft name. Audit before signing must be
aligned with DPDK releases. CI for signing is also currently missing.
Microsoft will discuss the topic externally and reach more people of needed.

2. DmitryK will work on interrupt support in DPDK and netuio.
   Intel will help with testing on their HW.
   Microsoft will help with code review.

3. Naty will finish the work on threading API.
   DmitryK to track them and review on time.

4. Tyler will work on enabling shared build of DPDK, mostly
solving the issues with thread-local storage. At least patches will be sent
by 21.11, not sure if merged. DmitryK will help with review.

6. DmitryK will replace SetupAPI with cfgmgr32 API in lib/eal and bus/pci.

7. Harini will expedite investigation by Microsoft,
   why netuio doesn't work with vmxnet3 HW in VMWare hypervisor.

8. External issues to track:

8.1) wpcap lacks pkg-config file:
 https://github.com/nmap/npcap/issues/299
8.2) meson 0.58 unable to build DPDK:
 https://github.com/mesonbuild/meson/issues/8981


# Misc

* We need to better automation scripts for things in Windows GSG:
  - to setup development environment;
  - to enable "Lock pages in memory privilege";
  - to install drivers.

* netuio needs tracing (logging), maybe it will be WPP tracing,
  maybe Microsoft will advise a better technology.


[dpdk-dev] [PATCH 0/4] cryptodev: expose driver interface as internal

2021-08-05 Thread Akhil Goyal
rte_cryptodev_pmd.* files are meant to be used for
DPDK internal usage only, but it was used illegally by
applications.
There is one API which can be used by applications to
check if the dev_id has a valid device or not.
This API is exposed and modified as rte_cryptodev_is_valid_dev()
from rte_cryptodev_pmd_is_valid_dev().

Akhil Goyal (4):
  test/crypto: remove illegal header include
  cryptodev: change valid dev API
  examples/fips_validation: remove illegal usage of APIs
  cryptodev: expose driver interface as internal

 app/test/test_cryptodev.c |  1 -
 app/test/test_cryptodev_asym.c|  1 -
 app/test/test_cryptodev_blockcipher.c |  1 -
 app/test/test_cryptodev_security_pdcp.c   |  1 -
 app/test/test_ipsec.c |  1 -
 drivers/crypto/aesni_gcm/aesni_gcm_pmd.c  |  2 +-
 drivers/crypto/aesni_gcm/aesni_gcm_pmd_ops.c  |  2 +-
 drivers/crypto/aesni_mb/rte_aesni_mb_pmd.c|  2 +-
 .../crypto/aesni_mb/rte_aesni_mb_pmd_ops.c|  2 +-
 drivers/crypto/armv8/rte_armv8_pmd.c  |  2 +-
 drivers/crypto/armv8/rte_armv8_pmd_ops.c  |  2 +-
 drivers/crypto/bcmfs/bcmfs_sym_pmd.c  |  2 +-
 drivers/crypto/bcmfs/bcmfs_sym_session.h  |  2 +-
 drivers/crypto/caam_jr/caam_jr.c  |  2 +-
 drivers/crypto/ccp/ccp_crypto.c   |  2 +-
 drivers/crypto/ccp/ccp_pmd_ops.c  |  2 +-
 drivers/crypto/ccp/rte_ccp_pmd.c  |  2 +-
 drivers/crypto/cnxk/cn10k_cryptodev.c |  2 +-
 drivers/crypto/cnxk/cn10k_cryptodev_ops.c |  2 +-
 drivers/crypto/cnxk/cn10k_cryptodev_ops.h |  2 +-
 drivers/crypto/cnxk/cn9k_cryptodev.c  |  2 +-
 drivers/crypto/cnxk/cn9k_cryptodev_ops.c  |  2 +-
 drivers/crypto/cnxk/cn9k_cryptodev_ops.h  |  2 +-
 drivers/crypto/cnxk/cnxk_cryptodev_ops.c  |  2 +-
 drivers/crypto/dpaa2_sec/dpaa2_sec_dpseci.c   |  2 +-
 drivers/crypto/dpaa_sec/dpaa_sec.c|  2 +-
 drivers/crypto/kasumi/rte_kasumi_pmd.c|  2 +-
 drivers/crypto/kasumi/rte_kasumi_pmd_ops.c|  2 +-
 drivers/crypto/mlx5/mlx5_crypto.h |  2 +-
 drivers/crypto/mvsam/rte_mrvl_pmd.c   |  2 +-
 drivers/crypto/mvsam/rte_mrvl_pmd_ops.c   |  2 +-
 drivers/crypto/nitrox/nitrox_sym.c|  2 +-
 drivers/crypto/null/null_crypto_pmd.c |  2 +-
 drivers/crypto/null/null_crypto_pmd_ops.c |  2 +-
 drivers/crypto/octeontx/otx_cryptodev.c   |  2 +-
 drivers/crypto/octeontx/otx_cryptodev_ops.c   |  2 +-
 drivers/crypto/octeontx2/otx2_cryptodev.c |  2 +-
 drivers/crypto/octeontx2/otx2_cryptodev_ops.c |  2 +-
 drivers/crypto/octeontx2/otx2_cryptodev_ops.h |  2 +-
 drivers/crypto/openssl/rte_openssl_pmd.c  |  2 +-
 drivers/crypto/openssl/rte_openssl_pmd_ops.c  |  2 +-
 drivers/crypto/qat/qat_asym.h |  2 +-
 drivers/crypto/qat/qat_asym_pmd.c |  2 +-
 drivers/crypto/qat/qat_sym.h  |  2 +-
 drivers/crypto/qat/qat_sym_hw_dp.c|  2 +-
 drivers/crypto/qat/qat_sym_pmd.c  |  2 +-
 drivers/crypto/qat/qat_sym_session.h  |  2 +-
 .../scheduler/rte_cryptodev_scheduler.c   |  2 +-
 drivers/crypto/scheduler/scheduler_pmd.c  |  2 +-
 drivers/crypto/scheduler/scheduler_pmd_ops.c  |  2 +-
 drivers/crypto/snow3g/rte_snow3g_pmd.c|  2 +-
 drivers/crypto/snow3g/rte_snow3g_pmd_ops.c|  2 +-
 drivers/crypto/virtio/virtio_cryptodev.c  |  2 +-
 drivers/crypto/virtio/virtio_rxtx.c   |  2 +-
 drivers/crypto/zuc/rte_zuc_pmd.c  |  2 +-
 drivers/crypto/zuc/rte_zuc_pmd_ops.c  |  2 +-
 .../octeontx2/otx2_evdev_crypto_adptr_rx.h|  2 +-
 .../octeontx2/otx2_evdev_crypto_adptr_tx.h|  2 +-
 .../net/softnic/rte_eth_softnic_cryptodev.c   |  4 +-
 examples/fips_validation/fips_dev_self_test.c | 19 +--
 examples/fips_validation/main.c   |  9 ++--
 examples/ip_pipeline/cryptodev.c  |  3 +-
 .../{rte_cryptodev_pmd.c => cryptodev_pmd.c}  |  2 +-
 .../{rte_cryptodev_pmd.h => cryptodev_pmd.h}  | 27 +-
 lib/cryptodev/meson.build | 18 +--
 lib/cryptodev/rte_cryptodev.c | 52 +--
 lib/cryptodev/rte_cryptodev.h | 11 
 lib/cryptodev/version.map | 27 ++
 lib/eventdev/rte_event_crypto_adapter.c   |  6 +--
 lib/eventdev/rte_eventdev.c   |  4 +-
 lib/pipeline/rte_table_action.c   |  4 +-
 71 files changed, 149 insertions(+), 148 deletions(-)
 rename lib/cryptodev/{rte_cryptodev_pmd.c => cryptodev_pmd.c} (99%)
 rename lib/cryptodev/{rte_cryptodev_pmd.h => cryptodev_pmd.h} (97%)

-- 
2.25.1



[dpdk-dev] [PATCH 2/4] cryptodev: change valid dev API

2021-08-05 Thread Akhil Goyal
The API rte_cryptodev_pmd_is_valid_dev, can be used
by the application as well as PMD to check whether
the device is valid or not. Hence, _pmd is removed
from the API.
The applications and drivers which use this API are
also updated.

Signed-off-by: Akhil Goyal 
---
 .../net/softnic/rte_eth_softnic_cryptodev.c   |  2 +-
 examples/fips_validation/main.c   |  2 +-
 examples/ip_pipeline/cryptodev.c  |  3 +-
 lib/cryptodev/rte_cryptodev.c | 50 +--
 lib/cryptodev/rte_cryptodev.h | 11 
 lib/cryptodev/rte_cryptodev_pmd.h | 11 
 lib/cryptodev/version.map |  2 +-
 lib/eventdev/rte_event_crypto_adapter.c   |  4 +-
 lib/eventdev/rte_eventdev.c   |  2 +-
 lib/pipeline/rte_table_action.c   |  2 +-
 10 files changed, 44 insertions(+), 45 deletions(-)

diff --git a/drivers/net/softnic/rte_eth_softnic_cryptodev.c 
b/drivers/net/softnic/rte_eth_softnic_cryptodev.c
index a1a4ca5650..8e278801c5 100644
--- a/drivers/net/softnic/rte_eth_softnic_cryptodev.c
+++ b/drivers/net/softnic/rte_eth_softnic_cryptodev.c
@@ -82,7 +82,7 @@ softnic_cryptodev_create(struct pmd_internals *p,
 
dev_id = (uint32_t)status;
} else {
-   if (rte_cryptodev_pmd_is_valid_dev(params->dev_id) == 0)
+   if (rte_cryptodev_is_valid_dev(params->dev_id) == 0)
return NULL;
 
dev_id = params->dev_id;
diff --git a/examples/fips_validation/main.c b/examples/fips_validation/main.c
index c175fe6ac2..e892078f0e 100644
--- a/examples/fips_validation/main.c
+++ b/examples/fips_validation/main.c
@@ -196,7 +196,7 @@ parse_cryptodev_id_arg(char *arg)
}
 
 
-   if (!rte_cryptodev_pmd_is_valid_dev(cryptodev_id)) {
+   if (!rte_cryptodev_is_valid_dev(cryptodev_id)) {
RTE_LOG(ERR, USER1, "Error %i: invalid cryptodev id %s\n",
cryptodev_id, arg);
return -1;
diff --git a/examples/ip_pipeline/cryptodev.c b/examples/ip_pipeline/cryptodev.c
index b0d9f3d217..9997d97456 100644
--- a/examples/ip_pipeline/cryptodev.c
+++ b/examples/ip_pipeline/cryptodev.c
@@ -6,7 +6,6 @@
 #include 
 
 #include 
-#include 
 #include 
 
 #include "cryptodev.h"
@@ -74,7 +73,7 @@ cryptodev_create(const char *name, struct cryptodev_params 
*params)
 
dev_id = (uint32_t)status;
} else {
-   if (rte_cryptodev_pmd_is_valid_dev(params->dev_id) == 0)
+   if (rte_cryptodev_is_valid_dev(params->dev_id) == 0)
return NULL;
 
dev_id = params->dev_id;
diff --git a/lib/cryptodev/rte_cryptodev.c b/lib/cryptodev/rte_cryptodev.c
index 447aa9d519..37502b9b3c 100644
--- a/lib/cryptodev/rte_cryptodev.c
+++ b/lib/cryptodev/rte_cryptodev.c
@@ -663,7 +663,7 @@ rte_cryptodev_is_valid_device_data(uint8_t dev_id)
 }
 
 unsigned int
-rte_cryptodev_pmd_is_valid_dev(uint8_t dev_id)
+rte_cryptodev_is_valid_dev(uint8_t dev_id)
 {
struct rte_cryptodev *dev = NULL;
 
@@ -761,7 +761,7 @@ rte_cryptodev_socket_id(uint8_t dev_id)
 {
struct rte_cryptodev *dev;
 
-   if (!rte_cryptodev_pmd_is_valid_dev(dev_id))
+   if (!rte_cryptodev_is_valid_dev(dev_id))
return -1;
 
dev = rte_cryptodev_pmd_get_dev(dev_id);
@@ -1032,7 +1032,7 @@ rte_cryptodev_configure(uint8_t dev_id, struct 
rte_cryptodev_config *config)
struct rte_cryptodev *dev;
int diag;
 
-   if (!rte_cryptodev_pmd_is_valid_dev(dev_id)) {
+   if (!rte_cryptodev_is_valid_dev(dev_id)) {
CDEV_LOG_ERR("Invalid dev_id=%" PRIu8, dev_id);
return -EINVAL;
}
@@ -1080,7 +1080,7 @@ rte_cryptodev_start(uint8_t dev_id)
 
CDEV_LOG_DEBUG("Start dev_id=%" PRIu8, dev_id);
 
-   if (!rte_cryptodev_pmd_is_valid_dev(dev_id)) {
+   if (!rte_cryptodev_is_valid_dev(dev_id)) {
CDEV_LOG_ERR("Invalid dev_id=%" PRIu8, dev_id);
return -EINVAL;
}
@@ -1110,7 +1110,7 @@ rte_cryptodev_stop(uint8_t dev_id)
 {
struct rte_cryptodev *dev;
 
-   if (!rte_cryptodev_pmd_is_valid_dev(dev_id)) {
+   if (!rte_cryptodev_is_valid_dev(dev_id)) {
CDEV_LOG_ERR("Invalid dev_id=%" PRIu8, dev_id);
return;
}
@@ -1136,7 +1136,7 @@ rte_cryptodev_close(uint8_t dev_id)
struct rte_cryptodev *dev;
int retval;
 
-   if (!rte_cryptodev_pmd_is_valid_dev(dev_id)) {
+   if (!rte_cryptodev_is_valid_dev(dev_id)) {
CDEV_LOG_ERR("Invalid dev_id=%" PRIu8, dev_id);
return -1;
}
@@ -1176,7 +1176,7 @@ rte_cryptodev_get_qp_status(uint8_t dev_id, uint16_t 
queue_pair_id)
 {
struct rte_cryptodev *dev;
 
-   if (!rte_cryptodev_pmd_is_valid_dev(dev_id)) {
+   if (!rte_cryptodev_is_valid_dev(dev_id)) {
CDEV_LOG_ERR("Invalid dev_id=%" PRIu8, dev_id);
 

[dpdk-dev] [PATCH 1/4] test/crypto: remove illegal header include

2021-08-05 Thread Akhil Goyal
rte_cryptodev_pmd.h is an interface between
driver and library and it is mentioned in the
file that application cannot use it directly.
Hence, removing the include.

Signed-off-by: Akhil Goyal 
---
 app/test/test_cryptodev.c   | 1 -
 app/test/test_cryptodev_asym.c  | 1 -
 app/test/test_cryptodev_blockcipher.c   | 1 -
 app/test/test_cryptodev_security_pdcp.c | 1 -
 app/test/test_ipsec.c   | 1 -
 5 files changed, 5 deletions(-)

diff --git a/app/test/test_cryptodev.c b/app/test/test_cryptodev.c
index 9ad0b37473..e8d63b2bc3 100644
--- a/app/test/test_cryptodev.c
+++ b/app/test/test_cryptodev.c
@@ -16,7 +16,6 @@
 
 #include 
 #include 
-#include 
 #include 
 
 #ifdef RTE_CRYPTO_SCHEDULER
diff --git a/app/test/test_cryptodev_asym.c b/app/test/test_cryptodev_asym.c
index afa0e91a45..603b2e4609 100644
--- a/app/test/test_cryptodev_asym.c
+++ b/app/test/test_cryptodev_asym.c
@@ -12,7 +12,6 @@
 #include 
 
 #include 
-#include 
 #include 
 
 #include "test_cryptodev.h"
diff --git a/app/test/test_cryptodev_blockcipher.c 
b/app/test/test_cryptodev_blockcipher.c
index 53fd4718af..1c948eb008 100644
--- a/app/test/test_cryptodev_blockcipher.c
+++ b/app/test/test_cryptodev_blockcipher.c
@@ -11,7 +11,6 @@
 
 #include 
 #include 
-#include 
 
 #include "test.h"
 #include "test_cryptodev.h"
diff --git a/app/test/test_cryptodev_security_pdcp.c 
b/app/test/test_cryptodev_security_pdcp.c
index 30f3eb892c..a7641bab7a 100644
--- a/app/test/test_cryptodev_security_pdcp.c
+++ b/app/test/test_cryptodev_security_pdcp.c
@@ -17,7 +17,6 @@
 
 #include 
 #include 
-#include 
 #include 
 
 #include 
diff --git a/app/test/test_ipsec.c b/app/test/test_ipsec.c
index fb90130ae2..c6d6b88d6d 100644
--- a/app/test/test_ipsec.c
+++ b/app/test/test_ipsec.c
@@ -15,7 +15,6 @@
 
 #include 
 #include 
-#include 
 #include 
 #include 
 #include 
-- 
2.25.1



[dpdk-dev] [PATCH 3/4] examples/fips_validation: remove illegal usage of APIs

2021-08-05 Thread Akhil Goyal
Some of the cryptodev APIs are not allowed to be used
by application directly. Hence removing the usage of
1. queue_pair_release: it is not required, as configure
   of queue pair release the previous queue pairs and the
   dev is not directly exposed to application, hence cannot
   use its ops from app.
2. rte_cryptodev_stop: it can be used directly without
   checking if the device is started or not.
3. rte_cryptodev_pmd_destroy: application should use
   rte_cryptodev_close instead.

Signed-off-by: Akhil Goyal 
---
 examples/fips_validation/fips_dev_self_test.c | 19 ++-
 examples/fips_validation/main.c   |  7 ++-
 2 files changed, 4 insertions(+), 22 deletions(-)

diff --git a/examples/fips_validation/fips_dev_self_test.c 
b/examples/fips_validation/fips_dev_self_test.c
index 17e85973c0..b4eab05a98 100644
--- a/examples/fips_validation/fips_dev_self_test.c
+++ b/examples/fips_validation/fips_dev_self_test.c
@@ -3,7 +3,7 @@
  */
 
 #include 
-#include 
+#include 
 
 #include "fips_dev_self_test.h"
 
@@ -1523,12 +1523,6 @@ static void
 fips_dev_auto_test_uninit(uint8_t dev_id,
struct fips_dev_auto_test_env *env)
 {
-   struct rte_cryptodev *dev = rte_cryptodev_pmd_get_dev(dev_id);
-   uint32_t i;
-
-   if (!dev)
-   return;
-
if (env->mbuf)
rte_pktmbuf_free(env->mbuf);
if (env->op)
@@ -1542,16 +1536,7 @@ fips_dev_auto_test_uninit(uint8_t dev_id,
if (env->sess_priv_pool)
rte_mempool_free(env->sess_priv_pool);
 
-   if (dev->data->dev_started)
-   rte_cryptodev_stop(dev_id);
-
-   if (dev->data->nb_queue_pairs) {
-   for (i = 0; i < dev->data->nb_queue_pairs; i++)
-   (*dev->dev_ops->queue_pair_release)(dev, i);
-   dev->data->nb_queue_pairs = 0;
-   rte_free(dev->data->queue_pairs);
-   dev->data->queue_pairs = NULL;
-   }
+   rte_cryptodev_stop(dev_id);
 }
 
 static int
diff --git a/examples/fips_validation/main.c b/examples/fips_validation/main.c
index e892078f0e..a8daad1f48 100644
--- a/examples/fips_validation/main.c
+++ b/examples/fips_validation/main.c
@@ -7,7 +7,7 @@
 #include 
 
 #include 
-#include 
+#include 
 #include 
 #include 
 #include 
@@ -73,10 +73,7 @@ cryptodev_fips_validate_app_int(void)
if (env.self_test) {
ret = fips_dev_self_test(env.dev_id, env.broken_test_config);
if (ret < 0) {
-   struct rte_cryptodev *cryptodev =
-   rte_cryptodev_pmd_get_dev(env.dev_id);
-
-   rte_cryptodev_pmd_destroy(cryptodev);
+   rte_cryptodev_close(env.dev_id);
 
return ret;
}
-- 
2.25.1



[dpdk-dev] [PATCH 4/4] cryptodev: expose driver interface as internal

2021-08-05 Thread Akhil Goyal
The rte_cryptodev_pmd.* files are for drivers only and should be
private to DPDK, and not installed for app use.

Signed-off-by: Akhil Goyal 
---
 drivers/crypto/aesni_gcm/aesni_gcm_pmd.c  |  2 +-
 drivers/crypto/aesni_gcm/aesni_gcm_pmd_ops.c  |  2 +-
 drivers/crypto/aesni_mb/rte_aesni_mb_pmd.c|  2 +-
 .../crypto/aesni_mb/rte_aesni_mb_pmd_ops.c|  2 +-
 drivers/crypto/armv8/rte_armv8_pmd.c  |  2 +-
 drivers/crypto/armv8/rte_armv8_pmd_ops.c  |  2 +-
 drivers/crypto/bcmfs/bcmfs_sym_pmd.c  |  2 +-
 drivers/crypto/bcmfs/bcmfs_sym_session.h  |  2 +-
 drivers/crypto/caam_jr/caam_jr.c  |  2 +-
 drivers/crypto/ccp/ccp_crypto.c   |  2 +-
 drivers/crypto/ccp/ccp_pmd_ops.c  |  2 +-
 drivers/crypto/ccp/rte_ccp_pmd.c  |  2 +-
 drivers/crypto/cnxk/cn10k_cryptodev.c |  2 +-
 drivers/crypto/cnxk/cn10k_cryptodev_ops.c |  2 +-
 drivers/crypto/cnxk/cn10k_cryptodev_ops.h |  2 +-
 drivers/crypto/cnxk/cn9k_cryptodev.c  |  2 +-
 drivers/crypto/cnxk/cn9k_cryptodev_ops.c  |  2 +-
 drivers/crypto/cnxk/cn9k_cryptodev_ops.h  |  2 +-
 drivers/crypto/cnxk/cnxk_cryptodev_ops.c  |  2 +-
 drivers/crypto/dpaa2_sec/dpaa2_sec_dpseci.c   |  2 +-
 drivers/crypto/dpaa_sec/dpaa_sec.c|  2 +-
 drivers/crypto/kasumi/rte_kasumi_pmd.c|  2 +-
 drivers/crypto/kasumi/rte_kasumi_pmd_ops.c|  2 +-
 drivers/crypto/mlx5/mlx5_crypto.h |  2 +-
 drivers/crypto/mvsam/rte_mrvl_pmd.c   |  2 +-
 drivers/crypto/mvsam/rte_mrvl_pmd_ops.c   |  2 +-
 drivers/crypto/nitrox/nitrox_sym.c|  2 +-
 drivers/crypto/null/null_crypto_pmd.c |  2 +-
 drivers/crypto/null/null_crypto_pmd_ops.c |  2 +-
 drivers/crypto/octeontx/otx_cryptodev.c   |  2 +-
 drivers/crypto/octeontx/otx_cryptodev_ops.c   |  2 +-
 drivers/crypto/octeontx2/otx2_cryptodev.c |  2 +-
 drivers/crypto/octeontx2/otx2_cryptodev_ops.c |  2 +-
 drivers/crypto/octeontx2/otx2_cryptodev_ops.h |  2 +-
 drivers/crypto/openssl/rte_openssl_pmd.c  |  2 +-
 drivers/crypto/openssl/rte_openssl_pmd_ops.c  |  2 +-
 drivers/crypto/qat/qat_asym.h |  2 +-
 drivers/crypto/qat/qat_asym_pmd.c |  2 +-
 drivers/crypto/qat/qat_sym.h  |  2 +-
 drivers/crypto/qat/qat_sym_hw_dp.c|  2 +-
 drivers/crypto/qat/qat_sym_pmd.c  |  2 +-
 drivers/crypto/qat/qat_sym_session.h  |  2 +-
 .../scheduler/rte_cryptodev_scheduler.c   |  2 +-
 drivers/crypto/scheduler/scheduler_pmd.c  |  2 +-
 drivers/crypto/scheduler/scheduler_pmd_ops.c  |  2 +-
 drivers/crypto/snow3g/rte_snow3g_pmd.c|  2 +-
 drivers/crypto/snow3g/rte_snow3g_pmd_ops.c|  2 +-
 drivers/crypto/virtio/virtio_cryptodev.c  |  2 +-
 drivers/crypto/virtio/virtio_rxtx.c   |  2 +-
 drivers/crypto/zuc/rte_zuc_pmd.c  |  2 +-
 drivers/crypto/zuc/rte_zuc_pmd_ops.c  |  2 +-
 .../octeontx2/otx2_evdev_crypto_adptr_rx.h|  2 +-
 .../octeontx2/otx2_evdev_crypto_adptr_tx.h|  2 +-
 .../net/softnic/rte_eth_softnic_cryptodev.c   |  2 +-
 .../{rte_cryptodev_pmd.c => cryptodev_pmd.c}  |  2 +-
 .../{rte_cryptodev_pmd.h => cryptodev_pmd.h}  | 16 +---
 lib/cryptodev/meson.build | 18 ++---
 lib/cryptodev/rte_cryptodev.c |  2 +-
 lib/cryptodev/version.map | 25 +++
 lib/eventdev/rte_event_crypto_adapter.c   |  2 +-
 lib/eventdev/rte_eventdev.c   |  2 +-
 lib/pipeline/rte_table_action.c   |  2 +-
 62 files changed, 101 insertions(+), 76 deletions(-)
 rename lib/cryptodev/{rte_cryptodev_pmd.c => cryptodev_pmd.c} (99%)
 rename lib/cryptodev/{rte_cryptodev_pmd.h => cryptodev_pmd.h} (98%)

diff --git a/drivers/crypto/aesni_gcm/aesni_gcm_pmd.c 
b/drivers/crypto/aesni_gcm/aesni_gcm_pmd.c
index 886e2a5aaa..330aad8157 100644
--- a/drivers/crypto/aesni_gcm/aesni_gcm_pmd.c
+++ b/drivers/crypto/aesni_gcm/aesni_gcm_pmd.c
@@ -5,7 +5,7 @@
 #include 
 #include 
 #include 
-#include 
+#include 
 #include 
 #include 
 #include 
diff --git a/drivers/crypto/aesni_gcm/aesni_gcm_pmd_ops.c 
b/drivers/crypto/aesni_gcm/aesni_gcm_pmd_ops.c
index 18dbc4c18c..edb7275e76 100644
--- a/drivers/crypto/aesni_gcm/aesni_gcm_pmd_ops.c
+++ b/drivers/crypto/aesni_gcm/aesni_gcm_pmd_ops.c
@@ -6,7 +6,7 @@
 
 #include 
 #include 
-#include 
+#include 
 
 #include "aesni_gcm_pmd_private.h"
 
diff --git a/drivers/crypto/aesni_mb/rte_aesni_mb_pmd.c 
b/drivers/crypto/aesni_mb/rte_aesni_mb_pmd.c
index a01c826a3c..60963a8208 100644
--- a/drivers/crypto/aesni_mb/rte_aesni_mb_pmd.c
+++ b/drivers/crypto/aesni_mb/rte_aesni_mb_pmd.c
@@ -7,7 +7,7 @@
 #include 
 #include 
 #include 
-#include 
+#include 
 #include 
 #include 
 #include 
diff --git a/drivers/crypto/aesni_mb/rte_aesni_mb_pmd_ops.c 
b/drivers/crypto/aesni_mb/rte_aesni_mb_pmd_ops.c
index fc7fdfec8e..48a8f91868 100644
--- a/drivers/crypto/aesni_mb/rte_aesni_mb_pmd_o

[dpdk-dev] [PATCH v1] doc: update release notes for 21.08

2021-08-05 Thread John McNamara
Fix grammar, spelling and formatting of DPDK 21.08 release notes.

Signed-off-by: John McNamara 
---
 doc/guides/rel_notes/release_21_08.rst | 78 --
 1 file changed, 24 insertions(+), 54 deletions(-)

diff --git a/doc/guides/rel_notes/release_21_08.rst 
b/doc/guides/rel_notes/release_21_08.rst
index d7559ec6bf..0a7b817d9f 100644
--- a/doc/guides/rel_notes/release_21_08.rst
+++ b/doc/guides/rel_notes/release_21_08.rst
@@ -57,20 +57,20 @@ New Features
 
 * **Added auxiliary bus support.**
 
-  Auxiliary bus provides a way to split function into child-devices
+  An auxiliary bus provides a way to split a function into child-devices
   representing sub-domains of functionality. Each auxiliary device
   represents a part of its parent functionality.
 
 * **Added XZ compressed firmware support.**
 
-  Using ``rte_firmware_read``, a driver can now handle XZ compressed firmware
-  in a transparent way, with EAL uncompressing using libarchive if this library
+  Using ``rte_firmware_read`` a driver can now handle XZ compressed firmware
+  in a transparent way, with EAL uncompressing using libarchive, if this 
library
   is available when building DPDK.
 
 * **Updated Amazon ENA PMD.**
 
-  The new driver version (v2.4.0) introduced bug fixes and improvements,
-  including:
+  Updated the Amazon ENA PMD. The new driver version (v2.4.0) introduced bug
+  fixes and improvements, including:
 
   * Added Rx interrupt support.
   * RSS hash function key reconfiguration support.
@@ -78,20 +78,20 @@ New Features
 * **Updated Intel iavf driver.**
 
   * Added Tx QoS VF queue TC mapping.
-  * Added FDIR and RSS for GTPoGRE, support filter based on GTPU TEID/QFI,
-outer most L3 or inner most l3/l4. 
+  * Added FDIR and RSS for GTPoGRE, and support for filters based on GTPU 
TEID/QFI,
+outermost L3 or innermost L3/L4.
 
 * **Updated Intel ice driver.**
 
-  * In AVX2 code, added the new RX and TX paths to use the HW offload
+  * Added new RX and TX paths in the AVX2 code to use HW offload
 features. When the HW offload features are configured to be used, the
 offload paths are chosen automatically. In parallel the support for HW
 offload features was removed from the legacy AVX2 paths.
   * Added Tx QoS TC bandwidth configuration in DCF.
 
-* **Added support for Marvell CN10K SoC ethernet device.**
+* **Added support for Marvell CN10K SoC Ethernet device.**
 
-  * Added net/cnxk driver which provides the support for the integrated 
ethernet
+  * Added net/cnxk driver which provides the support for the integrated 
Ethernet
 device.
 
 * **Updated Mellanox mlx5 driver.**
@@ -100,44 +100,44 @@ New Features
   * Added support for meter hierarchy.
   * Added support for metering policy actions of yellow color.
   * Added support for metering trTCM RFC2698 and RFC4115.
-  * Added devargs options ``allow_duplicate_pattern``.
+  * Added devargs option ``allow_duplicate_pattern``.
   * Added matching on IPv4 Internet Header Length (IHL).
   * Added support for matching on VXLAN header last 8-bits reserved field.
   * Optimized multi-thread flow rule insertion rate.
 
 * **Added Wangxun ngbe PMD.**
 
-  Added a new PMD driver for Wangxun 1 Gigabit Ethernet NICs.
+  Added a new PMD driver for Wangxun 1Gb Ethernet NICs.
   See the :doc:`../nics/ngbe` for more details.
 
 * **Updated Solarflare network PMD.**
 
   Updated the Solarflare ``sfc_efx`` driver with changes including:
 
-  * Added COUNT action support for SN1000 NICs
+  * Added COUNT action support for SN1000 NICs.
 
 * **Added inflight packets clear API in vhost library.**
 
-  Added an API which can clear the inflight packets submitted to DMA
-  engine in vhost async data path.
+  Added an API which can clear the inflight packets submitted to the DMA
+  engine in the vhost async data path.
 
 * **Updated Intel QuickAssist crypto PMD.**
 
   Added fourth generation of QuickAssist Technology(QAT) devices support.
-  Only symmetric crypto has been currently enabled, compression and asymmetric
+  Only symmetric crypto has been currently enabled. Compression and asymmetric
   crypto PMD will fail to create.
 
 * **Added support for Marvell CNXK crypto driver.**
 
   * Added cnxk crypto PMD which provides support for an integrated
 crypto driver for CN9K and CN10K series of SOCs. Support for
-symmetric crypto algorithms is added to both the PMDs.
+symmetric crypto algorithms was added to both the PMDs.
   * Added support for lookaside protocol (IPsec) offload in cn10k PMD.
   * Added support for asymmetric crypto operations in cn9k and cn10k PMD.
 
 * **Updated Marvell OCTEON TX crypto PMD.**
 
-  Added support for crypto adapter OP_FORWARD mode.
+  Added support for crypto adapter ``OP_FORWARD`` mode.
 
 * **Added support for Nvidia crypto device driver.**
 
@@ -150,14 +150,14 @@ New Features
 
 * **Added Baseband PHY CNXK PMD.**
 
-  Added Baseband PHY PMD which allows to configure BPHY hardware block
+  Added Baseband PHY

Re: [dpdk-dev] [WARNING: UNSCANNABLE EXTRACTION FAILED][WARNING: UNSCANNABLE EXTRACTION FAILED] [PATCH v3] doc: mtr: add API walk through

2021-08-05 Thread Dumitrescu, Cristian
Hi Jerin,
> 
> On Thu, Aug 5, 2021 at 4:36 PM Dumitrescu, Cristian
>  wrote:
> >
> > HI Jerin,
> >
> > Thanks for your patch!
> >
> > Initially, it looked like an easy job to review it, but there is actually an
> elephant in the room on how to chain the meters, see below.
> 
> Yes. That's why I send this patch to finalize how to chain the meter.
> It was hard for me to follow that's why added a digram.
> 

OK, got it :)



> > > +#. A meter object consists of a profile and a policy. Use above created
> > > objects to create
> > > +   meter object using ``rte_mtr_create()``. Application uses
> > > +   ``struct rte_mtr_params::meter_profile_id`` and ``struct
> > > rte_mtr_params::meter_policy_id``
> > > +   to specify the profile (created in step 2) and policy (created in 
> > > step 3).
> >
> > It is mainly the meter object configuration that consists of a profile and a
> policy, but not exactly the meter object itself.
> >
> > How about:
> > The application creates a meter object using the rte_mtr_create() 
> > API
> function. One of the previously created meter profile and meter policy are
> provided as arguments at this step.
> 
> Sure. I just though to add exact struct field so that it easy for end
> users to know.
> 
> How about your version + struct name.
> 
> The application creates a meter object using the rte_mtr_create() API
> function.
> One of the previously created meter profile (`struct
> rte_mtr_params::meter_profile_id``) and meter policy
> ``struct rte_mtr_params::meter_policy_id`` are provided as arguments
> at this step.
> 

Great, thanks!



> > > +#. The API allows chaining the meter objects to create complex
> metering
> > > topology
> > > +   by specifying ``struct rte_mtr_meter_policy_params::actions`` action
> as
> > > +   ``RTE_FLOW_ACTION_TYPE_METER`` to the parent meter object
> encoded
> > > as
> > > +   ``struct rte_flow_action_meter::mtr_id``.
> >
> > Now this could be the elephant in the room:
> >
> > With the latest API changes that went in recently, the rte_mtr API now
> allows for a list of (any) rte_flow actions to be specified per color for each
> meter object, which opens up the door for a meter action to call one (or
> more) subsequent meter actions (on the same or different meter objects)
> conditional of a specific color. Which is another (new) way to chain meters,
> right? Let's refer to this as the Meter Chaining - Approach B.
> 
> Yes, my diagram is approach B.
> 
> >
> > Before these API changes, the only way to chain meters was by specifying
> multiple meter actions (action on the same or different meter object) for the
> same rte_flow. Let's refer to this as the Meter Chaining - Approach A.
> 
> Yes. Me too was assuming that way. But no one really implemented the
> chaining. With the MLX patch that got changed.
> 
> >
> > The Meter Chaining - Approach A is valid. After a bit of thinking, I don't 
> > see
> any reason to invalidate the approach you describe, so I agree that Meter
> Chaining - Approach B is also valid, with the (small) advantage that is
> conditional of a specific color.
> >
> > So, I think we should describe here both approaches. How about adding a
> new distinct section for Meter Chaining, where we describe both approaches
> as valid? It would be great if you could have a separate diagram for each
> approach :)
> 
> This is the exact reason to send the patch. Approach B is a superset.
> Should we allow two approaches ? It will complicate the driver as it
> needs to track two ways of changing.
> Can we keep only the new approach, Just to make everyone's life easy?
> We started implementing this driver and realized two paths are painful
> for the driver.
> 

I agree the latest API changes push more complexity into the driver, but both 
approaches logically make sense and are already part of the API, so I think it 
is better to implement them both, if possible, and also describe them both in 
the doc. Supporting both will avoid confusing the users.

Also this problem that you mention is true for any action, not just for the 
meter action: now there are two different paths to enable any action type, one 
is enablement as a flow action, and the other one is enablement as a meter 
action; allowing just one path for the meter action leads to allowing just one 
path for  all the other actions as well, which defeats the purpose of the API 
update, right?



Regards,
Cristian


[dpdk-dev] [PATCH 0/4] net/ice: support IEEE 1588

2021-08-05 Thread Simei Su
[PATCH 1/4] add 1588 capability probe.
[PATCH 2/4] add low level functions for device clock control.
[PATCH 3/4] add clock initialization function.
[PATCH 4/4] add ethdev APIs to enable 1588 timesync.

Qi Zhang (3):
  net/ice/base: add 1588 capability probe
  net/ice/base: add low level functions for device clock control
  net/ice/base: add clock initialization function

Simei Su (1):
  net/ice: support IEEE 1588 PTP

 drivers/net/ice/base/ice_adminq_cmd.h |2 +
 drivers/net/ice/base/ice_cgu_regs.h   |  117 ++
 drivers/net/ice/base/ice_common.c |  254 
 drivers/net/ice/base/ice_common.h |   11 +
 drivers/net/ice/base/ice_controlq.c   |   52 +-
 drivers/net/ice/base/ice_controlq.h   |2 +
 drivers/net/ice/base/ice_ptp_consts.h |  160 +++
 drivers/net/ice/base/ice_ptp_hw.c | 2369 +
 drivers/net/ice/base/ice_ptp_hw.h |  400 ++
 drivers/net/ice/base/ice_type.h   |   75 ++
 drivers/net/ice/base/meson.build  |1 +
 drivers/net/ice/ice_ethdev.c  |  226 +++-
 drivers/net/ice/ice_ethdev.h  |5 +
 drivers/net/ice/ice_rxtx.c|   42 +-
 drivers/net/ice/ice_rxtx.h|1 +
 15 files changed, 3714 insertions(+), 3 deletions(-)
 create mode 100644 drivers/net/ice/base/ice_cgu_regs.h
 create mode 100644 drivers/net/ice/base/ice_ptp_consts.h
 create mode 100644 drivers/net/ice/base/ice_ptp_hw.c
 create mode 100644 drivers/net/ice/base/ice_ptp_hw.h

-- 
2.9.5



[dpdk-dev] [PATCH 1/4] net/ice/base: add 1588 capability probe

2021-08-05 Thread Simei Su
From: Qi Zhang 

Parse 1588 timesync capability during device capability probing.

Signed-off-by: Jacob Keller 
Signed-off-by: Qi Zhang 
---
 drivers/net/ice/base/ice_adminq_cmd.h |   1 +
 drivers/net/ice/base/ice_common.c | 111 ++
 drivers/net/ice/base/ice_type.h   |  72 ++
 3 files changed, 184 insertions(+)

diff --git a/drivers/net/ice/base/ice_adminq_cmd.h 
b/drivers/net/ice/base/ice_adminq_cmd.h
index 3805fc9..a0af35c 100644
--- a/drivers/net/ice/base/ice_adminq_cmd.h
+++ b/drivers/net/ice/base/ice_adminq_cmd.h
@@ -108,6 +108,7 @@ struct ice_aqc_list_caps_elem {
 #define ICE_AQC_CAPS_TXQS  0x0042
 #define ICE_AQC_CAPS_MSIX  0x0043
 #define ICE_AQC_CAPS_FD0x0045
+#define ICE_AQC_CAPS_1588  0x0046
 #define ICE_AQC_CAPS_MAX_MTU   0x0047
 #define ICE_AQC_CAPS_IWARP 0x0051
 #define ICE_AQC_CAPS_PCIE_RESET_AVOIDANCE  0x0076
diff --git a/drivers/net/ice/base/ice_common.c 
b/drivers/net/ice/base/ice_common.c
index cf0a7d4..56a4696 100644
--- a/drivers/net/ice/base/ice_common.c
+++ b/drivers/net/ice/base/ice_common.c
@@ -2091,6 +2091,60 @@ ice_parse_vsi_func_caps(struct ice_hw *hw, struct 
ice_hw_func_caps *func_p,
 }
 
 /**
+ * ice_parse_1588_func_caps - Parse ICE_AQC_CAPS_1588 function caps
+ * @hw: pointer to the HW struct
+ * @func_p: pointer to function capabilities structure
+ * @cap: pointer to the capability element to parse
+ *
+ * Extract function capabilities for ICE_AQC_CAPS_1588.
+ */
+static void
+ice_parse_1588_func_caps(struct ice_hw *hw, struct ice_hw_func_caps *func_p,
+struct ice_aqc_list_caps_elem *cap)
+{
+   struct ice_ts_func_info *info = &func_p->ts_func_info;
+   u32 number = LE32_TO_CPU(cap->number);
+
+   info->ena = ((number & ICE_TS_FUNC_ENA_M) != 0);
+   func_p->common_cap.ieee_1588 = info->ena;
+
+   info->src_tmr_owned = ((number & ICE_TS_SRC_TMR_OWND_M) != 0);
+   info->tmr_ena = ((number & ICE_TS_TMR_ENA_M) != 0);
+   info->tmr_index_owned = ((number & ICE_TS_TMR_IDX_OWND_M) != 0);
+   info->tmr_index_assoc = ((number & ICE_TS_TMR_IDX_ASSOC_M) != 0);
+
+   info->clk_freq = (number & ICE_TS_CLK_FREQ_M) >> ICE_TS_CLK_FREQ_S;
+   info->clk_src = ((number & ICE_TS_CLK_SRC_M) != 0);
+
+   if (info->clk_freq < NUM_ICE_TIME_REF_FREQ) {
+   info->time_ref = (enum ice_time_ref_freq)info->clk_freq;
+   } else {
+   /* Unknown clock frequency, so assume a (probably incorrect)
+* default to avoid out-of-bounds look ups of frequency
+* related information.
+*/
+   ice_debug(hw, ICE_DBG_INIT, "1588 func caps: unknown clock 
frequency %u\n",
+ info->clk_freq);
+   info->time_ref = ICE_TIME_REF_FREQ_25_000;
+   }
+
+   ice_debug(hw, ICE_DBG_INIT, "func caps: ieee_1588 = %u\n",
+ func_p->common_cap.ieee_1588);
+   ice_debug(hw, ICE_DBG_INIT, "func caps: src_tmr_owned = %u\n",
+ info->src_tmr_owned);
+   ice_debug(hw, ICE_DBG_INIT, "func caps: tmr_ena = %u\n",
+ info->tmr_ena);
+   ice_debug(hw, ICE_DBG_INIT, "func caps: tmr_index_owned = %u\n",
+ info->tmr_index_owned);
+   ice_debug(hw, ICE_DBG_INIT, "func caps: tmr_index_assoc = %u\n",
+ info->tmr_index_assoc);
+   ice_debug(hw, ICE_DBG_INIT, "func caps: clk_freq = %u\n",
+ info->clk_freq);
+   ice_debug(hw, ICE_DBG_INIT, "func caps: clk_src = %u\n",
+ info->clk_src);
+}
+
+/**
  * ice_parse_fdir_func_caps - Parse ICE_AQC_CAPS_FD function caps
  * @hw: pointer to the HW struct
  * @func_p: pointer to function capabilities structure
@@ -2155,6 +2209,9 @@ ice_parse_func_caps(struct ice_hw *hw, struct 
ice_hw_func_caps *func_p,
case ICE_AQC_CAPS_VSI:
ice_parse_vsi_func_caps(hw, func_p, &cap_resp[i]);
break;
+   case ICE_AQC_CAPS_1588:
+   ice_parse_1588_func_caps(hw, func_p, &cap_resp[i]);
+   break;
case ICE_AQC_CAPS_FD:
ice_parse_fdir_func_caps(hw, func_p);
break;
@@ -2209,6 +2266,57 @@ ice_parse_vsi_dev_caps(struct ice_hw *hw, struct 
ice_hw_dev_caps *dev_p,
 }
 
 /**
+ * ice_parse_1588_dev_caps - Parse ICE_AQC_CAPS_1588 device caps
+ * @hw: pointer to the HW struct
+ * @dev_p: pointer to device capabilities structure
+ * @cap: capability element to parse
+ *
+ * Parse ICE_AQC_CAPS_1588 for device capabilities.
+ */
+static void
+ice_parse_1588_dev_caps(struct ice_hw *hw, struct ice_hw_dev_caps *dev_p,
+   struct ice_aqc_list_caps_elem *cap)
+{
+   struct ice_ts_dev_i

[dpdk-dev] [PATCH 2/4] net/ice/base: add low level functions for device clock control

2021-08-05 Thread Simei Su
From: Qi Zhang 

The ice hardware supports exposing a hardware clock for high precision
timestamping. This is primarily intended for accelerating the Precision
Time Protocol.

Add several low level functions intended to be used as the basis for
enabling the device clock, and ensuring that the port timers are
synchronized properly.

Signed-off-by: Jacob Keller 
Signed-off-by: Qi Zhang 
---
 drivers/net/ice/base/ice_adminq_cmd.h |1 +
 drivers/net/ice/base/ice_common.c |  143 +++
 drivers/net/ice/base/ice_common.h |   11 +
 drivers/net/ice/base/ice_controlq.c   |   52 +-
 drivers/net/ice/base/ice_controlq.h   |2 +
 drivers/net/ice/base/ice_ptp_consts.h |   86 ++
 drivers/net/ice/base/ice_ptp_hw.c | 2023 +
 drivers/net/ice/base/ice_ptp_hw.h |  376 ++
 drivers/net/ice/base/ice_type.h   |3 +
 drivers/net/ice/base/meson.build  |1 +
 10 files changed, 2697 insertions(+), 1 deletion(-)
 create mode 100644 drivers/net/ice/base/ice_ptp_consts.h
 create mode 100644 drivers/net/ice/base/ice_ptp_hw.c
 create mode 100644 drivers/net/ice/base/ice_ptp_hw.h

diff --git a/drivers/net/ice/base/ice_adminq_cmd.h 
b/drivers/net/ice/base/ice_adminq_cmd.h
index a0af35c..470aa89 100644
--- a/drivers/net/ice/base/ice_adminq_cmd.h
+++ b/drivers/net/ice/base/ice_adminq_cmd.h
@@ -3120,6 +3120,7 @@ enum ice_adminq_opc {
ice_aqc_opc_set_event_mask  = 0x0613,
ice_aqc_opc_set_mac_lb  = 0x0620,
ice_aqc_opc_get_link_topo   = 0x06E0,
+   ice_aqc_opc_get_link_topo_pin   = 0x06E1,
ice_aqc_opc_read_i2c= 0x06E2,
ice_aqc_opc_write_i2c   = 0x06E3,
ice_aqc_opc_set_port_id_led = 0x06E9,
diff --git a/drivers/net/ice/base/ice_common.c 
b/drivers/net/ice/base/ice_common.c
index 56a4696..4748ca5 100644
--- a/drivers/net/ice/base/ice_common.c
+++ b/drivers/net/ice/base/ice_common.c
@@ -65,6 +65,28 @@ static enum ice_status ice_set_mac_type(struct ice_hw *hw)
 }
 
 /**
+ * ice_is_generic_mac
+ * @hw: pointer to the hardware structure
+ *
+ * returns true if mac_type is ICE_MAC_GENERIC, false if not
+ */
+bool ice_is_generic_mac(struct ice_hw *hw)
+{
+   return hw->mac_type == ICE_MAC_GENERIC;
+}
+
+/**
+ * ice_is_e810
+ * @hw: pointer to the hardware structure
+ *
+ * returns true if the device is E810 based, false if not.
+ */
+bool ice_is_e810(struct ice_hw *hw)
+{
+   return hw->mac_type == ICE_MAC_E810;
+}
+
+/**
  * ice_clear_pf_cfg - Clear PF configuration
  * @hw: pointer to the hardware structure
  *
@@ -1354,6 +1376,127 @@ ice_clear_tx_drbell_q_ctx(struct ice_hw *hw, u32 
tx_drbell_q_index)
return ICE_SUCCESS;
 }
 
+/* Sideband Queue command wrappers */
+
+/**
+ * ice_get_sbq - returns the right control queue to use for sideband
+ * @hw: pointer to the hardware structure
+ */
+static struct ice_ctl_q_info *ice_get_sbq(struct ice_hw *hw)
+{
+   if (!ice_is_generic_mac(hw))
+   return &hw->adminq;
+   return &hw->sbq;
+}
+
+/**
+ * ice_sbq_send_cmd - send Sideband Queue command to Sideband Queue
+ * @hw: pointer to the HW struct
+ * @desc: descriptor describing the command
+ * @buf: buffer to use for indirect commands (NULL for direct commands)
+ * @buf_size: size of buffer for indirect commands (0 for direct commands)
+ * @cd: pointer to command details structure
+ */
+static enum ice_status
+ice_sbq_send_cmd(struct ice_hw *hw, struct ice_sbq_cmd_desc *desc,
+void *buf, u16 buf_size, struct ice_sq_cd *cd)
+{
+   return ice_sq_send_cmd(hw, ice_get_sbq(hw), (struct ice_aq_desc *)desc,
+  buf, buf_size, cd);
+}
+
+/**
+ * ice_sbq_send_cmd_nolock - send Sideband Queue command to Sideband Queue
+ *   but do not lock sq_lock
+ * @hw: pointer to the HW struct
+ * @desc: descriptor describing the command
+ * @buf: buffer to use for indirect commands (NULL for direct commands)
+ * @buf_size: size of buffer for indirect commands (0 for direct commands)
+ * @cd: pointer to command details structure
+ */
+static enum ice_status
+ice_sbq_send_cmd_nolock(struct ice_hw *hw, struct ice_sbq_cmd_desc *desc,
+   void *buf, u16 buf_size, struct ice_sq_cd *cd)
+{
+   return ice_sq_send_cmd_nolock(hw, ice_get_sbq(hw),
+ (struct ice_aq_desc *)desc, buf,
+ buf_size, cd);
+}
+
+/**
+ * ice_sbq_rw_reg_lp - Fill Sideband Queue command, with lock parameter
+ * @hw: pointer to the HW struct
+ * @in: message info to be filled in descriptor
+ * @lock: true to lock the sq_lock (the usual case); false if the sq_lock has
+ *already been locked at a higher level
+ */
+enum ice_status ice_sbq_rw_reg_lp(struct ice_hw *hw,
+ struct ice_sbq_msg_input *in, bool lock)
+{
+  

[dpdk-dev] [PATCH 3/4] net/ice/base: add clock initialization function

2021-08-05 Thread Simei Su
From: Qi Zhang 

Before the device PTP hardware clock can be initialized, some steps must
be taken by the driver. This includes writing some registers and
initializing the PHY.

Some of these steps are distinct depending on the device type (E810 or
E822). Additionally, a future change will introduce more steps for E822
devices to program the Clock Generation Unit.

Introduce ice_ptp_init_phc as well as device-specific sub-functions for
e810 and e822 devices.

Signed-off-by: Jacob Keller 
Signed-off-by: Qi Zhang 

tmp

Signed-off-by: Qi Zhang 
---
 drivers/net/ice/base/ice_cgu_regs.h   | 117 
 drivers/net/ice/base/ice_ptp_consts.h |  74 
 drivers/net/ice/base/ice_ptp_hw.c | 348 +-
 drivers/net/ice/base/ice_ptp_hw.h |  24 +++
 4 files changed, 562 insertions(+), 1 deletion(-)
 create mode 100644 drivers/net/ice/base/ice_cgu_regs.h

diff --git a/drivers/net/ice/base/ice_cgu_regs.h 
b/drivers/net/ice/base/ice_cgu_regs.h
new file mode 100644
index 000..6751481
--- /dev/null
+++ b/drivers/net/ice/base/ice_cgu_regs.h
@@ -0,0 +1,117 @@
+/* SPDX-License-Identifier: BSD-3-Clause
+ * Copyright(c) 2001-2021 Intel Corporation
+ */
+
+#ifndef _ICE_CGU_REGS_H_
+#define _ICE_CGU_REGS_H_
+
+#define NAC_CGU_DWORD9 0x24
+union nac_cgu_dword9 {
+   struct {
+   u32 time_ref_freq_sel : 3;
+   u32 clk_eref1_en : 1;
+   u32 clk_eref0_en : 1;
+   u32 time_ref_en : 1;
+   u32 time_sync_en : 1;
+   u32 one_pps_out_en : 1;
+   u32 clk_ref_synce_en : 1;
+   u32 clk_synce1_en : 1;
+   u32 clk_synce0_en : 1;
+   u32 net_clk_ref1_en : 1;
+   u32 net_clk_ref0_en : 1;
+   u32 clk_synce1_amp : 2;
+   u32 misc6 : 1;
+   u32 clk_synce0_amp : 2;
+   u32 one_pps_out_amp : 2;
+   u32 misc24 : 12;
+   } field;
+   u32 val;
+};
+
+#define NAC_CGU_DWORD19 0x4c
+union nac_cgu_dword19 {
+   struct {
+   u32 tspll_fbdiv_intgr : 8;
+   u32 fdpll_ulck_thr : 5;
+   u32 misc15 : 3;
+   u32 tspll_ndivratio : 4;
+   u32 tspll_iref_ndivratio : 3;
+   u32 misc19 : 1;
+   u32 japll_ndivratio : 4;
+   u32 japll_iref_ndivratio : 3;
+   u32 misc27 : 1;
+   } field;
+   u32 val;
+};
+
+#define NAC_CGU_DWORD22 0x58
+union nac_cgu_dword22 {
+   struct {
+   u32 fdpll_frac_div_out_nc : 2;
+   u32 fdpll_lock_int_for : 1;
+   u32 synce_hdov_int_for : 1;
+   u32 synce_lock_int_for : 1;
+   u32 fdpll_phlead_slip_nc : 1;
+   u32 fdpll_acc1_ovfl_nc : 1;
+   u32 fdpll_acc2_ovfl_nc : 1;
+   u32 synce_status_nc : 6;
+   u32 fdpll_acc1f_ovfl : 1;
+   u32 misc18 : 1;
+   u32 fdpllclk_div : 4;
+   u32 time1588clk_div : 4;
+   u32 synceclk_div : 4;
+   u32 synceclk_sel_div2 : 1;
+   u32 fdpllclk_sel_div2 : 1;
+   u32 time1588clk_sel_div2 : 1;
+   u32 misc3 : 1;
+   } field;
+   u32 val;
+};
+
+#define NAC_CGU_DWORD24 0x60
+union nac_cgu_dword24 {
+   struct {
+   u32 tspll_fbdiv_frac : 22;
+   u32 misc20 : 2;
+   u32 ts_pll_enable : 1;
+   u32 time_sync_tspll_align_sel : 1;
+   u32 ext_synce_sel : 1;
+   u32 ref1588_ck_div : 4;
+   u32 time_ref_sel : 1;
+   } field;
+   u32 val;
+};
+
+#define TSPLL_CNTR_BIST_SETTINGS 0x344
+union tspll_cntr_bist_settings {
+   struct {
+   u32 i_irefgen_settling_time_cntr_7_0 : 8;
+   u32 i_irefgen_settling_time_ro_standby_1_0 : 2;
+   u32 reserved195 : 5;
+   u32 i_plllock_sel_0 : 1;
+   u32 i_plllock_sel_1 : 1;
+   u32 i_plllock_cnt_6_0 : 7;
+   u32 i_plllock_cnt_10_7 : 4;
+   u32 reserved200 : 4;
+   } field;
+   u32 val;
+};
+
+#define TSPLL_RO_BWM_LF 0x370
+union tspll_ro_bwm_lf {
+   struct {
+   u32 bw_freqov_high_cri_7_0 : 8;
+   u32 bw_freqov_high_cri_9_8 : 2;
+   u32 biascaldone_cri : 1;
+   u32 plllock_gain_tran_cri : 1;
+   u32 plllock_true_lock_cri : 1;
+   u32 pllunlock_flag_cri : 1;
+   u32 afcerr_cri : 1;
+   u32 afcdone_cri : 1;
+   u32 feedfwrdgain_cal_cri_7_0 : 8;
+   u32 m2fbdivmod_cri_7_0 : 8;
+   } field;
+   u32 val;
+};
+
+#endif /* _ICE_CGU_REGS_H_ */
diff --git a/drivers/net/ice/base/ice_ptp_consts.h 
b/drivers/net/ice/base/ice_ptp_consts.h
index 2bd338c..4583dd4 100644
--- a/drivers/net/ice/base/ice_ptp_consts.h
+++ b/drivers/net/ice/base/ice_ptp_consts.h
@@ -83,4 +83,78 @@ const struct ice_time_

[dpdk-dev] [PATCH 4/4] net/ice: support IEEE 1588 PTP

2021-08-05 Thread Simei Su
Add ice support for new ethdev APIs to enable and read IEEE1588
PTP timstamps. Currently, only normal path supports 1588 PTP,
vector path doesn't.

The example command for running ptpclinet is as below:
./build/examples/dpdk-ptpclient -c 1 -n 3 --force-max-simd-bitwidth=64 --
-T 0 -p 0x1

Signed-off-by: Simei Su 
---
 drivers/net/ice/ice_ethdev.c | 226 ++-
 drivers/net/ice/ice_ethdev.h |   5 +
 drivers/net/ice/ice_rxtx.c   |  42 +++-
 drivers/net/ice/ice_rxtx.h   |   1 +
 4 files changed, 272 insertions(+), 2 deletions(-)

diff --git a/drivers/net/ice/ice_ethdev.c b/drivers/net/ice/ice_ethdev.c
index 5fd5f99..1e76628 100644
--- a/drivers/net/ice/ice_ethdev.c
+++ b/drivers/net/ice/ice_ethdev.c
@@ -16,6 +16,7 @@
 #include "base/ice_flow.h"
 #include "base/ice_dcb.h"
 #include "base/ice_common.h"
+#include "base/ice_ptp_hw.h"
 
 #include "rte_pmd_ice.h"
 #include "ice_ethdev.h"
@@ -27,6 +28,8 @@
 #define ICE_PIPELINE_MODE_SUPPORT_ARG  "pipeline-mode-support"
 #define ICE_PROTO_XTR_ARG "proto_xtr"
 
+#define ICE_CYCLECOUNTER_MASK 0xULL
+
 static const char * const ice_valid_args[] = {
ICE_SAFE_MODE_SUPPORT_ARG,
ICE_PIPELINE_MODE_SUPPORT_ARG,
@@ -137,6 +140,18 @@ static int ice_dev_udp_tunnel_port_add(struct rte_eth_dev 
*dev,
struct rte_eth_udp_tunnel *udp_tunnel);
 static int ice_dev_udp_tunnel_port_del(struct rte_eth_dev *dev,
struct rte_eth_udp_tunnel *udp_tunnel);
+static int ice_timesync_enable(struct rte_eth_dev *dev);
+static int ice_timesync_read_rx_timestamp(struct rte_eth_dev *dev,
+ struct timespec *timestamp,
+ uint32_t flags);
+static int ice_timesync_read_tx_timestamp(struct rte_eth_dev *dev,
+ struct timespec *timestamp);
+static int ice_timesync_adjust_time(struct rte_eth_dev *dev, int64_t delta);
+static int ice_timesync_read_time(struct rte_eth_dev *dev,
+ struct timespec *timestamp);
+static int ice_timesync_write_time(struct rte_eth_dev *dev,
+  const struct timespec *timestamp);
+static int ice_timesync_disable(struct rte_eth_dev *dev);
 
 static const struct rte_pci_id pci_id_ice_map[] = {
{ RTE_PCI_DEVICE(ICE_INTEL_VENDOR_ID, ICE_DEV_ID_E823L_BACKPLANE) },
@@ -220,6 +235,13 @@ static const struct eth_dev_ops ice_eth_dev_ops = {
.udp_tunnel_port_del  = ice_dev_udp_tunnel_port_del,
.tx_done_cleanup  = ice_tx_done_cleanup,
.get_monitor_addr = ice_get_monitor_addr,
+   .timesync_enable  = ice_timesync_enable,
+   .timesync_read_rx_timestamp   = ice_timesync_read_rx_timestamp,
+   .timesync_read_tx_timestamp   = ice_timesync_read_tx_timestamp,
+   .timesync_adjust_time = ice_timesync_adjust_time,
+   .timesync_read_time   = ice_timesync_read_time,
+   .timesync_write_time  = ice_timesync_write_time,
+   .timesync_disable = ice_timesync_disable,
 };
 
 /* store statistics names and its offset in stats structure */
@@ -3442,7 +3464,8 @@ ice_dev_info_get(struct rte_eth_dev *dev, struct 
rte_eth_dev_info *dev_info)
DEV_RX_OFFLOAD_QINQ_STRIP |
DEV_RX_OFFLOAD_OUTER_IPV4_CKSUM |
DEV_RX_OFFLOAD_VLAN_EXTEND |
-   DEV_RX_OFFLOAD_RSS_HASH;
+   DEV_RX_OFFLOAD_RSS_HASH |
+   DEV_RX_OFFLOAD_TIMESTAMP;
dev_info->tx_offload_capa |=
DEV_TX_OFFLOAD_QINQ_INSERT |
DEV_TX_OFFLOAD_IPV4_CKSUM |
@@ -5254,6 +5277,207 @@ ice_dev_udp_tunnel_port_del(struct rte_eth_dev *dev,
 }
 
 static int
+ice_timesync_enable(struct rte_eth_dev *dev)
+{
+   struct ice_hw *hw = ICE_DEV_PRIVATE_TO_HW(dev->data->dev_private);
+   struct ice_adapter *ad =
+   ICE_DEV_PRIVATE_TO_ADAPTER(dev->data->dev_private);
+   int ret;
+
+   if (hw->func_caps.ts_func_info.src_tmr_owned) {
+   ret = ice_ptp_init_phc(hw);
+   if (ret) {
+   PMD_DRV_LOG(ERR, "Failed to initialize PHC\n");
+   return -1;
+   }
+
+   ret = ice_ptp_write_incval(hw, ICE_PTP_NOMINAL_INCVAL_E810);
+   if (ret) {
+   PMD_DRV_LOG(ERR,
+   "Failed to write PHC increment time 
value\n");
+   return -1;
+   }
+   }
+
+   /* Initialize cycle counters for system time/RX/TX timestamp */
+   memset(&ad->systime_tc, 0, sizeof(struct rte_timecounter));
+   memset(&ad->rx_tstamp_tc, 0, sizeof(struct rte_timecounter));
+   memset(&ad->tx_tstamp_tc, 0, sizeof(struct rte_timecounter));
+
+   ad->systime_tc.c

Re: [dpdk-dev] [PATCH v2] doc: announce change in crypto raw data vector

2021-08-05 Thread Hemant Agrawal

ping for review.


On 8/5/2021 7:25 PM, Hemant Agrawal wrote:

The current crypto raw data vectors need to be extended to support
out of place processing. It is proposed to add additional desl_sgl
to provide details for destination sgl.
The same is also extended to support rte_security usecases, where
we need total data length to know how much additional memory space
is available in buffer other than data length so that driver/HW
can write expanded size data after encryption.

Signed-off-by: Gagandeep Singh 
Signed-off-by: Hemant Agrawal 
---
  doc/guides/rel_notes/deprecation.rst | 12 
  1 file changed, 12 insertions(+)

diff --git a/doc/guides/rel_notes/deprecation.rst 
b/doc/guides/rel_notes/deprecation.rst
index f4a4d00db2..c19a306c93 100644
--- a/doc/guides/rel_notes/deprecation.rst
+++ b/doc/guides/rel_notes/deprecation.rst
@@ -193,3 +193,15 @@ Deprecation Notices
reserved bytes to 2 (from 3), and use 1 byte to indicate warnings and other
information from the crypto/security operation. This field will be used to
communicate events such as soft expiry with IPsec in lookaside mode.
+
+* cryptodev: The structure ``rte_crypto_sym_vec`` would be updated to add
+  ``dest_sgl`` to support out of place processing. This field will be null for
+  inplace processing. This change is targeted for DPDK 21.11
+
+* cryptodev: The structure ``rte_crypto_vec`` would be updated to add
+  ``tot_len`` to support total buffer length. This is required for security
+  cases like IPsec and PDCP encryption offload to know how much additional
+  memory space is available in buffer other than data length so that driver/HW
+  can write expanded size data after encryption. This change is targeted for
+  DPDK 21.11
+