net: dp83640: Fix tx timestamp overflow handling.
PHY status frames are not reliable, the PHY may not be able to send them during heavy receive traffic. This overflow condition is signaled by the PHY in the next status frame, but the driver did not make use of it. Instead it always reported wrong tx timestamps to user space after an overflow happened because it assigned newly received tx timestamps to old packets in the queue. This commit fixes this issue by clearing the tx timestamp queue every time an overflow happens, so that no timestamps are delivered for overflow packets. This way time stamping will continue correctly after an overflow. Signed-off-by: Manfred Rudigier <manfred.rudigier@omicron.at> Acked-by: Richard Cochran <richardcochran@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		 Manfred Rudigier
					Manfred Rudigier
				
			
				
					committed by
					
						 David S. Miller
						David S. Miller
					
				
			
			
				
	
			
			
			 David S. Miller
						David S. Miller
					
				
			
						parent
						
							7c1306723e
						
					
				
				
					commit
					81e8f2e930
				
			| @@ -846,6 +846,11 @@ static void decode_rxts(struct dp83640_private *dp83640, | ||||
| 	struct skb_shared_hwtstamps *shhwtstamps = NULL; | ||||
| 	struct sk_buff *skb; | ||||
| 	unsigned long flags; | ||||
| 	u8 overflow; | ||||
|  | ||||
| 	overflow = (phy_rxts->ns_hi >> 14) & 0x3; | ||||
| 	if (overflow) | ||||
| 		pr_debug("rx timestamp queue overflow, count %d\n", overflow); | ||||
|  | ||||
| 	spin_lock_irqsave(&dp83640->rx_lock, flags); | ||||
|  | ||||
| @@ -888,6 +893,7 @@ static void decode_txts(struct dp83640_private *dp83640, | ||||
| 	struct skb_shared_hwtstamps shhwtstamps; | ||||
| 	struct sk_buff *skb; | ||||
| 	u64 ns; | ||||
| 	u8 overflow; | ||||
|  | ||||
| 	/* We must already have the skb that triggered this. */ | ||||
|  | ||||
| @@ -897,6 +903,17 @@ static void decode_txts(struct dp83640_private *dp83640, | ||||
| 		pr_debug("have timestamp but tx_queue empty\n"); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	overflow = (phy_txts->ns_hi >> 14) & 0x3; | ||||
| 	if (overflow) { | ||||
| 		pr_debug("tx timestamp queue overflow, count %d\n", overflow); | ||||
| 		while (skb) { | ||||
| 			skb_complete_tx_timestamp(skb, NULL); | ||||
| 			skb = skb_dequeue(&dp83640->tx_queue); | ||||
| 		} | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	ns = phy2txts(phy_txts); | ||||
| 	memset(&shhwtstamps, 0, sizeof(shhwtstamps)); | ||||
| 	shhwtstamps.hwtstamp = ns_to_ktime(ns); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user