From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by smtp.lore.kernel.org (Postfix) with ESMTP id 21E99CDB479 for ; Wed, 24 Jun 2026 02:05:16 +0000 (UTC) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 9070040E1E; Wed, 24 Jun 2026 04:03:23 +0200 (CEST) Received: from cstnet.cn (smtp81.cstnet.cn [159.226.251.81]) by mails.dpdk.org (Postfix) with ESMTP id 36A2B4068E for ; Wed, 24 Jun 2026 04:02:58 +0200 (CEST) Received: from localhost.localdomain (unknown [118.112.177.181]) by APP-03 (Coremail) with SMTP id rQCowAD32+LJOjtqf4aoFQ--.21305S2; Wed, 24 Jun 2026 10:02:49 +0800 (CST) From: liujie5@linkdatatechnology.com To: stephen@networkplumber.org Cc: dev@dpdk.org, Jie Liu Subject: [PATCH v6 23/23] net/sxe2: update sxe2 feature matrix docs Date: Wed, 24 Jun 2026 10:02:49 +0800 Message-ID: <20260624020249.3687380-1-liujie5@linkdatatechnology.com> X-Mailer: git-send-email 2.52.0 In-Reply-To: <20260622092731.3092201-1-liujie5@linkdatatechnology.com> References: <20260622092731.3092201-1-liujie5@linkdatatechnology.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-CM-TRANSID: rQCowAD32+LJOjtqf4aoFQ--.21305S2 X-Coremail-Antispam: 1UD129KBjvJXoW3XFyUCFy3WrWxWFWrKrW8Crg_yoWfAFWDpa yUZ34rtFWkJr1aq3srAa18Grn5Zwsay343CryDGa4aqan8GryFvw47Ka45Ka9rCa4UA34j vr1j9347ua1DZrJanT9S1TB71UUUUU7qnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUUkl14x267AKxVWUJVW8JwAFc2x0x2IEx4CE42xK8VAvwI8IcIk0 rVWrJVCq3wAFIxvE14AKwVWUJVWUGwA2ocxC64kIII0Yj41l84x0c7CEw4AK67xGY2AK02 1l84ACjcxK6xIIjxv20xvE14v26ryj6F1UM28EF7xvwVC0I7IYx2IY6xkF7I0E14v26F4j 6r4UJwA2z4x0Y4vEx4A2jsIE14v26F4j6r4UJwA2z4x0Y4vEx4A2jsIEc7CjxVAFwI0_Gr 1j6F4UJwAS0I0E0xvYzxvE52x082IY62kv0487Mc02F40EFcxC0VAKzVAqx4xG6I80ewAv 7VC0I7IYx2IY67AKxVWUtVWrXwAv7VC2z280aVAFwI0_Gr0_Cr1lOx8S6xCaFVCjc4AY6r 1j6r4UM4x0Y48IcxkI7VAKI48JM4x0x7Aq67IIx4CEVc8vx2IErcIFxwAKzVCY07xG64k0 F24l42xK82IYc2Ij64vIr41l4I8I3I0E4IkC6x0Yz7v_Jr0_Gr1lx2IqxVAqx4xG67AKxV WUJVWUGwC20s026x8GjcxK67AKxVWUGVWUWwC2zVAF1VAY17CE14v26r1Y6r17MIIYrxkI 7VAKI48JMIIF0xvE2Ix0cI8IcVAFwI0_Xr0_Ar1lIxAIcVC0I7IYx2IY6xkF7I0E14v26F 4j6r4UJwCI42IY6xAIw20EY4v20xvaj40_Jr0_JF4lIxAIcVC2z280aVAFwI0_Gr0_Cr1l IxAIcVC2z280aVCY1x0267AKxVW8JVW8JrUvcSsGvfC2KfnxnUUI43ZEXa7VUjwID7UUUU U== X-Originating-IP: [118.112.177.181] X-CM-SenderInfo: xolxyxrhv6zxpqngt3pdwhux5qro0w31of0z/ X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org From: Jie Liu Update the sxe2.ini feature sheet to accurately reflect the recently implemented hardware capabilities in the sxe2 PMD. Signed-off-by: Jie Liu --- doc/guides/nics/features/sxe2.ini | 56 ++++++++++++ doc/guides/nics/sxe2.rst | 147 ++++++++++++++++++++++++++++++ 2 files changed, 203 insertions(+) diff --git a/doc/guides/nics/features/sxe2.ini b/doc/guides/nics/features/sxe2.ini index 09ba2f558c..3c1e6a8a39 100644 --- a/doc/guides/nics/features/sxe2.ini +++ b/doc/guides/nics/features/sxe2.ini @@ -7,17 +7,73 @@ ; is selected. ; [Features] +Speed capabilities = Y +Link status = Y +Link status event = Y +Rx interrupt = Y Fast mbuf free = P Free Tx mbuf on demand = Y Burst mode info = Y Queue start/stop = Y +Power mgmt address monitor = Y Buffer split on Rx = P Scattered Rx = Y +Traffic manager = Y CRC offload = Y +VLAN offload = Y +QinQ offload = P L3 checksum offload = Y L4 checksum offload = Y +Timestamp offload = P +Inner L3 checksum = P +Inner L4 checksum = P Rx descriptor status = Y Tx descriptor status = Y +MTU update = Y +TSO = P +Promiscuous mode = Y +Allmulticast mode = Y +Unicast MAC filter = Y +RSS hash = Y +RSS key update = Y +RSS reta update = Y +VLAN filter = Y +Inline crypto = Y +Packet type parsing = Y +Timesync = Y +Basic stats = Y +Extended stats = Y +FW version = Y +Module EEPROM dump = Y +Multiprocess aware = Y Linux = Y x86-32 = Y x86-64 = Y + +[rte_flow items] +eth = P +geneve = Y +gre = Y +gtpu = Y +ipv4 = Y +ipv6 = Y +ipv6_frag_ext = Y +nvgre = Y +sctp = Y +tcp = Y +udp = Y +vlan = P +vxlan = Y +vxlan_gpe = Y + +[rte_flow actions] +count = Y +drop = Y +mark = Y +passthru = Y +port_representor = Y +queue = Y +represented_port = Y +rss = Y +send_to_kernel = Y +port_id = Y diff --git a/doc/guides/nics/sxe2.rst b/doc/guides/nics/sxe2.rst index 539072b076..6cf1b825a1 100644 --- a/doc/guides/nics/sxe2.rst +++ b/doc/guides/nics/sxe2.rst @@ -35,3 +35,150 @@ preventing unauthorized access to random physical memory. This capability allows the PMD to coexist with kernel network interfaces which remain functional, although they stop receiving unicast packets as long as they share the same MAC address. + +Configuration +------------- + +Runtime Configuration +~~~~~~~~~~~~~~~~~~~~~ + +- ``Traffic Management Scheduling Levels`` + + The DPDK Traffic Management (rte_tm) APIs can be used to configure the Tx scheduler on the NIC. + The ``sched-layer-mode`` parameter can be used to set the number of scheduling levels + in the transmit scheduling hierarchy. + The provided value must be between 0 and 3. + If the value provided is greater than the number of levels supported by the HW, + the driver will use the hardware maximum value. + +- ``fnav-stat-type`` parameter [int] + + This parameter controls the Fnav flow engine statistics type used + for flow rule hit counting (via ``rte_flow_query``). + + - 1: Only count the number of packets. + - 2: Only count the number of bytes. + - 3: Count both packets and bytes (default). + + Default value is 3 (count both packets and bytes). + +- ``drv-sw-stats`` parameter [int] + + This parameter controls whether per-packet software statistics + (SW stats) are collected in the Rx data path. + + Hardware packet statistic counters may be inaccurate for certain + packet types due to hardware design limitations. + When accuracy of Rx packet classification statistics is critical, + enabling this parameter allows the driver to accumulate statistics + in software as packets are received, providing an alternative + statistical path that bypasses hardware counter inaccuracies. + + - 0: Disable software statistics collection (default). + The basic port statistics (``ipackets``, ``ibytes``) are reported + from the hardware counters. + - 1: Enable software statistics collection. + Per-packet software statistics are accumulated for unicast, + multicast, broadcast, and dropped packets in the Rx data path. + + When enabled, the following extended statistics (xstats) are available: + ``rx_sw_unicast_packets``, ``rx_sw_multicast_packets``, + ``rx_sw_broadcast_packets``, ``rx_sw_drop_packets``, + and ``rx_sw_drop_bytes``. + +- ``no-sched-mode`` parameter [int] + + This parameter enables non-scheduling mode (no-sched mode). + When enabled, the transmit path bypasses the hardware scheduling module + and packets are sent directly out through the port. + This results in lower transmit latency and higher throughput, + but Traffic Management (rte_tm) APIs are not supported in this mode. + + - 0: Disable non-scheduling mode (default). + The transmit path goes through the hardware scheduling hierarchy. + Traffic Management (rte_tm) APIs can be used to configure the Tx scheduler. + - 1: Enable non-scheduling mode. + The transmit path bypasses the hardware scheduling module. + Packets are sent directly from the port at full speed without scheduling. + Traffic Management (rte_tm) APIs are not available in this mode. + +- ``rx-low-latency`` parameter [int] + + This parameter controls the interrupt throttling (ITR) interval + for Rx queue interrupts. + + When enabled, the driver sets a shorter interrupt coalescing timeout + (``SXE2_ITR_INTERVAL_LOW``, approximately 1 μs), + reducing the time between packet arrival and interrupt delivery to the CPU. + This lowers receive latency at the cost of increased CPU interrupt rate. + + When disabled (default), the driver uses the normal interrupt throttling + interval (``SXE2_ITR_INTERVAL_NORMAL``, approximately 20 μs), + which reduces the CPU interrupt rate at the expense of higher receive latency. + + - 0: Disable Rx low latency (default). + Normal interrupt throttling interval (~20 μs) is used. + - 1: Enable Rx low latency. + Low interrupt throttling interval (~1 μs) is used + for reduced receive latency. + +- ``function-flow-direct`` parameter [int] + + This parameter controls whether flow rules from different functional units + (DPDK vs kernel driver) are isolated or combined when both drivers + control the same physical port. + + When the DPDK PMD and the kernel network driver coexist on the same port, + flow rules may originate from either driver. + This parameter determines how the source VSI (Virtual Switch Interface) + of each flow rule is handled during hardware programming. + + - 0 (default): Isolate flow rules between DPDK and kernel. + When ``flow_isolated`` is enabled (``rte_flow_isolate()`` called), + kernel-side flow rules take priority and DPDK-side flow rules are suppressed. + When ``flow_isolated`` is disabled, DPDK-side flow rules take priority + and kernel-side flow rules are suppressed. + Only one functional unit's flows are active at a time. + + - 1: Allow direct flow rules from both DPDK and kernel simultaneously. + Both DPDK and kernel source VSIs are preserved in the hardware flow table. + Flow rules from both sides are programmed without isolation. + + This option only applies to FNAV and ACL flow engine types + and does not apply to PF bond devices. + +Extended Statistics (xstats) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The PMD provides the following extended statistics (xstats) for detailed +monitoring of receive-side packet classification and software-level accounting. +The software statistics path is provided as a workaround for hardware +counter inaccuracies on certain packet types --- it accumulates per-packet +statistics directly in the Rx data path, ensuring that unicast, multicast, +broadcast, and drop counts reflect the actual packets processed by the driver. + +Receive Software Statistics + These counters are collected in the Rx data path when ``drv-sw-stats=1`` + is configured (see the ``drv-sw-stats`` devarg above). + When ``drv-sw-stats`` is disabled (default), these xstats report zero. + + - ``rx_sw_unicast_packets``: Number of unicast packets received. + - ``rx_sw_multicast_packets``: Number of multicast packets received. + - ``rx_sw_broadcast_packets``: Number of broadcast packets received. + - ``rx_sw_drop_packets``: Number of packets dropped in the Rx data path. + - ``rx_sw_drop_bytes``: Number of bytes dropped in the Rx data path. + + When ``drv-sw-stats`` is enabled, the basic counters ``ipackets`` and + ``ibytes`` (from ``rte_eth_stats``) also reflect the software-accumulated + packet and byte counts. Otherwise, they are reported from hardware counters. + +Fnav Flow Engine Statistics + The Fnav flow engine statistics type is controlled by the ``fnav-stat-type`` + devarg (see above). Depending on the configuration: + + - ``fnav-stat-type=1``: Only packet count is available. + - ``fnav-stat-type=2``: Only byte count is available. + - ``fnav-stat-type=3`` (default): Both packet and byte counts are available. + + Flow query results (via ``rte_flow_query``) expose these per-flow counters + through the query API, not via xstats. -- 2.52.0