]> git.baikalelectronics.ru Git - kernel.git/commitdiff
i40e: fix PTP on 5Gb links
authorJesse Brandeburg <jesse.brandeburg@intel.com>
Fri, 7 May 2021 18:56:25 +0000 (11:56 -0700)
committerTony Nguyen <anthony.l.nguyen@intel.com>
Thu, 24 Jun 2021 18:06:28 +0000 (11:06 -0700)
As reported by Alex Sergeev, the i40e driver is incrementing the PTP
clock at 40Gb speeds when linked at 5Gb. Fix this bug by making
sure that the right multiplier is selected when linked at 5Gb.

Fixes: 3dbdd6c2f70a ("i40e: Add support for 5Gbps cards")
Cc: stable@vger.kernel.org
Reported-by: Alex Sergeev <asergeev@carbonrobotics.com>
Suggested-by: Alex Sergeev <asergeev@carbonrobotics.com>
Signed-off-by: Jesse Brandeburg <jesse.brandeburg@intel.com>
Tested-by: Tony Brelinski <tonyx.brelinski@intel.com>
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
drivers/net/ethernet/intel/i40e/i40e_ptp.c

index f1f6fc3744e9caed689be3d5a965482edb87500a..7b971b205d36af493ebcaa34ed0de0877e7dafc9 100644 (file)
  * operate with the nanosecond field directly without fear of overflow.
  *
  * Much like the 82599, the update period is dependent upon the link speed:
- * At 40Gb link or no link, the period is 1.6ns.
- * At 10Gb link, the period is multiplied by 2. (3.2ns)
+ * At 40Gb, 25Gb, or no link, the period is 1.6ns.
+ * At 10Gb or 5Gb link, the period is multiplied by 2. (3.2ns)
  * At 1Gb link, the period is multiplied by 20. (32ns)
  * 1588 functionality is not supported at 100Mbps.
  */
 #define I40E_PTP_40GB_INCVAL           0x0199999999ULL
 #define I40E_PTP_10GB_INCVAL_MULT      2
+#define I40E_PTP_5GB_INCVAL_MULT       2
 #define I40E_PTP_1GB_INCVAL_MULT       20
 
 #define I40E_PRTTSYN_CTL1_TSYNTYPE_V1  BIT(I40E_PRTTSYN_CTL1_TSYNTYPE_SHIFT)
@@ -465,6 +466,9 @@ void i40e_ptp_set_increment(struct i40e_pf *pf)
        case I40E_LINK_SPEED_10GB:
                mult = I40E_PTP_10GB_INCVAL_MULT;
                break;
+       case I40E_LINK_SPEED_5GB:
+               mult = I40E_PTP_5GB_INCVAL_MULT;
+               break;
        case I40E_LINK_SPEED_1GB:
                mult = I40E_PTP_1GB_INCVAL_MULT;
                break;