On 2/8/2023 5:12 PM, Ankur Dwivedi wrote:
> This series adds trace points for functions in the ethdev library.
> The trace points are added in ethdev, flow, mtr and tm files.
> 
> v11:
>  - Added rte_trace_point_emit_blob to capture mac address list in
>    rte_ethdev_trace_set_mc_addr_list tracepoint.  
>  - Added ack by Ori in patch (4/6) ethdev: add trace points for flow.
> 
> v10:
>  - Removed const in basic types in tracepoint.
>  - Removed capture of pointer value where some fields in structure are
>    captured.
>  - Resolved RHEL 7 failure:
>    ../lib/ethdev/rte_ethdev.c:3260:2: error: 'for' loop initial declarations
>    are only allowed in C99 mode
>  - In patch (3/6) removed next_port and last_port in
>    rte_ethdev_trace_callback_register.
>  - In patch (3/6) simplified the return logic in
>    rte_eth_dev_priority_flow_ctrl_set,
>    rte_eth_dev_priority_flow_ctrl_queue_info_get and
>    rte_eth_dev_priority_flow_ctrl_queue_configure.
>  - In patch (4/6, 5/6 and 6/6), removed capture of structure fields in
>    tracepoint where the structure pointer can be null.
> 
> v9:
>  - Added __rte_eal_trace_generic_blob in lib/eal/version.map
>    file.
> 
> v8:
>  - Resolved review comments on ethdev patch.
>  - The file rte_ethdev_trace.h and rte_ethdev_trace_fp_burst.h(added in
>    this patch series) is removed. The file ethdev_trace.h is added as an
>    internal header. It  contains internal slow path and fastpath
>    tracepoints. The rte_ethdev_trace_fp.h contains public fastpath
>    tracepoints.
>  - In patch (2/6) removed extra call to rte_eth_trace_find_next with
>    RTE_MAX_ETHPORTS. 
>  - In patch (2/6), added parent argument in rte_eth_trace_find_next_of().
>  - In patches (2/6 and 4/6), provided appropriate data type to bit fields
>    in following tracepoints:
>    rte_eth_trace_rx_hairpin_queue_setup,
>    rte_eth_trace_tx_hairpin_queue_setup, rte_eth_trace_link_get_nowait,
>    rte_eth_trace_link_to_str, rte_eth_trace_link_get,
>    rte_flow_trace_pattern_template_create,
>    rte_flow_trace_actions_template_create and
>    rte_flow_trace_action_handle_create.
>  - Tracepoints moved from fastpath to slowpath in ethdev, mtr and tm.
>  - Moved few flow related tracepoints to fastpath as suggested in review
>    comments.
>  - Added const to the pointer parameters in tracepoints.
>  - The following tracepoints are moved to the end of the function to
>    capture return values:
>    rte_eth_trace_link_speed_to_str, rte_flow_trace_conv,
>    rte_mtr_trace_meter_policy_validate, rte_mtr_trace_meter_policy_add,
>    rte_mtr_trace_meter_policy_delete, rte_eth_find_next_sibling and
>    rte_eth_trace_speed_bitflag.
>  - Removed tracepoints from version.map file.
>  - Formatting changes.
> 
> v7:
>  - Resolves build failure.
>  - Changes in rte_trace_point_emit_blob() function in rte_trace_point.h
>    and rte_trace_point_register.h.
> 
> v6:
>  - Resolves compilation error with 32 bit build.
>  - Resolves a bug found in v5 in the trace autotest application where
>    the traces where not getting generated after the first blob test case.
>    The trace size needs to be known at trace point register, so a dynamic
>    length array cannot be implemented with current implementation.
>    So changing the metadata of blob to make the array as 64 bytes. The
>    length will denote the blob length(passed by the application). The
>    trailing unused fields will be set to zero if length is less than 64.
> 
>    For example, the following is the ctf metadata created to display
>    a mac addr array in rte_eth_trace_macaddr_get():
>    struct {
>       ...
>       uint8_t len;
>       uint8_t mac_addr_addr_bytes[64];
>    };
>  - Minor changes in the subject of patches (2/6) and (3/6).
> 
> v5:
>  - The rte_trace_point_emit_char_array function is renamed to 
>    rte_trace_point_emit_blob. With this function an array of
>    any length upto 65535 bytes can be captured.
>    For example, the following is the ctf metadata created to display
>    a mac addr array in rte_eth_trace_macaddr_get():
>    struct {
>       ...
>       uint16_t len;
>       uint8_t mac_addr_addr_bytes[len];
>    };
>  - Added additional test cases for rte_eal_trace_generic_blob
>    test case.
>  - Capturing of return value of a function is added to tracepoint 
>    for flow, mtr and tm patches.
>  - In ehdev patch (1/6), removed extra line. Also added rx_pkts and
>    tx_pkts pointer in trace point.
> 
> v4:
>  - Adds tracepoint function to emit char array. Also adds the
>    test case.
>  - Resolved review comments on "ethdev: add trace point" patch.
>    This patch is divided into 2 patches to minimize per patch
>    size.
>  - From the earlier version (v3), few tracepoints in ethdev,
>    flow, mtr, tm are made as fast path tracepoints. For the 
>    tracepoint which i was unsure, i have made it as fastpath.
>    All the fast path tracepoints can be found in 
>    rte_ethdev_trace_fp.h and rte_ethdev_trace_fp_burst.h.
>    All the slow path tracepoints can be found in rte_ethdev_trace.h.
>  - Capturing of return value is added to tracepoint in ethdev.
>    For flow, mtr and tm these changes are still yet to bde done.
>    Will do it in the next versions.
>  - Moved the trace functions from INTERNAL to EXPERIMENTAL in
>    version.map.
> 
> v3:
>  - Moved the trace functions from EXPERIMENTAL to INTERNAL in
>    version.map.
>  - Moved trace functions call to the end, in ethdev and flow trace.
>  - Added code to print the input value of features in
>    rte_eth_trace_rx_metadata_negotiate().
>  - Added code to capture return value in flow trace.
> 
> Ankur Dwivedi (6):
>   eal: trace: add trace point emit for blob
>   ethdev: add trace points for ethdev (part one)
>   ethdev: add trace points for ethdev (part two)
>   ethdev: add trace points for flow
>   ethdev: add trace points for mtr
>   ethdev: add trace points for tm

For series,
Acked-by: Ferruh Yigit <ferruh.yi...@amd.com>

Series applied to dpdk-next-net/main, thanks.

Reply via email to