# TN00065 # LPC55S1x/LPC551x 无需外部晶振的全速 USB 设备解决方案 版本 1.0 — 2020 年 3 月 17 日 技术笔记 目录 介绍......1 描述......1 MCU 内部时钟 FRO 的校准库.....1 头文件......1 源代码的修改......1 LPC55S16 EVK 开发板......2 1 2 2.1 2.2 2.3 2.4 # 1 介绍 LPC55(S)1x 产品系列具有一个全速 USB2.0 主从接口,通过软件的手段我们可以实现全速 USB 设备模式下无需外部晶振,这样做的好处是可以降低产品的成本。 为了实现无需外部晶振的全速 USB 设备操作,NXP 提供了基于软件的解决方案,该方案利用全速 USB 每 1 mS 发送的开始帧(SOF)来同步内部 FRO 时 钟,提高 FRO 的时钟精度,从而使 FRO 达到全速 USB 设备操作的时钟精度要求(全速 USB 数据传输需要的时钟精度为± 0.25%)。 本技术笔记将讲解如何通过修改用户的应用软件实现无晶振的全速 USB 设备操作所需的步骤。在此技术说明之外,在MCUXpresso、Keil 和 IAR IDE 中还提供了一个 SDK 软件示例(usb\_device\_composite\_hid\_audio\_unified)。 ## 2 描述 本节描述了 LPC55S1x/LPC551x 系列如何实现无外部晶振的 USB 全速设备操作的步骤。 ## 2.1 MCU 内部时钟 FRO 的校准库 包括 FRO 校准库,可以校准 FRO 提高 FRO 的精度来满足全速 USB 通信对时钟精度的要求。 MCUXpresso、Keil、IAR的 SDK 中预编译的库为: - Keil IDE: keil\_lib\_fro\_calib\_CM33.lib - IAR IDE: iar\_lib\_fro\_calib\_CM33.a - MCUXpresso IDE: libfro\_calib\_hardabi.a, libfro\_calib\_softabi.a ### 2.2 头文件 基于 SDK 开发的全速 USB 设备的工程项目中的.c 文件, 需要包括头文件: fsl fro calib.h。 #### 2.3 源代码的修改 无论您创建项目所使用的 IDE 是什么,都需要在编译器中添加一个用于预处理的宏定义声明 "USB\_DEVICE\_FRO\_CAL\_LIBRARY\_ENABLE=1"。用户在工程的代码中全局搜索这个关键字就可以找到所有需要修改的地方。 向源代码添加以下更改。 - 1. 调用 fro\_calib\_Get\_Lib\_Ver (void)函数。这个函数读取校准库的版本并返回 0x00010000。 - 2. 用户应用程序代码必须选择 FRO 96MHz 时钟作为时钟源(值 0x3 在 USB0CLKSEL 寄存器),因为外部晶振不再需要。在本例中,I2S MCLK, 24.576MHz 使用 PLL0 时钟输出,然后将 PLL0 的输入时钟从原来的外部晶体切换到 FRO 12MHz。 更多细节请参见与时钟配置相关的 LPC55S1x/LPC551x User Manua(文档 UM11295)。 - 3. 校准库必须使用一个 32 位计时器来测量 USB 的 SOF 帧间隔时间并计算 FRO 的校准值。 注 使用 AHBCLKCTRL1 寄存器将时钟启用到 CTimer 0、CTimer1 或 CTimer2。使用 AHBCLKCTRL2 寄存器启用时 钟到 CTimer3 或 CTimer4。 - a. 使用 CTIMERCLKSEL0/1/2/3/4 寄存器,选择 96MHz 时钟作为 CTimer0/1/2/3/4 时钟源。 - b. 通过定时器外设(CTIMERO, CTIMER1, CTIMER2, CTIMER3 或 CTIMER4)和系统时钟在 KHz 的库调用 SDK, void Chip Timer Instance Freq (CTIMER Type \*base, unsigned int ctimerFreq); - c. 将定时器外设(CTIMER0 或 CTIMER1 或 CTIMER2 或 CTIMER3 或 CTIMER4)和系统时钟(KHz)的值传递给 SDK 库调用, void Chip Timer Instance Freq (CTIMER Type \*base, unsigned int ctimerFreq); - 4. 用户应用程序代码必须在 usb\_device\_lpcip3511.c 文件中启用 INTEN 寄存器的 FRAME\_INT\_EN: 用户必须要在 usb\_device\_lpcip3511.c 文件中注意 FRAME\_INT 的处理。 ``` #if (defined(USB_DEVICE_SOF_EVENT_ENABLE) && (USB_DEVICE_SOF_EVENT_ENABLE > 0U)) if (interruptStatus & USB_LPC3511IP_INTSTAT_FRAME_INT_MASK) { USB_DeviceLpc3511IpSofEvent(lpc3511IpState); } #endif ``` 5. 当 FRAME\_INT 出现时,用户的应用程序代码必须调用 USB\_SOF\_Event() ,不断地通过 USB 主机发来的 SOF 帧来校准 FRO。 #### 2.4 LPC55S16 EVK 开发板 因为不再需要外部晶振,LPC55S16-EVK 开发板上的 16 MHz 晶体(PCB 上器件标识符 Y2),用户也可以移除 16 MHz 晶体的匹配电容可以删除电容器(PCB 上器件标识 C463,C462),查看 LPC55S16-EVK 开发板用户手册和原理图以获取更多的细节。 How To Reach Us Home Page: nxp.com Web Support: nxp.com/support **Limited warranty and liability** — Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. NXP reserves the right to make changes without further notice to any products herein. NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: nxp.com/SalesTermsandConditions. **Right to make changes** - NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof. Security — Customer understands that all NXP products may be subject to unidentified or documented vulnerabilities. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately. Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP. NXP has a Product Security Incident Response Team (PSIRT) (reachable at PSIRT@nxp.com) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products. NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX,EMBRACE, GREENCHIP, HITAG, ICODE, JCOP, LIFE, VIBES, MIFARE, MIFARE CLASSIC, MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4MOBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHMOS, UCODE, Freescale, the Freescale logo, AltiVec, CodeWarrior, ColdFire, ColdFire+, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QorlQ, QorlQ Qonverge, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, Tower, TurboLink, EdgeScale, EdgeLock, elQ, and Immersive3D are trademarks of NXP B.V. All other product or service names are the property of their respective owners. AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamIQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, μVision, Versatile are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org. M, M Mobileye and other Mobileye trademarks or logos appearing herein are trademarks of Mobileye Vision Technologies Ltd. in the United States, the EU and/or other jurisdictions. © NXP B.V. 2020-2021. All rights reserved. For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com Date of release: 2020 年 3 月 17 日 Document identifier: TN00065