Add debugfs entries to expose hardware configuration and diagnostic
information that aids in debugging driver initialization and runtime
operations without adding noise to dmesg.

Device-level entries (under /sys/kernel/debug/mana/<slot>/):
  - num_msix_usable, max_num_queues: Max resources from hardware
  - gdma_protocol_ver, pf_cap_flags1: VF version negotiation results
  - num_vports, bm_hostmode: Device configuration

Per-vPort entries (under /sys/kernel/debug/mana/<slot>/vportN/):
  - port_handle: Hardware vPort handle
  - max_sq, max_rq: Max queues from vPort config
  - indir_table_sz: Indirection table size
  - steer_rx, steer_rss, steer_update_tab, steer_cqe_coalescing:
    Last applied steering configuration parameters

Signed-off-by: Erni Sri Satya Vennela <[email protected]>
---
Changes in v2:
* Add debugfs_remove_recursice for gc>mana_pci_debugfs in
  mana_gd_suspend to handle multiple duplicates creation in
  mana_gd_setup and mana_gd_resume path.
* Move debugfs creation for num_vports and bm_hostmode out of
  if(!resuming) condition since we have to create it again even for
  resume.
* Recreate mana_pci_debugfs in mana_gd_resume.
---
 .../net/ethernet/microsoft/mana/gdma_main.c   | 21 +++++++++++++
 drivers/net/ethernet/microsoft/mana/mana_en.c | 31 +++++++++++++++++++
 include/net/mana/gdma.h                       |  1 +
 include/net/mana/mana.h                       |  8 +++++
 4 files changed, 61 insertions(+)

diff --git a/drivers/net/ethernet/microsoft/mana/gdma_main.c 
b/drivers/net/ethernet/microsoft/mana/gdma_main.c
index aef8612b73cb..43fb366dc183 100644
--- a/drivers/net/ethernet/microsoft/mana/gdma_main.c
+++ b/drivers/net/ethernet/microsoft/mana/gdma_main.c
@@ -152,6 +152,11 @@ static int mana_gd_query_max_resources(struct pci_dev 
*pdev)
        if (gc->max_num_queues > gc->num_msix_usable - 1)
                gc->max_num_queues = gc->num_msix_usable - 1;
 
+       debugfs_create_u32("num_msix_usable", 0400, gc->mana_pci_debugfs,
+                          &gc->num_msix_usable);
+       debugfs_create_u32("max_num_queues", 0400, gc->mana_pci_debugfs,
+                          &gc->max_num_queues);
+
        return 0;
 }
 
@@ -1222,6 +1227,13 @@ int mana_gd_verify_vf_version(struct pci_dev *pdev)
                return err ? err : -EPROTO;
        }
        gc->pf_cap_flags1 = resp.pf_cap_flags1;
