[RFC 0/2] vhost: add port mirroring function in the vhost lib

2022-08-14 Thread Cheng Jiang
Similar to the port mirroring function on the switch or router, this patch set also implements such function on the Vhost lib. When data is sent to a front-end, it will also send the data to its mirror front-end. When data is received from a front-end, it will also send the data to its mirrorfront-

[RFC 1/2] vhost: add ingress API for port mirroring datapath

2022-08-14 Thread Cheng Jiang
From: Wenwu Ma Similar to the port mirroring function on the switch or router, this patch also implements an ingress function on the Vhost lib. When data is sent to a front-end, it will also send the data to its mirror front-end. Signed-off-by: Cheng Jiang Signed-off-by: Wenwu Ma --- lib/vhos

[RFC 2/2] vhost: add egress API for port mirroring datapath

2022-08-14 Thread Cheng Jiang
This patch implements such an egress function on the Vhost lib. When data is received from a front-end, it will also send the data to its mirrorfront-end. Signed-off-by: Cheng Jiang Signed-off-by: Wenwu Ma --- lib/vhost/rte_vhost_async.h | 12 +- lib/vhost/version.map | 3 + lib/vhost/

RE: [Patch v2] net/mlx4: fix verbs fd leak in the secondary process

2022-08-14 Thread Raslan Darawsheh
Hi, > -Original Message- > From: lon...@linuxonhyperv.com > Sent: Wednesday, July 6, 2022 8:49 PM > To: Matan Azrad ; Ferruh Yigit > > Cc: dev@dpdk.org; Karanjot Singh ; NBU- > Contact-longli (EXTERNAL) > Subject: [Patch v2] net/mlx4: fix verbs fd leak in the secondary process > > From

RE: [Patch v2] net/mlx5: fix verbs fd leak in the secondary process

2022-08-14 Thread Raslan Darawsheh
Hi, > -Original Message- > From: lon...@linuxonhyperv.com > Sent: Wednesday, July 6, 2022 8:49 PM > To: Matan Azrad ; Ferruh Yigit > > Cc: dev@dpdk.org; Karanjot Singh ; NBU- > Contact-longli (EXTERNAL) > Subject: [Patch v2] net/mlx5: fix verbs fd leak in the secondary process > > From

RE: [PATCH v3] common/mlx5: update DevX error logging

2022-08-14 Thread Raslan Darawsheh
Hi, > -Original Message- > From: Gregory Etelson > Sent: Sunday, July 10, 2022 7:03 PM > To: dev@dpdk.org > Cc: Gregory Etelson ; Matan Azrad > ; Raslan Darawsheh ; NBU- > Contact-Thomas Monjalon (EXTERNAL) ; Slava > Ovsiienko > Subject: [PATCH v3] common/mlx5: update DevX error logging

[PATCH v1 0/2] vhost: introduce DMA vchannel unconfiguration

2022-08-14 Thread xuan . ding
From: Xuan Ding This patchset introduces a new API rte_vhost_async_dma_unconfigure() to help user to manually free the DMA vchannel finished to use. Note: this API should be called after async channel unregister. Xuan Ding (2): vhost: introduce DMA vchannel unconfiguration example/vhost: un

[PATCH v1 1/2] vhost: introduce DMA vchannel unconfiguration

2022-08-14 Thread xuan . ding
From: Xuan Ding This patch adds a new API rte_vhost_async_dma_unconfigure() to unconfigure DMA vchannels in vhost async data path. Signed-off-by: Xuan Ding --- doc/guides/prog_guide/vhost_lib.rst| 5 doc/guides/rel_notes/release_22_11.rst | 2 ++ lib/vhost/rte_vhost_async.h

[PATCH v1 2/2] example/vhost: unconfigure DMA vchannel

2022-08-14 Thread xuan . ding
From: Xuan Ding This patch uses rte_vhost_async_dma_unconfigure() API to manually free 'dma_coy_track' array rather than wait for the program to finish before being freed. Signed-off-by: Xuan Ding --- examples/vhost/main.c | 7 +++ 1 file changed, 7 insertions(+) diff --git a/examples/vho

Re: [RFC 1/2] vhost: add ingress API for port mirroring datapath

2022-08-14 Thread Stephen Hemminger
On Sun, 14 Aug 2022 12:49:19 + Cheng Jiang wrote: > From: Wenwu Ma > > Similar to the port mirroring function on the switch or router, this > patch also implements an ingress function on the Vhost lib. When > data is sent to a front-end, it will also send the data to its mirror > front-end.

[PATCH] net/vhost: support asynchronous data path

2022-08-14 Thread Jiayu Hu
Vhost asynchronous data-path offloads packet copy from the CPU to the DMA engine. As a result, large packet copy can be accelerated by the DMA engine, and vhost can free CPU cycles for higher level functions. In this patch, we enable asynchronous data-path for vhostpmd. Asynchronous data path is e

