From: Ciara Power Date: Tue, 29 Oct 2019 13:41:47 +0000 (+0000) Subject: raw/ioat: support xstats reset X-Git-Url: http://git.droids-corp.org/?a=commitdiff_plain;h=fe084d35cd4a589b0366eab6dfebf59a6d9979aa;p=dpdk.git raw/ioat: support xstats reset The rawdev xstats_reset function is now enabled. It is called when the ioat autotest completes, to reset all xstat values after they have been modified during testing. Signed-off-by: Ciara Power Reviewed-by: Bruce Richardson --- diff --git a/drivers/raw/ioat/ioat_rawdev.c b/drivers/raw/ioat/ioat_rawdev.c index 7270ad7aa4..af8414b34c 100644 --- a/drivers/raw/ioat/ioat_rawdev.c +++ b/drivers/raw/ioat/ioat_rawdev.c @@ -161,6 +161,43 @@ ioat_xstats_get_names(const struct rte_rawdev *dev, return RTE_DIM(xstat_names); } +static int +ioat_xstats_reset(struct rte_rawdev *dev, const uint32_t *ids, uint32_t nb_ids) +{ + struct rte_ioat_rawdev *ioat = dev->dev_private; + unsigned int i; + + if (!ids) { + ioat->enqueue_failed = 0; + ioat->enqueued = 0; + ioat->started = 0; + ioat->completed = 0; + return 0; + } + + for (i = 0; i < nb_ids; i++) { + switch (ids[i]) { + case 0: + ioat->enqueue_failed = 0; + break; + case 1: + ioat->enqueued = 0; + break; + case 2: + ioat->started = 0; + break; + case 3: + ioat->completed = 0; + break; + default: + IOAT_PMD_WARN("Invalid xstat id - cannot reset value"); + break; + } + } + + return 0; +} + extern int ioat_rawdev_test(uint16_t dev_id); static int @@ -173,6 +210,7 @@ ioat_rawdev_create(const char *name, struct rte_pci_device *dev) .dev_info_get = ioat_dev_info_get, .xstats_get = ioat_xstats_get, .xstats_get_names = ioat_xstats_get_names, + .xstats_reset = ioat_xstats_reset, .dev_selftest = ioat_rawdev_test, }; diff --git a/drivers/raw/ioat/ioat_rawdev_test.c b/drivers/raw/ioat/ioat_rawdev_test.c index e99f97ec41..c37351af2d 100644 --- a/drivers/raw/ioat/ioat_rawdev_test.c +++ b/drivers/raw/ioat/ioat_rawdev_test.c @@ -223,6 +223,11 @@ ioat_rawdev_test(uint16_t dev_id) printf("\n"); rte_rawdev_stop(dev_id); + if (rte_rawdev_xstats_reset(dev_id, NULL, 0) != 0) { + printf("Error resetting xstat values\n"); + goto err; + } + rte_mempool_free(pool); free(snames); free(stats); @@ -231,6 +236,7 @@ ioat_rawdev_test(uint16_t dev_id) err: rte_rawdev_stop(dev_id); + rte_rawdev_xstats_reset(dev_id, NULL, 0); rte_mempool_free(pool); free(snames); free(stats);