scsi: lpfc: Adjust bytes received vales during cmf timer interval
authorJames Smart <jsmart2021@gmail.com>
Fri, 10 Sep 2021 23:31:55 +0000 (16:31 -0700)
committerMartin K. Petersen <martin.petersen@oracle.com>
Wed, 15 Sep 2021 03:33:21 +0000 (23:33 -0400)
The newly added congestion mgmt framework is seeing unexpected congestion
FPINs and signals.  In analysis, time values given to the adapter are not
at hard time intervals. Thus the drift vs the transfer count seen is
affecting how the framework manages things.

Adjust counters to cover the drift.

Link: https://lore.kernel.org/r/20210910233159.115896-11-jsmart2021@gmail.com
Co-developed-by: Justin Tee <justin.tee@broadcom.com>
Signed-off-by: Justin Tee <justin.tee@broadcom.com>
Signed-off-by: James Smart <jsmart2021@gmail.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/lpfc/lpfc_init.c

index 3fd730613de3ef1774aa751f29ad9fb24a1257ca..d3a2281cb48b4397b3e7b3f7f9ff27752cc4922e 100644 (file)
@@ -5876,7 +5876,7 @@ lpfc_cmf_timer(struct hrtimer *timer)
        uint32_t io_cnt;
        uint32_t head, tail;
        uint32_t busy, max_read;
-       uint64_t total, rcv, lat, mbpi;
+       uint64_t total, rcv, lat, mbpi, extra;
        int timer_interval = LPFC_CMF_INTERVAL;
        uint32_t ms;
        struct lpfc_cgn_stat *cgs;
@@ -5943,7 +5943,19 @@ lpfc_cmf_timer(struct hrtimer *timer)
            phba->hba_flag & HBA_SETUP) {
                mbpi = phba->cmf_last_sync_bw;
                phba->cmf_last_sync_bw = 0;
-               lpfc_issue_cmf_sync_wqe(phba, LPFC_CMF_INTERVAL, total);
+               extra = 0;
+
+               /* Calculate any extra bytes needed to account for the
+                * timer accuracy. If we are less than LPFC_CMF_INTERVAL
+                * add an extra 3% slop factor, equal to LPFC_CMF_INTERVAL
+                * add an extra 2%. The goal is to equalize total with a
+                * time > LPFC_CMF_INTERVAL or <= LPFC_CMF_INTERVAL + 1
+                */
+               if (ms == LPFC_CMF_INTERVAL)
+                       extra = div_u64(total, 50);
+               else if (ms < LPFC_CMF_INTERVAL)
+                       extra = div_u64(total, 33);
+               lpfc_issue_cmf_sync_wqe(phba, LPFC_CMF_INTERVAL, total + extra);
        } else {
                /* For Monitor mode or link down we want mbpi
                 * to be the full link speed