[PATCH 0/3] security: support MACsec

2022-08-14 Thread Akhil Goyal
Added support for MACsec in rte_security for offloading MACsec Protocol operation to inline NIC device or a crypto device. To support MACsec we cannot just make one security session and send with the packet to process it. MACsec specifications suggest, it can have 3 different entities - SECY Entit

[PATCH 1/3] net: add MACsec header

2022-08-14 Thread Akhil Goyal
Added MACsec protocol header to be used for supporting MACsec protocol offload in hardware or directly in the application. Signed-off-by: Akhil Goyal --- doc/api/doxy-api-index.md | 3 ++- lib/net/meson.build | 1 + lib/net/rte_macsec.h | 56 +++

[PATCH 2/3] security: support MACsec

2022-08-14 Thread Akhil Goyal
Added support for MACsec in rte_security for offloading MACsec Protocol operation to inline NIC device or a crypto device. To support MACsec we cannot just make one security session and send with the packet to process it. MACsec specifications suggest, it has 3 different entities - SECY Entity, SC

[PATCH 3/3] ethdev: add MACsec flow item

2022-08-14 Thread Akhil Goyal
A new flow item is defined for MACsec flows which can be offloaded to an inline device. If the flow matches with MACsec header, device will process as per the security session created using rte_security APIs. If an error comes while MACsec processing in HW, PMD will notify with the events defined i

[PATCH 00/70] ice base code update

2022-08-14 Thread Qi Zhang
Update ice base code to 2022-Aug internal release. Summary: 1. Baseline support for L2TPv2 FDIR/RSS. 2. Refactor DDP module. 3. Support 56G PHY 4. Add GTP/GRE tunnel. 6. Clean code and fix bug 5. update copyright. Qi Zhang (70): net/ice/base: add netlist helper functions net/ice/base: get N

[PATCH 01/70] net/ice/base: add netlist helper functions

2022-08-14 Thread Qi Zhang
Add new functions to check in netlist if HW has: - Recovered Clock device, - Clock Generation Unit, - Clock Multiplexer, - GPS generic device. Signed-off-by: Michal Michalik Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 54 +++ drivers/net/ice/base/ice_common.c

[PATCH 02/70] net/ice/base: get NVM CSS Header length from the CSS Header

2022-08-14 Thread Qi Zhang
The CSS Header length is defined as ICE_CSS_HEADER_LENGTH. To support changes in CSS Header length, calculate the CSS Header length from the NVM CSS Header length field plus the Authentication Header length. Signed-off-by: Paul Greenwalt Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_nvm.

[PATCH 03/70] net/ice/base: combine functions for VSI promisc

2022-08-14 Thread Qi Zhang
Remove ice_get_vsi_vlan_promisc, cause of similar implementation as ice_get_vsi_promisc, which will now handle the use case of ice_get_vsi_vlan_promisc. Signed-off-by: Wiktor Pilarczyk Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_switch.c | 58 ++- 1 file cha

[PATCH 04/70] net/ice/base: make function names more generic

2022-08-14 Thread Qi Zhang
Previously "e810t" was part of few function names. In the future it will require to add similar functions for different NIC types. Make "NIC type" a suffix of the function name. Signed-off-by: Arkadiusz Kubalewski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 12 ++--

[PATCH 05/70] net/ice/base: fix incorrect division during E822 PTP init

2022-08-14 Thread Qi Zhang
When initializing the device hardware for PTP, the E822 devices requirea number of values to be calculated and programmed to hardware.These values are calculated using unsigned 64-bit division. The DIV_64BIT macro currently translates into a specific Linux functionthat triggers a *signed* division

[PATCH 06/70] net/ice/base: added auto drop blocking packets functionality

2022-08-14 Thread Qi Zhang
Extended ice_aq_set_mac_cfg()function to add support for auto drop blocking packets. Signed-off-by: Mateusz Rusinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c | 22 -- drivers/net/ice/base/ice_common.h | 5 - drivers/net/ice/base/ice_type.h | 6 ++

[PATCH 07/70] net/ice/base: fix 100M speed

2022-08-14 Thread Qi Zhang
Couple of 10GBase-T devices don't support advertising 100M speed. For these devices, ice_is_100m_speed_supported should return false. Meanwhile add device that supports 100M speed. Fixes: 486d29fda54c ("net/ice/base: add dedicate MAC type for E810") Cc: sta...@dpdk.org Signed-off-by: Anirudh Venk

[PATCH 08/70] net/ice/base: support VXLAN and GRE for RSS

