# **AN1505: CP2101/2/3/4/9/2N to CP2102C Porting Guide** The CP2102C device is designed to act as a USB to UART bridge that works with the default CDC driver provided by the Operating System. This device can be used to replace existing single-interface CP210x USB-to-UART devices without installing any drivers. For some devices, such as the CP2102, CP2102N, and CP2104, the CP2102C is virtually a drop in replacement. Apart from the addition of two resistors, no other hardware changes or software are required to use the CP2102C in existing designs. For other devices, slight package or feature differences may require minor changes to hardware. This application note describes in detail the steps required to integrate a CP2102C device into a design in place of a previous CP210x device. Devices covered by this application note are: CP2101, CP2102/9, CP2103, CP2104, and CP2102N. The multiple-interface devices, such as the CP2105 and CP2108, are not discussed. #### **KEY POINTS** - The CP2102C maintains a high degree of UART feature compatibility with most existing CP210x devices. - Design will require minimal hardware changes when migrating to the CP2102C. - The CP2102C provides a migration path for: - CP2101 - · CP2102/9 - CP2103 - CP2104 - CP2102N # 1. Device Comparison # 1.1 Feature Compatibility The table below provides a full feature comparison table for all CP210x devices, including the CP2102C. In general, the CP2102C meets or exceeds the feature set of all previous CP210x devices. Table 1.1. CP210x Family Features | Feature | CP2101 | CP2102 | CP2109 | CP2103 | CP2104 | CP2102N | CP2102C | |-----------------------------|-----------|-----------|-----------|-----------|-----------|---------|----------------| | Re-programmable | Х | Х | | Х | | Х | | | One-time-programmable | | | Х | | Х | | | | UART Features | | | | | | | I | | Max Baud Rate | 921.6kbps | 921.6kbps | 921.6kbps | 921.6kbps | 921.6kbps | 3Mbps | 3Mbps | | Data Bits: 8 | Х | Х | Х | Х | Х | Х | Х | | Data Bits: 5, 6, 7 | | Х | Х | Х | Х | Х | Х | | Stop Bits: 1 | Х | Х | Х | Х | Х | Х | Х | | Stop Bits: 1.5, 2 | | Х | Х | Х | Х | Х | Х | | Parity Bit: Odd, Even, None | Х | Х | Х | Х | Х | Х | Х | | Parity Bit: Mark, Space | | Х | Х | Х | Х | Х | Х | | Hardware Handshake | Х | Х | Х | Х | Х | Х | X <sup>1</sup> | | X-ON/X-OFF Handshake | Х | Х | Х | Х | Х | Х | | | Event Character Support | Х | Х | Х | | | Х | | | Line Break Transmission | | Х | Х | | Х | Х | X <sup>2</sup> | | Baud Rate Aliasing | | Х | Х | Х | | | | | Driver Support | | | | | | | | | Virtual COM Port Driver | Х | Х | Х | Х | Х | Х | | | USBXpress Driver | Х | Х | Х | Х | Х | Х | | | Other Features | | | | | | | | | RS-232 Support | Х | Х | Х | Х | Х | Х | Х | | RS-485 Support | | | | Х | Х | Х | | | GPIOs | None | None | None | 4 | 4 | 4-7 | None | | Battery Charger Detect | | | | | | Х | | | Remote Wake-up | | | | | | Х | | | Clock Output | | | | | | Х | | # Note: - 1. Because the hardware handshake is default enabled, we recommend connecting CTS with a weak pull down resistor so that the device can still work normally if the pins are not fully connected (RTS, CTS). - 2. The CP2102C supports break signaling with an external 10 kOhm resistor between TXD and ground. # 1.2 Pin Compatibility With the exception of its VBUS pin, which must be connected to a voltage divider for proper operation, the CP2102C is largely pincompatible with most CP210x devices. Below is a table of variants of the CP2102C that can be used to replace previous CP210x devices. Table 1.2. CP2102C Replacements for CP210x Devices | CP210x Device | Pin-Compatible Replacement | |---------------|----------------------------------------------| | CP2101 | CP2102C-A01-GQFN28 | | CP2102/9 | CP2102C-A01-GQFN28 | | CP2103 | None (refer to for migration considerations) | | CP2104 | CP2102C-A01-GQFN24 | | CP2102N | CP2102C-A01-GQFN24 / CP2102C-A01-GQFN28 | As the CP2102C datasheet notes, there are two relevant restrictions on the VBUS pin voltage in self-powered and bus-powered configurations. The first is the absolute maximum voltage allowed on the VBUS pin, which is defined as VIO + 2.5 V in Absolute Maximum Ratings table. The second is the input high voltage (VIH) that is applied to VBUS when the device is connected to a bus, which is defined as VIO -0.6 V in the table of GPIO specifications. A resistor divider (or functionally-equivalent circuit) on VBUS, as shown in Figure 1.1 Bus-Powered Connection Diagram for USB Pins on page 3 and Figure 1.2 Self-Powered Connection Diagram for USB Pins on page 4 for bus- and self-powered operation, respectively, is required to meet these specifications and ensure reliable device operation. In this case, the current limitation of the resistor divider prevents high VBUS pin leakage current, even though the VIO + 2.5 V specification is not strictly met while the device is not powered. Figure 1.1. Bus-Powered Connection Diagram for USB Pins Figure 1.2. Self-Powered Connection Diagram for USB Pins # 2. Device Migration The following sections describe the migration considerations when transitioning from an existing CP210x device to a CP2102C device. #### 2.1 CP2101 to CP2102C #### **Hardware Compatibility** The CP2102C-A01-GQFN28 is pin-compatible with the CP2101 with the addition of the voltage divider circuit shown in Figure 1.1 Bus-Powered Connection Diagram for USB Pins on page 3 and Figure 1.2 Self-Powered Connection Diagram for USB Pins on page 4. ## **Software Compatibility** The CP2102C has a UART feature compatible with the CP2101. No software changes will be required when transitioning a CP2101 design to the CP2012C. #### 2.2 CP2102/9 to CP2102C #### **Hardware Compatibility** The CP2102C-A01-GQFN28 is pin compatible with the CP2102/9 with the addition of the voltage divider circuit shown in Figure 1.1 Bus-Powered Connection Diagram for USB Pins on page 3 and Figure 1.2 Self-Powered Connection Diagram for USB Pins on page 4. The CP2109 has an additional hardware requirement that the VPP pin (pin 18) should be connected to a capacitor to ground for insystem programming. This capacitor is not required on the CP2102C and can be safely omitted. # **Software Compatibility** The CP2102C is compatible with the CP2102/9 with one exception: Baud Rate Aliasing Baud Rate Aliasing is a feature that allows a device to use a pre-defined baud rate in place of a baud rate that is requested by the user. For example, a device using Baud Rate Aliasing can be programmed to use a baud rate of 45 bps whenever 300 bps is requested. Baud Rate Aliasing is not supported on the CP2102C. If Baud Rate Aliasing is used in a CP2102/9 design, the CP2102C is incompatible as a replacement. #### 2.3 CP2103 to CP2102C #### **Hardware Compatibility** The CP2102C does not have a pin-compatible variant that can replace the CP2103: - The CP2103 QFN28 package has an additional VIO pin at pin 5 which shifts the function of the previous pins on the package clockwise around the package by one pin compared to the CP2102C QFN28 package. This affects pins 1-5 and 22-28. - Unlike the CP2103, the CP2102C does not support extra functionality on pins 16-19. - · All other pins remain in the same configuration. If a separate VIO rail is required for a design, the smaller CP2102C QFN24 variant can be used. This variant has an identical functionality set as the CP2103, but in the smaller QFN24 package. Aside from this difference in pin-outs, no other hardware changes are required to migrate from the CP2103 to the CP2102C. # **Software Compatibility** The CP2102C has a UART feature compatible with the CP2103 with one exception: Baud Rate Aliasing. Baud Rate Aliasing is a feature that allows a device to use a pre-defined baud rate in place of a baud rate that is requested by the user. For example, a device using Baud Rate Aliasing can be programmed to use a baud rate of 45 bps whenever 300 bps is requested. Baud Rate Aliasing is not supported on the CP2102C. If Baud Rate Aliasing is used in a CP2103 design, the CP2102C is incompatible as a replacement. #### 2.4 CP2104 to CP2102C #### **Hardware Compatibility** The CP2102C-A01-GQFN24 is pin compatible with the CP2104 with the addition of the voltage divider circuit shown in Figure 1.1 Bus-Powered Connection Diagram for USB Pins on page 3 and Figure 1.2 Self-Powered Connection Diagram for USB Pins on page 4. No other hardware changes are required when transitioning a CP2104 design to the CP2102C. The CP2104 does require a capacitor between VPP (pin 16) and ground for in-system programming, but this pin is not connected on the CP2102C. Whether or not this capacitor is attached to this pin will have no effect on the CP2102C. ## **Software Compatibility** The CP2102C has a UART feature compatible with the CP2104. No software changes will be required when transitioning a CP2104 design to the CP2012C. # 2.5 CP2102N to CP2102C #### **Hardware Compatibility** The CP2102C-A01-GQFN24 / CP2102C-A01-GQFN28 are pin compatible with the CP2102N-A02-GQFN24 / CP2102N-A02-GQFN28 with the addition of the voltage divider circuit shown in Figure 1.1 Bus-Powered Connection Diagram for USB Pins on page 3 and Figure 1.2 Self-Powered Connection Diagram for USB Pins on page 4. No other hardware changes are required when transitioning a CP2102N design to the CP2102C. # **Software Compatibility** The CP2102C has a UART feature compatible with the CP2102N. No software changes will be required when transitioning a CP2102N design to the CP2012C. # 3. Revision History # Revision 1.0 March 2025 · Initial version. **IoT Portfolio** www.silabs.com/IoT **SW/HW** www.silabs.com/simplicity **Quality** www.silabs.com/quality **Support & Community** www.silabs.com/community #### Disclaimer Silicon Labs intends to provide customers with the latest, accurate, and in-depth documentation of all peripherals and modules available for system and software implementers using or intending to use the Silicon Labs products. Characterization data, available modules and peripherals, memory sizes and memory addresses refer to each specific device, and "Typical" parameters provided can and do vary in different applications. Application examples described herein are for illustrative purposes only. Silicon Labs reserves the right to make changes without further notice to the product information, specifications, and descriptions herein, and does not give warranties as to the accuracy or completeness of the included information. Without prior notification, Silicon Labs may update product firmware during the manufacturing process for security or reliability reasons. Such changes will not alter the specifications or the performance of the product. Silicon Labs shall have no liability for the consequences of use of the information supplied in this document. This document does not imply or expressly grant any license to design or fabricate any integrated circuits. The products are not designed or authorized to be used within any FDA Class III devices, applications for which FDA premarket approval is required or Life Support Systems without the specific written consent of Silicon Labs. A "Life Support System" is any product or system intended to support or sustain life and/or health, which, if it fails, can be reasonably expected to result in significant personal injury or death. Silicon Labs products are not designed or authorized for military applications. Silicon Labs products shall under no circumstances be used in weapons of mass destruction including (but not limited to) nuclear, biological or chemical weapons, or missiles capable of delivering such weapons. Silicon Labs disclaims all express and implied warranties and shall not be responsible or liable for any injuries or damages related to use of a Silicon Labs p #### Trademark Information Silicon Laboratories Inc.®, Silicon Laboratories®, Silicon Labs®, Silabs® and the Silicon Labs logo®, Bluegiga Logo®, EFM®, EFM32®, EFR, Ember®, Energy Micro, Energy Micro logo and combinations thereof, "the world's most energy friendly microcontrollers", Redpine Signals®, WiSeConnect, n-Link, EZLink®, EZRadio®, EZRadioPRO®, Gecko®, Gecko OS, Gecko OS, Studio, Precision32®, Simplicity Studio®, Telegesis, the Telegesis Logo®, USBXpress®, Zentri, the Zentri logo and Zentri DMS, Z-Wave®, and others are trademarks or registered trademarks of Silicon Labs. ARM, CORTEX, Cortex-M3 and THUMB are trademarks or registered trademarks of ARM Holdings. Keil is a registered trademark of ARM Limited. Wi-Fi is a registered trademark of the Wi-Fi Alliance. All other products or brand names mentioned herein are trademarks of their respective holders. Silicon Laboratories Inc. 400 West Cesar Chavez Austin, TX 78701 USA