mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	net: phy: Add driver for Motorcomm YT8531S Gigabit ethernet phy
Add driver for Motorcomm YT8531S Gigabit ethernet phy. Signed-off-by: Frank Sae <Frank.Sae@motor-comm.com>
This commit is contained in:
		
							parent
							
								
									dc5ff7443e
								
							
						
					
					
						commit
						1b45d980f4
					
				@ -1,8 +1,9 @@
 | 
				
			|||||||
// SPDX-License-Identifier: GPL-2.0+
 | 
					// SPDX-License-Identifier: GPL-2.0+
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Motorcomm 8531 PHY driver.
 | 
					 * Motorcomm YT8511/YT8531/YT8531S/YT8821 PHY driver.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * Copyright (C) 2023 StarFive Technology Co., Ltd.
 | 
					 * Copyright (C) 2023 StarFive Technology Co., Ltd.
 | 
				
			||||||
 | 
					 * Copyright (C) 2024 Motorcomm Electronic Technology Co., Ltd.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <config.h>
 | 
					#include <config.h>
 | 
				
			||||||
@ -13,6 +14,7 @@
 | 
				
			|||||||
#define PHY_ID_YT8511				0x0000010a
 | 
					#define PHY_ID_YT8511				0x0000010a
 | 
				
			||||||
#define PHY_ID_YT8531				0x4f51e91b
 | 
					#define PHY_ID_YT8531				0x4f51e91b
 | 
				
			||||||
#define PHY_ID_YT8821				0x4f51ea19
 | 
					#define PHY_ID_YT8821				0x4f51ea19
 | 
				
			||||||
 | 
					#define PHY_ID_YT8531S				0x4f51e91a
 | 
				
			||||||
#define PHY_ID_MASK				GENMASK(31, 0)
 | 
					#define PHY_ID_MASK				GENMASK(31, 0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Extended Register's Address Offset Register */
 | 
					/* Extended Register's Address Offset Register */
 | 
				
			||||||