+       gc->gdma_protocol_ver = resp.gdma_protocol_ver;
+
+       debugfs_create_x64("gdma_protocol_ver", 0400, gc->mana_pci_debugfs,
+                          &gc->gdma_protocol_ver);
+       debugfs_create_x64("pf_cap_flags1", 0400, gc->mana_pci_debugfs,
+                          &gc->pf_cap_flags1);
+
        if (resp.pf_cap_flags1 & GDMA_DRV_CAP_FLAG_1_HWC_TIMEOUT_RECONFIG) {
                err = mana_gd_query_hwc_timeout(pdev, &hwc->hwc_timeout);
                if (err) {
@@ -2128,6 +2140,9 @@ int mana_gd_suspend(struct pci_dev *pdev, pm_message_t 
state)
 
        mana_gd_cleanup(pdev);
 
+       debugfs_remove_recursive(gc->mana_pci_debugfs);
+       gc->mana_pci_debugfs = NULL;
+
        return 0;
 }
 
@@ -2140,6 +2155,12 @@ int mana_gd_resume(struct pci_dev *pdev)
        struct gdma_context *gc = pci_get_drvdata(pdev);
        int err;
 
+       if (gc->is_pf)
+               gc->mana_pci_debugfs = debugfs_create_dir("0", 
mana_debugfs_root);
+       else
+               gc->mana_pci_debugfs = 
debugfs_create_dir(pci_slot_name(pdev->slot),
+                                                         mana_debugfs_root);
+
        err = mana_gd_setup(pdev);
        if (err)
                return err;
diff --git a/drivers/net/ethernet/microsoft/mana/mana_en.c 
b/drivers/net/ethernet/microsoft/mana/mana_en.c
index ea71de39f996..1117ae16b065 100644
--- a/drivers/net/ethernet/microsoft/mana/mana_en.c
+++ b/drivers/net/ethernet/microsoft/mana/mana_en.c
@@ -1263,6 +1263,9 @@ static int mana_query_vport_cfg(struct mana_port_context 
*apc, u32 vport_index,
        apc->port_handle = resp.vport;
        ether_addr_copy(apc->mac_addr, resp.mac_addr);
 
+       apc->vport_max_sq = *max_sq;
+       apc->vport_max_rq = *max_rq;
+
        return 0;
 }
 
@@ -1409,6 +1412,11 @@ static int mana_cfg_vport_steering(struct 
mana_port_context *apc,
 
        netdev_info(ndev, "Configured steering vPort %llu entries %u\n",
                    apc->port_handle, apc->indir_table_sz);
+
+       apc->steer_rx = rx;
+       apc->steer_rss = apc->rss_state;
+       apc->steer_update_tab = update_tab;
+       apc->steer_cqe_coalescing = req->cqe_coalescing_enable;
 out:
        kfree(req);
        return err;
@@ -3110,6 +3118,24 @@ static int mana_init_port(struct net_device *ndev)
        eth_hw_addr_set(ndev, apc->mac_addr);
        sprintf(vport, "vport%d", port_idx);
        apc->mana_port_debugfs = debugfs_create_dir(vport, 
gc->mana_pci_debugfs);
+
+       debugfs_create_u64("port_handle", 0400, apc->mana_port_debugfs,
+                          &apc->port_handle);
+       debugfs_create_u32("max_sq", 0400, apc->mana_port_debugfs,
+                          &apc->vport_max_sq);
+       debugfs_create_u32("max_rq", 0400, apc->mana_port_debugfs,
+                          &apc->vport_max_rq);
+       debugfs_create_u32("indir_table_sz", 0400, apc->mana_port_debugfs,
+                          &apc->indir_table_sz);
+       debugfs_create_u32("steer_rx", 0400, apc->mana_port_debugfs,
+                          &apc->steer_rx);
+       debugfs_create_u32("steer_rss", 0400, apc->mana_port_debugfs,
+                          &apc->steer_rss);
+       debugfs_create_u32("steer_update_tab", 0400, apc->mana_port_debugfs,
+                          &apc->steer_update_tab);
+       debugfs_create_u32("steer_cqe_coalescing", 0400, apc->mana_port_debugfs,
+                          &apc->steer_cqe_coalescing);
+
        return 0;
 
 reset_apc:
@@ -3598,6 +3624,11 @@ int mana_probe(struct gdma_dev *gd, bool resuming)
 
        ac->bm_hostmode = bm_hostmode;
 
+       debugfs_create_u16("num_vports", 0400, gc->mana_pci_debugfs,
+                          &ac->num_ports);
+       debugfs_create_u8("bm_hostmode", 0400, gc->mana_pci_debugfs,
+                         &ac->bm_hostmode);
+
        if (!resuming) {
                ac->num_ports = num_ports;
 
diff --git a/include/net/mana/gdma.h b/include/net/mana/gdma.h
index ec17004b10c0..917945f0e3dc 100644
--- a/include/net/mana/gdma.h
+++ b/include/net/mana/gdma.h
@@ -440,6 +440,7 @@ struct gdma_context {
        struct gdma_dev         mana_ib;
 
        u64 pf_cap_flags1;
+       u64 gdma_protocol_ver;
 
        struct workqueue_struct *service_wq;
 
diff --git a/include/net/mana/mana.h b/include/net/mana/mana.h
index a078af283bdd..83f6de67c0cc 100644
--- a/include/net/mana/mana.h
+++ b/include/net/mana/mana.h
@@ -563,6 +563,14 @@ struct mana_port_context {
 
        /* Debugfs */
        struct dentry *mana_port_debugfs;
+
+       /* Cached vport/steering config for debugfs */
+       u32 vport_max_sq;
+       u32 vport_max_rq;
+       u32 steer_rx;
+       u32 steer_rss;
+       u32 steer_update_tab;
+       u32 steer_cqe_coalescing;
 };
 
 netdev_tx_t mana_start_xmit(struct sk_buff *skb, struct net_device *ndev);
-- 
2.34.1


Reply via email to