LPC55S69 USB1 HS PHY PLL initialization

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

LPC55S69 USB1 HS PHY PLL initialization

207 次查看
pettel
Contributor II

The documentation (UM11126, Rev. 2.8, Table 850) says for Bit 21 PLL_REG_ENABLE:

SW must set this bit 15 us before settiing PLL_POWER to avoid glitches on PLL output clock.

 

When I look in the source code of the the SDK (Version 25.6.0) into fsl_clock.c:
2045 │ /* Enable USB PHY clock */
2046 │ bool CLOCK_EnableUsbhs0PhyPllClock(clock_usb_phy_src_t src, uint32_t freq)
....

2120 │ USBPHY->PLL_SIC = (USBPHY->PLL_SIC & ~USBPHY_PLL_SIC_PLL_DIV_SEL(0x7)) | phyPllDiv;
2121 │ USBPHY->PLL_SIC_SET = USBPHY_PLL_SIC_SET_PLL_REG_ENABLE_MASK;
2122 │ USBPHY->PLL_SIC_CLR = (1UL << 16U); // Reserved. User must set this bit to 0x0
2123 │ USBPHY->PLL_SIC_SET = USBPHY_PLL_SIC_SET_PLL_POWER_MASK;
2124 │ USBPHY->PLL_SIC_SET = USBPHY_PLL_SIC_SET_PLL_EN_USB_CLKS_MASK;
2125 │
2126 │ USBPHY->CTRL_CLR = USBPHY_CTRL_CLR_CLKGATE_MASK;

 

PLL_REG_ENABLE is set in line 2121 and PLL_POWER is set in line 2123 with no regard for the 15 us time delay required in the user manual. Is this function in fsl_clock.c flawed or am I missing something?

0 项奖励
回复
1 回复

162 次查看
ZhangJennie
NXP TechSupport
NXP TechSupport

Hi @pettel 

I have reviewed both the UM11126 and the SDK  implementation for enabling the USB PHY PLL.
According to the UM, software must set the PLL_REG_ENABLE bit at least 15 microseconds before setting PLL_POWER to avoid glitches on the PLL output clock:

ZhangJennie_0-1758513929134.png

However, in the current SDK implementation (fsl_clock.c), PLL_REG_ENABLE and PLL_POWER are set consecutively without any delay in between.

To ensure reliable operation, I suggest adding a 15-microsecond delay between setting PLL_REG_ENABLE and PLL_POWER.

I will report it to the SDK team meanwhile. Thank you so much for bringing the problem to our attention.

Best Regards

Jun Zhang

