From mboxrd@z Thu Jan 1 00:00:00 1970 From: Gagandeep Singh Subject: [PATCH v5 12/15] crypto/caam_jr: add statistics ops Date: Mon, 22 Oct 2018 14:57:48 +0000 Message-ID: <20181022145644.29277-13-g.singh@nxp.com> References: <20181022141657.4727-1-g.singh@nxp.com> <20181022145644.29277-1-g.singh@nxp.com> Mime-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable Cc: Hemant Agrawal , Gagandeep Singh To: "dev@dpdk.org" , Akhil Goyal Return-path: Received: from EUR02-VE1-obe.outbound.protection.outlook.com (mail-eopbgr20051.outbound.protection.outlook.com [40.107.2.51]) by dpdk.org (Postfix) with ESMTP id C8C7B1B419 for ; Mon, 22 Oct 2018 16:57:50 +0200 (CEST) In-Reply-To: <20181022145644.29277-1-g.singh@nxp.com> Content-Language: en-US List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" From: Hemant Agrawal This patch adds the following statistics operations: - stats_get - stats_reset Signed-off-by: Gagandeep Singh Signed-off-by: Hemant Agrawal Acked-by: Akhil Goyal --- drivers/crypto/caam_jr/caam_jr.c | 54 ++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/drivers/crypto/caam_jr/caam_jr.c b/drivers/crypto/caam_jr/caam= _jr.c index 0d3a49145..c89d76dab 100644 --- a/drivers/crypto/caam_jr/caam_jr.c +++ b/drivers/crypto/caam_jr/caam_jr.c @@ -103,6 +103,58 @@ caam_jr_alloc_ctx(struct caam_jr_session *ses) return ctx; } =20 +static +void caam_jr_stats_get(struct rte_cryptodev *dev, + struct rte_cryptodev_stats *stats) +{ + struct caam_jr_qp **qp =3D (struct caam_jr_qp **) + dev->data->queue_pairs; + int i; + + PMD_INIT_FUNC_TRACE(); + if (stats =3D=3D NULL) { + CAAM_JR_ERR("Invalid stats ptr NULL"); + return; + } + for (i =3D 0; i < dev->data->nb_queue_pairs; i++) { + if (qp[i] =3D=3D NULL) { + CAAM_JR_WARN("Uninitialised queue pair"); + continue; + } + + stats->enqueued_count +=3D qp[i]->tx_pkts; + stats->dequeued_count +=3D qp[i]->rx_pkts; + stats->enqueue_err_count +=3D qp[i]->tx_errs; + stats->dequeue_err_count +=3D qp[i]->rx_errs; + CAAM_JR_INFO("extra stats:\n\tRX Poll ERR =3D %" PRIu64 + "\n\tTX Ring Full =3D %" PRIu64, + qp[i]->rx_poll_err, + qp[i]->tx_ring_full); + } +} + +static +void caam_jr_stats_reset(struct rte_cryptodev *dev) +{ + int i; + struct caam_jr_qp **qp =3D (struct caam_jr_qp **) + (dev->data->queue_pairs); + + PMD_INIT_FUNC_TRACE(); + for (i =3D 0; i < dev->data->nb_queue_pairs; i++) { + if (qp[i] =3D=3D NULL) { + CAAM_JR_WARN("Uninitialised queue pair"); + continue; + } + qp[i]->rx_pkts =3D 0; + qp[i]->rx_errs =3D 0; + qp[i]->rx_poll_err =3D 0; + qp[i]->tx_pkts =3D 0; + qp[i]->tx_errs =3D 0; + qp[i]->tx_ring_full =3D 0; + } +} + static inline int is_cipher_only(struct caam_jr_session *ses) { @@ -1695,6 +1747,8 @@ static struct rte_cryptodev_ops caam_jr_ops =3D { .dev_stop =3D caam_jr_dev_stop, .dev_close =3D caam_jr_dev_close, .dev_infos_get =3D caam_jr_dev_infos_get, + .stats_get =3D caam_jr_stats_get, + .stats_reset =3D caam_jr_stats_reset, .queue_pair_setup =3D caam_jr_queue_pair_setup, .queue_pair_release =3D caam_jr_queue_pair_release, .queue_pair_count =3D caam_jr_queue_pair_count, --=20 2.17.1