ethdev: dump single flow rule
authorHaifei Luo <haifeil@nvidia.com>
Wed, 14 Apr 2021 10:19:59 +0000 (13:19 +0300)
committerFerruh Yigit <ferruh.yigit@intel.com>
Wed, 14 Apr 2021 11:19:55 +0000 (13:19 +0200)
Previous implementations support dump all the flows. Add new arg
rte_flow in rte_flow_dev_dump to dump one flow.

Signed-off-by: Haifei Luo <haifeil@nvidia.com>
Acked-by: Ajit Khaparde <ajit.khaparde@broadcom.com>
Acked-by: Ori Kam <orika@nvidia.com>
app/test-pmd/config.c
doc/guides/nics/mlx5.rst
doc/guides/rel_notes/release_21_05.rst
drivers/net/mlx5/linux/mlx5_socket.c
drivers/net/mlx5/mlx5.h
drivers/net/mlx5/mlx5_flow.c
drivers/net/octeontx2/otx2_flow.c
lib/librte_ethdev/rte_flow.c
lib/librte_ethdev/rte_flow.h
lib/librte_ethdev/rte_flow_driver.h

index a8bd664..995171f 100644 (file)
@@ -1931,7 +1931,7 @@ port_flow_dump(portid_t port_id, const char *file_name)
                        return -errno;
                }
        }
-       ret = rte_flow_dev_dump(port_id, file, &error);
+       ret = rte_flow_dev_dump(port_id, NULL, file, &error);
        if (ret) {
                port_flow_complain(&error);
                printf("Failed to dump flow: %s\n", strerror(-ret));
index 490329a..7ff92b0 100644 (file)
@@ -1837,13 +1837,16 @@ all flows with assistance of external tools.
 
    .. code-block:: console
 
-       testpmd> flow dump <port> <output_file>
+       To dump all flows:
+       testpmd> flow dump <port> all <output_file>
+       and dump one flow:
+       testpmd> flow dump <port> rule <rule_id> <output_file>
 
    - call rte_flow_dev_dump api:
 
    .. code-block:: console
 
-       rte_flow_dev_dump(port, file, NULL);
+       rte_flow_dev_dump(port, flow, file, NULL);
 
 #. Dump human-readable flows from raw file:
 
@@ -1851,4 +1854,4 @@ all flows with assistance of external tools.
 
    .. code-block:: console
 
-       mlx_steering_dump.py -f <output_file>
+       mlx_steering_dump.py -f <output_file> -flowptr <flow_ptr>
index d7fdc8d..cbfa6b9 100644 (file)
@@ -248,6 +248,9 @@ API Changes
 * pci: The value ``PCI_ANY_ID`` is marked as deprecated
   and can be replaced with ``RTE_PCI_ANY_ID``.
 
+* ethdev: Added a ``rte_flow`` pointer parameter to the function
+  ``rte_flow_dev_dump()`` allowing dump for single flow.
+
 * cryptodev: The experimental raw data path API for dequeue
   ``rte_cryptodev_raw_dequeue_burst`` got a new parameter
   ``max_nb_to_dequeue`` to provide flexible control on dequeue.
index b1f41bc..6e354f4 100644 (file)
@@ -84,7 +84,7 @@ mlx5_pmd_socket_handle(void *cb __rte_unused)
        }
        /* Dump flow. */
        dev = &rte_eth_devices[port_id];
-       ret = mlx5_flow_dev_dump(dev, file, NULL);
+       ret = mlx5_flow_dev_dump(dev, NULL, file, NULL);
        /* Set-up the ancillary data and reply. */
        msg.msg_controllen = 0;
        msg.msg_control = NULL;
index bac8bc0..2a39aca 100644 (file)
@@ -1244,8 +1244,8 @@ uint32_t mlx5_counter_alloc(struct rte_eth_dev *dev);
 void mlx5_counter_free(struct rte_eth_dev *dev, uint32_t cnt);
 int mlx5_counter_query(struct rte_eth_dev *dev, uint32_t cnt,
                       bool clear, uint64_t *pkts, uint64_t *bytes);
-int mlx5_flow_dev_dump(struct rte_eth_dev *dev, FILE *file,
-                      struct rte_flow_error *error);
+int mlx5_flow_dev_dump(struct rte_eth_dev *dev, struct rte_flow *flow,
+                       FILE *file, struct rte_flow_error *error);
 void mlx5_flow_rxq_dynf_metadata_set(struct rte_eth_dev *dev);
 int mlx5_flow_get_aged_flows(struct rte_eth_dev *dev, void **contexts,
                        uint32_t nb_contexts, struct rte_flow_error *error);