0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-2172921%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3ELPC55S69%20USB1%20HS%20PHY%20PLL%20%E5%88%9D%E5%A7%8B%E5%8C%96%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2172921%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E6%96%87%E4%BB%B6%20(UM11126%2C%20Rev.%202.8%2C%20%E8%A1%A8%20850)%20%E6%8C%87%E5%87%BA%EF%BC%8C%E4%BD%8D%2021%20PLL_REG_ENABLE%EF%BC%9A%3C%2FP%3E%3CP%3ESW%20%E5%BF%85%E9%A1%BB%3CSTRONG%3E%E5%9C%A8%E8%AE%BE%E7%BD%AE%20PLL_POWER%20%E5%89%8D%2015%3C%2FSTRONG%3E%E4%BD%8D%E8%AE%BE%E7%BD%AE%E8%AF%A5%E4%BD%8D%EF%BC%8C%E4%BB%A5%E9%81%BF%E5%85%8D%20PLL%20%E8%BE%93%E5%87%BA%E6%97%B6%E9%92%9F%E5%87%BA%E7%8E%B0%E6%AF%9B%E5%88%BA%E3%80%82%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%E5%BD%93%E6%88%91%E6%9F%A5%E7%9C%8B%20SDK%EF%BC%88%E7%89%88%E6%9C%AC%2025.6.0%EF%BC%89%E7%9A%84%E6%BA%90%E4%BB%A3%E7%A0%81%E6%97%B6%E8%BF%9B%E5%85%A5%20fsl_clock.c%EF%BC%9A%3CBR%20%2F%3E2045%20%E2%94%82%20%2F*%20%E5%90%AF%E7%94%A8%20USB%20PHY%20%E6%97%B6%E9%92%9F%20*%2F%3CBR%20%2F%3E2046%20%E2%94%82%20bool%20CLOCK_EnableUsbhs0PhyPllClock(clock_usb_phy_src_t%20src%2C%20uint32_t%20freq)%3CBR%20%2F%3E%3CSPAN%3E....%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%3CSPAN%3E2120%20%E2%94%82%20USBPHY-%26gt%3BPLL_SIC%20%3D%20(USBPHY-%26gt%3BPLL_SIC%26amp%3B%20~USBPHY_PLL_SIC_PLL_DIV_SEL(0x7))%7C%20phyPllDiv%3B%3CBR%20%2F%3E2121%20%E2%94%82%20USBPHY-%26gt%3BPLL_SIC_SET%20%3D%20USBPHY_PLL_SIC_SET_PLL_REG_ENABLE_MASK%3B%3CBR%20%2F%3E2122%20%E2%94%82%20USBPHY-%26gt%3BPLL_SIC_CLR%20%3D%20(1UL%26lt%3B%26lt%3B%2016U)%3B%20%2F%2F%20Reserved.%E7%94%A8%E6%88%B7%E5%BF%85%E9%A1%BB%E5%B0%86%E8%AF%A5%E4%BD%8D%E8%AE%BE%E7%BD%AE%E4%B8%BA%200x0%3CBR%20%2F%3E2123%20%E2%94%82%20USBPHY-%26gt%3BPLL_SIC_SET%20%3D%20USBPHY_PLL_SIC_SET_PLL_POWER_MASK%EF%BC%9B%3CBR%20%2F%3E2124%20%E2%94%82%20usbphy-%26gt%3Bpll_sic_set%20%3D%20usbphy_pll_sic_set_pll_en_usb_clks_mask%3B%3CBR%20%2F%3E2125%20%E2%94%82%3CBR%20%2F%3E2126%20%E2%94%82%20usbphy-%26gt%3Bctrl_clr%20%3D%20usbphy_ctrl_clr_clkgate_mask%EF%BC%9B%3C%2FSPAN%3E%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%3CSPAN%3E%E5%9C%A8%E7%AC%AC%202121%20%E8%A1%8C%E8%AE%BE%E7%BD%AE%20PLL_REG_ENABLE%EF%BC%8C%E5%9C%A8%E7%AC%AC%202123%20%E8%A1%8C%E8%AE%BE%E7%BD%AE%20PLL_POWER%EF%BC%8C%E4%B8%8D%E8%80%83%E8%99%91%E7%94%A8%E6%88%B7%E6%89%8B%E5%86%8C%E4%B8%AD%E8%A6%81%E6%B1%82%E7%9A%84%2015%20us%20%E6%97%B6%E5%BB%B6%E3%80%82%E8%BF%99%E4%B8%AA%E5%87%BD%E6%95%B0%E6%98%AF%E5%90%A6%E5%9C%A8%20fsl_clock.c%20%E4%B8%AD%EF%BC%9F%E6%98%AF%E6%9C%89%E7%BC%BA%E9%99%B7%E8%BF%98%E6%98%AF%E6%88%91%E9%81%97%E6%BC%8F%E4%BA%86%E4%BB%80%E4%B9%88%EF%BC%9F%3C%2FSPAN%3E%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2173232%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20LPC55S69%20USB1%20HS%20PHY%20PLL%20initialization%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2173232%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F244769%22%20target%3D%22_blank%22%3E%40pettel%3C%2FA%3E%3C%2FP%3E%0A%3CP%3E%E6%88%91%E6%9F%A5%E7%9C%8B%E4%BA%86%20UM11126%20%E5%92%8C%20SDK%20%E7%9A%84%E5%AE%9E%E7%8E%B0%E6%83%85%E5%86%B5%EF%BC%8C%E4%BB%A5%E5%90%AF%E7%94%A8%20USB%20PHY%20PLL%E3%80%82%3CBR%20%2F%3E%E6%A0%B9%E6%8D%AE%E8%8B%B1%E5%9B%BD%E7%9A%84%E8%AF%B4%E6%B3%95%EF%BC%8C%E5%9C%A8%E8%AE%BE%E7%BD%AE%20PLL_POWER%20%E4%B9%8B%E5%89%8D%EF%BC%8C%E8%BD%AF%E4%BB%B6%E5%BF%85%E9%A1%BB%E5%B0%86%20PLL_REG_ENABLE%20%E4%BD%8D%E8%AE%BE%E7%BD%AE%E4%B8%BA%E8%87%B3%E5%B0%91%2015%20%E5%BE%AE%E7%A7%92%EF%BC%8C%E4%BB%A5%E9%81%BF%E5%85%8D%20PLL%20%E8%BE%93%E5%87%BA%E6%97%B6%E9%92%9F%E5%87%BA%E7%8E%B0%E6%95%85%E9%9A%9C%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%20lia-image-align-inline%22%20image-alt%3D%22ZhangJennie_0-1758513929134.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cspan%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22ZhangJennie_0-1758513929134.png%22%20style%3D%22width%3A%20400px%3B%22%3E%3Cimg%20src%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fimage%2Fserverpage%2Fimage-id%2F357869iA2D2E338DCD01848%2Fimage-size%2Fmedium%3Fv%3Dv2%26amp%3Bpx%3D400%22%20role%3D%22button%22%20title%3D%22ZhangJennie_0-1758513929134.png%22%20alt%3D%22ZhangJennie_0-1758513929134.png%22%20%2F%3E%3C%2Fspan%3E%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%3E%E4%B8%8D%E8%BF%87%EF%BC%8C%E5%9C%A8%E5%BD%93%E5%89%8D%E7%9A%84%20SDK%20%E5%AE%9E%E7%8E%B0%E4%B8%AD%EF%BC%88fsl_clock.c%EF%BC%89%E3%80%81PLL_REG_ENABLE%20%E5%92%8C%20PLL_POWER%20%E8%BF%9E%E7%BB%AD%E8%AE%BE%E7%BD%AE%EF%BC%8C%E4%B8%AD%E9%97%B4%E6%B2%A1%E6%9C%89%E4%BB%BB%E4%BD%95%E5%BB%B6%E8%BF%9F%E3%80%82%3C%2FP%3E%0A%3CP%3E%E4%B8%BA%E4%BA%86%E7%A1%AE%E4%BF%9D%E5%8F%AF%E9%9D%A0%E8%BF%90%E8%A1%8C%EF%BC%8C%E6%88%91%E5%BB%BA%E8%AE%AE%E5%9C%A8%E8%AE%BE%E7%BD%AE%20PLL_REG_ENABLE%20%E5%92%8C%20PLL_POWER%20%E4%B9%8B%E9%97%B4%E5%A2%9E%E5%8A%A0%2015%20%E5%BE%AE%E7%A7%92%E7%9A%84%E5%BB%B6%E8%BF%9F%E3%80%82%3C%2FP%3E%0A%3CP%3E%E5%90%8C%E6%97%B6%EF%BC%8C%E6%88%91%E4%BC%9A%E5%90%91%20SDK%20%E5%9B%A2%E9%98%9F%E6%8A%A5%E5%91%8A%E3%80%82%E9%9D%9E%E5%B8%B8%E6%84%9F%E8%B0%A2%E4%BD%A0%E6%8F%90%E8%AF%B7%E6%88%91%E4%BB%AC%E6%B3%A8%E6%84%8F%E8%BF%99%E4%B8%AA%E9%97%AE%E9%A2%98%E3%80%82%3C%2FP%3E%0A%3CP%3E%E9%A1%BA%E7%A5%9D%E5%95%86%E7%A5%BA%EF%BC%81%3C%2FP%3E%0A%3CP%3E%E5%BC%A0%E4%BF%8A%3C%2FP%3E%3C%2FLINGO-BODY%3E