Hi Ankur,

I get an error message when I launch testpmd with Asan, I need your help to 
confirm this issue.
For more information please refer to https://bugs.dpdk.org/show_bug.cgi?id=1184.
Waiting for your reply.

Best regards,
Dukai,Yuan

> -----Original Message-----
> From: Ankur Dwivedi <adwiv...@marvell.com>
> Sent: 2023年2月8日 21:28
> To: dev@dpdk.org
> Cc: tho...@monjalon.net; david.march...@redhat.com; m...@ashroe.eu;
> or...@nvidia.com; ferruh.yi...@amd.com; ch...@att.com;
> humi...@huawei.com; linvi...@tuxdriver.com; Loftus, Ciara
> <ciara.lof...@intel.com>; Zhang, Qi Z <qi.z.zh...@intel.com>;
> m...@semihalf.com; m...@semihalf.com; shaib...@amazon.com;
> evge...@amazon.com; igo...@amazon.com; cha...@amd.com;
> irussk...@marvell.com; Shepard Siegel <shepard.sie...@atomicrules.com>;
> Czeck, Ed <ed.cz...@atomicrules.com>; john.mil...@atomicrules.com;
> ajit.khapa...@broadcom.com; somnath.ko...@broadcom.com;
> jer...@marvell.com; mcze...@marvell.com; sthot...@marvell.com;
> sriniva...@marvell.com; hka...@marvell.com; rahul.lakkire...@chelsio.com;
> Daley, John <johnd...@cisco.com>; hyon...@cisco.com;
> liudongdo...@huawei.com; yisen.zhu...@huawei.com;
> xuanziya...@huawei.com; cloud.wangxiao...@huawei.com;
> zhouguoy...@huawei.com; Su, Simei <simei...@intel.com>; Wu, Wenjun1
> <wenjun1...@intel.com>; Yang, Qiming <qiming.y...@intel.com>; Zhang,
> Yuying <yuying.zh...@intel.com>; Xing, Beilei <beilei.x...@intel.com>;
> Wang, Xiao W <xiao.w.w...@intel.com>; Wu, Jingjing
> <jingjing...@intel.com>; Guo, Junfeng <junfeng....@intel.com>; Xu,
> Rosen <rosen...@intel.com>; ndabilpu...@marvell.com;
> kirankum...@marvell.com; sk...@marvell.com; skotesh...@marvell.com;
> lir...@marvell.com; z...@semihalf.com; rad...@marvell.com;
> vbu...@marvell.com; sed...@marvell.com; ma...@nvidia.com;
> viachesl...@nvidia.com; lon...@microsoft.com; spin...@cesnet.cz;
> chaoyong...@corigine.com; niklas.soderl...@corigine.com;
> hemant.agra...@nxp.com; sachin.sax...@oss.nxp.com; g.si...@nxp.com;
> apeksha.gu...@nxp.com; sachin.sax...@nxp.com; abo...@pensando.io;
> rm...@marvell.com; shsha...@marvell.com; dsinghra...@marvell.com;
> andrew.rybche...@oktetlabs.ru; jiawe...@trustnetic.com;
> jianw...@trustnetic.com; Behrens, Jochen <jbehr...@vmware.com>;
> maxime.coque...@redhat.com; Xia, Chenbo <chenbo....@intel.com>;
> Webster, Steven <steven.webs...@windriver.com>; Peters, Matt
> <matt.pet...@windriver.com>; Richardson, Bruce
> <bruce.richard...@intel.com>; mtetsu...@gmail.com; gr...@u256.net;
> Singh, Jasvinder <jasvinder.si...@intel.com>; Dumitrescu, Cristian
> <cristian.dumitre...@intel.com>; jgraj...@cisco.com;
> m...@smartsharesystems.com; Ankur Dwivedi <adwiv...@marvell.com>
> Subject: [PATCH v10 6/6] ethdev: add trace points for tm
> 
> Adds trace points for rte_tm specific functions in ethdev lib.
> 
> Signed-off-by: Ankur Dwivedi <adwiv...@marvell.com>
> ---
>  lib/ethdev/ethdev_trace.h        | 304
> +++++++++++++++++++++++++++++++
>  lib/ethdev/ethdev_trace_points.c |  90 +++++++++
>  lib/ethdev/rte_tm.c              | 225 ++++++++++++++++++++---
>  3 files changed, 590 insertions(+), 29 deletions(-)
> 
> diff --git a/lib/ethdev/ethdev_trace.h b/lib/ethdev/ethdev_trace.h index
> 973e2ac6d4..0b0a791aeb 100644
> --- a/lib/ethdev/ethdev_trace.h
> +++ b/lib/ethdev/ethdev_trace.h
> @@ -20,6 +20,7 @@ extern "C" {
> 
>  #include "rte_ethdev.h"
>  #include "rte_mtr.h"
> +#include "rte_tm.h"
> 
>  RTE_TRACE_POINT(
>       rte_ethdev_trace_configure,
> @@ -1831,6 +1832,309 @@ RTE_TRACE_POINT(
>       rte_trace_point_emit_int(ret);
>  )
> 
> +RTE_TRACE_POINT(
> +     rte_tm_trace_get_number_of_leaf_nodes,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t n_leaf_nodes),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(n_leaf_nodes);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_type_get,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id, int
> is_leaf,
> +             int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_int(is_leaf);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_capabilities_get,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id,
> +             const struct rte_tm_capabilities *cap, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_ptr(cap);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_level_capabilities_get,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t level_id,
> +             const struct rte_tm_level_capabilities *cap, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(level_id);
> +     rte_trace_point_emit_ptr(cap);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_capabilities_get,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             const struct rte_tm_node_capabilities *cap, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_ptr(cap);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_wred_profile_add,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t wred_profile_id,
> +             const struct rte_tm_wred_params *profile, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(wred_profile_id);
> +     rte_trace_point_emit_ptr(profile);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_wred_profile_delete,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t wred_profile_id,
> +             int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(wred_profile_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_shared_wred_context_add_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t
> shared_wred_context_id,
> +             uint32_t wred_profile_id, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(shared_wred_context_id);
> +     rte_trace_point_emit_u32(wred_profile_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_shared_wred_context_delete,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t
> shared_wred_context_id,
> +             int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(shared_wred_context_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_shaper_profile_add,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t
> shaper_profile_id,
> +             const struct rte_tm_shaper_params *profile, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(shaper_profile_id);
> +     rte_trace_point_emit_ptr(profile);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_shaper_profile_delete,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t
> shaper_profile_id,
> +             int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(shaper_profile_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_shared_shaper_add_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t
> shared_shaper_id,
> +             uint32_t shaper_profile_id, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(shared_shaper_id);
> +     rte_trace_point_emit_u32(shaper_profile_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_shared_shaper_delete,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t
> shared_shaper_id,
> +             int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(shared_shaper_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_add,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             uint32_t parent_node_id, uint32_t priority,
> +             uint32_t weight, uint32_t level_id,
> +             const struct rte_tm_node_params *params, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_u32(parent_node_id);
> +     rte_trace_point_emit_u32(priority);
> +     rte_trace_point_emit_u32(weight);
> +     rte_trace_point_emit_u32(level_id);
> +     rte_trace_point_emit_ptr(params);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_delete,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id, int
> ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_suspend,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id, int
> ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_resume,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id, int
> ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_hierarchy_commit,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, int clear_on_fail, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_int(clear_on_fail);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_parent_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             uint32_t parent_node_id, uint32_t priority,
> +             uint32_t weight, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_u32(parent_node_id);
> +     rte_trace_point_emit_u32(priority);
> +     rte_trace_point_emit_u32(weight);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_shaper_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             uint32_t shaper_profile_id, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_u32(shaper_profile_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_shared_shaper_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             uint32_t shared_shaper_id, int add, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_u32(shared_shaper_id);
> +     rte_trace_point_emit_int(add);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_stats_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             uint64_t stats_mask, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_u64(stats_mask);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_wfq_weight_mode_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             const int *wfq_weight_mode, uint32_t n_sp_priorities,
> +             int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_ptr(wfq_weight_mode);
> +     rte_trace_point_emit_u32(n_sp_priorities);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_cman_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             enum rte_tm_cman_mode cman, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_int(cman);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_wred_context_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             uint32_t wred_profile_id, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_u32(wred_profile_id);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_shared_wred_context_update,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             uint32_t shared_wred_context_id, int add, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_u32(shared_wred_context_id);
> +     rte_trace_point_emit_int(add);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_node_stats_read,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, uint32_t node_id,
> +             const struct rte_tm_node_stats *stats,
> +             uint64_t stats_mask, int clear, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_u32(node_id);
> +     rte_trace_point_emit_ptr(stats);
> +     rte_trace_point_emit_u64(stats_mask);
> +     rte_trace_point_emit_int(clear);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_mark_vlan_dei,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, int mark_green,
> +             int mark_yellow, int mark_red, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_int(mark_green);
> +     rte_trace_point_emit_int(mark_yellow);
> +     rte_trace_point_emit_int(mark_red);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_mark_ip_ecn,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, int mark_green,
> +             int mark_yellow, int mark_red, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_int(mark_green);
> +     rte_trace_point_emit_int(mark_yellow);
> +     rte_trace_point_emit_int(mark_red);
> +     rte_trace_point_emit_int(ret);
> +)
> +
> +RTE_TRACE_POINT(
> +     rte_tm_trace_mark_ip_dscp,
> +     RTE_TRACE_POINT_ARGS(uint16_t port_id, int mark_green,
> +             int mark_yellow, int mark_red, int ret),
> +     rte_trace_point_emit_u16(port_id);
> +     rte_trace_point_emit_int(mark_green);
> +     rte_trace_point_emit_int(mark_yellow);
> +     rte_trace_point_emit_int(mark_red);
> +     rte_trace_point_emit_int(ret);
> +)
> +
>  /* Fast path trace points */
> 
>  /* Called in loop in examples/qos_sched and examples/distributor */ diff --
> git a/lib/ethdev/ethdev_trace_points.c b/lib/ethdev/ethdev_trace_points.c
> index c34c06941c..34d12e2859 100644
> --- a/lib/ethdev/ethdev_trace_points.c
> +++ b/lib/ethdev/ethdev_trace_points.c
> @@ -654,3 +654,93 @@
> RTE_TRACE_POINT_REGISTER(rte_mtr_trace_color_in_protocol_priority_get,
> 
>  RTE_TRACE_POINT_REGISTER(rte_mtr_trace_color_in_protocol_set,
>       lib.ethdev.mtr.color_in_protocol_set)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_capabilities_get,
> +     lib.ethdev.tm.capabilities_get)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_get_number_of_leaf_nodes,
> +     lib.ethdev.tm.get_number_of_leaf_nodes)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_hierarchy_commit,
> +     lib.ethdev.tm.hierarchy_commit)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_level_capabilities_get,
> +     lib.ethdev.tm.level_capabilities_get)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_mark_ip_dscp,
> +     lib.ethdev.tm.mark_ip_dscp)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_mark_ip_ecn,
> +     lib.ethdev.tm.mark_ip_ecn)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_mark_vlan_dei,
> +     lib.ethdev.tm.mark_vlan_dei)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_add,
> +     lib.ethdev.tm.node_add)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_capabilities_get,
> +     lib.ethdev.tm.node_capabilities_get)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_cman_update,
> +     lib.ethdev.tm.node_cman_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_delete,
> +     lib.ethdev.tm.node_delete)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_parent_update,
> +     lib.ethdev.tm.node_parent_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_resume,
> +     lib.ethdev.tm.node_resume)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_shaper_update,
> +     lib.ethdev.tm.node_shaper_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_shared_shaper_update,
> +     lib.ethdev.tm.node_shared_shaper_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_shared_wred_context_
> update,
> +     lib.ethdev.tm.node_shared_wred_context_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_stats_read,
> +     lib.ethdev.tm.node_stats_read)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_stats_update,
> +     lib.ethdev.tm.node_stats_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_suspend,
> +     lib.ethdev.tm.node_suspend)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_type_get,
> +     lib.ethdev.tm.node_type_get)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_wfq_weight_mode_up
> date,
> +     lib.ethdev.tm.node_wfq_weight_mode_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_node_wred_context_update,
> +     lib.ethdev.tm.node_wred_context_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_shaper_profile_add,
> +     lib.ethdev.tm.shaper_profile_add)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_shaper_profile_delete,
> +     lib.ethdev.tm.shaper_profile_delete)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_shared_shaper_add_update,
> +     lib.ethdev.tm.shared_shaper_add_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_shared_shaper_delete,
> +     lib.ethdev.tm.shared_shaper_delete)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_shared_wred_context_add_u
> pdate,
> +     lib.ethdev.tm.shared_wred_context_add_update)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_shared_wred_context_delete,
> +     lib.ethdev.tm.shared_wred_context_delete)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_wred_profile_add,
> +     lib.ethdev.tm.wred_profile_add)
> +
> +RTE_TRACE_POINT_REGISTER(rte_tm_trace_wred_profile_delete,
> +     lib.ethdev.tm.wred_profile_delete)
> diff --git a/lib/ethdev/rte_tm.c b/lib/ethdev/rte_tm.c index
> 9709454f35..2d08141133 100644
> --- a/lib/ethdev/rte_tm.c
> +++ b/lib/ethdev/rte_tm.c
> @@ -5,6 +5,7 @@
>  #include <stdint.h>
> 
>  #include <rte_errno.h>
> +#include "ethdev_trace.h"
>  #include "rte_ethdev.h"
>  #include "rte_tm_driver.h"
>  #include "rte_tm.h"
> @@ -79,6 +80,9 @@ rte_tm_get_number_of_leaf_nodes(uint16_t port_id,
>       }
> 
>       *n_leaf_nodes = dev->data->nb_tx_queues;
> +
> +     rte_tm_trace_get_number_of_leaf_nodes(port_id, *n_leaf_nodes);
> +
>       return 0;
>  }
> 
> @@ -90,8 +94,13 @@ rte_tm_node_type_get(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_type_get)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_type_get)(dev,
>               node_id, is_leaf, error);
> +
> +     rte_tm_trace_node_type_get(port_id, node_id, *is_leaf, ret);
> +
> +     return ret;
>  }
> 
>  /* Get capabilities */
> @@ -100,8 +109,13 @@ int rte_tm_capabilities_get(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, capabilities_get)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, capabilities_get)(dev,
>               cap, error);
> +
> +     rte_tm_trace_capabilities_get(port_id, cap, ret);
> +
> +     return ret;
>  }
> 
>  /* Get level capabilities */
> @@ -111,8 +125,13 @@ int rte_tm_level_capabilities_get(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, level_capabilities_get)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, level_capabilities_get)(dev,
>               level_id, cap, error);
> +
> +     rte_tm_trace_level_capabilities_get(port_id, level_id, cap, ret);
> +
> +     return ret;
>  }
> 
>  /* Get node capabilities */
> @@ -122,8 +141,13 @@ int rte_tm_node_capabilities_get(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_capabilities_get)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_capabilities_get)(dev,
>               node_id, cap, error);
> +
> +     rte_tm_trace_node_capabilities_get(port_id, node_id, cap, ret);
> +
> +     return ret;
>  }
> 
>  /* Add WRED profile */
> @@ -133,8 +157,13 @@ int rte_tm_wred_profile_add(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, wred_profile_add)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, wred_profile_add)(dev,
>               wred_profile_id, profile, error);
> +
> +     rte_tm_trace_wred_profile_add(port_id, wred_profile_id, profile,
> ret);
> +
> +     return ret;
>  }
> 
>  /* Delete WRED profile */
> @@ -143,8 +172,13 @@ int rte_tm_wred_profile_delete(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, wred_profile_delete)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, wred_profile_delete)(dev,
>               wred_profile_id, error);
> +
> +     rte_tm_trace_wred_profile_delete(port_id, wred_profile_id, ret);
> +
> +     return ret;
>  }
> 
>  /* Add/update shared WRED context */
> @@ -154,8 +188,15 @@ int
> rte_tm_shared_wred_context_add_update(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id,
> shared_wred_context_add_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id,
> shared_wred_context_add_update)(dev,
>               shared_wred_context_id, wred_profile_id, error);
> +
> +     rte_tm_trace_shared_wred_context_add_update(port_id,
> +                                                 shared_wred_context_id,
> +                                                 wred_profile_id, ret);
> +
> +     return ret;
>  }
> 
>  /* Delete shared WRED context */
> @@ -164,8 +205,14 @@ int rte_tm_shared_wred_context_delete(uint16_t
> port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, shared_wred_context_delete)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, shared_wred_context_delete)(dev,
>               shared_wred_context_id, error);
> +
> +     rte_tm_trace_shared_wred_context_delete(port_id,
> +                                             shared_wred_context_id,
> ret);
> +
> +     return ret;
>  }
> 
>  /* Add shaper profile */
> @@ -175,8 +222,14 @@ int rte_tm_shaper_profile_add(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, shaper_profile_add)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, shaper_profile_add)(dev,
>               shaper_profile_id, profile, error);
> +
> +     rte_tm_trace_shaper_profile_add(port_id, shaper_profile_id,
> profile,
> +                                     ret);
> +
> +     return ret;
>  }
> 
>  /* Delete WRED profile */
> @@ -185,8 +238,13 @@ int rte_tm_shaper_profile_delete(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, shaper_profile_delete)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, shaper_profile_delete)(dev,
>               shaper_profile_id, error);
> +
> +     rte_tm_trace_shaper_profile_delete(port_id, shaper_profile_id,
> ret);
> +
> +     return ret;
>  }
> 
>  /* Add shared shaper */
> @@ -196,8 +254,14 @@ int rte_tm_shared_shaper_add_update(uint16_t
> port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, shared_shaper_add_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, shared_shaper_add_update)(dev,
>               shared_shaper_id, shaper_profile_id, error);
> +
> +     rte_tm_trace_shared_shaper_add_update(port_id,
> shared_shaper_id,
> +                                           shaper_profile_id, ret);
> +
> +     return ret;
>  }
> 
>  /* Delete shared shaper */
> @@ -206,8 +270,13 @@ int rte_tm_shared_shaper_delete(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, shared_shaper_delete)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, shared_shaper_delete)(dev,
>               shared_shaper_id, error);
> +
> +     rte_tm_trace_shared_shaper_delete(port_id, shared_shaper_id,
> ret);
> +
> +     return ret;
>  }
> 
>  /* Add node to port traffic manager hierarchy */ @@ -221,9 +290,15 @@ int
> rte_tm_node_add(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_add)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_add)(dev,
>               node_id, parent_node_id, priority, weight, level_id,
>               params, error);
> +
> +     rte_tm_trace_node_add(port_id, node_id, parent_node_id, priority,
> +                           weight, level_id, params, ret);
> +
> +     return ret;
>  }
> 
>  /* Delete node from traffic manager hierarchy */ @@ -232,8 +307,13 @@ int
> rte_tm_node_delete(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_delete)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_delete)(dev,
>               node_id, error);
> +
> +     rte_tm_trace_node_delete(port_id, node_id, ret);
> +
> +     return ret;
>  }
> 
>  /* Suspend node */
> @@ -242,8 +322,13 @@ int rte_tm_node_suspend(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_suspend)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_suspend)(dev,
>               node_id, error);
> +
> +     rte_tm_trace_node_suspend(port_id, node_id, ret);
> +
> +     return ret;
>  }
> 
>  /* Resume node */
> @@ -252,8 +337,13 @@ int rte_tm_node_resume(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_resume)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_resume)(dev,
>               node_id, error);
> +
> +     rte_tm_trace_node_resume(port_id, node_id, ret);
> +
> +     return ret;
>  }
> 
>  /* Commit the initial port traffic manager hierarchy */ @@ -262,8 +352,13
> @@ int rte_tm_hierarchy_commit(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, hierarchy_commit)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, hierarchy_commit)(dev,
>               clear_on_fail, error);
> +
> +     rte_tm_trace_hierarchy_commit(port_id, clear_on_fail, ret);
> +
> +     return ret;
>  }
> 
>  /* Update node parent  */
> @@ -275,8 +370,14 @@ int rte_tm_node_parent_update(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_parent_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_parent_update)(dev,
>               node_id, parent_node_id, priority, weight, error);
> +
> +     rte_tm_trace_node_parent_update(port_id, node_id,
> parent_node_id,
> +                                     priority, weight, ret);
> +
> +     return ret;
>  }
> 
>  /* Update node private shaper */
> @@ -286,8 +387,14 @@ int rte_tm_node_shaper_update(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_shaper_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_shaper_update)(dev,
>               node_id, shaper_profile_id, error);
> +
> +     rte_tm_trace_node_shaper_update(port_id, node_id,
> shaper_profile_id,
> +                                     ret);
> +
> +     return ret;
>  }
> 
>  /* Update node shared shapers */
> @@ -298,8 +405,14 @@ int rte_tm_node_shared_shaper_update(uint16_t
> port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_shared_shaper_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_shared_shaper_update)(dev,
>               node_id, shared_shaper_id, add, error);
> +
> +     rte_tm_trace_node_shared_shaper_update(port_id, node_id,
> +                                            shared_shaper_id, add, ret);
> +
> +     return ret;
>  }
> 
>  /* Update node stats */
> @@ -309,8 +422,13 @@ int rte_tm_node_stats_update(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_stats_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_stats_update)(dev,
>               node_id, stats_mask, error);
> +
> +     rte_tm_trace_node_stats_update(port_id, node_id, stats_mask,
> ret);
> +
> +     return ret;
>  }
> 
>  /* Update WFQ weight mode */
> @@ -321,8 +439,15 @@ int
> rte_tm_node_wfq_weight_mode_update(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id,
> node_wfq_weight_mode_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id,
> node_wfq_weight_mode_update)(dev,
>               node_id, wfq_weight_mode, n_sp_priorities, error);
> +
> +     rte_tm_trace_node_wfq_weight_mode_update(port_id, node_id,
> +                                              wfq_weight_mode,
> +                                              n_sp_priorities, ret);
> +
> +     return ret;
>  }
> 
>  /* Update node congestion management mode */ @@ -332,8 +457,13 @@
> int rte_tm_node_cman_update(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_cman_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_cman_update)(dev,
>               node_id, cman, error);
> +
> +     rte_tm_trace_node_cman_update(port_id, node_id, cman, ret);
> +
> +     return ret;
>  }
> 
>  /* Update node private WRED context */
> @@ -343,8 +473,14 @@ int rte_tm_node_wred_context_update(uint16_t
> port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_wred_context_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_wred_context_update)(dev,
>               node_id, wred_profile_id, error);
> +
> +     rte_tm_trace_node_wred_context_update(port_id, node_id,
> wred_profile_id,
> +                                           ret);
> +
> +     return ret;
>  }
> 
>  /* Update node shared WRED context */
> @@ -355,8 +491,15 @@ int
> rte_tm_node_shared_wred_context_update(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id,
> node_shared_wred_context_update)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id,
> node_shared_wred_context_update)(dev,
>               node_id, shared_wred_context_id, add, error);
> +
> +     rte_tm_trace_node_shared_wred_context_update(port_id,
> node_id,
> +                                                  shared_wred_context_id,
> +                                                  add, ret);
> +
> +     return ret;
>  }
> 
>  /* Read and/or clear stats counters for specific node */ @@ -368,8 +511,14
> @@ int rte_tm_node_stats_read(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, node_stats_read)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, node_stats_read)(dev,
>               node_id, stats, stats_mask, clear, error);
> +
> +     rte_tm_trace_node_stats_read(port_id, node_id, stats,
> *stats_mask,
> +                                  clear, ret);
> +
> +     return ret;
>  }
> 
>  /* Packet marking - VLAN DEI */
> @@ -380,8 +529,14 @@ int rte_tm_mark_vlan_dei(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, mark_vlan_dei)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, mark_vlan_dei)(dev,
>               mark_green, mark_yellow, mark_red, error);
> +
> +     rte_tm_trace_mark_vlan_dei(port_id, mark_green, mark_yellow,
> mark_red,
> +                                ret);
> +
> +     return ret;
>  }
> 
>  /* Packet marking - IPv4/IPv6 ECN */
> @@ -392,8 +547,14 @@ int rte_tm_mark_ip_ecn(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, mark_ip_ecn)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, mark_ip_ecn)(dev,
>               mark_green, mark_yellow, mark_red, error);
> +
> +     rte_tm_trace_mark_ip_ecn(port_id, mark_green, mark_yellow,
> mark_red,
> +                              ret);
> +
> +     return ret;
>  }
> 
>  /* Packet marking - IPv4/IPv6 DSCP */
> @@ -404,6 +565,12 @@ int rte_tm_mark_ip_dscp(uint16_t port_id,
>       struct rte_tm_error *error)
>  {
>       struct rte_eth_dev *dev = &rte_eth_devices[port_id];
> -     return RTE_TM_FUNC(port_id, mark_ip_dscp)(dev,
> +     int ret;
> +     ret = RTE_TM_FUNC(port_id, mark_ip_dscp)(dev,
>               mark_green, mark_yellow, mark_red, error);
> +
> +     rte_tm_trace_mark_ip_dscp(port_id, mark_green, mark_yellow,
> mark_red,
> +                               ret);
> +
> +     return ret;
>  }
> --
> 2.25.1


Reply via email to