@ -1114,6 +1116,86 @@ static int yt8821_startup(struct phy_device *phydev)
 | 
				
			|||||||
	return 0;
 | 
						return 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int yt8531s_config(struct phy_device *phydev)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct ytphy_plat_priv *priv = phydev->priv;
 | 
				
			||||||
 | 
						u16 mask, val;
 | 
				
			||||||
 | 
						int ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ret = genphy_config_aneg(phydev);
 | 
				
			||||||
 | 
						if (ret < 0)
 | 
				
			||||||
 | 
							return ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ytphy_dt_parse(phydev);
 | 
				
			||||||
 | 
						switch (priv->clk_out_frequency) {
 | 
				
			||||||
 | 
						case YTPHY_DTS_OUTPUT_CLK_DIS:
 | 
				
			||||||
 | 
							mask = YT8531_SCR_SYNCE_ENABLE;
 | 
				
			||||||
 | 
							val = 0;
 | 
				
			||||||
 | 
							break;
 | 
				
			||||||
 | 
						case YTPHY_DTS_OUTPUT_CLK_25M:
 | 
				
			||||||
 | 
							mask = YT8531_SCR_SYNCE_ENABLE | YT8531_SCR_CLK_SRC_MASK |
 | 
				
			||||||
 | 
								   YT8531_SCR_CLK_FRE_SEL_125M;
 | 
				
			||||||
 | 
							val = YT8531_SCR_SYNCE_ENABLE |
 | 
				
			||||||
 | 
								  FIELD_PREP(YT8531_SCR_CLK_SRC_MASK,
 | 
				
			||||||
 | 
									     YT8531_SCR_CLK_SRC_REF_25M);
 | 
				
			||||||
 | 
							break;
 | 
				
			||||||
 | 
						case YTPHY_DTS_OUTPUT_CLK_125M:
 | 
				
			||||||
 | 
							mask = YT8531_SCR_SYNCE_ENABLE | YT8531_SCR_CLK_SRC_MASK |
 | 
				
			||||||
 | 
								   YT8531_SCR_CLK_FRE_SEL_125M;
 | 
				
			||||||
 | 
							val = YT8531_SCR_SYNCE_ENABLE | YT8531_SCR_CLK_FRE_SEL_125M |
 | 
				
			||||||
 | 
								  FIELD_PREP(YT8531_SCR_CLK_SRC_MASK,
 | 
				
			||||||
 | 
									     YT8531_SCR_CLK_SRC_PLL_125M);
 | 
				
			||||||
 | 
							break;
 | 
				
			||||||
 | 
						default:
 | 
				
			||||||
 | 
							pr_warn("Freq err:%u\n", priv->clk_out_frequency);
 | 
				
			||||||
 | 
							return -EINVAL;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ret = ytphy_modify_ext(phydev, YTPHY_SYNCE_CFG_REG, mask,
 | 
				
			||||||
 | 
								       val);
 | 
				
			||||||
 | 
						if (ret < 0)
 | 
				
			||||||
 | 
							return ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ret = ytphy_rgmii_clk_delay_config(phydev);
 | 
				
			||||||
 | 
						if (ret < 0)
 | 
				
			||||||
 | 
							return ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (priv->flag & AUTO_SLEEP_DISABLED) {
 | 
				
			||||||
 | 
							/* disable auto sleep */
 | 
				
			||||||
 | 
							ret = ytphy_modify_ext(phydev,
 | 
				
			||||||
 | 
									       YT8531_EXTREG_SLEEP_CONTROL1_REG,
 | 
				
			||||||
 | 
									       YT8531_ESC1R_SLEEP_SW, 0);
 | 
				
			||||||
 | 
							if (ret < 0)
 | 
				
			||||||
 | 
								return ret;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (priv->flag & KEEP_PLL_ENABLED) {
 | 
				
			||||||
 | 
							/* enable RXC clock when no wire plug */
 | 
				
			||||||
 | 
							ret = ytphy_modify_ext(phydev,
 | 
				
			||||||
 | 
									       YT8531_CLOCK_GATING_REG,
 | 
				
			||||||
 | 
									       YT8531_CGR_RX_CLK_EN, 0);
 | 
				
			||||||
 | 
							if (ret < 0)
 | 
				
			||||||
 | 
								return ret;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int yt8531s_startup(struct phy_device *phydev)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						int ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ret = genphy_update_link(phydev);
 | 
				
			||||||
 | 
						if (ret)
 | 
				
			||||||
 | 
							return ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ret = yt8531_parse_status(phydev);
 | 
				
			||||||
 | 
						if (ret)
 | 
				
			||||||
 | 
							return ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
U_BOOT_PHY_DRIVER(motorcomm8511) = {
 | 
					U_BOOT_PHY_DRIVER(motorcomm8511) = {
 | 
				
			||||||
	.name          = "YT8511 Gigabit Ethernet",
 | 
						.name          = "YT8511 Gigabit Ethernet",
 | 
				
			||||||
	.uid           = PHY_ID_YT8511,
 | 
						.uid           = PHY_ID_YT8511,
 | 
				
			||||||
@ -1145,3 +1227,14 @@ U_BOOT_PHY_DRIVER(motorcomm8821) = {
 | 
				
			|||||||
	.startup	= &yt8821_startup,
 | 
						.startup	= &yt8821_startup,
 | 
				
			||||||
	.shutdown	= &genphy_shutdown,
 | 
						.shutdown	= &genphy_shutdown,
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					U_BOOT_PHY_DRIVER(motorcomm8531S) = {
 | 
				
			||||||
 | 
						.name		= "YT8531S Gigabit Ethernet Transceiver",
 | 
				
			||||||
 | 
						.uid		= PHY_ID_YT8531S,
 | 
				
			||||||
 | 
						.mask		= PHY_ID_MASK,
 | 
				
			||||||
 | 
						.features	= PHY_GBIT_FEATURES,
 | 
				
			||||||
 | 
						.probe		= &yt8531_probe,
 | 
				
			||||||
 | 
						.config		= &yt8531s_config,
 | 
				
			||||||
 | 
						.startup	= &yt8531s_startup,
 | 
				
			||||||
 | 
						.shutdown	= &genphy_shutdown,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user