From: Harman Kalra <hkalra@marvell.com>
To: Gowrishankar Muthukrishnan <gmuthukrishn@marvell.com>,
"dev@dpdk.org" <dev@dpdk.org>
Cc: Jerin Jacob Kollanukkaran <jerinj@marvell.com>,
Kiran Kumar Kokkilagadda <kirankumark@marvell.com>,
Nithin Kumar Dabilpuram <ndabilpuram@marvell.com>,
Sunil Kumar Kori <skori@marvell.com>,
Satha Koteswara Rao Kottidi <skoteshwar@marvell.com>,
Ashwin Sekhar Thalakalath Kottilveetil <asekhar@marvell.com>,
Pavan Nikhilesh Bhagavatula <pbhagavatula@marvell.com>,
Gowrishankar Muthukrishnan <gmuthukrishn@marvell.com>
Subject: Re: [dpdk-dev] [EXT] [v9 2/4] common/cnxk: add telemetry endpoints to nix
Date: Thu, 14 Oct 2021 16:37:05 +0000 [thread overview]
Message-ID: <BN9PR18MB4204E68BCD5457921AB3BD4AC5B89@BN9PR18MB4204.namprd18.prod.outlook.com> (raw)
In-Reply-To: <6fb65d36ad31999c2d46fcc84e380402d131303e.1632896495.git.gmuthukrishn@marvell.com>
> -----Original Message-----
> From: dev <dev-bounces@dpdk.org> On Behalf Of Gowrishankar
> Muthukrishnan
> Sent: Wednesday, September 29, 2021 12:25 PM
> To: dev@dpdk.org
> Cc: Jerin Jacob Kollanukkaran <jerinj@marvell.com>; Kiran Kumar
> Kokkilagadda <kirankumark@marvell.com>; Nithin Kumar Dabilpuram
> <ndabilpuram@marvell.com>; Sunil Kumar Kori <skori@marvell.com>; Satha
> Koteswara Rao Kottidi <skoteshwar@marvell.com>; Ashwin Sekhar
> Thalakalath Kottilveetil <asekhar@marvell.com>; Pavan Nikhilesh
> Bhagavatula <pbhagavatula@marvell.com>; Gowrishankar Muthukrishnan
> <gmuthukrishn@marvell.com>
> Subject: [EXT] [dpdk-dev] [v9 2/4] common/cnxk: add telemetry endpoints to
> nix
>
> External Email
>
> ----------------------------------------------------------------------
> Add telemetry endpoints to nix.
>
> Signed-off-by: Gowrishankar Muthukrishnan <gmuthukrishn@marvell.com>
Patch looks good to me.
Reviewed-by: Harman Kalra <hkalra@marvell.com>
Thanks
Harman
> ---
> drivers/common/cnxk/cnxk_telemetry_nix.c | 849
> +++++++++++++++++++++++
> drivers/common/cnxk/meson.build | 3 +-
> drivers/common/cnxk/roc_nix.c | 3 +
> drivers/common/cnxk/roc_nix_priv.h | 9 +
> drivers/common/cnxk/roc_nix_queue.c | 15 +-
> drivers/common/cnxk/roc_platform.h | 3 +
> 6 files changed, 878 insertions(+), 4 deletions(-) create mode 100644
> drivers/common/cnxk/cnxk_telemetry_nix.c
>
> diff --git a/drivers/common/cnxk/cnxk_telemetry_nix.c
> b/drivers/common/cnxk/cnxk_telemetry_nix.c
> new file mode 100644
> index 0000000000..1175f68a51
> --- /dev/null
> +++ b/drivers/common/cnxk/cnxk_telemetry_nix.c
> @@ -0,0 +1,849 @@
> +/* SPDX-License-Identifier: BSD-3-Clause
> + * Copyright(C) 2021 Marvell.
> + */
> +
> +#include "cnxk_telemetry.h"
> +#include "roc_api.h"
> +#include "roc_priv.h"
> +
> +struct nix_tel_node {
> + TAILQ_ENTRY(nix_tel_node) node;
> + struct roc_nix *nix;
> + uint16_t n_rq;
> + uint16_t n_cq;
> + uint16_t n_sq;
> + struct roc_nix_rq **rqs;
> + struct roc_nix_cq **cqs;
> + struct roc_nix_sq **sqs;
> +};
> +
> +TAILQ_HEAD(nix_tel_node_list, nix_tel_node); static struct
> +nix_tel_node_list nix_list;
> +
> +static struct nix_tel_node *
> +nix_tel_node_get(struct roc_nix *roc_nix) {
> + struct nix_tel_node *node, *roc_node = NULL;
> +
> + TAILQ_FOREACH(node, &nix_list, node) {
> + if (node->nix == roc_nix) {
> + roc_node = node;
> + break;
> + }
> + }
> +
> + return roc_node;
> +}
> +
> +int
> +nix_tel_node_add(struct roc_nix *roc_nix) {
> + struct nix *nix = roc_nix_to_nix_priv(roc_nix);
> + struct nix_tel_node *node;
> +
> + node = nix_tel_node_get(roc_nix);
> + if (node) {
> + if (nix->nb_rx_queues == node->n_rq &&
> + nix->nb_tx_queues == node->n_sq)
> + return 0;
> +
> + nix_tel_node_del(roc_nix);
> + }
> +
> + node = plt_zmalloc(sizeof(struct nix_tel_node), 0);
> + if (!node)
> + return -1;
> +
> + node->nix = roc_nix;
> + node->rqs =
> + plt_zmalloc(nix->nb_rx_queues * sizeof(struct roc_nix_rq *),
> 0);
> + node->cqs =
> + plt_zmalloc(nix->nb_rx_queues * sizeof(struct roc_nix_cq *),
> 0);
> + node->sqs =
> + plt_zmalloc(nix->nb_tx_queues * sizeof(struct roc_nix_sq *),
> 0);
> + TAILQ_INSERT_TAIL(&nix_list, node, node);
> +
> + return 0;
> +}
> +
> +void
> +nix_tel_node_del(struct roc_nix *roc_nix) {
> + struct nix_tel_node *node;
> +
> + TAILQ_FOREACH(node, &nix_list, node) {
> + if (node->nix == roc_nix) {
> + plt_free(node->rqs);
> + plt_free(node->cqs);
> + plt_free(node->sqs);
> + TAILQ_REMOVE(&nix_list, node, node);
> + }
> + }
> +
> + plt_free(node);
> +}
> +
> +static struct nix_tel_node *
> +nix_tel_node_get_by_pcidev_name(const char *name) {
> + struct nix_tel_node *node, *roc_node = NULL;
> +
> + TAILQ_FOREACH(node, &nix_list, node) {
> + if (!strncmp(node->nix->pci_dev->name, name,
> + PCI_PRI_STR_SIZE)) {
> + roc_node = node;
> + break;
> + }
> + }
> +
> + return roc_node;
> +}
> +
> +int
> +nix_tel_node_add_rq(struct roc_nix_rq *rq) {
> + struct nix_tel_node *node;
> +
> + node = nix_tel_node_get(rq->roc_nix);
> + if (!node)
> + return -1;
> +
> + node->rqs[rq->qid] = rq;
> + node->n_rq++;
> + return 0;
> +}
> +
> +int
> +nix_tel_node_add_cq(struct roc_nix_cq *cq) {
> + struct nix_tel_node *node;
> +
> + node = nix_tel_node_get(cq->roc_nix);
> + if (!node)
> + return -1;
> +
> + node->cqs[cq->qid] = cq;
> + node->n_cq++;
> + return 0;
> +}
> +
> +int
> +nix_tel_node_add_sq(struct roc_nix_sq *sq) {
> + struct nix_tel_node *node;
> +
> + node = nix_tel_node_get(sq->roc_nix);
> + if (!node)
> + return -1;
> +
> + node->sqs[sq->qid] = sq;
> + node->n_sq++;
> + return 0;
> +}
> +
> +static int
> +cnxk_tel_nix(struct roc_nix *roc_nix, struct plt_tel_data *d) {
> + struct nix *nix = roc_nix_to_nix_priv(roc_nix);
> +
> + struct dev *dev = &nix->dev;
> +
> + plt_tel_data_add_dict_ptr(d, "nix", nix);
> + plt_tel_data_add_dict_int(d, "pf_func", dev->pf_func);
> + plt_tel_data_add_dict_int(d, "pf", dev_get_pf(dev->pf_func));
> + plt_tel_data_add_dict_int(d, "vf", dev_get_vf(dev->pf_func));
> +
> + CNXK_TEL_DICT_PTR(d, dev, bar2);
> + CNXK_TEL_DICT_PTR(d, dev, bar4);
> + CNXK_TEL_DICT_INT(d, roc_nix, port_id);
> + CNXK_TEL_DICT_INT(d, roc_nix, rss_tag_as_xor);
> + CNXK_TEL_DICT_INT(d, roc_nix, max_sqb_count);
> + CNXK_TEL_DICT_PTR(d, nix, pci_dev);
> + CNXK_TEL_DICT_PTR(d, nix, base);
> + CNXK_TEL_DICT_PTR(d, nix, lmt_base);
> + CNXK_TEL_DICT_INT(d, nix, reta_sz);
> + CNXK_TEL_DICT_INT(d, nix, tx_chan_base);
> + CNXK_TEL_DICT_INT(d, nix, rx_chan_base);
> + CNXK_TEL_DICT_INT(d, nix, nb_tx_queues);
> + CNXK_TEL_DICT_INT(d, nix, nb_rx_queues);
> + CNXK_TEL_DICT_INT(d, nix, lso_tsov6_idx);
> + CNXK_TEL_DICT_INT(d, nix, lso_tsov4_idx);
> +
> + plt_tel_data_add_dict_int(d, "lso_udp_tun_v4v4",
> + nix-
> >lso_udp_tun_idx[ROC_NIX_LSO_TUN_V4V4]);
> + plt_tel_data_add_dict_int(d, "lso_udp_tun_v4v6",
> + nix-
> >lso_udp_tun_idx[ROC_NIX_LSO_TUN_V4V6]);
> + plt_tel_data_add_dict_int(d, "lso_udp_tun_v6v4",
> + nix-
> >lso_udp_tun_idx[ROC_NIX_LSO_TUN_V6V4]);
> + plt_tel_data_add_dict_int(d, "lso_udp_tun_v6v6",
> + nix-
> >lso_udp_tun_idx[ROC_NIX_LSO_TUN_V6V6]);
> + plt_tel_data_add_dict_int(d, "lso_tun_v4v4",
> + nix-
> >lso_tun_idx[ROC_NIX_LSO_TUN_V4V4]);
> + plt_tel_data_add_dict_int(d, "lso_tun_v4v6",
> + nix-
> >lso_tun_idx[ROC_NIX_LSO_TUN_V4V6]);
> + plt_tel_data_add_dict_int(d, "lso_tun_v6v4",
> + nix-
> >lso_tun_idx[ROC_NIX_LSO_TUN_V6V4]);
> + plt_tel_data_add_dict_int(d, "lso_tun_v6v6",
> + nix-
> >lso_tun_idx[ROC_NIX_LSO_TUN_V6V6]);
> +
> + CNXK_TEL_DICT_INT(d, nix, lf_tx_stats);
> + CNXK_TEL_DICT_INT(d, nix, lf_rx_stats);
> + CNXK_TEL_DICT_INT(d, nix, cgx_links);
> + CNXK_TEL_DICT_INT(d, nix, lbk_links);
> + CNXK_TEL_DICT_INT(d, nix, sdp_links);
> + CNXK_TEL_DICT_INT(d, nix, tx_link);
> + CNXK_TEL_DICT_INT(d, nix, sqb_size);
> + CNXK_TEL_DICT_INT(d, nix, msixoff);
> + CNXK_TEL_DICT_INT(d, nix, cints);
> + CNXK_TEL_DICT_INT(d, nix, qints);
> + CNXK_TEL_DICT_INT(d, nix, sdp_link);
> + CNXK_TEL_DICT_INT(d, nix, ptp_en);
> + CNXK_TEL_DICT_INT(d, nix, rss_alg_idx);
> + CNXK_TEL_DICT_INT(d, nix, tx_pause);
> +
> + return 0;
> +}
> +
> +static int
> +cnxk_tel_nix_rq(struct roc_nix_rq *rq, struct plt_tel_data *d) {
> + plt_tel_data_add_dict_ptr(d, "nix_rq", rq);
> + CNXK_TEL_DICT_INT(d, rq, qid);
> + CNXK_TEL_DICT_PTR(d, rq, aura_handle);
> + CNXK_TEL_DICT_INT(d, rq, ipsech_ena);
> + CNXK_TEL_DICT_INT(d, rq, first_skip);
> + CNXK_TEL_DICT_INT(d, rq, later_skip);
> + CNXK_TEL_DICT_INT(d, rq, lpb_size);
> + CNXK_TEL_DICT_INT(d, rq, sso_ena);
> + CNXK_TEL_DICT_INT(d, rq, tag_mask);
> + CNXK_TEL_DICT_INT(d, rq, flow_tag_width);
> + CNXK_TEL_DICT_INT(d, rq, tt);
> + CNXK_TEL_DICT_INT(d, rq, hwgrp);
> + CNXK_TEL_DICT_INT(d, rq, vwqe_ena);
> + CNXK_TEL_DICT_INT(d, rq, vwqe_first_skip);
> + CNXK_TEL_DICT_INT(d, rq, vwqe_max_sz_exp);
> + CNXK_TEL_DICT_INT(d, rq, vwqe_wait_tmo);
> + CNXK_TEL_DICT_INT(d, rq, vwqe_aura_handle);
> + CNXK_TEL_DICT_PTR(d, rq, roc_nix);
> +
> + return 0;
> +}
> +
> +static int
> +cnxk_tel_nix_cq(struct roc_nix_cq *cq, struct plt_tel_data *d) {
> + plt_tel_data_add_dict_ptr(d, "nix_cq", cq);
> + CNXK_TEL_DICT_INT(d, cq, qid);
> + CNXK_TEL_DICT_INT(d, cq, nb_desc);
> + CNXK_TEL_DICT_PTR(d, cq, roc_nix);
> + CNXK_TEL_DICT_PTR(d, cq, door);
> + CNXK_TEL_DICT_PTR(d, cq, status);
> + CNXK_TEL_DICT_PTR(d, cq, wdata);
> + CNXK_TEL_DICT_PTR(d, cq, desc_base);
> + CNXK_TEL_DICT_INT(d, cq, qmask);
> +
> + return 0;
> +}
> +
> +static int
> +cnxk_tel_nix_sq(struct roc_nix_sq *sq, struct plt_tel_data *d) {
> + plt_tel_data_add_dict_ptr(d, "nix_sq", sq);
> + CNXK_TEL_DICT_INT(d, sq, qid);
> + CNXK_TEL_DICT_INT(d, sq, max_sqe_sz);
> + CNXK_TEL_DICT_INT(d, sq, nb_desc);
> + CNXK_TEL_DICT_INT(d, sq, sqes_per_sqb_log2);
> + CNXK_TEL_DICT_PTR(d, sq, roc_nix);
> + CNXK_TEL_DICT_PTR(d, sq, aura_handle);
> + CNXK_TEL_DICT_INT(d, sq, nb_sqb_bufs_adj);
> + CNXK_TEL_DICT_INT(d, sq, nb_sqb_bufs);
> + CNXK_TEL_DICT_PTR(d, sq, io_addr);
> + CNXK_TEL_DICT_PTR(d, sq, lmt_addr);
> + CNXK_TEL_DICT_PTR(d, sq, sqe_mem);
> + CNXK_TEL_DICT_PTR(d, sq, fc);
> +
> + return 0;
> +}
> +
> +static void
> +nix_rq_ctx_cn9k(void *qctx, struct plt_tel_data *d) {
> + struct nix_rq_ctx_s *ctx = (struct nix_rq_ctx_s *)qctx;
> +
> + /* W0 */
> + CNXK_TEL_DICT_INT(d, ctx, wqe_aura, w0_);
> + CNXK_TEL_DICT_BF_PTR(d, ctx, substream, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, cq, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, ena_wqwd, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, ipsech_ena, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, sso_ena, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, ena, w0_);
> +
> + /* W1 */
> + CNXK_TEL_DICT_INT(d, ctx, lpb_drop_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_drop_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_drop_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, wqe_caching, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, pb_caching, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, sso_tt, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, sso_grp, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_aura, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_aura, w1_);
> +
> + /* W2 */
> + CNXK_TEL_DICT_INT(d, ctx, xqe_hdr_split, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_imm_copy, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_imm_size, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, later_skip, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, first_skip, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_sizem1, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_ena, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, wqe_skip, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_sizem1, w2_);
> +
> + /* W3 */
> + CNXK_TEL_DICT_INT(d, ctx, spb_pool_pass, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_pool_drop, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_aura_pass, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_aura_drop, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, wqe_pool_pass, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, wqe_pool_drop, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_pass, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_drop, w3_);
> +
> + /* W4 */
> + CNXK_TEL_DICT_INT(d, ctx, qint_idx, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, rq_int_ena, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, rq_int, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_pool_pass, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_pool_drop, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_aura_pass, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_aura_drop, w4_);
> +
> + /* W5 */
> + CNXK_TEL_DICT_INT(d, ctx, flow_tagw, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, bad_utag, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, good_utag, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, ltag, w5_);
> +
> + /* W6 */
> + CNXK_TEL_DICT_U64(d, ctx, octs, w6_);
> +
> + /* W7 */
> + CNXK_TEL_DICT_U64(d, ctx, pkts, w7_);
> +
> + /* W8 */
> + CNXK_TEL_DICT_U64(d, ctx, drop_octs, w8_);
> +
> + /* W9 */
> + CNXK_TEL_DICT_U64(d, ctx, drop_pkts, w9_);
> +
> + /* W10 */
> + CNXK_TEL_DICT_U64(d, ctx, re_pkts, w10_); }
> +
> +static void
> +nix_rq_ctx(void *qctx, struct plt_tel_data *d) {
> + struct nix_cn10k_rq_ctx_s *ctx = (struct nix_cn10k_rq_ctx_s *)qctx;
> +
> + /* W0 */
> + CNXK_TEL_DICT_INT(d, ctx, wqe_aura, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, len_ol3_dis, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, len_ol4_dis, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, len_il3_dis, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, len_il4_dis, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, csum_ol4_dis, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, lenerr_dis, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, ena_wqwd, w0);
> + CNXK_TEL_DICT_INT(d, ctx, ipsech_ena, w0);
> + CNXK_TEL_DICT_INT(d, ctx, sso_ena, w0);
> + CNXK_TEL_DICT_INT(d, ctx, ena, w0);
> +
> + /* W1 */
> + CNXK_TEL_DICT_INT(d, ctx, chi_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, ipsecd_drop_en, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, pb_stashing, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_drop_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_drop_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_drop_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, wqe_caching, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, pb_caching, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, sso_tt, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, sso_grp, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_aura, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_aura, w1_);
> +
> + /* W2 */
> + CNXK_TEL_DICT_INT(d, ctx, xqe_hdr_split, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_imm_copy, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_imm_size, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, later_skip, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, first_skip, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_sizem1, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_ena, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, wqe_skip, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_sizem1, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, policer_ena, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, band_prof_id, w2_);
> +
> + /* W3 */
> + CNXK_TEL_DICT_INT(d, ctx, spb_pool_pass, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_pool_drop, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_aura_pass, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, spb_aura_drop, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, wqe_pool_pass, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, wqe_pool_drop, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_pass, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, xqe_drop, w3_);
> +
> + /* W4 */
> + CNXK_TEL_DICT_INT(d, ctx, qint_idx, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, rq_int_ena, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, rq_int, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_pool_pass, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_pool_drop, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_aura_pass, w4_);
> + CNXK_TEL_DICT_INT(d, ctx, lpb_aura_drop, w4_);
> +
> + /* W5 */
> + CNXK_TEL_DICT_INT(d, ctx, vwqe_skip, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, max_vsize_exp, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, vtime_wait, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, vwqe_ena, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, ipsec_vwqe, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, flow_tagw, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, bad_utag, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, good_utag, w5_);
> + CNXK_TEL_DICT_INT(d, ctx, ltag, w5_);
> +
> + /* W6 */
> + CNXK_TEL_DICT_U64(d, ctx, octs, w6_);
> +
> + /* W7 */
> + CNXK_TEL_DICT_U64(d, ctx, pkts, w7_);
> +
> + /* W8 */
> + CNXK_TEL_DICT_U64(d, ctx, drop_octs, w8_);
> +
> + /* W9 */
> + CNXK_TEL_DICT_U64(d, ctx, drop_pkts, w9_);
> +
> + /* W10 */
> + CNXK_TEL_DICT_U64(d, ctx, re_pkts, w10_); }
> +
> +static int
> +cnxk_tel_nix_rq_ctx(struct roc_nix *roc_nix, uint8_t n, struct
> +plt_tel_data *d) {
> + struct nix *nix = roc_nix_to_nix_priv(roc_nix);
> + struct dev *dev = &nix->dev;
> + struct npa_lf *npa_lf;
> + volatile void *qctx;
> + int rc = -1;
> +
> + npa_lf = idev_npa_obj_get();
> + if (npa_lf == NULL)
> + return NPA_ERR_DEVICE_NOT_BOUNDED;
> +
> + rc = nix_q_ctx_get(dev, NIX_AQ_CTYPE_RQ, n, &qctx);
> + if (rc) {
> + plt_err("Failed to get rq context");
> + return rc;
> + }
> +
> + if (roc_model_is_cn9k())
> + nix_rq_ctx_cn9k(&qctx, d);
> + else
> + nix_rq_ctx(&qctx, d);
> +
> + return 0;
> +}
> +
> +static int
> +cnxk_tel_nix_cq_ctx(struct roc_nix *roc_nix, uint8_t n, struct
> +plt_tel_data *d) {
> + struct nix *nix = roc_nix_to_nix_priv(roc_nix);
> + struct dev *dev = &nix->dev;
> + struct npa_lf *npa_lf;
> + volatile struct nix_cq_ctx_s *ctx;
> + int rc = -1;
> +
> + npa_lf = idev_npa_obj_get();
> + if (npa_lf == NULL)
> + return NPA_ERR_DEVICE_NOT_BOUNDED;
> +
> + rc = nix_q_ctx_get(dev, NIX_AQ_CTYPE_CQ, n, (void *)&ctx);
> + if (rc) {
> + plt_err("Failed to get cq context");
> + return rc;
> + }
> +
> + /* W0 */
> + CNXK_TEL_DICT_PTR(d, ctx, base, w0_);
> +
> + /* W1 */
> + CNXK_TEL_DICT_U64(d, ctx, wrptr, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, avg_con, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, cint_idx, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, cq_err, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, qint_idx, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, bpid, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, bp_ena, w1_);
> +
> + /* W2 */
> + CNXK_TEL_DICT_INT(d, ctx, update_time, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, avg_level, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, head, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, tail, w2_);
> +
> + /* W3 */
> + CNXK_TEL_DICT_INT(d, ctx, cq_err_int_ena, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, cq_err_int, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, qsize, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, caching, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, substream, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, ena, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, drop_ena, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, drop, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, bp, w3_);
> +
> + return 0;
> +}
> +
> +static void
> +nix_sq_ctx_cn9k(void *qctx, struct plt_tel_data *d) {
> + struct nix_sq_ctx_s *ctx = (struct nix_sq_ctx_s *)qctx;
> +
> + /* W0 */
> + CNXK_TEL_DICT_INT(d, ctx, sqe_way_mask, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, cq, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, sdp_mcast, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, substream, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, qint_idx, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, ena, w0_);
> +
> + /* W1 */
> + CNXK_TEL_DICT_INT(d, ctx, sqb_count, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, default_chan, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_rr_quantum, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, sso_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, xoff, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, cq_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, smq, w1_);
> +
> + /* W2 */
> + CNXK_TEL_DICT_INT(d, ctx, sqe_stype, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, sq_int_ena, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, sq_int, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, sqb_aura, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_rr_count, w2_);
> +
> + /* W3 */
> + CNXK_TEL_DICT_INT(d, ctx, smq_next_sq_vld, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_pend, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smenq_next_sqb_vld, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, head_offset, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smenq_offset, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, tail_offset, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_lso_segnum, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_next_sq, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, mnq_dis, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, lmt_dis, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, cq_limit, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, max_sqe_size, w3_);
> +
> + /* W4 */
> + CNXK_TEL_DICT_PTR(d, ctx, next_sqb, w4_);
> +
> + /* W5 */
> + CNXK_TEL_DICT_PTR(d, ctx, tail_sqb, w5_);
> +
> + /* W6 */
> + CNXK_TEL_DICT_PTR(d, ctx, smenq_sqb, w6_);
> +
> + /* W7 */
> + CNXK_TEL_DICT_PTR(d, ctx, smenq_next_sqb, w7_);
> +
> + /* W8 */
> + CNXK_TEL_DICT_PTR(d, ctx, head_sqb, w8_);
> +
> + /* W9 */
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_vld, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_vlan1_ins_ena, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_vlan0_ins_ena, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_mps, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_sb, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_sizem1, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_total, w9_);
> +
> + /* W10 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, scm_lso_rem, w10_);
> +
> + /* W11 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, octs, w11_);
> +
> + /* W12 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, pkts, w12_);
> +
> + /* W14 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, drop_octs, w14_);
> +
> + /* W15 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, drop_pkts, w15_); }
> +
> +static void
> +nix_sq_ctx(void *qctx, struct plt_tel_data *d) {
> + struct nix_cn10k_sq_ctx_s *ctx = (struct nix_cn10k_sq_ctx_s *)qctx;
> +
> + /* W0 */
> + CNXK_TEL_DICT_INT(d, ctx, sqe_way_mask, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, cq, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, sdp_mcast, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, substream, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, qint_idx, w0_);
> + CNXK_TEL_DICT_INT(d, ctx, ena, w0_);
> +
> + /* W1 */
> + CNXK_TEL_DICT_INT(d, ctx, sqb_count, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, default_chan, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_rr_weight, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, sso_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, xoff, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, cq_ena, w1_);
> + CNXK_TEL_DICT_INT(d, ctx, smq, w1_);
> +
> + /* W2 */
> + CNXK_TEL_DICT_INT(d, ctx, sqe_stype, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, sq_int_ena, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, sq_int, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, sqb_aura, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_rr_count_ub, w2_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_rr_count_lb, w2_);
> +
> + /* W3 */
> + CNXK_TEL_DICT_INT(d, ctx, smq_next_sq_vld, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_pend, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smenq_next_sqb_vld, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, head_offset, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smenq_offset, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, tail_offset, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_lso_segnum, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, smq_next_sq, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, mnq_dis, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, lmt_dis, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, cq_limit, w3_);
> + CNXK_TEL_DICT_INT(d, ctx, max_sqe_size, w3_);
> +
> + /* W4 */
> + CNXK_TEL_DICT_PTR(d, ctx, next_sqb, w4_);
> +
> + /* W5 */
> + CNXK_TEL_DICT_PTR(d, ctx, tail_sqb, w5_);
> +
> + /* W6 */
> + CNXK_TEL_DICT_PTR(d, ctx, smenq_sqb, w6_);
> +
> + /* W7 */
> + CNXK_TEL_DICT_PTR(d, ctx, smenq_next_sqb, w7_);
> +
> + /* W8 */
> + CNXK_TEL_DICT_PTR(d, ctx, head_sqb, w8_);
> +
> + /* W9 */
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_vld, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_vlan1_ins_ena, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_vlan0_ins_ena, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_mps, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_sb, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_sizem1, w9_);
> + CNXK_TEL_DICT_INT(d, ctx, vfi_lso_total, w9_);
> +
> + /* W10 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, scm_lso_rem, w10_);
> +
> + /* W11 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, octs, w11_);
> +
> + /* W12 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, pkts, w12_);
> +
> + /* W14 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, drop_octs, w14_);
> +
> + /* W15 */
> + CNXK_TEL_DICT_BF_PTR(d, ctx, drop_pkts, w15_); }
> +
> +static int
> +cnxk_tel_nix_sq_ctx(struct roc_nix *roc_nix, uint8_t n, struct
> +plt_tel_data *d) {
> + struct nix *nix = roc_nix_to_nix_priv(roc_nix);
> + struct dev *dev = &nix->dev;
> + struct npa_lf *npa_lf;
> + volatile void *qctx;
> + int rc = -1;
> +
> + npa_lf = idev_npa_obj_get();
> + if (npa_lf == NULL)
> + return NPA_ERR_DEVICE_NOT_BOUNDED;
> +
> + rc = nix_q_ctx_get(dev, NIX_AQ_CTYPE_SQ, n, &qctx);
> + if (rc) {
> + plt_err("Failed to get rq context");
> + return rc;
> + }
> +
> + if (roc_model_is_cn9k())
> + nix_sq_ctx_cn9k(&qctx, d);
> + else
> + nix_sq_ctx(&qctx, d);
> +
> + return 0;
> +}
> +
> +static int
> +cnxk_nix_tel_handle_list(const char *cmd __plt_unused,
> + const char *params __plt_unused,
> + struct plt_tel_data *d)
> +{
> + struct nix_tel_node *node;
> + struct roc_nix *roc_nix;
> +
> + plt_tel_data_start_array(d, PLT_TEL_STRING_VAL);
> +
> + TAILQ_FOREACH(node, &nix_list, node) {
> + roc_nix = node->nix;
> + plt_tel_data_add_array_string(d, roc_nix->pci_dev->name);
> + }
> +
> + return 0;
> +}
> +
> +static int
> +cnxk_nix_tel_handle_info(const char *cmd __plt_unused, const char
> *params,
> + struct plt_tel_data *d)
> +{
> + char name[PCI_PRI_STR_SIZE];
> + struct nix_tel_node *node;
> +
> + if (params == NULL || strlen(params) == 0 || !isdigit(*params))
> + return -1;
> +
> + plt_strlcpy(name, params, PCI_PRI_STR_SIZE);
> +
> + node = nix_tel_node_get_by_pcidev_name(name);
> + if (!node)
> + return -1;
> +
> + plt_tel_data_start_dict(d);
> + return cnxk_tel_nix(node->nix, d);
> +}
> +
> +static int
> +cnxk_nix_tel_handle_info_x(const char *cmd, const char *params,
> + struct plt_tel_data *d)
> +{
> + struct nix_tel_node *node;
> + char *name, *param;
> + char buf[1024];
> + int rc = -1;
> +
> + if (params == NULL || strlen(params) == 0 || !isdigit(*params))
> + goto exit;
> +
> + plt_strlcpy(buf, params, PCI_PRI_STR_SIZE + 1);
> + name = strtok(buf, ",");
> + param = strtok(NULL, "\0");
> +
> + node = nix_tel_node_get_by_pcidev_name(name);
> + if (!node)
> + goto exit;
> +
> + plt_tel_data_start_dict(d);
> +
> + if (strstr(cmd, "rq")) {
> + char *tok = strtok(param, ",");
> + int rq;
> +
> + if (!tok)
> + goto exit;
> +
> + rq = strtol(tok, NULL, 10);
> + if ((node->n_rq <= rq) || (rq < 0))
> + goto exit;
> +
> + if (strstr(cmd, "ctx"))
> + rc = cnxk_tel_nix_rq_ctx(node->nix, rq, d);
> + else
> + rc = cnxk_tel_nix_rq(node->rqs[rq], d);
> +
> + } else if (strstr(cmd, "cq")) {
> + char *tok = strtok(param, ",");
> + int cq;
> +
> + if (!tok)
> + goto exit;
> +
> + cq = strtol(tok, NULL, 10);
> + if ((node->n_cq <= cq) || (cq < 0))
> + goto exit;
> +
> + if (strstr(cmd, "ctx"))
> + rc = cnxk_tel_nix_cq_ctx(node->nix, cq, d);
> + else
> + rc = cnxk_tel_nix_cq(node->cqs[cq], d);
> +
> + } else if (strstr(cmd, "sq")) {
> + char *tok = strtok(param, ",");
> + int sq;
> +
> + if (!tok)
> + goto exit;
> +
> + sq = strtol(tok, NULL, 10);
> + if ((node->n_sq <= sq) || (sq < 0))
> + goto exit;
> +
> + if (strstr(cmd, "ctx"))
> + rc = cnxk_tel_nix_sq_ctx(node->nix, sq, d);
> + else
> + rc = cnxk_tel_nix_sq(node->sqs[sq], d);
> + }
> +
> +exit:
> + return rc;
> +}
> +
> +PLT_INIT(cnxk_telemetry_nix_init)
> +{
> + TAILQ_INIT(&nix_list);
> +
> + plt_telemetry_register_cmd(
> + "/cnxk/nix/list", cnxk_nix_tel_handle_list,
> + "Returns list of available NIX devices. Takes no parameters");
> + plt_telemetry_register_cmd(
> + "/cnxk/nix/info", cnxk_nix_tel_handle_info,
> + "Returns nix information. Parameters: pci id");
> + plt_telemetry_register_cmd(
> + "/cnxk/nix/rq/info", cnxk_nix_tel_handle_info_x,
> + "Returns nix rq information. Parameters: pci id, rq id");
> + plt_telemetry_register_cmd(
> + "/cnxk/nix/rq/ctx", cnxk_nix_tel_handle_info_x,
> + "Returns nix rq context. Parameters: pci id, rq id");
> + plt_telemetry_register_cmd(
> + "/cnxk/nix/cq/info", cnxk_nix_tel_handle_info_x,
> + "Returns nix cq information. Parameters: pci id, cq id");
> + plt_telemetry_register_cmd(
> + "/cnxk/nix/cq/ctx", cnxk_nix_tel_handle_info_x,
> + "Returns nix cq context. Parameters: pci id, cq id");
> + plt_telemetry_register_cmd(
> + "/cnxk/nix/sq/info", cnxk_nix_tel_handle_info_x,
> + "Returns nix sq information. Parameters: pci id, sq id");
> + plt_telemetry_register_cmd(
> + "/cnxk/nix/sq/ctx", cnxk_nix_tel_handle_info_x,
> + "Returns nix sq context. Parameters: pci id, sq id"); }
> diff --git a/drivers/common/cnxk/meson.build
> b/drivers/common/cnxk/meson.build index f0a1c9f115..fe7a95b526 100644
> --- a/drivers/common/cnxk/meson.build
> +++ b/drivers/common/cnxk/meson.build
> @@ -65,6 +65,7 @@ sources = files(
> sources += files('cnxk_security.c')
>
> # Telemetry common code
> -sources += files('cnxk_telemetry_npa.c')
> +sources += files('cnxk_telemetry_npa.c',
> + 'cnxk_telemetry_nix.c')
>
> deps += ['bus_pci', 'net', 'telemetry'] diff --git
> a/drivers/common/cnxk/roc_nix.c b/drivers/common/cnxk/roc_nix.c index
> 3ab954e94d..17beb1a736 100644
> --- a/drivers/common/cnxk/roc_nix.c
> +++ b/drivers/common/cnxk/roc_nix.c
> @@ -178,6 +178,8 @@ roc_nix_lf_alloc(struct roc_nix *roc_nix, uint32_t
> nb_rxq, uint32_t nb_txq,
> nix->sqs = plt_zmalloc(sizeof(struct roc_nix_sq *) * nb_txq, 0);
> if (!nix->sqs)
> return -ENOMEM;
> +
> + nix_tel_node_add(roc_nix);
> fail:
> return rc;
> }
> @@ -413,6 +415,7 @@ roc_nix_dev_init(struct roc_nix *roc_nix)
> dev_fini:
> rc |= dev_fini(dev, pci_dev);
> fail:
> + nix_tel_node_del(roc_nix);
> return rc;
> }
>
> diff --git a/drivers/common/cnxk/roc_nix_priv.h
> b/drivers/common/cnxk/roc_nix_priv.h
> index 2cd5a72347..ba639791ce 100644
> --- a/drivers/common/cnxk/roc_nix_priv.h
> +++ b/drivers/common/cnxk/roc_nix_priv.h
> @@ -424,4 +424,13 @@ int nix_lf_int_reg_dump(uintptr_t nix_lf_base,
> uint64_t *data, uint16_t qints, int nix_q_ctx_get(struct dev *dev, uint8_t
> ctype, uint16_t qid,
> __io void **ctx_p);
>
> +/*
> + * Telemetry
> + */
> +int nix_tel_node_add(struct roc_nix *roc_nix); void
> +nix_tel_node_del(struct roc_nix *roc_nix); int
> +nix_tel_node_add_rq(struct roc_nix_rq *rq); int
> +nix_tel_node_add_cq(struct roc_nix_cq *cq); int
> +nix_tel_node_add_sq(struct roc_nix_sq *sq);
> +
> #endif /* _ROC_NIX_PRIV_H_ */
> diff --git a/drivers/common/cnxk/roc_nix_queue.c
> b/drivers/common/cnxk/roc_nix_queue.c
> index 8fbb13ecbd..f546fc83c5 100644
> --- a/drivers/common/cnxk/roc_nix_queue.c
> +++ b/drivers/common/cnxk/roc_nix_queue.c
> @@ -387,7 +387,11 @@ roc_nix_rq_init(struct roc_nix *roc_nix, struct
> roc_nix_rq *rq, bool ena)
> if (rc)
> return rc;
>
> - return mbox_process(mbox);
> + rc = mbox_process(mbox);
> + if (rc)
> + return rc;
> +
> + return nix_tel_node_add_rq(rq);
> }
>
> int
> @@ -415,7 +419,11 @@ roc_nix_rq_modify(struct roc_nix *roc_nix, struct
> roc_nix_rq *rq, bool ena)
> if (rc)
> return rc;
>
> - return mbox_process(mbox);
> + rc = mbox_process(mbox);
> + if (rc)
> + return rc;
> +
> + return nix_tel_node_add_rq(rq);
> }
>
> int
> @@ -504,7 +512,7 @@ roc_nix_cq_init(struct roc_nix *roc_nix, struct
> roc_nix_cq *cq)
> if (rc)
> goto free_mem;
>
> - return 0;
> + return nix_tel_node_add_cq(cq);
>
> free_mem:
> plt_free(cq->desc_base);
> @@ -884,6 +892,7 @@ roc_nix_sq_init(struct roc_nix *roc_nix, struct
> roc_nix_sq *sq)
> ((qid & RVU_CN9K_LMT_SLOT_MASK)
> << 12));
> }
>
> + rc = nix_tel_node_add_sq(sq);
> return rc;
> nomem:
> plt_free(sq->fc);
> diff --git a/drivers/common/cnxk/roc_platform.h
> b/drivers/common/cnxk/roc_platform.h
> index 57073d62aa..b95af115f7 100644
> --- a/drivers/common/cnxk/roc_platform.h
> +++ b/drivers/common/cnxk/roc_platform.h
> @@ -145,7 +145,10 @@
>
> #define plt_strlcpy rte_strlcpy
>
> +#define PLT_TEL_STRING_VAL RTE_TEL_STRING_VAL
> #define plt_tel_data rte_tel_data
> +#define plt_tel_data_start_array rte_tel_data_start_array
> +#define plt_tel_data_add_array_string rte_tel_data_add_array_string
> #define plt_tel_data_start_dict rte_tel_data_start_dict
> #define plt_tel_data_add_dict_int rte_tel_data_add_dict_int
> #define plt_tel_data_add_dict_ptr(d, n, v) \
> --
> 2.25.1
next prev parent reply other threads:[~2021-10-14 16:37 UTC|newest]
Thread overview: 121+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-07-29 15:25 [dpdk-dev] [v1, 0/3] common/cnxk: enable npa telemetry Gowrishankar Muthukrishnan
2021-07-29 15:25 ` [dpdk-dev] [v1, 1/3] telemetry: enable storing pointer value Gowrishankar Muthukrishnan
2021-07-29 15:48 ` Bruce Richardson
2021-07-30 12:08 ` [dpdk-dev] [EXT] " Gowrishankar Muthukrishnan
2021-08-01 17:40 ` Gowrishankar Muthukrishnan
2021-07-29 15:25 ` [dpdk-dev] [v1, 2/3] test/telemetry: add unit tests for " Gowrishankar Muthukrishnan
2021-07-29 15:25 ` [dpdk-dev] [v1, 3/3] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-08-01 17:37 ` [dpdk-dev] [v2, 0/3] common/cnxk: enable npa telemetry Gowrishankar Muthukrishnan
2021-08-01 17:37 ` [dpdk-dev] [v2, 1/3] telemetry: enable storing pointer value Gowrishankar Muthukrishnan
2021-08-01 17:37 ` [dpdk-dev] [v2, 2/3] test/telemetry: add unit tests for " Gowrishankar Muthukrishnan
2021-08-01 17:37 ` [dpdk-dev] [v2, 3/3] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-08-03 8:05 ` [dpdk-dev] [v3, 0/3] common/cnxk: enable npa telemetry Gowrishankar Muthukrishnan
2021-08-03 8:05 ` [dpdk-dev] [v3, 1/3] telemetry: enable storing pointer value Gowrishankar Muthukrishnan
2021-08-03 8:05 ` [dpdk-dev] [v3, 2/3] test/telemetry: add unit tests for " Gowrishankar Muthukrishnan
2021-08-03 8:05 ` [dpdk-dev] [v3, 3/3] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-08-11 15:59 ` [dpdk-dev] [v3, 0/3] common/cnxk: enable npa telemetry Power, Ciara
2021-08-11 16:18 ` Gowrishankar Muthukrishnan
2021-08-24 8:53 ` Gowrishankar Muthukrishnan
2021-08-25 10:09 ` Thomas Monjalon
2021-08-25 14:38 ` [dpdk-dev] [EXT] " Gowrishankar Muthukrishnan
2021-08-26 17:15 ` [dpdk-dev] [v4, 0/2] cnxk: enable npa and mempool telemetry Gowrishankar Muthukrishnan
2021-08-26 17:15 ` [dpdk-dev] [v4, 1/2] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-08-26 18:06 ` Bruce Richardson
2021-08-27 6:43 ` [dpdk-dev] [EXT] " Gowrishankar Muthukrishnan
2021-08-26 17:15 ` [dpdk-dev] [v4, 2/2] mempool/cnxk: add telemetry end points Gowrishankar Muthukrishnan
2021-08-27 6:41 ` [dpdk-dev] [v5, 0/2] cnxk: enable npa and mempool telemetry Gowrishankar Muthukrishnan
2021-08-27 6:41 ` [dpdk-dev] [v5, 1/2] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-08-27 6:41 ` [dpdk-dev] [v5, 2/2] mempool/cnxk: add telemetry end points Gowrishankar Muthukrishnan
2021-09-04 3:25 ` [dpdk-dev] [v6, 0/4] cnxk: enable telemetry endpoints Gowrishankar Muthukrishnan
2021-09-04 3:25 ` [dpdk-dev] [v6, 1/4] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-09-04 3:25 ` [dpdk-dev] [v6, 2/4] mempool/cnxk: add telemetry end points Gowrishankar Muthukrishnan
2021-09-04 3:25 ` [dpdk-dev] [v6, 3/4] common/cnxk: add telemetry endpoints to nix Gowrishankar Muthukrishnan
2021-09-04 3:25 ` [dpdk-dev] [v6, 4/4] net/cnxk: add telemetry endpoing to ethdev Gowrishankar Muthukrishnan
2021-09-08 17:03 ` [dpdk-dev] [v7, 0/6] cnxk: enable telemetry endpoints Gowrishankar Muthukrishnan
2021-09-08 17:03 ` [dpdk-dev] [v7, 1/6] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-09-08 17:03 ` [dpdk-dev] [v7, 2/6] mempool/cnxk: add telemetry end points Gowrishankar Muthukrishnan
2021-09-08 17:03 ` [dpdk-dev] [v7, 3/6] common/cnxk: add telemetry endpoints to nix Gowrishankar Muthukrishnan
2021-09-08 17:03 ` [dpdk-dev] [v7, 4/6] net/cnxk: add telemetry endpoing to ethdev Gowrishankar Muthukrishnan
2021-09-08 17:03 ` [dpdk-dev] [v7, 5/6] telemetry: fix json output buffer size Gowrishankar Muthukrishnan
2021-09-21 11:02 ` [dpdk-dev] [v2] " Gowrishankar Muthukrishnan
2021-09-22 9:21 ` Power, Ciara
2021-09-23 5:53 ` Gowrishankar Muthukrishnan
2021-09-30 8:47 ` Power, Ciara
2021-09-30 9:00 ` Gowrishankar Muthukrishnan
2021-10-07 9:04 ` Power, Ciara
2021-09-23 6:21 ` [dpdk-dev] [v3] " Gowrishankar Muthukrishnan
2021-09-23 6:26 ` [dpdk-dev] [v4] " Gowrishankar Muthukrishnan
2021-09-29 4:18 ` [dpdk-dev] [v5] " Gowrishankar Muthukrishnan
2021-10-06 17:38 ` Thomas Monjalon
2021-10-07 4:58 ` [dpdk-dev] [EXT] " Gowrishankar Muthukrishnan
2021-10-07 7:22 ` Thomas Monjalon
2021-10-07 8:36 ` Gowrishankar Muthukrishnan
2021-10-11 10:54 ` [dpdk-dev] [v6] telemetry: remove limitation on JSON output buffer length Gowrishankar Muthukrishnan
2021-10-13 11:06 ` Power, Ciara
2021-10-13 15:25 ` Thomas Monjalon
2021-09-08 17:03 ` [dpdk-dev] [v7, 6/6] crypto/cnxk: add telemetry endpoints to cryptodev Gowrishankar Muthukrishnan
2021-09-21 11:32 ` [dpdk-dev] [v2] " Gowrishankar Muthukrishnan
2021-09-29 6:45 ` [dpdk-dev] [v1] cryptodev: add telemetry endpoint for cryptodev info Gowrishankar Muthukrishnan
2021-10-22 12:28 ` [dpdk-dev] [v2] cryptodev: add telemetry endpoint for cryptodev capabilities Gowrishankar Muthukrishnan
2021-10-22 12:37 ` [dpdk-dev] [v5] crypto/cnxk: add telemetry endpoints to cryptodev Gowrishankar Muthukrishnan
2021-10-22 12:59 ` [dpdk-dev] [v6] " Gowrishankar Muthukrishnan
2021-10-22 12:57 ` [dpdk-dev] [v3] cryptodev: add telemetry endpoint for cryptodev capabilities Gowrishankar Muthukrishnan
2021-10-22 16:02 ` [dpdk-dev] [v7] crypto/cnxk: add telemetry endpoints to cryptodev Gowrishankar Muthukrishnan
2021-10-26 13:44 ` [dpdk-dev] [v8] " Gowrishankar Muthukrishnan
2021-10-26 14:10 ` Akhil Goyal
2021-11-03 4:43 ` Gowrishankar Muthukrishnan
2021-10-30 17:41 ` [dpdk-dev] [v9] " Gowrishankar Muthukrishnan
2021-10-30 17:45 ` [dpdk-dev] [v1] security: add telemetry endpoint for cryptodev security capabilities Gowrishankar Muthukrishnan
2021-10-31 5:24 ` [dpdk-dev] [v2] " Gowrishankar Muthukrishnan
2021-11-02 14:42 ` [dpdk-dev] [v3] " Gowrishankar Muthukrishnan
2021-11-02 14:52 ` [dpdk-dev] [v4] " Gowrishankar Muthukrishnan
2021-11-03 19:37 ` Akhil Goyal
2021-11-04 4:29 ` Gowrishankar Muthukrishnan
2021-11-04 5:11 ` [dpdk-dev] [v5] " Gowrishankar Muthukrishnan
2021-11-04 10:50 ` Akhil Goyal
2021-10-25 7:26 ` [dpdk-dev] [v3] cryptodev: add telemetry endpoint for cryptodev capabilities Akhil Goyal
2021-10-26 13:13 ` [dpdk-dev] [v5] " Gowrishankar Muthukrishnan
2021-10-26 14:12 ` Akhil Goyal
2021-10-26 15:44 ` Gowrishankar Muthukrishnan
2021-10-26 18:34 ` Akhil Goyal
2021-10-26 12:52 ` [dpdk-dev] [v4] " Gowrishankar Muthukrishnan
2021-09-29 7:01 ` [dpdk-dev] [v3] crypto/cnxk: add telemetry endpoints to cryptodev Gowrishankar Muthukrishnan
2021-09-29 8:56 ` [dpdk-dev] [v4] " Gowrishankar Muthukrishnan
2021-09-16 8:52 ` [dpdk-dev] [v7, 0/6] cnxk: enable telemetry endpoints Jerin Jacob
2021-09-21 10:52 ` [dpdk-dev] [v8, 0/4] cnxk: enable telemetry endpoints for mempool and ethdev Gowrishankar Muthukrishnan
2021-09-21 10:52 ` [dpdk-dev] [v8, 1/4] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-09-21 10:52 ` [dpdk-dev] [v8, 2/4] mempool/cnxk: add telemetry end points Gowrishankar Muthukrishnan
2021-09-29 6:40 ` [dpdk-dev] [v1] mempool: add telemetry endpoint for mempool info Gowrishankar Muthukrishnan
2021-10-13 15:21 ` Thomas Monjalon
2021-10-13 15:26 ` Bruce Richardson
2021-10-13 15:40 ` Bruce Richardson
2021-10-22 3:28 ` [dpdk-dev] [v2] " Gowrishankar Muthukrishnan
2021-10-22 5:55 ` David Marchand
2021-10-22 16:11 ` [dpdk-dev] [v3] " Gowrishankar Muthukrishnan
2021-10-22 20:38 ` Thomas Monjalon
2021-09-21 10:52 ` [dpdk-dev] [v8, 3/4] common/cnxk: add telemetry endpoints to nix Gowrishankar Muthukrishnan
2021-09-21 10:52 ` [dpdk-dev] [v8, 4/4] net/cnxk: add telemetry endpoing to ethdev Gowrishankar Muthukrishnan
2021-09-21 11:27 ` Jerin Jacob
2021-09-21 11:53 ` Bruce Richardson
2021-09-21 12:16 ` Olivier Matz
2021-09-29 4:25 ` [dpdk-dev] [v1] ethdev: add telemetry endpoint for device info Gowrishankar Muthukrishnan
2021-10-11 14:40 ` Ferruh Yigit
2021-10-11 15:40 ` Bruce Richardson
2021-10-11 15:44 ` Ferruh Yigit
2021-10-14 21:47 ` Ferruh Yigit
2021-09-29 6:54 ` [dpdk-dev] [v9 0/4] cnxk: enable telemetry endpoints Gowrishankar Muthukrishnan
2021-09-29 6:55 ` [dpdk-dev] [v9 1/4] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-10-14 15:22 ` [dpdk-dev] [EXT] " Harman Kalra
2021-09-29 6:55 ` [dpdk-dev] [v9 2/4] common/cnxk: add telemetry endpoints to nix Gowrishankar Muthukrishnan
2021-10-14 16:37 ` Harman Kalra [this message]
2021-09-29 6:55 ` [dpdk-dev] [v9 3/4] mempool/cnxk: add telemetry endpoints mempool Gowrishankar Muthukrishnan
2021-10-14 16:43 ` [dpdk-dev] [EXT] " Harman Kalra
2021-09-29 6:55 ` [dpdk-dev] [v9 4/4] net/cnxk: add telemetry endpoints to ethdev Gowrishankar Muthukrishnan
2021-10-14 16:47 ` [dpdk-dev] [EXT] " Harman Kalra
2021-10-19 11:27 ` [dpdk-dev] [v10 0/4] cnxk: enable telemetry endpoints Gowrishankar Muthukrishnan
2021-10-19 11:27 ` [dpdk-dev] [v10 1/4] common/cnxk: add telemetry endpoints to npa Gowrishankar Muthukrishnan
2021-10-19 11:27 ` [dpdk-dev] [v10 2/4] common/cnxk: add telemetry endpoints to nix Gowrishankar Muthukrishnan
2021-10-19 11:27 ` [dpdk-dev] [v10 3/4] mempool/cnxk: add telemetry endpoints mempool Gowrishankar Muthukrishnan
2021-10-19 11:27 ` [dpdk-dev] [v10 4/4] net/cnxk: add telemetry endpoints to ethdev Gowrishankar Muthukrishnan
2021-10-19 16:42 ` [dpdk-dev] [v9 0/4] cnxk: enable telemetry endpoints Jerin Jacob
2021-10-20 13:30 ` Ferruh Yigit
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=BN9PR18MB4204E68BCD5457921AB3BD4AC5B89@BN9PR18MB4204.namprd18.prod.outlook.com \
--to=hkalra@marvell.com \
--cc=asekhar@marvell.com \
--cc=dev@dpdk.org \
--cc=gmuthukrishn@marvell.com \
--cc=jerinj@marvell.com \
--cc=kirankumark@marvell.com \
--cc=ndabilpuram@marvell.com \
--cc=pbhagavatula@marvell.com \
--cc=skori@marvell.com \
--cc=skoteshwar@marvell.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).