mirror of
				git://git.yoctoproject.org/linux-yocto.git
				synced 2025-10-22 23:13:01 +02:00 
			
		
		
		
	phy: mscc: Fix when PTP clock is register and unregister
[ Upstream commit 882e57cbc7204662f6c5672d5b04336c1d790b03 ]
It looks like that every time when the interface was set down and up the
driver was creating a new ptp clock. On top of this the function
ptp_clock_unregister was never called.
Therefore fix this by calling ptp_clock_register and initialize the
mii_ts struct inside the probe function and call ptp_clock_unregister when
driver is removed.
Fixes: 7d272e63e0 ("net: phy: mscc: timestamping and PHC support")
Signed-off-by: Horatiu Vultur <horatiu.vultur@microchip.com>
Reviewed-by: Vadim Fedorenko <vadim.fedorenko@linux.dev>
Reviewed-by: Vladimir Oltean <vladimir.oltean@nxp.com>
Link: https://patch.msgid.link/20250825065543.2916334-1-horatiu.vultur@microchip.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
			
			
This commit is contained in:
		
							parent
							
								
									5680a4dd10
								
							
						
					
					
						commit
						f64abfa064
					
				|  | @ -474,6 +474,7 @@ static inline void vsc8584_config_macsec_intr(struct phy_device *phydev) | |||
| void vsc85xx_link_change_notify(struct phy_device *phydev); | ||||
| void vsc8584_config_ts_intr(struct phy_device *phydev); | ||||
| int vsc8584_ptp_init(struct phy_device *phydev); | ||||
| void vsc8584_ptp_deinit(struct phy_device *phydev); | ||||
| int vsc8584_ptp_probe_once(struct phy_device *phydev); | ||||
| int vsc8584_ptp_probe(struct phy_device *phydev); | ||||
| irqreturn_t vsc8584_handle_ts_interrupt(struct phy_device *phydev); | ||||
|  | @ -488,6 +489,9 @@ static inline int vsc8584_ptp_init(struct phy_device *phydev) | |||
| { | ||||
| 	return 0; | ||||
| } | ||||
| static inline void vsc8584_ptp_deinit(struct phy_device *phydev) | ||||
| { | ||||
| } | ||||
| static inline int vsc8584_ptp_probe_once(struct phy_device *phydev) | ||||
| { | ||||
| 	return 0; | ||||
|  |  | |||
|  | @ -2326,9 +2326,7 @@ static int vsc85xx_probe(struct phy_device *phydev) | |||
| 
 | ||||
| static void vsc85xx_remove(struct phy_device *phydev) | ||||
| { | ||||
| 	struct vsc8531_private *priv = phydev->priv; | ||||
| 
 | ||||
| 	skb_queue_purge(&priv->rx_skbs_list); | ||||
| 	vsc8584_ptp_deinit(phydev); | ||||
| } | ||||
| 
 | ||||
| /* Microsemi VSC85xx PHYs */ | ||||
|  |  | |||
|  | @ -1294,7 +1294,6 @@ static void vsc8584_set_input_clk_configured(struct phy_device *phydev) | |||
| 
 | ||||
| static int __vsc8584_init_ptp(struct phy_device *phydev) | ||||
| { | ||||
| 	struct vsc8531_private *vsc8531 = phydev->priv; | ||||
| 	static const u32 ltc_seq_e[] = { 0, 400000, 0, 0, 0 }; | ||||
| 	static const u8  ltc_seq_a[] = { 8, 6, 5, 4, 2 }; | ||||
| 	u32 val; | ||||
|  | @ -1511,17 +1510,7 @@ static int __vsc8584_init_ptp(struct phy_device *phydev) | |||
| 
 | ||||
| 	vsc85xx_ts_eth_cmp1_sig(phydev); | ||||
| 
 | ||||
| 	vsc8531->mii_ts.rxtstamp = vsc85xx_rxtstamp; | ||||
| 	vsc8531->mii_ts.txtstamp = vsc85xx_txtstamp; | ||||
| 	vsc8531->mii_ts.hwtstamp = vsc85xx_hwtstamp; | ||||
| 	vsc8531->mii_ts.ts_info  = vsc85xx_ts_info; | ||||
| 	phydev->mii_ts = &vsc8531->mii_ts; | ||||
| 
 | ||||
| 	memcpy(&vsc8531->ptp->caps, &vsc85xx_clk_caps, sizeof(vsc85xx_clk_caps)); | ||||
| 
 | ||||
| 	vsc8531->ptp->ptp_clock = ptp_clock_register(&vsc8531->ptp->caps, | ||||
| 						     &phydev->mdio.dev); | ||||
| 	return PTR_ERR_OR_ZERO(vsc8531->ptp->ptp_clock); | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| void vsc8584_config_ts_intr(struct phy_device *phydev) | ||||
|  | @ -1548,6 +1537,16 @@ int vsc8584_ptp_init(struct phy_device *phydev) | |||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| void vsc8584_ptp_deinit(struct phy_device *phydev) | ||||
| { | ||||
| 	struct vsc8531_private *vsc8531 = phydev->priv; | ||||
| 
 | ||||
| 	if (vsc8531->ptp->ptp_clock) { | ||||
| 		ptp_clock_unregister(vsc8531->ptp->ptp_clock); | ||||
| 		skb_queue_purge(&vsc8531->rx_skbs_list); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| irqreturn_t vsc8584_handle_ts_interrupt(struct phy_device *phydev) | ||||
| { | ||||
| 	struct vsc8531_private *priv = phydev->priv; | ||||
|  | @ -1605,7 +1604,16 @@ int vsc8584_ptp_probe(struct phy_device *phydev) | |||
| 
 | ||||
| 	vsc8531->ptp->phydev = phydev; | ||||
| 
 | ||||
| 	return 0; | ||||
| 	vsc8531->mii_ts.rxtstamp = vsc85xx_rxtstamp; | ||||
| 	vsc8531->mii_ts.txtstamp = vsc85xx_txtstamp; | ||||
| 	vsc8531->mii_ts.hwtstamp = vsc85xx_hwtstamp; | ||||
| 	vsc8531->mii_ts.ts_info  = vsc85xx_ts_info; | ||||
| 	phydev->mii_ts = &vsc8531->mii_ts; | ||||
| 
 | ||||
| 	memcpy(&vsc8531->ptp->caps, &vsc85xx_clk_caps, sizeof(vsc85xx_clk_caps)); | ||||
| 	vsc8531->ptp->ptp_clock = ptp_clock_register(&vsc8531->ptp->caps, | ||||
| 						     &phydev->mdio.dev); | ||||
| 	return PTR_ERR_OR_ZERO(vsc8531->ptp->ptp_clock); | ||||
| } | ||||
| 
 | ||||
| int vsc8584_ptp_probe_once(struct phy_device *phydev) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Horatiu Vultur
						Horatiu Vultur