2022-08-14 Thread Qi Zhang
Add RSS of inner headers for VXLAN tunnel packet. Add packet types for packets with outer IPv4/IPv6 header support GRE and VXLAN tunnel packet. Following rules can use new packet types: - eth / ipv4(6) / udp / vxlan / ipv4(6) - eth / ipv4(6) / udp / vxlan / ipv4(6) / tcp - eth / ipv4(

[PATCH 09/70] net/ice/base: fix DSCP PFC TLV creation

2022-08-14 Thread Qi Zhang
When creating the TLV to send to the FW for configuring DSCP mode PFC, the PFCENABLE field was being masked with a 4 bit mask (0xF), but this is an 8 bit bitmask for enabled classes for PFC. This means that traffic classes 4-7 could not be enabled for PFC. Remove the mask completely, as it is not

[PATCH 10/70] net/ice/base: complete the health status codes

2022-08-14 Thread Qi Zhang
add definitions for async health status codes. Signed-off-by: Leszek Zygo Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 10 ++ 1 file changed, 10 insertions(+) diff --git a/drivers/net/ice/base/ice_adminq_cmd.h b/drivers/net/ice/base/ice_adminq_cmd.h index a3add4

[PATCH 11/70] net/ice/base: explicitly name E822 HW-dependent functions

2022-08-14 Thread Qi Zhang
Add the suffix to E822 HW-dependent function names Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 23 --- drivers/net/ice/base/ice_ptp_hw.h | 7 --- 2 files changed, 16 insertions(+), 14 deletions(-) diff --git a/drive

[PATCH 12/70] net/ice/base: move code block

2022-08-14 Thread Qi Zhang
Move some code block to the beginning of ice_ptp_hw.c to align withkernel driver. Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 997 +++--- 1 file changed, 498 insertions(+), 499 deletions(-) diff --git a/drivers/net/i

[PATCH 13/70] net/ice/base: add PHY 56G destination address

2022-08-14 Thread Qi Zhang
Add PHY 56G destination address. PHY56G is a single device incorporating all SerDes lanes Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_sbq_cmd.h | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/net/ice/base/ice_sbq_cmd.h b/drivers/net/ice/ba

[PATCH 14/70] net/ice/base: add 56G PHY register definitions

2022-08-14 Thread Qi Zhang
Add 56G PHY register address definitions to facilitate 56G PHY support. Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.h | 75 +++ 1 file changed, 75 insertions(+) diff --git a/drivers/net/ice/base/ice_ptp_hw.h b/drive

[PATCH 15/70] net/ice/base: implement 56G PHY access functions

2022-08-14 Thread Qi Zhang
Implement 56G PHY register and memory read/write functions to facilitate PTP support Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 1094 +++-- drivers/net/ice/base/ice_ptp_hw.h | 44 +- drivers/net/ice/base/ice_type.h

[PATCH 16/70] net/ice/base: implement 56G PHY setup functions

2022-08-14 Thread Qi Zhang
Implement setup functions for the 56G PHY Simics model Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 29 + drivers/net/ice/base/ice_ptp_hw.h | 2 ++ 2 files changed, 31 insertions(+) diff --git a/drivers/net/ice/b

[PATCH 17/70] net/ice/base: work around missing PTP caps

2022-08-14 Thread Qi Zhang
Provide a WA for missing PTP caps on Simics, this code shall be removed after cap reporting is fixed Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c | 7 ++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/drivers/net/ice/base/ice

[PATCH 18/70] net/ice/base: enable calling of ETH56G functions

2022-08-14 Thread Qi Zhang
Enable calling of ETH56G functions in the base code when the appropriate PHY has been detected Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 523 -- 1 file changed, 498 insertions(+), 25 deletions(-) diff --git a/d

[PATCH 19/70] net/ice/base: fix PHY type 10G SFI C2C to media type mapping

2022-08-14 Thread Qi Zhang
PHY type ICE_PHY_TYPE_LOW_10G_SFI_C2C is incorrectly mapped to media type Fiber which results in ethtool reporting the wrong Supported ports. PHY type ICE_PHY_TYPE_LOW_10G_SFI_C2C should map to media type Backplane. Fixes: 453d087ccaff ("net/ice/base: add common functions") Cc: sta...@dpdk.org S

[PATCH 21/70] net/ice/base: add E822 generic PCI device ID

2022-08-14 Thread Qi Zhang
The E822 has a generic PCI device ID that can be used in the PLDM header when updating the device so add it. Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_devids.h | 3 ++- drivers/net/ice/ice_ethdev.c | 1 + 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/net/i

[PATCH 22/70] net/ice/base: support double VLAN rules

2022-08-14 Thread Qi Zhang
Add support for double vlan rules with c-tag and s-tag in it. Enable the caller to configure double vlan rules, and use extended package capabilities to allow adding flow with double vlans. The patch also re-order the code in ice_switch.c to align with kernel driver. Signed-off-by: Wiktor Pilarcz

[PATCH 23/70] net/ice/base: report NVM version numbers on mismatch

2022-08-14 Thread Qi Zhang
Report NVM version numbers (both detected and expected) when a mismatch b/w driver and firmware is detected. This would provide more useful information about which NVM version the driver expects instead of looking up the code Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers

[PATCH 24/70] net/ice/base: create duplicate detection for ACL rules

2022-08-14 Thread Qi Zhang
Currently there is no check for adding duplicate ACL rules, this creates subtle bugs, for example unability to remove filters. Adding check + refactoring a redundant function. Signed-off-by: Michal Wilczynski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_fdir.c | 99 -

[PATCH 25/70] net/ice/base: fix incorrect function descriptions for parser

2022-08-14 Thread Qi Zhang
Some function descriptions for parser are mismatched, thus fixed with this patch. Fixes: 7fe2d98070e0 ("net/ice/base: add parser create and destroy skeleton") Fixes: 1792942b2df6 ("net/ice/base: init boost TCAM table for parser") Fixes: f787952d13d2 ("net/ice/base: init flag redirect table for par

[PATCH 26/70] net/ice/base: fix endian format

2022-08-14 Thread Qi Zhang
A few functions failed to properly convert some values into Little Endian format before sending them to the firmware. This will produce incorrect results when running on a Big Endian platform. Fix this by adding the necessary CPU_TO_LE* macros around the input to firmware. These issues were detec

[PATCH 27/70] net/ice/base: convert IO expander handle to u16

2022-08-14 Thread Qi Zhang
The io_expander_handle cached value is marked as an __le16, but several places track the node handle with u16 values. Unify all the interfaces so that it is stored and reported as a u16, and keep the low level conversion to LE16 only at the direct firmware interface. This fixes warnings from spars

[PATCH 28/70] net/ice/base: convert array of u8 to bitmap

2022-08-14 Thread Qi Zhang
Previously the ice_add_prof function took an array of u8 and looped over it with for_each_set_bit, examining each 8 bit value as a bitmap. This was just hard to understand and unnecessary, and was triggering undefined behavior sanitizers with unaligned accesses within bitmap fields. Since the ptyp

[PATCH 29/70] net/ice/base: fix array overflow in add switch recipe code

2022-08-14 Thread Qi Zhang
The array indexes in this function are used with a zero index in the fv_idx table, and with a +1 index in the lkup_idx arrays. The code was using the lookup index for the field vector in only one place in this function, but the code was never used after this point so just remove the bad line. This

[PATCH 30/70] net/ice/base: fix bit finding range over ptype bitmap

2022-08-14 Thread Qi Zhang
The 2nd argument to function ice_find_first_bit is the bitmap size, (in bits) not a mask. Thus, use of UINT16_MAX or 0x will allow a potential run off the end of the ptype array. Also, the ptype bitmap (i.e., prof->ptypes) is declared with size ICE_FLOW_PTYPE_MAX, thus finding the bits within t

[PATCH 31/70] net/ice/base: move function to internal

2022-08-14 Thread Qi Zhang
The function ice_disable_fd_swap should be defined as static. Signed-off-by: Junfeng Guo Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_flex_pipe.c | 2 +- drivers/net/ice/base/ice_flex_pipe.h | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/drivers/net/ice/base/ice_fl

[PATCH 32/70] net/ice/base: change PHY/QUAD/ports definitions

2022-08-14 Thread Qi Zhang
Rename PHY/QUAD/ports definitions to reflect the correct HW specification. Signed-off-by: Karol Kolacinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 45 --- drivers/net/ice/base/ice_type.h | 14 +- 2 files changed, 31 insertions(+), 28

[PATCH 33/70] net/ice/base: add AQ command to config node attribute

2022-08-14 Thread Qi Zhang
Added AQ command to config nod attribute. Signed-off-by: Ben Shelton Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 17 + drivers/net/ice/base/ice_sched.c | 27 +++ drivers/net/ice/base/ice_sched.h | 4 3 files changed

[PATCH 34/70] net/ice/base: fix null pointer dereference during

2022-08-14 Thread Qi Zhang
Sometimes, during the shutdown process, an PCIe unrecoverable error occurs. This leads to the following NULL pointer dereference error while clearing hardware tables: The patch fixes this bug by checking every table pointer against NULL before reference it, as some of them probably have been clear

[PATCH 35/70] net/ice/base: refine default VSI config

2022-08-14 Thread Qi Zhang
Refine API ice_cfg_dflt_vsi and add new API ice_check_if_dflt_vsi. Signed-off-by: Michal Wilczynski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_switch.c | 95 +-- drivers/net/ice/base/ice_switch.h | 2 + 2 files changed, 53 insertions(+), 44 deletions(-) d

[PATCH 36/70] net/ice/base: ice-shared: fix add mac rule

2022-08-14 Thread Qi Zhang
Fix ice_add_mac_rule function by not overriding action value with vsi id. It's possible to add MAC based switch filters with action other than FWD_TO_VSI. In current implementation fwd_id member of filter config structure was always overwritten with hw vsi index, regardless of action type. Fix it,

[PATCH 37/70] net/ice/base: support Tx topo config

2022-08-14 Thread Qi Zhang
Complete the Tx topo config implementation. Signed-off-by: Victor Raj Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 3 +++ drivers/net/ice/base/ice_common.c | 3 +++ 2 files changed, 6 insertions(+) diff --git a/drivers/net/ice/base/ice_adminq_cmd.h b/drivers/net/ice

[PATCH 38/70] net/ice/base: adjust the VSI/Aggregator layers

2022-08-14 Thread Qi Zhang
Adjust the VSI/Aggregator layers based on the number of logical layers supported by the FW. Currently the VSI and aggregator layers are fixed based on the 9 layer scheduler tree layout. Due to performance reasons the number of layers of the scheduler tree is changing from 9 to 5. It requires a read

[PATCH 39/70] net/ice/base: add data typecasting to match sizes

2022-08-14 Thread Qi Zhang
Adding typecast to variables to avoid compiler warnings generated if variables of a particular data type are assigned to ones of a smaller data type. For example assigning an unsigned 16 bit integer to an 8 bit integer could trigger data loss warnings or errors. Signed-off-by: Vignesh Sridhar Sig

[PATCH 40/70] net/ice/base: add helper function to check if device is E823

2022-08-14 Thread Qi Zhang
Add a simple function checking if the device is E823-L or E823-C based. Signed-off-by: Karol Kolacinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c | 25 + drivers/net/ice/base/ice_common.h | 1 + 2 files changed, 26 insertions(+) diff --git a/drivers

[PATCH 41/70] net/ice/base: add low latency Tx timestamp read

2022-08-14 Thread Qi Zhang
E810 products can support low latency Tx timestamp register read. Add a check for the device capability and use the new method if supported. Signed-off-by: Karol Kolacinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c | 7 ++- drivers/net/ice/base/ice_ptp_hw.c | 95 +++

[PATCH 42/70] net/ice/base: fix double VLAN error in promisc mode

2022-08-14 Thread Qi Zhang
Avoid enabling or disabling vlan 0 when trying to set promiscuous vlan mode if double vlan mode is enabled. This fix is needed because the driver tries to add the vlan 0 filter twice (once for inner and once for outer) when double VLAN mode is enabled. The filter program is rejected by the firmware

[PATCH 43/70] net/ice/base: move functions

2022-08-14 Thread Qi Zhang
Move function ice_ptp_set_vernier_wl and ice_ptp_src_cmd to align with kernel driver. Signed-off-by: Jacob Keller Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 130 +++--- 1 file changed, 66 insertions(+), 64 deletions(-) diff --git a/drivers/net/ice/b

[PATCH 44/70] net/ice/base: complete support for Tx balancing

2022-08-14 Thread Qi Zhang
Add module ID and struct necessary to read and save Tx Scheduler Topology Tree User Selection data from PFA TLV. Signed-off-by: Lukasz Czapnik Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 9 + 1 file changed, 9 insertions(+) diff --git a/drivers/net/ice/base/ice_

[PATCH 45/70] net/ice/base: update definitions for AQ internal debug dump

2022-08-14 Thread Qi Zhang
Add defines for Queue Mng and Full CSR Space in debug dump internal data. This defines are used in Lanconf for debug dump. Added QV_SUPPORT macro in ifdef for ACL. Signed-off-by: Dawid Zielinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 20 +++- 1 file

[PATCH 46/70] net/ice/base: update macros of L2TPv2 ptype value

2022-08-14 Thread Qi Zhang
Because the macros of L2TPv2 packet type value were changed in ice_ppp-o-l2tpv2-o-udp-1.3.4.0.pkg. So update the macros of L2TPv2 packet type value and the bitmaps of packet types for relevant protocol header to match the new DDP package. Signed-off-by: Jie Wang Signed-off-by: Qi Zhang --- driv

[PATCH 47/70] net/ice/base: refine header file include

2022-08-14 Thread Qi Zhang
The ice_switch.h and ice_fdir.h headers include ice_common.h. They are both themselves included in ice_common.h. This causes a circular dependency ordering. Signed-off-by: Jacob Keller Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_fdir.h | 2 +- drivers/net/ice/base/ice_switch.c | 1 +

[PATCH 48/70] net/ice/base: ignore already exist error

2022-08-14 Thread Qi Zhang
Ignore ERR_ALREADY_EXISTS error when setting promiscuous mode. This fix is needed because the driver could set promiscuous mode when it still has not cleared properly. Promiscuous mode could be set only once, so setting it second time will be rejected. Fixes: 60ff6f5ce2d8 ("net/ice/base: consolida

[PATCH 49/70] net/ice/base: clean up with no lookups

2022-08-14 Thread Qi Zhang
The add rule functionality works fine with a NULL lookups parameter. However when running the undefined behavior sanitizer it noticed that the function could trigger a memcpy from a NULL target. Fix the code to handle NULL lkups and a zero lkups_cnt variable more explicitly, and clean up the test

[PATCH 50/70] net/ice/base: add support for Auto FEC with FEC disabled

2022-08-14 Thread Qi Zhang
The default Link Establishment State Machine (LESM) behavior does not allow the use of FEC disable mode if the media does not support FEC disabled. However users may want to override this behavior. Add support for settng Auto FEC with FEC disabled. Signed-off-by: Paul Greenwalt Signed-off-by: Qi

[PATCH 51/70] net/ice/base: update PHY type high max index

2022-08-14 Thread Qi Zhang
ICE_PHY_TYPE_HIGH_MAX_INDEX should be the maximum index value and not the length/number of ICE_PHY_TYPE_HIGH. Signed-off-by: Paul Greenwalt Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/net/ice/base/

[PATCH 52/70] net/ice/base: clean the main timer command register

2022-08-14 Thread Qi Zhang
Clean the main timer command register after use to avoid residual command execution, such as re-initialization of the main timer. Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 4 1 file changed, 4 insertions(+) diff --git a/drivers/net/i

[PATCH 53/70] net/ice/base: add support for custom WPC and LGB NICs

2022-08-14 Thread Qi Zhang
There are few custom Westport Channel (WPC) and Logan Beach (LGB) network interface cards (NICs) - add their subdevice IDs to be able to distinguish them. Signed-off-by: Michal Michalik Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c | 15 --- drivers/net/ice/base/ice_

[PATCH 54/70] net/ice/base: add generic MAC with 3K signature segment

2022-08-14 Thread Qi Zhang
Define new type id ICE_MAC_GENERIC_3k in ice_mac_type enum, to distinguish devices which use RSA-3K/SHA-384 segment signature type. Use 3k signinig type for E824S device. Signed-off-by: Grzegorz Nitka Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c | 3 ++- 1 file changed, 2 inser

[PATCH 55/70] net/ice/base: enable RSS support for L2TPv2 session ID

2022-08-14 Thread Qi Zhang
Add L2TPv2 session ID field support for RSS. Enable L2TPv2 non-tunneled packet types for UDP protocol header bitmaps. Signed-off-by: Jie Wang Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_flow.c | 12 drivers/net/ice/base/ice_flow.h | 14 ++ 2 files changed, 26

[PATCH 56/70] net/ice/base: enable FDIR support for L2TPv2

2022-08-14 Thread Qi Zhang
Add L2TPv2(include PPP over L2TPv2) support for FDIR. And add support PPPoL2TPv2oUDP with inner IPV4/IPV6/UDP/TCP for FDIR. The supported L2TPv2 packets are defined as below: ICE_FLTR_PTYPE_NONF_IPV4_L2TPV2_CONTROL ICE_FLTR_PTYPE_NONF_IPV4_L2TPV2 ICE_FLTR_PTYPE_NONF_IPV4_L2TPV2_PPP ICE_FLTR_PTYPE

[PATCH 57/70] net/ice/base: add GRE Tap tunnel type

2022-08-14 Thread Qi Zhang
Added new tunnel type to support NvGRE Signed-off-by: Michal Swiatkowski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_flex_type.h | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/net/ice/base/ice_flex_type.h b/drivers/net/ice/base/ice_flex_type.h index 2855d67831..070d2aeb1e

[PATCH 58/70] net/ice/base: fix wrong inputset of GTPoGRE packet

2022-08-14 Thread Qi Zhang
For GTPoGRE, When setting the prot_id of prot, it should be set to second inner. Fixes: 34a0e7c44f2b ("net/ice/base: improve flow director masking") Cc: sta...@dpdk.org Signed-off-by: Kevin Liu Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_flow.c | 10 -- 1 file changed, 8 inser

[PATCH 59/70] net/ice/base: add unload flag for control queue shutdown

2022-08-14 Thread Qi Zhang
Admin queue command for shutdown AQ contains flag to indicate driver unload. However the flag is always set in driver, even for the resets. It causes Firmware to consider driver as unloaded once the PF reset is triggered on all ports of device. Firmware then restores default configuration of some f

[PATCH 60/70] net/ice/base: update comment for overloaded GCO bit

2022-08-14 Thread Qi Zhang
The bit that is overloaded is bit 11 in the flex descriptor, updating the comment to have the right one reflected. Signed-off-by: Alice Michael Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_lan_tx_rx.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/net/ice/ba

[PATCH 61/70] net/ice/base: complete pending LLDP MIB

2022-08-14 Thread Qi Zhang
Completed structure ice_aqc_lldp_get_mib. Added 'Pending Event Enable' bit. Signed-off-by: Tsotne Chakhvadze Signed-off-by: Karen Sornek Signed-off-by: Anatolii Gerasymenko Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 20 ++-- drivers/net/ice/base/ice_dc

[PATCH 62/70] net/ice/base: add function to parse DCBX config

2022-08-14 Thread Qi Zhang
LLDP MIB Change Event (opcode 0x0A01) already contains MIB, which has been changed. Add ice_dcb_process_lldp_set_mib_change() function, which will set local/remote DCBX config from LLDP MIB Change Event's buffer. This function will be used in a base driver handler for LLDP MIB Chang Event. Signed

[PATCH 63/70] net/ice/base: handle default VSI lookup type

2022-08-14 Thread Qi Zhang
ICE_SW_LKUP_DFLT is handled in ice_update_vsi_list_rule and ice_aq_alloc_free_vsi_list. Signed-off-by: Lukasz Kupczak Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_switch.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/net/ice/base/ice_switch.c b/drivers/net/ice/base/ice

[PATCH 64/70] net/ice/base: convert 1588 structs to use bitfields

2022-08-14 Thread Qi Zhang
Use bitfields in 1588 structs so they don't waste too much space. Signed-off-by: Karol Kolacinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_type.h | 28 ++-- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/drivers/net/ice/base/ice_type.h b/driv

[PATCH 65/70] net/ice/base: remove unnecessary fields

2022-08-14 Thread Qi Zhang
Remove unnecessary fields in data structure for 1588 and QoS func capabilities. Signed-off-by: Karol Kolacinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c | 5 ++--- drivers/net/ice/base/ice_switch.c | 2 -- drivers/net/ice/base/ice_type.h | 6 -- 3 files changed, 2 ins

[PATCH 66/70] net/ice/base: add GTP tunnel

2022-08-14 Thread Qi Zhang
Added GTP tunnel type and also re-order the code to align with kernel driver. Signed-off-by: Marcin Szycik Signed-off-by: Michal Swiatkowski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_flex_type.h | 10 +++--- drivers/net/ice/base/ice_protocol_type.h | 2 +- drivers/net/ice/b

[PATCH 67/70] net/ice/base: check for PTP HW lock more frequently

2022-08-14 Thread Qi Zhang
PTP HW semaphore can be held for ~50 ms in worst case. SW should wait longer and check more frequently if the HW lock is held. Signed-off-by: Karol Kolacinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 8 1 file changed, 4 insertions(+), 4 deletions(-) diff --git

[PATCH 68/70] net/ice/base: expose API for move sched element

2022-08-14 Thread Qi Zhang
Exposed ice_aq_move_sched_elems to support sched element moving by AQ command. Signed-off-by: Ben Shelton Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_sched.c | 2 +- drivers/net/ice/base/ice_sched.h | 10 +++--- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/driver

[PATCH 69/70] net/ice/base: couple code clean

2022-08-14 Thread Qi Zhang
1. remove unused code 2. reduce variable scope 3. fix comment Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c| 2 +- drivers/net/ice/base/ice_flex_pipe.c | 20 ++-- drivers/net/ice/base/ice_flow.c | 1 - drivers/net/ice/base/ice_nvm.c | 2 +- drive

[PATCH 70/70] net/ice/base: update copyright

2022-08-14 Thread Qi Zhang
Updated copyright to 2022 and update base code version. Signed-off-by: Paul M. Stillwell Jr Signed-off-by: Qi Zhang --- drivers/net/ice/base/README | 4 ++-- drivers/net/ice/base/ice_acl.c | 2 +- drivers/net/ice/base/ice_acl.h | 2 +- drivers/net/ice/base/ice_a

[PATCH v2 00/70] ice base code update

2022-08-14 Thread Qi Zhang
Update ice base code to 2022-Aug internal release. Summary: 1. Baseline support for L2TPv2 FDIR/RSS. 2. Refactor DDP module. 3. Support 56G PHY 4. Add GTP/GRE tunnel. 6. Clean code and fix bug 5. update copyright v2: - fix couple patchwork warnings. Qi Zhang (70): net/ice/base: add netlist h

[PATCH v2 01/70] net/ice/base: add netlist helper functions

2022-08-14 Thread Qi Zhang
Add new functions to check in netlist if HW has: - Recovered Clock device, - Clock Generation Unit, - Clock Multiplexer, - GPS generic device. Signed-off-by: Michal Michalik Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 54 +++ drivers/net/ice/base/ice_common.c

[PATCH v2 02/70] net/ice/base: get NVM CSS Header length from the CSS Header

2022-08-14 Thread Qi Zhang
The CSS Header length is defined as ICE_CSS_HEADER_LENGTH. To support changes in CSS Header length, calculate the CSS Header length from the NVM CSS Header length field plus the Authentication Header length. Signed-off-by: Paul Greenwalt Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_nvm.

[PATCH v2 03/70] net/ice/base: combine functions for VSI promisc

2022-08-14 Thread Qi Zhang
Remove ice_get_vsi_vlan_promisc, cause of similar implementation as ice_get_vsi_promisc, which will now handle the use case of ice_get_vsi_vlan_promisc. Signed-off-by: Wiktor Pilarczyk Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_switch.c | 58 ++- 1 file cha

[PATCH v2 04/70] net/ice/base: make function names more generic

2022-08-14 Thread Qi Zhang
Previously "e810t" was part of few function names. In the future it will require to add similar functions for different NIC types. Make "NIC type" a suffix of the function name. Signed-off-by: Arkadiusz Kubalewski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 12 ++--

[PATCH v2 05/70] net/ice/base: fix incorrect division during E822 PTP init

2022-08-14 Thread Qi Zhang
When initializing the device hardware for PTP, the E822 devices requirea number of values to be calculated and programmed to hardware.These values are calculated using unsigned 64-bit division. The DIV_64BIT macro currently translates into a specific Linux functionthat triggers a *signed* division

[PATCH v2 06/70] net/ice/base: added auto drop blocking packets functionality

2022-08-14 Thread Qi Zhang
Extended ice_aq_set_mac_cfg()function to add support for auto drop blocking packets. Signed-off-by: Mateusz Rusinski Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_common.c | 22 -- drivers/net/ice/base/ice_common.h | 5 - drivers/net/ice/base/ice_type.h | 6 ++

[PATCH v2 07/70] net/ice/base: fix 100M speed

2022-08-14 Thread Qi Zhang
Couple of 10GBase-T devices don't support advertising 100M speed. For these devices, ice_is_100m_speed_supported should return false. Meanwhile add device that supports 100M speed. Fixes: 486d29fda54c ("net/ice/base: add dedicate MAC type for E810") Cc: sta...@dpdk.org Signed-off-by: Anirudh Venk

[PATCH v2 08/70] net/ice/base: support VXLAN and GRE for RSS

2022-08-14 Thread Qi Zhang
Add RSS of inner headers for VXLAN tunnel packet. Add packet types for packets with outer IPv4/IPv6 header support GRE and VXLAN tunnel packet. Following rules can use new packet types: - eth / ipv4(6) / udp / vxlan / ipv4(6) - eth / ipv4(6) / udp / vxlan / ipv4(6) / tcp - eth / ipv4(

[PATCH v2 09/70] net/ice/base: fix DSCP PFC TLV creation

2022-08-14 Thread Qi Zhang
When creating the TLV to send to the FW for configuring DSCP mode PFC, the PFCENABLE field was being masked with a 4 bit mask (0xF), but this is an 8 bit bitmask for enabled classes for PFC. This means that traffic classes 4-7 could not be enabled for PFC. Remove the mask completely, as it is not

[PATCH v2 10/70] net/ice/base: complete the health status codes

2022-08-14 Thread Qi Zhang
add definitions for async health status codes. Signed-off-by: Leszek Zygo Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_adminq_cmd.h | 10 ++ 1 file changed, 10 insertions(+) diff --git a/drivers/net/ice/base/ice_adminq_cmd.h b/drivers/net/ice/base/ice_adminq_cmd.h index a3add4

[PATCH v2 11/70] net/ice/base: explicitly name E822 HW-dependent functions

2022-08-14 Thread Qi Zhang
Add the suffix to E822 HW-dependent function names Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 23 --- drivers/net/ice/base/ice_ptp_hw.h | 7 --- 2 files changed, 16 insertions(+), 14 deletions(-) diff --git a/drive

[PATCH v2 12/70] net/ice/base: move code block

2022-08-14 Thread Qi Zhang
Move some code block to the beginning of ice_ptp_hw.c to align withkernel driver. Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.c | 997 +++--- 1 file changed, 498 insertions(+), 499 deletions(-) diff --git a/drivers/net/i

[PATCH v2 13/70] net/ice/base: add PHY 56G destination address

2022-08-14 Thread Qi Zhang
Add PHY 56G destination address. PHY56G is a single device incorporating all SerDes lanes Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_sbq_cmd.h | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/net/ice/base/ice_sbq_cmd.h b/drivers/net/ice/ba

[PATCH v2 14/70] net/ice/base: add 56G PHY register definitions

2022-08-14 Thread Qi Zhang
Add 56G PHY register address definitions to facilitate 56G PHY support. Signed-off-by: Sergey Temerkhanov Signed-off-by: Qi Zhang --- drivers/net/ice/base/ice_ptp_hw.h | 75 +++ 1 file changed, 75 insertions(+) diff --git a/drivers/net/ice/base/ice_ptp_hw.h b/drive

  1   2   >