LPC55S69 USB1 HS PHY PLL initialization

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

LPC55S69 USB1 HS PHY PLL initialization

202件の閲覧回数
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 返信

157件の閲覧回数
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%E5%88%9D%E6%9C%9F%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%E3%83%89%E3%82%AD%E3%83%A5%E3%83%A1%E3%83%B3%E3%83%88%20(UM11126%E3%80%81Rev.%202.8%E3%80%81%E8%A1%A8%20850)%20%E3%81%AB%E3%81%AF%E3%80%81%E3%83%93%E3%83%83%E3%83%88%2021%20PLL_REG_ENABLE%20%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E6%AC%A1%E3%81%AE%E3%82%88%E3%81%86%E3%81%AB%E8%A8%98%E8%BC%89%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3EPLL%20%E5%87%BA%E5%8A%9B%E3%82%AF%E3%83%AD%E3%83%83%E3%82%AF%E3%81%AE%E3%82%B0%E3%83%AA%E3%83%83%E3%83%81%E3%82%92%E5%9B%9E%E9%81%BF%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%E3%80%81SW%20%E3%81%AF%3CSTRONG%3EPLL_POWER%20%E3%82%92%E8%A8%AD%E5%AE%9A%E3%81%99%E3%82%8B%2015%20us%20%E5%89%8D%E3%81%AB%3C%2FSTRONG%3E%E3%81%93%E3%81%AE%E3%83%93%E3%83%83%E3%83%88%E3%82%92%E8%A8%AD%E5%AE%9A%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CBR%20%2F%3E%3CP%3ESDKs%EF%BC%88%E3%83%90%E3%83%BC%E3%82%B8%E3%83%A7%E3%83%B325.6.0%EF%BC%89%E3%81%AE%E3%82%BD%E3%83%BC%E3%82%B9%E3%82%B3%E3%83%BC%E3%83%89%E3%82%92%E8%A6%8B%E3%82%8B%E3%81%A8fsl_clock.c%20%E3%81%AB%3A%3CBR%20%2F%3E2045%20%E2%94%82%20%2F*%20USB%20PHY%E3%82%AF%E3%83%AD%E3%83%83%E3%82%AF%E3%82%92%E6%9C%89%E5%8A%B9%E3%81%AB%E3%81%99%E3%82%8B%20*%2F%3CBR%20%2F%3E%202046%20%E2%94%82%20bool%20CLOCK_EnableUsbhs0PhyPllClock(clock_usb_phy_src_t%20src%2C%20uint32_t%20freq)%3CBR%20%2F%3E%20%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%20%26amp%3B%20~USBPHY_PLL_SIC_PLL_DIV_SEL(0x7))%20%7C%20phyPllDiv%3B%3CBR%20%2F%3E%202121%20%E2%94%82%20USBPHY-%26gt%3BPLL_SIC_SET%20%3D%20USBPHY_PLL_SIC_SET_PLL_REG_ENABLE_MASK%3B%3CBR%20%2F%3E%202122%20%E2%94%82%20USBPHY-%26gt%3BPLL_SIC_CLR%20%3D%20(1UL%20%26lt%3B%26lt%3B%2016U)%3B%20%2F%2F%20%E4%BA%88%E7%B4%84%E6%B8%88%E3%81%BF%E3%80%82%E3%83%A6%E3%83%BC%E3%82%B6%E3%83%BC%E3%81%AF%E3%81%93%E3%81%AE%E3%83%93%E3%83%83%E3%83%88%E3%82%920x0%E3%81%AB%E8%A8%AD%E5%AE%9A%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%3CBR%20%2F%3E2123%20%E2%94%82%20USBPHY-%26gt%3BPLL_SIC_SET%20%3D%20USBPHY_PLL_SIC_SET_PLL_POWER_MASK%3B%3CBR%20%2F%3E%202124%20%E2%94%82%20USBPHY-%26gt%3BPLL_SIC_SET%20%3D%20USBPHY_PLL_SIC_SET_PLL_EN_USB_CLKS_MASK%3B%3CBR%20%2F%3E%202125%20%E2%94%82%3CBR%20%2F%3E%202126%20%E2%94%82%20USBPHY-%26gt%3BCTRL_CLR%20%3D%20USBPHY_CTRL_CLR_CLKGATE_MASK%3B%3C%2FSPAN%3E%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%3CSPAN%3EPLL_REG_ENABLE%20%E3%81%AF%202121%20%E8%A1%8C%E7%9B%AE%E3%81%A7%E8%A8%AD%E5%AE%9A%E3%81%95%E3%82%8C%E3%80%81PLL_POWER%20%E3%81%AF%E3%83%A6%E3%83%BC%E3%82%B6%E3%83%BC%20%E3%83%9E%E3%83%8B%E3%83%A5%E3%82%A2%E3%83%AB%E3%81%A7%E8%A6%81%E6%B1%82%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%82%8B%2015%20%E3%83%9E%E3%82%A4%E3%82%AF%E3%83%AD%E7%A7%92%E3%81%AE%E6%99%82%E9%96%93%E9%81%85%E5%BB%B6%E3%82%92%E8%80%83%E6%85%AE%E3%81%9B%E3%81%9A%E3%81%AB%202123%20%E8%A1%8C%E7%9B%AE%E3%81%A7%E8%A8%AD%E5%AE%9A%E3%81%95%E3%82%8C%E3%81%BE%E3%81%99%E3%80%82%E3%81%93%E3%81%AE%E9%96%A2%E6%95%B0%E3%81%AFfsl_clock.c%E3%81%AB%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E6%AC%A0%E9%99%A5%E3%81%8C%E3%81%82%E3%82%8B%E3%81%AE%E3%81%A7%E3%81%97%E3%82%87%E3%81%86%E3%81%8B%E3%80%81%E3%81%9D%E3%82%8C%E3%81%A8%E3%82%82%E4%BD%95%E3%81%8B%E8%A6%8B%E8%90%BD%E3%81%A8%E3%81%97%E3%81%A6%E3%81%84%E3%82%8B%E3%81%AE%E3%81%A7%E3%81%97%E3%82%87%E3%81%86%E3%81%8B%3F%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%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%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%3EUSB%20PHY%20PLL%20%E3%82%92%E6%9C%89%E5%8A%B9%E3%81%AB%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%E3%80%81UM11126%20%E3%81%A8%20SDKs%20%E5%AE%9F%E8%A3%85%E3%81%AE%E4%B8%A1%E6%96%B9%E3%82%92%E7%A2%BA%E8%AA%8D%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%3CBR%20%2F%3EUM%20%E3%81%AB%E3%82%88%E3%82%8C%E3%81%B0%E3%80%81PLL%20%E5%87%BA%E5%8A%9B%E3%82%AF%E3%83%AD%E3%83%83%E3%82%AF%E3%81%AE%E3%82%B0%E3%83%AA%E3%83%83%E3%83%81%E3%82%92%E5%9B%9E%E9%81%BF%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%E3%80%81%E3%82%BD%E3%83%95%E3%83%88%E3%82%A6%E3%82%A7%E3%82%A2%E3%81%AF%20PLL_POWER%20%E3%82%92%E8%A8%AD%E5%AE%9A%E3%81%99%E3%82%8B%E5%B0%91%E3%81%AA%E3%81%8F%E3%81%A8%E3%82%82%2015%20%E3%83%9E%E3%82%A4%E3%82%AF%E3%83%AD%E7%A7%92%E5%89%8D%E3%81%AB%20PLL_REG_ENABLE%20%E3%83%93%E3%83%83%E3%83%88%E3%82%92%E8%A8%AD%E5%AE%9A%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%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%E3%81%97%E3%81%8B%E3%81%97%E3%80%81%E7%8F%BE%E5%9C%A8%E3%81%AESDKs%E5%AE%9F%E8%A3%85%EF%BC%88fsl_clock.c%EF%BC%89%E3%81%A7%E3%81%AF%E3%80%81PLL_REG_ENABLE%20%E3%81%A8%20PLL_POWER%20%E3%81%AF%E3%80%81%E9%96%93%E3%81%AB%E9%81%85%E5%BB%B6%E3%81%AA%E3%81%8F%E9%80%A3%E7%B6%9A%E3%81%97%E3%81%A6%E8%A8%AD%E5%AE%9A%E3%81%95%E3%82%8C%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%E4%BF%A1%E9%A0%BC%E6%80%A7%E3%81%AE%E9%AB%98%E3%81%84%E5%8B%95%E4%BD%9C%E3%82%92%E7%A2%BA%E4%BF%9D%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%E3%80%81PLL_REG_ENABLE%20%E3%81%A8%20PLL_POWER%20%E3%81%AE%E8%A8%AD%E5%AE%9A%E3%81%AE%E9%96%93%E3%81%AB%2015%20%E3%83%9E%E3%82%A4%E3%82%AF%E3%83%AD%E7%A7%92%E3%81%AE%E9%81%85%E5%BB%B6%E3%82%92%E8%BF%BD%E5%8A%A0%E3%81%99%E3%82%8B%E3%81%93%E3%81%A8%E3%82%92%E3%81%8A%E5%8B%A7%E3%82%81%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%E3%81%A8%E3%82%8A%E3%81%82%E3%81%88%E3%81%9A%20SDKs%20%E3%83%81%E3%83%BC%E3%83%A0%E3%81%AB%E5%A0%B1%E5%91%8A%E3%81%97%E3%81%A6%E3%81%8A%E3%81%8D%E3%81%BE%E3%81%99%E3%80%82%E3%81%93%E3%81%AE%E5%95%8F%E9%A1%8C%E3%82%92%E3%81%94%E5%A0%B1%E5%91%8A%E3%81%84%E3%81%9F%E3%81%A0%E3%81%8DSO%E3%81%82%E3%82%8A%E3%81%8C%E3%81%A8%E3%81%86%E3%81%94%E3%81%96%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%E3%82%88%E3%82%8D%E3%81%97%E3%81%8F%E3%81%8A%E9%A1%98%E3%81%84%E3%81%84%E3%81%9F%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%E3%82%B8%E3%83%A3%E3%83%B3%E3%83%BB%E3%82%B8%E3%83%A5%E3%83%B3%3C%2FP%3E%3C%2FLINGO-BODY%3E