This patch is to add get all loaded profiles function.

Signed-off-by: Beilei Xing <beilei.x...@intel.com>
---
 drivers/net/i40e/i40e_ethdev.c            | 28 ++++++++++++++++++++++++++++
 drivers/net/i40e/rte_pmd_i40e.h           | 12 ++++++++++++
 drivers/net/i40e/rte_pmd_i40e_version.map |  1 +
 3 files changed, 41 insertions(+)

diff --git a/drivers/net/i40e/i40e_ethdev.c b/drivers/net/i40e/i40e_ethdev.c
index bea593f..bec3e5d 100644
--- a/drivers/net/i40e/i40e_ethdev.c
+++ b/drivers/net/i40e/i40e_ethdev.c
@@ -11260,6 +11260,9 @@ rte_pmd_i40e_reset_vf_stats(uint8_t port,
        return 0;
 }
 
+#define I40E_PROFILE_INFO_SIZE 48
+#define I40E_MAX_PROFILE_NUM 16
+
 static void
 i40e_generate_profile_info_sec(char *name, struct i40e_ppp_version *version,
                               uint32_t track_id, uint8_t *profile_info_sec,
@@ -11457,3 +11460,28 @@ rte_pmd_i40e_process_ppp_package(uint8_t port, uint8_t 
*buff,
        rte_free(profile_info_sec);
        return status;
 }
+
+int
+rte_pmd_i40e_get_ppp_list(uint8_t port, uint8_t *buff, uint32_t size)
+{
+       struct rte_eth_dev *dev;
+       struct i40e_hw *hw;
+       enum i40e_status_code status = I40E_SUCCESS;
+
+       RTE_ETH_VALID_PORTID_OR_ERR_RET(port, -ENODEV);
+
+       dev = &rte_eth_devices[port];
+
+       if (!is_device_supported(dev, &rte_i40e_pmd))
+               return -ENOTSUP;
+
+       if (size < (I40E_PROFILE_INFO_SIZE * I40E_MAX_PROFILE_NUM + 4))
+               return -EINVAL;
+
+       hw = I40E_DEV_PRIVATE_TO_HW(dev->data->dev_private);
+
+       status = i40e_aq_get_ppp_list(hw, (void *)buff,
+                                     size, 0, NULL);
+
+       return status;
+}
diff --git a/drivers/net/i40e/rte_pmd_i40e.h b/drivers/net/i40e/rte_pmd_i40e.h
index 4f6cdb5..d157a49 100644
--- a/drivers/net/i40e/rte_pmd_i40e.h
+++ b/drivers/net/i40e/rte_pmd_i40e.h
@@ -383,4 +383,16 @@ int rte_pmd_i40e_reset_vf_stats(uint8_t port,
 int rte_pmd_i40e_process_ppp_package(uint8_t port, uint8_t *buff,
                                     uint32_t size, bool add);
 
+/**
+ * rte_pmd_i40e_get_ppp_list - Get loaded profile list
+ * @port: port id
+ * @buff: buffer for response
+ * @size: buffer size
+ * @return
+ *   - (0) if successful.
+ *   - (-ENODEV) if *port* invalid.
+ *   - (-EINVAL) if bad parameter.
+ */
+int rte_pmd_i40e_get_ppp_list(uint8_t port, uint8_t *buff, uint32_t size);
+
 #endif /* _PMD_I40E_H_ */
diff --git a/drivers/net/i40e/rte_pmd_i40e_version.map 
b/drivers/net/i40e/rte_pmd_i40e_version.map
index 01c4a90..9808893 100644
--- a/drivers/net/i40e/rte_pmd_i40e_version.map
+++ b/drivers/net/i40e/rte_pmd_i40e_version.map
@@ -27,4 +27,5 @@ DPDK_17.05 {
        global:
 
        rte_pmd_i40e_process_ppp_package;
+       rte_pmd_i40e_get_ppp_list;
 };
-- 
2.5.5

Reply via email to