提交 7c8089f9 编写于 作者: D David S. Miller

Merge branch '100GbE' of git://git.kernel.org/pub/scm/linux/kernel/git/tnguy/net-queue

Tony Nguyen says:

====================
Intel Wired LAN Driver Updates 2021-12-14

This series contains updates to ice driver only.

Karol corrects division that was causing incorrect calculations and
adds a check to ensure stale timestamps are not being used.
====================
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
...@@ -705,7 +705,7 @@ static int ice_ptp_adjfine(struct ptp_clock_info *info, long scaled_ppm) ...@@ -705,7 +705,7 @@ static int ice_ptp_adjfine(struct ptp_clock_info *info, long scaled_ppm)
scaled_ppm = -scaled_ppm; scaled_ppm = -scaled_ppm;
} }
while ((u64)scaled_ppm > div_u64(U64_MAX, incval)) { while ((u64)scaled_ppm > div64_u64(U64_MAX, incval)) {
/* handle overflow by scaling down the scaled_ppm and /* handle overflow by scaling down the scaled_ppm and
* the divisor, losing some precision * the divisor, losing some precision
*/ */
...@@ -1540,19 +1540,16 @@ static void ice_ptp_tx_tstamp_work(struct kthread_work *work) ...@@ -1540,19 +1540,16 @@ static void ice_ptp_tx_tstamp_work(struct kthread_work *work)
if (err) if (err)
continue; continue;
/* Check if the timestamp is valid */ /* Check if the timestamp is invalid or stale */
if (!(raw_tstamp & ICE_PTP_TS_VALID)) if (!(raw_tstamp & ICE_PTP_TS_VALID) ||
raw_tstamp == tx->tstamps[idx].cached_tstamp)
continue; continue;
/* clear the timestamp register, so that it won't show valid
* again when re-used.
*/
ice_clear_phy_tstamp(hw, tx->quad, phy_idx);
/* The timestamp is valid, so we'll go ahead and clear this /* The timestamp is valid, so we'll go ahead and clear this
* index and then send the timestamp up to the stack. * index and then send the timestamp up to the stack.
*/ */
spin_lock(&tx->lock); spin_lock(&tx->lock);
tx->tstamps[idx].cached_tstamp = raw_tstamp;
clear_bit(idx, tx->in_use); clear_bit(idx, tx->in_use);
skb = tx->tstamps[idx].skb; skb = tx->tstamps[idx].skb;
tx->tstamps[idx].skb = NULL; tx->tstamps[idx].skb = NULL;
......
...@@ -55,15 +55,21 @@ struct ice_perout_channel { ...@@ -55,15 +55,21 @@ struct ice_perout_channel {
* struct ice_tx_tstamp - Tracking for a single Tx timestamp * struct ice_tx_tstamp - Tracking for a single Tx timestamp
* @skb: pointer to the SKB for this timestamp request * @skb: pointer to the SKB for this timestamp request
* @start: jiffies when the timestamp was first requested * @start: jiffies when the timestamp was first requested
* @cached_tstamp: last read timestamp
* *
* This structure tracks a single timestamp request. The SKB pointer is * This structure tracks a single timestamp request. The SKB pointer is
* provided when initiating a request. The start time is used to ensure that * provided when initiating a request. The start time is used to ensure that
* we discard old requests that were not fulfilled within a 2 second time * we discard old requests that were not fulfilled within a 2 second time
* window. * window.
* Timestamp values in the PHY are read only and do not get cleared except at
* hardware reset or when a new timestamp value is captured. The cached_tstamp
* field is used to detect the case where a new timestamp has not yet been
* captured, ensuring that we avoid sending stale timestamp data to the stack.
*/ */
struct ice_tx_tstamp { struct ice_tx_tstamp {
struct sk_buff *skb; struct sk_buff *skb;
unsigned long start; unsigned long start;
u64 cached_tstamp;
}; };
/** /**
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册