IB/hfi1: Add software counter for ctxt0 seq drop
authorMike Marciniszyn <mike.marciniszyn@intel.com>
Mon, 6 Jan 2020 13:42:28 +0000 (08:42 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 28 Feb 2020 15:36:03 +0000 (16:36 +0100)
[ Upstream commit 5ffd048698ea5139743acd45e8ab388a683642b8 ]

All other code paths increment some form of drop counter.

This was missed in the original implementation.

Fixes: 82c2611daaf0 ("staging/rdma/hfi1: Handle packets with invalid RHF on context 0")
Link: https://lore.kernel.org/r/20200106134228.119356.96828.stgit@awfm-01.aw.intel.com
Reviewed-by: Kaike Wan <kaike.wan@intel.com>
Signed-off-by: Mike Marciniszyn <mike.marciniszyn@intel.com>
Signed-off-by: Dennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/infiniband/hw/hfi1/chip.c
drivers/infiniband/hw/hfi1/chip.h
drivers/infiniband/hw/hfi1/driver.c
drivers/infiniband/hw/hfi1/hfi.h

index 4a0b7c00347718db316989f8c5331ff652e322d3..cb5785dda524e5c7aad967da86104870ed645aa3 100644 (file)
@@ -1686,6 +1686,14 @@ static u64 access_sw_pio_drain(const struct cntr_entry *entry,
        return dd->verbs_dev.n_piodrain;
 }
 
+static u64 access_sw_ctx0_seq_drop(const struct cntr_entry *entry,
+                                  void *context, int vl, int mode, u64 data)
+{
+       struct hfi1_devdata *dd = context;
+
+       return dd->ctx0_seq_drop;
+}
+
 static u64 access_sw_vtx_wait(const struct cntr_entry *entry,
                              void *context, int vl, int mode, u64 data)
 {
@@ -4246,6 +4254,8 @@ static struct cntr_entry dev_cntrs[DEV_CNTR_LAST] = {
                            access_sw_cpu_intr),
 [C_SW_CPU_RCV_LIM] = CNTR_ELEM("RcvLimit", 0, 0, CNTR_NORMAL,
                            access_sw_cpu_rcv_limit),
+[C_SW_CTX0_SEQ_DROP] = CNTR_ELEM("SeqDrop0", 0, 0, CNTR_NORMAL,
+                           access_sw_ctx0_seq_drop),
 [C_SW_VTX_WAIT] = CNTR_ELEM("vTxWait", 0, 0, CNTR_NORMAL,
                            access_sw_vtx_wait),
 [C_SW_PIO_WAIT] = CNTR_ELEM("PioWait", 0, 0, CNTR_NORMAL,
index 50b8645d0b876dbf6d58f56d677e3cfcc7984e55..a88ef2433cea28c1c33e85244fac2356a0104f46 100644 (file)
@@ -864,6 +864,7 @@ enum {
        C_DC_PG_STS_TX_MBE_CNT,
        C_SW_CPU_INTR,
        C_SW_CPU_RCV_LIM,
+       C_SW_CTX0_SEQ_DROP,
        C_SW_VTX_WAIT,
        C_SW_PIO_WAIT,
        C_SW_PIO_DRAIN,
index 72c836b826ca84d29fffceceea036b753d095722..7aa1aabb7a43c23eeb30f4f099f69d1c362661c1 100644 (file)
@@ -710,6 +710,7 @@ static noinline int skip_rcv_packet(struct hfi1_packet *packet, int thread)
 {
        int ret;
 
+       packet->rcd->dd->ctx0_seq_drop++;
        /* Set up for the next packet */
        packet->rhqoff += packet->rsize;
        if (packet->rhqoff >= packet->maxcnt)
index 810ef5114772ce0ce9314066df56d5f874755720..cf9bc95d80396b74803494e255a06428a4f6f584 100644 (file)
@@ -1043,6 +1043,8 @@ struct hfi1_devdata {
 
        char *boardname; /* human readable board info */
 
+       u64 ctx0_seq_drop;
+
        /* reset value */
        u64 z_int_counter;
        u64 z_rcv_limit;