net/cnxk: support registers dump
authorSatha Rao <skoteshwar@marvell.com>
Wed, 23 Jun 2021 04:46:52 +0000 (10:16 +0530)
committerJerin Jacob <jerinj@marvell.com>
Wed, 30 Jun 2021 00:29:15 +0000 (02:29 +0200)
With this patch implemented api to dump platform registers for
debug purposes.

Signed-off-by: Satha Rao <skoteshwar@marvell.com>
doc/guides/nics/cnxk.rst
doc/guides/nics/features/cnxk.ini
doc/guides/nics/features/cnxk_vec.ini
doc/guides/nics/features/cnxk_vf.ini
drivers/net/cnxk/cnxk_ethdev.c
drivers/net/cnxk/cnxk_ethdev.h
drivers/net/cnxk/cnxk_ethdev_ops.c

index bdf1fb1..cb2a51e 100644 (file)
@@ -32,6 +32,7 @@ Features of the CNXK Ethdev PMD are:
 - MTU update
 - Scatter-Gather IO support
 - Vector Poll mode driver
+- Debug utilities - Context dump and error interrupt support
 - Support Rx interrupt
 
 Prerequisites
index 08776e0..53187bd 100644 (file)
@@ -37,6 +37,7 @@ Stats per queue      = Y
 Extended stats       = Y
 FW version           = Y
 Module EEPROM dump   = Y
+Registers dump       = Y
 Linux                = Y
 ARMv8                = Y
 Usage doc            = Y
index bafe050..705c44c 100644 (file)
@@ -35,6 +35,7 @@ Stats per queue      = Y
 Extended stats       = Y
 FW version           = Y
 Module EEPROM dump   = Y
+Registers dump       = Y
 Linux                = Y
 ARMv8                = Y
 Usage doc            = Y
index 9d49175..00cf5c9 100644 (file)
@@ -32,6 +32,7 @@ Stats per queue      = Y
 Extended stats       = Y
 FW version           = Y
 Module EEPROM dump   = Y
+Registers dump       = Y
 Linux                = Y
 ARMv8                = Y
 Usage doc            = Y
index 26e4ddf..b76442d 100644 (file)
@@ -1227,6 +1227,7 @@ struct eth_dev_ops cnxk_eth_dev_ops = {
        .txq_info_get = cnxk_nix_txq_info_get,
        .tx_done_cleanup = cnxk_nix_tx_done_cleanup,
        .flow_ops_get = cnxk_nix_flow_ops_get,
+       .get_reg = cnxk_nix_dev_get_reg,
 };
 
 static int
index a25be8a..d51a6d7 100644 (file)
@@ -328,6 +328,10 @@ void *cnxk_nix_fastpath_lookup_mem_get(void);
 int cnxk_ethdev_parse_devargs(struct rte_devargs *devargs,
                              struct cnxk_eth_dev *dev);
 
+/* Debug */
+int cnxk_nix_dev_get_reg(struct rte_eth_dev *eth_dev,
+                        struct rte_dev_reg_info *regs);
+
 /* Inlines */
 static __rte_always_inline uint64_t
 cnxk_pktmbuf_detach(struct rte_mbuf *m)
index 228c624..c879b25 100644 (file)
@@ -697,3 +697,28 @@ cnxk_nix_tx_done_cleanup(void *txq, uint32_t free_cnt)
 
        return 0;
 }
+
+int
+cnxk_nix_dev_get_reg(struct rte_eth_dev *eth_dev, struct rte_dev_reg_info *regs)
+{
+       struct cnxk_eth_dev *dev = cnxk_eth_pmd_priv(eth_dev);
+       struct roc_nix *nix = &dev->nix;
+       uint64_t *data = regs->data;
+       int rc = -ENOTSUP;
+
+       if (data == NULL) {
+               rc = roc_nix_lf_get_reg_count(nix);
+               if (rc > 0) {
+                       regs->length = rc;
+                       regs->width = 8;
+                       rc = 0;
+               }
+               return rc;
+       }
+
+       if (!regs->length ||
+           regs->length == (uint32_t)roc_nix_lf_get_reg_count(nix))
+               return roc_nix_lf_reg_dump(nix, data);
+
+       return rc;
+}