index b34d295..d153fc2 100644 (file)
@@ -7153,7 +7153,7 @@ mlx5_flow_discover_mreg_c(struct rte_eth_dev *dev)
  *   0 on success, a nagative value otherwise.
  */
 int
-mlx5_flow_dev_dump(struct rte_eth_dev *dev,
+mlx5_flow_dev_dump(struct rte_eth_dev *dev, struct rte_flow *flow_idx,
                   FILE *file,
                   struct rte_flow_error *error __rte_unused)
 {
@@ -7165,8 +7165,11 @@ mlx5_flow_dev_dump(struct rte_eth_dev *dev,
                        return -errno;
                return -ENOTSUP;
        }
-       return mlx5_devx_cmd_flow_dump(sh->fdb_domain, sh->rx_domain,
-                                      sh->tx_domain, file);
+
+       if (!flow_idx)
+               return mlx5_devx_cmd_flow_dump(sh->fdb_domain,
+                               sh->rx_domain, sh->tx_domain, file);
+       return -ENOTSUP;
 }
 
 /**
index 14ac9bc..1c90d75 100644 (file)
@@ -807,7 +807,7 @@ err_exit:
 
 static int
 otx2_flow_dev_dump(struct rte_eth_dev *dev,
-                 FILE *file,
+                 struct rte_flow *flow, FILE *file,
                  struct rte_flow_error *error)
 {
        struct otx2_eth_dev *hw = dev->data->dev_private;
@@ -822,6 +822,13 @@ otx2_flow_dev_dump(struct rte_eth_dev *dev,
                                   "Invalid file");
                return -EINVAL;
        }
+       if (flow != NULL) {
+               rte_flow_error_set(error, EINVAL,
+                                  RTE_FLOW_ERROR_TYPE_HANDLE,
+                                  NULL,
+                                  "Invalid argument");
+               return -EINVAL;
+       }
 
        max_prio = hw->npc_flow.flow_max_priority;
 
index e07e617..7241f00 100644 (file)
@@ -1027,7 +1027,8 @@ rte_flow_copy(struct rte_flow_desc *desc, size_t len,
 }
 
 int
-rte_flow_dev_dump(uint16_t port_id, FILE *file, struct rte_flow_error *error)
+rte_flow_dev_dump(uint16_t port_id, struct rte_flow *flow,
+                       FILE *file, struct rte_flow_error *error)
 {
        struct rte_eth_dev *dev = &rte_eth_devices[port_id];
        const struct rte_flow_ops *ops = rte_flow_ops_get(port_id, error);
@@ -1037,7 +1038,7 @@ rte_flow_dev_dump(uint16_t port_id, FILE *file, struct rte_flow_error *error)
                return -rte_errno;
        if (likely(!!ops->dev_dump)) {
                fts_enter(dev);
-               ret = ops->dev_dump(dev, file, error);
+               ret = ops->dev_dump(dev, flow, file, error);
                fts_exit(dev);
                return flow_err(port_id, ret, error);
        }
index c476a0f..5eba79d 100644 (file)
@@ -3232,6 +3232,8 @@ enum rte_flow_conv_op {
  *
  * @param[in] port_id
  *    The port identifier of the Ethernet device.
+ * @param[in] flow
+ *   The pointer of flow rule to dump. Dump all rules if NULL.
  * @param[in] file
  *   A pointer to a file for output.
  * @param[out] error
@@ -3242,7 +3244,8 @@ enum rte_flow_conv_op {
  */
 __rte_experimental
 int
-rte_flow_dev_dump(uint16_t port_id, FILE *file, struct rte_flow_error *error);
+rte_flow_dev_dump(uint16_t port_id, struct rte_flow *flow,
+               FILE *file, struct rte_flow_error *error);
 
 /**
  * Check if mbuf dynamic field for metadata is registered.
index da594d9..6ae1f8c 100644 (file)
@@ -75,6 +75,7 @@ struct rte_flow_ops {
        /** See rte_flow_dev_dump(). */
        int (*dev_dump)
                (struct rte_eth_dev *dev,
+                struct rte_flow *flow,
                 FILE *file,
                 struct rte_flow_error *error);
        /** See rte_flow_get_aged_flows() */