Commit 26b0ce8d authored by Jesse Brandeburg's avatar Jesse Brandeburg Committed by Tony Nguyen

i40e: fix PTP on 5Gb links

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: 3dbdd6c2 ("i40e: Add support for 5Gbps cards")
Cc: stable@vger.kernel.org
Reported-by: default avatarAlex Sergeev <asergeev@carbonrobotics.com>
Suggested-by: default avatarAlex Sergeev <asergeev@carbonrobotics.com>
Signed-off-by: default avatarJesse Brandeburg <jesse.brandeburg@intel.com>
Tested-by: default avatarTony Brelinski <tonyx.brelinski@intel.com>
Signed-off-by: default avatarTony Nguyen <anthony.l.nguyen@intel.com>
parent 9262793e
...@@ -11,13 +11,14 @@ ...@@ -11,13 +11,14 @@
* operate with the nanosecond field directly without fear of overflow. * operate with the nanosecond field directly without fear of overflow.
* *
* Much like the 82599, the update period is dependent upon the link speed: * 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 40Gb, 25Gb, or no link, the period is 1.6ns.
* At 10Gb link, the period is multiplied by 2. (3.2ns) * At 10Gb or 5Gb link, the period is multiplied by 2. (3.2ns)
* At 1Gb link, the period is multiplied by 20. (32ns) * At 1Gb link, the period is multiplied by 20. (32ns)
* 1588 functionality is not supported at 100Mbps. * 1588 functionality is not supported at 100Mbps.
*/ */
#define I40E_PTP_40GB_INCVAL 0x0199999999ULL #define I40E_PTP_40GB_INCVAL 0x0199999999ULL
#define I40E_PTP_10GB_INCVAL_MULT 2 #define I40E_PTP_10GB_INCVAL_MULT 2
#define I40E_PTP_5GB_INCVAL_MULT 2
#define I40E_PTP_1GB_INCVAL_MULT 20 #define I40E_PTP_1GB_INCVAL_MULT 20
#define I40E_PRTTSYN_CTL1_TSYNTYPE_V1 BIT(I40E_PRTTSYN_CTL1_TSYNTYPE_SHIFT) #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) ...@@ -465,6 +466,9 @@ void i40e_ptp_set_increment(struct i40e_pf *pf)
case I40E_LINK_SPEED_10GB: case I40E_LINK_SPEED_10GB:
mult = I40E_PTP_10GB_INCVAL_MULT; mult = I40E_PTP_10GB_INCVAL_MULT;
break; break;
case I40E_LINK_SPEED_5GB:
mult = I40E_PTP_5GB_INCVAL_MULT;
break;
case I40E_LINK_SPEED_1GB: case I40E_LINK_SPEED_1GB:
mult = I40E_PTP_1GB_INCVAL_MULT; mult = I40E_PTP_1GB_INCVAL_MULT;
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment