

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China









# XR21B1421

# Enhanced 1-Ch Full-Speed USB HID to UART Bridge

# **General Description**

The XR21B1421 is an enhanced Universal Asynchronous Receiver and Transmitter (UART) bridge to HID class USB interface. The USB interface is fully compliant to the USB 2.0 (Full-Speed) specification with 12 Mbps USB data transfer rate. The USB interface also supports USB suspend, resume and remote wakeup operations. The USB Vendor ID, Product ID, power mode, remote wakeup support, maximum power, and numerous other settings may be programmed in the no-chip OTP memory via the USB interface using either HID reports or Exar-supplied OTP programming tools.

The XR21B1421 includes an internal oscillator and does not require an external crystal/oscillator. Any UART baud rate up to 12 Mbps may be generated with this internal clock and the fractional baud rate generator.

The UART pins for each port may also be configured as GPIO; direction, state, output driver type and input pull-up or pull-down resistors are programmed either through on chip OTP, or on the fly via memory mapped registers.

Large 512-byte TX and RX FIFOs prevent buffer overflow errors and optimize data throughput. Automatic half-duplex direction control and optional multi drop (9-bit) mode simplify both hardware and software in half-duplex RS-485 applications.

The XR21B1421 uses the native OS HID driver using HID reports. The HID reports perform a variety of functions, including device configuration, transmitting and receiving UART data, and programming of the on-chip OTP. Exar provides a .dll as an easy to use programming interface to the HID reports.

The XR21B1421 operates from a single 5V or 3.3V power supply and is available in a 24 or 28 pin QFN package. When powered with 5V input, the XR21B1421 supplies a regulated 3.3V output. The 24 pin package has a separate  $V_{IO}$  supply voltage input for the Modem / GPIO pins. The 28 pin package has  $V_{IO}$  internally tied to 3.3V.

#### **FEATURES**

- ±15kV ESD on USBD+/USBD-
- USB 2.0 Compliant, Full-Speed (12Mbps)
- Unique pre-programmed USB serial number
- Internally generated 48MHz core clock
- · Enhanced UART features
  - Baud rates up to 12 Mbps
  - Fractional Baud Rate Generator
  - 512-byte TX and 512-byte RX FIFOs
  - Auto Hardware / Software Flow Control
  - Multidrop and Half-Duplex Modes
  - Auto RS-485 Half-Duplex Control
  - Selectable GPIO or Modem I/O
- Up to 10 GPIOs
- 5V tolerant GPIO inputs
- · Suspend state GPIO configuration
- · Configurable clock output
- 24-pin or 28-pin QFN package
- Industrial -40°C to +85°C Temperature Range

#### **APPLICATIONS**

- · Portable Medical Diagnostics
- Blood Glucose Meters
- Health and Fitness Wellness Monitors
- Uninterruptible Power Supplies
- Energy Management Consoles

Ordering Information – page 50

## **Block Diagram**



# **Absolute Maximum Ratings**

Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. Exposure to any Maximum Rating condition for extended periods may affect device reliability and lifetime.

| Supply Voltage (VCC_REG)       | +5.75V        |
|--------------------------------|---------------|
| Supply Voltage (VCC, VIO)      | +4V           |
| Input Voltage (VBUS_SENSE)     | 0.3 to +5.75V |
| Input Voltage (All other pins) | 0.3 to +5.6V  |
| Junction Temperature           | 125°C         |

# **Operating Conditions**

Operating Temperature Range.....-40°C to +85°C

## **Electrical Characteristics**

Unless otherwise noted:  $T_A = -40$ °C to +85°C, VCC\_REG = 4.4V to 5.25V or 3.0V to 3.6V, VIO = 1.8V to 3.6V

| Symbol            | Parameter                          | Conditions                                                                                                 | Min          | Тур  | Max          | Units |
|-------------------|------------------------------------|------------------------------------------------------------------------------------------------------------|--------------|------|--------------|-------|
| Power             |                                    |                                                                                                            |              |      |              |       |
| I <sub>CC</sub>   | Power Supply Current               | VCC_REG = +4.4V to +5.25V                                                                                  |              | 13   | 19           | mA    |
| I <sub>SUSP</sub> | Lowpower Mode Current              |                                                                                                            |              | 0.85 | 1.25         | mA    |
| V <sub>OUT</sub>  | Regulated Output Voltage (VCC pin) | VCC_REG = +4.4V to +5.25V.  Maximum output current = 200 mA including the supply current of the XR21B1421. | 3            | 3.3  | 3.6          | V     |
| UART, USI         | B_STAT and GPIO Pins               |                                                                                                            |              | •    | •            |       |
| V <sub>IL</sub>   | Input Low Voltage                  |                                                                                                            | -0.3         |      | 0.25*<br>VIO | V     |
| V <sub>IH</sub>   | Input High Voltage                 |                                                                                                            | 0.70*<br>VIO |      | 5.5          | V     |
| V <sub>OL</sub>   | Output Low Voltage                 | IOL = 1mA, VIO = +1.6V                                                                                     |              |      | 0.3          | V     |
|                   |                                    | IOL = 4mA, VIO = +3.6V                                                                                     |              |      | 0.5          | V     |
| V <sub>OH</sub>   | Output High Voltage                | IOH = -400uA, VIO = +1.6V                                                                                  | 1.3          |      | VIO          | V     |
|                   |                                    | IOH = -1.5mA, VIO = +3.6V                                                                                  | 2.8          |      | VIO          | V     |
| I <sub>IL</sub>   | Input Low Leakage Current          | VIO = +3V to +3.6V, VCC_REG = +4.4V to<br>+5.25V, V <sub>INPUT</sub> = 0V                                  |              |      | ±10          | μΑ    |
| I <sub>IH</sub>   | Input High Leakage Current         | VIO = +3V to +3.6V, VCC_REG = +4.4V to +5.25V, V <sub>INPUT</sub> = +3.3V                                  |              |      | ±10          | μΑ    |
|                   |                                    | VIO = +3V to +3.6V, VCC_REG = +4.4V to +5.25V, V <sub>INPUT</sub> = +5.5V                                  |              |      | ±120         | μΑ    |
| C <sub>IN</sub>   | Input Pin Capacitance              |                                                                                                            |              |      | 5            | pF    |

# XR21B1421

| Symbol            | Parameter               | Conditions                                   |  | Min  | Тур | Max | Units |  |  |
|-------------------|-------------------------|----------------------------------------------|--|------|-----|-----|-------|--|--|
| USB I/O Pi        | USB I/O Pins            |                                              |  |      |     |     |       |  |  |
| V <sub>IL</sub>   | Input Low Voltage       |                                              |  | -0.3 |     | 0.8 | V     |  |  |
| V <sub>IH</sub>   | Input High Voltage      |                                              |  | 2.0  |     | 5.5 | V     |  |  |
| V <sub>OL</sub>   | Output Low Voltage      | External 15kΩ to GND on USBD+ and USBD- pins |  | 0    |     | 0.3 | V     |  |  |
| V <sub>OH</sub>   | Output High Voltage     | External 15kΩ to GND on USBD+ and USBD- pins |  | 2.8  |     | 3.6 | V     |  |  |
| V <sub>DrvZ</sub> | Driver Output Impedance |                                              |  | 28   |     | 44  | Ω     |  |  |

# **Pin Configuration**





# **Pin Assignments**

|         | 24-pin QFN     |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|---------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Pin No. | Pin Name       | Туре   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| 1       | GPIO0/CLK      | I/O    | General purpose I/O, or clock or pulse output. Defaults to GPIO input with internal pull-up. See "GET / SET_GPIO_CONFIG" on page 28 and "GET / SET_PIN_CONFIG" on page 41.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 2       | GND            | PWR    | Power supply common, ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 3       | USBD+          | I/O    | USB port differential data positive input. This pin has internal pull-up resistor compliant to USB 2.0 specification. The ESD protection on this pin is +/-15 kV HBM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 4       | USBD-          | I/O    | USB port differential data negative input. The ESD protection on this pin is +/-15 kV HBM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 5       | VIO            | PWR    | Supply voltage for the UART and GPIO signals. The voltage range for VIO is + 1.8V to + 3.6V. In QFN28 package, the VIO is internally tied to core 3.3V. If VCC_REG is powered by 5V, VCC output 3.3V may be externally connected to VIO pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 6       | VCC            | PWR    | 3.3V power to the device, or 3.3V power output from the device when 5V power is supplied to VCC_REG pin. 3.3V output power may source up to 200 mA maximum (including the device) and should be decoupled by minimum of 4.7 uF ceramic capacitor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| 7       | VCC_REG        | PWR    | 5V or 3.3V power to the device. In bus-powered mode, connect VBUS power from the USB host to this pin and to the VBUS_SENSE pin. See Figure 1. In self-powered mode, connect on board 5V or 3.3V source to this pin and VBUS from the USB host to the VBUS_SENSE pin. See Figure 2 and Figure 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| 8       | VBUS_SENSE     | I      | Must be connected to VBUS power from the USB host PC. This pin is used to disable the internal pull-up resistor on the USBD+ signal when VBUS is not present in self-powered mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| 9       | RESET#         | I/O OD | Active low open drain output. Asserted at power on or any time device is reset by either register or USB bus reset. As an input, must be asserted for at least 15 us to force a device reset. Reset pulse width input of shorter than 15 us will have unknown effects. A weak internal pull-up resistor provides noise immunity if left unconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| 10      | NC             |        | No Connect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 11      | USB_STAT1      | OD     | The USB_STAT1 output pin may be used to indicate any of three USB status conditions:  1. USB_STAT1 is asserted when the USB host asserts USB reset. 2. USB_STAT1 is asserted when the USB host PC places the XR21B1421 device into the suspend state. 3. USB_STAT1 is asserted when it is not safe to draw the amount of current requested in the Device Maximum Power field of the Configuration Descriptor. a. For a low power device (<= 1 unit load or 100 mA, bMaxPower <= 0x32), USB_STAT1 will be asserted when the USB UART is in the suspend mode. b. For a high power device (bMaxPower > 0x32), USB_STAT1 will be asserted when the USB UART is in the suspend mode or when it is not yet configured.  The assertion polarity and status condition are selectable via the PIN_CFG_STAT1 register. The USB_STAT pin will be de-asserted whenever the selected condition(s) is / are not met. The default output for this pin is active high polarity, asserted whenever the XR21B1421 is placed into a suspended state. |  |  |  |  |  |
| 12      | GPIO9/DSR#     | I/O    | General purpose I/O, or UART Data-Set-Ready input (active low). Defaults to GPIO push-pull output. See "Automatic DTR/DSR Hardware Flow Control" on page 16.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 13      | GPIO8/DTR#     | I/O    | General purpose I/O, or UART Data-Terminal-Ready push-pull output (active low). Defaults to GPIO push-pull output. See "Automatic DTR/DSR Hardware Flow Control" on page 16.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 14      | GPIO7/RI#/RWK# | I/O    | General purpose I/O, or UART Ring-Indicator input (active low) or Remote Wakeup input (active low). Defaults to GPIO input with internal pull-up.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |

|               | 24-pin QFN       |      |                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|---------------|------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Pin No.       | Pin Name         | Туре | Description                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 15            | GPIO6/CD#        | I/O  | General purpose I/O, or UART Carrier-Detect input (active low). Defaults to GPIO input with internal pull-up.                                                                                                                                                                                                                   |  |  |  |  |  |
| 16            | NC               |      | No Connect                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 17            | USB_STAT2        | OD   | This pin has the same functionality as the USB_STAT1 pin. However, the default output for this pin is active low polarity, asserted whenever the XR21B1421 is placed into a suspended state. This default may be changed via the PIN_CFG_USB_STAT2 register.                                                                    |  |  |  |  |  |
| 18            | GPIO5/RXT        | I/O  | General purpose I/O, or UART receive indicator. Defaults to receive indicator push-pull output.  When configured as receive indicator, this pin will toggle at ~10 Hz intervals while the UART is receiving data.                                                                                                               |  |  |  |  |  |
| 19            | GPIO4/TXT        | I/O  | General purpose I/O, or UART transmit indicator. Defaults to transmit indicator push-pull output. When configured as transmit indicator, this pin will toggle at ~10 Hz intervals during UART data transmission.                                                                                                                |  |  |  |  |  |
| 20            | RX               | I    | UART Receive Data.                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| 21            | TX               | 0    | UART Transmit Data.                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 22            | GPIO3/RS485      | I/O  | General purpose I/O, or auto RS-485 half-duplex enable. Defaults to active high push-pull output Auto RS-485 half-duplex enable.                                                                                                                                                                                                |  |  |  |  |  |
| 23            | GPIO2/CTS#       | I/O  | General purpose I/O, or UART Clear-to-Send input (active low). Defaults to CTS input with internal pull-up. See "Automatic RTS/CTS Hardware Flow Control" on page 15.                                                                                                                                                           |  |  |  |  |  |
| 24            | GPIO1/RTS#/RS485 | I/O  | General purpose I/O, or UART Request-to-Send output (active low) or auto. RS-485 half-duplex enable. Defaults to open drain RTS output. See "GET / SET_GPIO_CONFIG" on page 28 and "GET / SET_PIN_CONFIG" on page 41.                                                                                                           |  |  |  |  |  |
| Center<br>Pad | GND              | PWR  | The center pad on the back side of the QFN package is metallic and should be connected to GND on the PCB. The thermal pad size on the PCB should be the approximate size of this center pad and should be solder mask defined. The solder mask opening should be at least 0.0025" inwards from the edge of the PCB thermal pad. |  |  |  |  |  |

<sup>1.</sup> Pin type: I=Input, O=Push-pull Output, I/O= Input/output, PWR=Power, OD=Open Drain Output with weak internal pull-up

<sup>2.</sup> All GPIO pins as well as USB\_STAT1 and USB\_STAT2 may be configured for a variety of pin type options using the GPIO\_MODE register or by writing to the OTP using XR\_SET\_OTP.

<sup>3.</sup> All enabled pull-up and pull-down resistors are maintained during USB suspend state.

<sup>4.</sup> Pin configurations set using XR\_SET\_OTP are enabled following the next power up reset and are permanent. During USB bus reset, resistors are disabled and re-enabled after bus reset is deasserted. Pin configurations set using the GPIO\_MODE register will be lost after POR or USB bus reset.

|         |             |        | 28-pin QFN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin No. | Pin Name    | Туре   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1       | GPIO3/RS485 | I/O    | General purpose I/O, or auto RS-485 half-duplex enable. Defaults to active high push-pull output Auto RS-485 half-duplex enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2       | GPIO0/CLK   | I/O    | General purpose I/O, or clock or pulse output. Defaults to GPIO input with internal pull-up. See "GET / SET_GPIO_CONFIG" on page 28 and "GET / SET_PIN_CONFIG" on page 41.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3       | GND         | PWR    | Power supply common, ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4       | USBD+       | I/O    | USB port differential data positive input. This pin has internal pull-up resistor compliant to USB 2.0 specification. The ESD protection on this pin is +/-15 kV HBM.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5       | USBD-       | I/O    | USB port differential data negative input. The ESD protection on this pin is +/-15 kV HBM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6       | VCC         | PWR    | 3.3V power to the device, or 3.3V power output from the device when 5V power is supplied to VCC_REG pin. 3.3V output power may source up to 200 mA maximum and should be decoupled by minimum of 4.7 uF ceramic capacitor.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7       | VCC_REG     | PWR    | 5V or 3.3V power to the device. In bus-powered mode, connect VBUS power from the USB host to this pin and to the VBUS_SENSE pin. See Figure 1. In self-powered mode, connect on board 5V or 3.3V source to this pin and VBUS from the USB host to the VBUS_SENSE pin. See Figure 2 and Figure 3.                                                                                                                                                                                                                                                                                                                           |
| 8       | VBUS_SENSE  | I      | Must be connected to VBUS power from the USB host PC. This pin is used to disable the internal pull-up resistor on the USBD+ signal when VBUS is not present in self-powered mode.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9       | RESET#      | I/O OD | Active low open drain output. Asserted at power on or any time device is reset by either register or USB bus reset. As an input, must be asserted for at least 15 us to force a device reset. Reset pulse width input of shorter than 15 us will have unknown effects. A weak internal pull-up resistor provides noise immunity if left unconnected.                                                                                                                                                                                                                                                                       |
| 10      | GPIO9/DSR#  | I/O    | General purpose I/O, or UART Data-Set-Ready input (active low). Defaults to GPIO push-pull output. See "Automatic DTR/DSR Hardware Flow Control" on page 16.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11      | USB_STAT2   | OD     | This pin has the same functionality as the USB_STAT1 pin. However, the default output for this pin is active low polarity, asserted whenever the XR21B1421 is placed into a suspended state. This default may be changed via the PIN_CFG_USB_STAT2 register.                                                                                                                                                                                                                                                                                                                                                               |
| 12      | USB_STAT1   | OD     | The USB_STAT1 output pin may be used to indicate any of three USB status conditions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         |             |        | 1. USB_STAT1 is asserted when the USB host asserts USB reset. 2. USB_STAT1 is asserted when the USB host PC places the XR21B1421 device into the suspend state. 3. USB_STAT1 is asserted when it is not safe to draw the amount of current requested in the Device Maximum Power field of the Configuration Descriptor. a. For a low power device (<= 1 unit load or 100 mA, bMaxPower <= 0x32), USB_STAT1 will be asserted when the USB UART is in the suspend mode. b. For a high power device (bMaxPower > 0x32), USB_STAT1 will be asserted when the USB UART is in the suspend mode or when it is not yet configured. |
|         |             |        | The assertion polarity and status condition are selectable via the PIN_CFG_STAT1 register. The USB_STAT pin will be de-asserted whenever the selected condition(s) is / are not met. The default output for this pin is active high polarity, asserted whenever the XR21B1421 is placed into a suspended state.                                                                                                                                                                                                                                                                                                            |
| 13      | NC          |        | No Connect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 14      | NC          |        | No Connect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15      | TEST#       |        | Test mode. Must be left open or pulled high to VCC for normal operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|               | 28-pin QFN       |      |                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|---------------|------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Pin No.       | Pin Name         | Туре | Description                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 16            | GPIO8/DTR#       | I/O  | General purpose I/O, or UART Data-Terminal-Ready push-pull output (active low). Defaults to GPIO push-pull output. See "Automatic DTR/DSR Hardware Flow Control" on page 16.                                                                                                                                                    |  |  |  |  |  |
| 17            | GPIO7/RI#/RWK#   | I/O  | General purpose I/O, or UART Ring-Indicator input (active low) or Remote Wakeup input (active low). Defaults to GPIO input with internal pull-up.                                                                                                                                                                               |  |  |  |  |  |
| 18            | NC               |      | No Connect                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 19            | GPIO6/CD#        | I/O  | General purpose I/O, or UART Carrier-Detect input (active low). Defaults to GPIO input with internal pull-up.                                                                                                                                                                                                                   |  |  |  |  |  |
| 20            | NC               |      | No Connect                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 21            | NC               |      | No Connect                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 22            | NC               |      | No Connect                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| 23            | GPIO2/CTS#       | I/O  | General purpose I/O, or UART Clear-to-Send input (active low). Defaults to CTS input with internal pull-up. See "Automatic RTS/CTS Hardware Flow Control" on page 15.                                                                                                                                                           |  |  |  |  |  |
| 24            | GPIO1/RTS#/RS485 | I/O  | General purpose I/O, or UART Request-to-Send output (active low) or auto. RS-485 half-duplex enable. Defaults to open drain RTS output. See "GET / SET_GPIO_CONFIG" on page 28 and "GET / SET_PIN_CONFIG" on page 41.                                                                                                           |  |  |  |  |  |
| 25            | RX               | I    | UART Receive Data.                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| 26            | TX               | 0    | UART Transmit Data.                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 27            | GPIO5/RXT        | I/O  | General purpose I/O, or UART receive indicator. Defaults to receive indicator push-pull output. When configured as receive indicator, this pin will toggle at ~10 Hz intervals while the UART is receiving data.                                                                                                                |  |  |  |  |  |
| 28            | GPIO4/TXT        | I/O  | General purpose I/O, or UART transmit indicator. Defaults to transmit indicator push-pull output. When configured as transmit indicator, this pin will toggle at ~10 Hz intervals during UART data transmission.                                                                                                                |  |  |  |  |  |
| Center<br>Pad | GND              | PWR  | The center pad on the back side of the QFN package is metallic and should be connected to GND on the PCB. The thermal pad size on the PCB should be the approximate size of this center pad and should be solder mask defined. The solder mask opening should be at least 0.0025" inwards from the edge of the PCB thermal pad. |  |  |  |  |  |

- 1. Pin type: I=Input, O=Push-pull Output, I/O= Input/output, PWR=Power, OD=Open Drain Output with weak internal pull-up
- 2. All GPIO pins as well as USB\_STAT1 and USB\_STAT2 may be configured for a variety of pin type options using the GPIO\_MODE register or by writing to the OTP using XR\_SET\_OTP.
- 3. All enabled pull-up and pull-down resistors are maintained during USB suspend state.
- 4. Pin configurations set using XR\_SET\_OTP are enabled following the next power up reset and are permanent. During USB bus reset, resistors are disabled and re-enabled after bus reset is deasserted. Pin configurations set using the GPIO\_MODE register will be lost after POR or USB bus reset.

# **Functional Block Diagram**



# **Functional Description**

#### **USB** Interface

The USB interface of the XR21B1421 is compliant with the USB 2.0 Full-Speed Specifications.

The XR21B1421 uses the following set of parameters:

- 1 Control Endpoint
  - Endpoint 0 as outlined in the USB specifications
- 1 Configuration is supported
- 1 HID Interface for the UART channel
  - Interrupt-in endpoint for UART receive data

Interrupt-out endpoint for UART transmit data

#### **USB Vendor and Product IDs**

Exar's USB Vendor ID is 0x04E2. This is the default Vendor ID that is used for the XR21B1421. Customers may obtain their own Vendor ID from USB.org. The default USB Product ID for the XR21B1421 is 0x1421. Upon request, Exar will provide up to 8 PID values for use with Exar's VID. The VID and PID may be modified by the SET\_USB\_CONFIG HID report. However, the Exar VID and PID values will always be returned in the GET\_CHIP\_ID report (0x4F) irrespective of any changes to the VID and PID using the SET\_USB\_CONFIG report. Refer to Table 1.

#### **USB Suspend**

All USB peripheral devices must support the USB suspend mode. Per USB standard, the XR21B1421 device will begin to enter the suspend state if it does not detect any activity, (including Start of Frame or SOF packets) on its USB data lines for 3 ms. The peripheral device must then reduce power consumption from VBUS power within the next 7 ms to the allowed limit of 2.5 mA for the suspended state. Note that in this context, the "device" is all circuitry (including the XR21B1421) that draws power from the host VBUS.

# **Remote Wakeup**

If the XR21B1421 device has been placed into suspend state by the USB host, the RI#/RWK# and / or RX pins may be used to request that the host exit the suspended state. By default the XR21B1421 device reports in its device attributes that it does not support remote wakeup. If remote wakeup is enabled via the OTP, the device will respond to a high to low transition on the RI#/RWK# pin if it is configured as an input, and remotely wake up the USB host. Note that Windows OS does not support remote wakeup for HID class devices that are not identified as either keyboard or mouse. RX pin remote wakeup is disabled by default and must also be separately enabled.

# **USB Strings**

USB specifies three character string descriptors that are provided to the USB host during enumeration in string descriptors: the manufacturer, product and serial strings. The defaults manufacturer, and product strings for the XR21B1421 device are "Exar Corp." and, "Exar USB UART" respectively. The serial number string is a unique alpha-numeric string programmed into the device at the factory. All character strings use Unicode UTF-16LE format by default, but the Unicode language ID may be changed for the manufacturer and product strings. The default character string language ID is US English. If the language ID is modified via OTP, the serial number string should also be modified accordingly. However, note that USB.org requires any serial number string for a specific VID/PID combination to be unique for each device.

**Table 1: USB String Descriptor Defaults** 

| Descriptor          | Value         |
|---------------------|---------------|
| Exar USB Vendor ID  | 0x04E2        |
| Exar USB Product ID | 0x1421        |
| Manufacturer String | Exar Corp.    |
| Product String      | Exar USB UART |

#### **Device Driver**

The XR21B1421 device will utilize the native OS supplied HID driver. No other driver is required, however a custom dll supplied by Exar provides a function library to any user that is developing applications that utilize the HID reporting capabilities. Exar also supplies a sample GUI using the .dll as well as source code (upon request).

#### **USB Power Modes**

The XR21B1421 device may be configured in any one of three power modes: Bus-powered, Self-powered 5V, or Self-powered 3.3V. In all three modes, the VBUS power signal from the USB host must be connected to the VBUS\_SENSE pin of the device.

The default power mode for the XR21B1421 is bus-powered. In this mode, a maximum power required for the USB device from the host must be specified. In this context, the USB device includes all components on the PCB that will draw power from the USB VBUS power. The default power request for the XR21B1421 is 100 mA but this may be changed using the Maxpower field of the SET\_USB\_CONFIG HID report.

#### **Bus-Powered**

In bus-powered mode, VBUS from the USB cable supplies 5V to the XR21B1421 device. The VCC pin will supply 3.3V output. The VIO pins may be externally connected to VCC or to an alternate voltage source.



Figure 1: Bus-Powered Mode

#### Self-Powered 5V

In self-powered 5V mode, a local source supplies 5V to the XR21B1421 device. The USB attributes should be changed using SET\_USB\_CONFIG to report self powered mode. The VCC pin will supply 3.3V output. VIO pins may be externally connected to VCC or to an alternate voltage source.



Figure 2: Self-Powered 5V Mode

#### Self-Powered 3.3V

In self-powered 3.3V mode, a local source supplies 3.3V to both the VCC\_REG and VCC pins of the XR21B1421 device. The USB attributes should be changed using SET\_USB\_CONFIG to report self-powered mode. The VIO pin (on the QFN24 package) may be externally connected to VCC or to an alternate voltage source.



Figure 3: Self-Powered 3.3V Mode

#### Reset

The XR21B1421 has four different types of resets: power-on reset or POR, hardware reset, software reset and USB bus reset. The results of each of the four types of resets are listed in Table 2.

Table 2: Device Resets

| Reset Type           | Device Actions                                                                                                                          |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Power On Reset (POR) | Resets all registers and pins to default states including any OTP modifications. Locks OTP from further writes if Global Lock is set.   |
| Hardware Reset       | Resets all registers and pins to default states including any OTP modifications. Locks OTP from further writes if Global Lock is set.   |
| Software Reset       | Reset USB Interface, re-enumerate device, reset all internal states, clear UART FIFOs. Does not reset registers or pin configurations.  |
| USB Bus Reset        | Resets USB Interface, re-enumerate device, reset all internal states, clear UART FIFOs. Does not reset registers or pin configurations. |

#### **UART**

The UART transmitter and receiver sections are described separately below. The UART may be configured via HID reports. Wide mode is discussed in "Wide Mode" on page 13.

#### **Transmitter**

The transmitter consists of a 512-byte TX FIFO and a Transmit Shift Register (TSR). Once a SET\_TRANSMIT\_DATA report using interrupt out packets has been received and is validated, the data bytes in that packet are written into the TX FIFO. Data from the TX FIFO is transferred to the TSR when the TSR is idle or has completed sending the previous data byte. The TSR shifts the data out onto the TX output pin at the selected baud rate. The transmitter sends the start bit followed by the data bits (starting with the LSB), inserts the proper parity-bit if enabled, and adds the stop-bit(s).

The transmitter may be configured for 5, 6, 7 or 8 data bits with or without parity or 9 data bits without parity. If 5, 6, 7 or 8 bit data with parity is selected, the TX FIFO contains 8 bits data and the parity bit is automatically generated and transmitted. If 9 bit data is selected, parity cannot be generated. The 9th bit will not be transmitted unless the wide mode is enabled.

#### **Wide Mode**

The XR21B1421 device may be configured for wide mode using the SET\_TRANSFER\_MODE (report 0x48). In wide mode the XR21B1421 checks each received character for parity, framing or overrun errors, and for break status. Note that although the GET\_UART\_STATUS (report 0x42), reports these same errors, they are historical or latched errors indicating that an error has occured at least once since the previous GET\_UART\_STATUS report. By comparison, in wide mode, each character is accompanied by real time error and status indicators.

#### **Wide Mode Transmit**

Wide mode may be selected with any (5, 6, 7, 8 or 9 bit) character size. For 5, 6 and 7 bit data, bits 5-7, 6-7, or 7 (respectively) are filled with '0'. Two bytes from the USB host are used to form the data character which is serialized and transmitted. The least significant bit of the second byte contains the parity bit or the 9th bit of the character in 9 bit mode. The remaining 7 bits of the second byte are discarded.

#### Receiver

The receiver consists of a 512-byte RX FIFO and a Receive Shift Register (RSR). Data that is received in the RSR via the RX pin is transferred into the RX FIFO. Data from the RX FIFO is sent to the USB host by in response to a interrupt-in request. Depending on the mode, error / status information for that data character may or may not be stored in the RX FIFO with the data.

## Normal receive operation with 5, 6, 7 or 8-bit data

Received data is stored in the RX FIFO. Any parity, framing or overrun error or break status information related to the data is discarded. The receive data format is shown in Figure 4.



**Figure 4: Normal Operation Receive Data Format** 

# Normal receive operation with 9-bit data

The first 8 bits of data received is stored in the RX FIFO. The 9th bit as well as any parity, framing or overrun error or break status information related to the data is discarded.

## Wide mode receive operation with 5, 6, 7 or 8-bit data

Two bytes of data are loaded into the RX FIFO for each byte of data received. The first byte is the received data. The second byte consists of the error bits and break status. The wide mode receive data format is shown in Figure 5.



Figure 5: Wide Mode Receive Data Format

#### Wide mode receive operation with 9-bit data

Two bytes of data are loaded into the RX FIFO for each byte of data received. The first byte is the first 8 bits of the received data. The 9th bit received is stored in the bit 0 of the second byte. The parity bit is not received / checked. The remainder of the 2nd byte consists of the framing and overrun error bits and break status.

# **RX FIFO Low Latency**

In normal operation, all bulk-in transfers will be of maxPacketSize (64) bytes to improve throughput and to minimize host processing. When there are 64 bytes of data in the RX FIFO, the XR21B1421 will acknowledge a bulk-in request from the host and transfer the data packet. If there are less than 64 bytes in the RX FIFO, the XR21B1421 may respond to the bulk-in request with a NAK indicating that data is not ready to transfer at that time. However, if there are less than 64 bytes in the RX FIFO and no data has been received for more than 3 character times, the XR21B1421 will acknowledge the bulk-in request and transfer any data in the RX FIFO to the USB host.

In some cases, especially when the baud rate is low, this behavior may increase latency unacceptably. The low latency mode is automatically set whenever the baud rate is set to a value of less than 46921 bps. Additionally, a user may manually enable the low latency mode using the SET\_TRANSFER\_MODE report (0x48) to immediately transfer any received data in the RX FIFO to the USB host without waiting for 3 character times.

#### **GPIO**

Each UART has 10 GPIO pins in addition to the TX and RX pins. Each GPIO pin may also be configured for one or more special functions. Please refer to the pin descriptions for the default functionality of each of the general purpose I/Os.

#### **Clock Out**

The GPIO0/CLK pin may be configured as a clock output using the SET\_PIN\_CONFIG or SET\_GPIO\_CONFIG reports. The output frequency of the clock out may be programmed between 24 MHz and approximately 47 KHz. The duty cycle may also be programmed from 50/50 to single low or high going pulse. The default values of 0 for both DIV\_HI and DIV\_LO will result in a frequency of 24 MHz. For any non-zero values for DIV\_HI and DIV\_LO, the clock frequency is determined by the formula:

FREQ = 24 MHz / (DIV HI + DIV LO).

The duty cycle is determined by the ratio of DIV\_HI to DIV\_LO. GPIO0 will output this clock if is enabled in the GPIO\_-MODE register.

#### **Flow Control**

The XR21B1421 is able to perform both hardware and software flow control. Both hardware and software flow control modes are configured via the SET\_UART\_CONFIG report. In both modes, flow control is asserted when the bytes in the RX FIFO reach the watermark set in the RX\_THRESHOLD setting. Hardware flow control may either be RTS/CTS or DTR/DSR controlled. Note that although the default pin configuration for GPIO1/RTS# and GPIO2/CTS# are for RTS output and CTS input respectively, the hardware RTS/CTS flow control mode must be set in order to utilize the flow control functionality. Alternately, the pin configurations may be changed to GPIO functionality using the SET\_PIN\_CONFIG or SET\_GPIO\_CONFIG reports for these pins to be used for GPIO functionality.

#### **Automatic RTS/CTS Hardware Flow Control**

Automatic RTS/CTS flow control is used to prevent data overrun errors in the local RX FIFO using the RTS signal to the remote UART. The RTS signal will be asserted (low) when there are less than 450 bytes in the receive FIFO. When the RX FIFO reaches the 450 byte threshold, the RTS pin will be deasserted. The CTS# input of the remote UART is monitored to suspend/restart the transmitter. Refer to Figure 6. Conversely, when the remote UART reaches its receive FIFO threshold, its RTS will be deasserted, and the XR21B1421 CTS input will cause the device to suspend data transmission.



Figure 6: Auto RTS and CTS Flow Control Operation

#### **Automatic DTR/DSR Hardware Flow Control**

Auto DTR/DSR hardware flow control behaves the same as the Auto RTS/CTS hardware flow control described above except that it uses the DTR# and DSR# signals. GPIO8 and GPIO9 become DTR# and DSR#, respectively, when the SET\_UART\_CONFIG or SET\_PIN\_CONFIG report configures the device for DTR/DSR hardware flow control.

#### Automatic XON/XOFF Software Flow Control

When software flow control is enabled, the XR21B1421 compares the receive data characters with the programmed XON or XOFF characters. If the received character matches the programmed XOFF character, the XR21B1421 will halt transmission as soon as the current character has completed transmission. Data transmission is resumed when a received character matches the XON character.

In the receive data direction, the XOFF character will be sent when there are 450 bytes in the receive FIFO. When there are again less than 450 bytes in the RX FIFO, the XON character will be send. This threshold may be changed using the SET\_FLOW\_CTRL\_THRESHOLD HID report.

Software flow control is enabled / disabled by the SET\_UART\_CONFIG report. Additionally, the SET\_SW\_FLOW\_CONFIG report may be used to configure the start (XON) and stop (XOFF) characters.

## Multidrop mode with address matching

The XR21B1421 device has two address matching modes which are set by the SET\_ADDR\_MATCH\_CONFIG report. These modes are intended for a multi-drop network application. In these modes, the UNI\_ADD holds a unicast address and the MULTI\_ADD holds a multicast address. An address match occurs when an address byte (9th bit or parity bit is '1') is received that matches the value stored in either the UNI\_ADD or MULTI\_ADD field. To send an address byte use 8 bit data with mark parity. To send data bytes, use 8 bit data with space parity.

#### Receiver

If an address match occurs in either of the address matching modes, the address byte will not be loaded into the RX FIFO, but all subsequent data bytes will be loaded into the RX FIFO. The UART Receiver will automatically be disabled when an address byte is received that does not match the values in the UNI\_ADD or MULTI\_ADD characters.

#### **Transmitter**

In flow control mode 3, the UART transmitter will transmit irrespective of the RX address match. In flow control mode 4, the UART will only transmit following an RX address match.

# **Programmable Turn-Around Delay**

By default, the selected auto RS-485 half-duplex enable pin (either GPIO3/RS485 or GPIO1/RTS#/RS485) will be deasserted immediately after the stop bit of the last byte has been shifted. However, this may not be ideal for systems where the signal needs to propagate over long cables. Therefore, the de-assertion of the auto RS-485 half-duplex enable may be delayed from 1 to 15 bit times via the SET\_XCVR\_EN\_DELAY report to allow for the data to reach distant UARTs.

## **UART Half-Duplex Mode**

In half-duplex mode, the UART will ignore any data on the RX input when the UART is transmitting data. The half-duplex mode may be configured using the SET\_UART\_CONFIG report.

#### **IR Mode**

The XR21B1421 supports IR mode at a maximum baud rate of 2.5 Mbaud with transmit pulses of 3/16th or 4/16th of a bit period and centered in the bit period. Receive data may be inverted to conform to some manufacturer's non-standard devices. IR mode is disabled by default but may be enabled by the SET\_IR\_MODE report 0x56.

#### **USB\_STAT Pins**

The XR21B1421 has two USB\_STAT output pins that may be used to indicate 3 different statuses in either positive or negative polarity. The SUSPEND status indicates that the XR21B1421 device has been placed into a suspended state by the USB host. This output may then be used by external circuitry, for example, to power down devices in order to meet USB power requirements for suspend mode. The LOW\_POWER status is similar to the SUSPEND status, but LOW\_POWER is also asserted for high power devices (any device that consume more than 100 mA of VBUS power from the USB host), before the device is configured during enumeration by the USB host. For low power devices (devices that consume 100 mA or less of VBUS power), SUSPEND and LOW\_POWER status outputs are functionally the same. Lastly, the BUS\_RST output status is asserted any time the XR21B1421 device is being reset by the USB host. This status output could be used, for example, by an FPGA or other logic device to reset this external logic.

#### Use Suspend

The USE\_SUSPEND bit controls the GPIO pins when the XR21B1421 device is suspended by the USB host. If USE\_SUSPEND is cleared to '0', GPIO pins retain their output states when the device is suspended. When USE\_SUSPEND is set to '1', GPIO pins are assigned behavior defined by the SUSPEND\_STATE and SUSPEND\_MODE fields of SET\_PIN\_CONFIG or SET\_SUSPEND\_OUTPUT\_CONFIG reports, with the following exceptions: GPIO0/CLK when configured as an output clock will always be driven low, i.e the clock output will stop, and GPIO1/RTS#/RS485 or GPIO3/RS485 when configured as a auto RS-485 half-duplex enable will always be deasserted.

The SUSPEND\_STATE field will set or clear the GPIO pin and the SUSPEND\_MODE field will configure any GPIO output as open drain or push-pull output. Refer to "GET / SET\_PIN\_CONFIG" on page 41 or "GET / SET\_SUSPEND\_OUTPUT\_CONFIG" on page 31. Configuration using the SET\_SUSPEND\_OUTPUT\_CONFIG report will be lost at the next power cycle or bus reset of the device. Configuration using the SET\_PIN\_CONFIG report will be permanent.

#### **TXT and RXT Pins**

The Transmit toggle and Receive toggle pins "toggle" at a rate of approximately 10 Hz whenever the UART transmit and receive pins (respectively) are active.

#### **OTP**

The OTP is an on-chip non-volatile memory, that is incrementally one-time programmable via the USB interface. Some bits are pre-programmed at the factory and caution must be taken not to program any locations except those user defined addresses given in this data sheet. Some of the HID reports result in irreversible programming of the OTP. Once a specific report programs a portion of the OTP, the lock bit for that section of the OTP will be set and further changes to that section will not be allowed. Note that all OTP writes will take immediate effect, except for setting the global lock bit (report 0x68), which requires a hardware or power on reset to take effect.

# **USB Control Commands**

The following table shows all of the USB Control Commands that are supported by the XR21B1421. Commands include standard USB commands, CDC-ACM commands and custom Exar commands.

**Table 3: Supported USB Control Commands** 

| Name              | Request | Damusat | Va   | lue | Ind              | ex     | Ler        | ngth       | Dogovinkiov                               |
|-------------------|---------|---------|------|-----|------------------|--------|------------|------------|-------------------------------------------|
| Name              | Туре    | Request | LSB  | MSB | LSB              | MSB    | LSB        | MSB        | Description                               |
| DEV GET_STATUS    | 0x80    | 0       | 0    | 0   | 0                | 0      | 2          | 0          | Device: remote wake-up + self-<br>powered |
| IF GET_STATUS     | 0x81    | 0       | 0    | 0   | 0                | 0      | 2          | 0          | Interface: zero                           |
| EP GET_STATUS     | 0x82    | 0       | 0    | 0   | 0x0,0x4,<br>0x84 | 0      | 2          | 0          | Endpoint: halted                          |
| DEV CLEAR_FEATURE | 0x00    | 1       | 1    | 0   | 0                | 0      | 0          | 0          | Device remote wake-up                     |
| EP CLEAR_FEATURE  | 0x02    | 1       | 0    | 0   | 0x0,0x4,<br>0x84 | 0      | 0          | 0          | Endpoint halt                             |
| DEV SET_FEATURE   | 0x00    | 3       | 1    | 0   | 0                | 0      | 0          | 0          | Device remote wake-up                     |
| DEV SET_FEATURE   | 0x00    | 3       | 2    | 0   | 0                | test   | 0          | 0          | Test mode - factory use only              |
| EP SET_FEATURE    | 0x02    | 3       | 0    | 0   | 0x0,0x4,<br>0x84 | 0      | 0          | 0          | Endpoint halt                             |
| SET_ADDRESS       | 0x00    | 5       | addr | 0   | 0                | 0      | 0          | 0          | addr = 1 to 127                           |
| GET_DESCRIPTOR    | 0x80    | 6       | 0    | 1   | 0                | 0      | len<br>MSB | len<br>MSB | Device descriptor                         |
| GET_DESCRIPTOR    | 0x80    | 6       | 0    | 2   | LangID           | LangID | len<br>MSB | len<br>MSB | Configuration descriptor                  |
| GET_DESCRIPTOR    | 0x80    | 6       | 0    | 3   | 0                | 0      | len<br>MSB | len<br>MSB | String descriptor                         |
| GET_CONFIGURATION | 0x80    | 8       | 0    | 0   | 0                | 0      | 1          | 0          |                                           |
| SET_CONFIGURATION | 0x00    | 9       | n    | 0   | 0                | 0      | 0          | 0          | n = 0, 1                                  |
| GET_INTERFACE     | 0x81    | 10      | 0    | 0   | 0                | 0      | 1          | 0          |                                           |

# **HID Reports**

All of the functionality of the XR21B1421 device is controlled via HID reports. Some of these reports will program the onchip OTP memory. All of the HID reports in the OTP customization section (reports 0x47 and 0x60 through 0x67) will permanently program the on-chip OTP. All other HID reports do not program the OTP. The SET\_GPIO\_CONFIG (report 0x49) dynamically configures the GPIO pins, but does not program the OTP as does the SET\_PIN\_CONFIG report.

Table 4: XR21B1421 HID Reports

| Report ID  | Report Name                                               | Size   |
|------------|-----------------------------------------------------------|--------|
|            |                                                           |        |
| 0X1 - 0x3F | ART Data Transfer (Interrupt Transfers) SET TRANSMIT DATA | 2 - 64 |
| 0X1 - 0x3F | GET RECEIVE DATA                                          | 2 - 64 |
| De         | l<br>evice Configuration (Control Transfers)              |        |
| 0x40       | SET DEVICE RESET                                          | 2      |
| 0x41       | GET / SET UART ENABLE                                     | 2      |
| 0x42       | GET UART STATUS                                           | 7      |
| 0x43       | SET CLEAR FIFOS                                           | 2      |
| 0x44       | GET GPIO STATE                                            | 3      |
| 0x45       | SET GPIO STATE                                            | 5      |
| 0x46       | GET VERSION                                               | 3      |
| 0x48       | GET / SET TRANSFER MODE                                   | 3      |
| 0x49       | GET / SET GPIO CONFIG                                     | 13     |
| 0x4A       | GET / SET SUSPEND OUTPUT<br>CONFIG                        | 5      |
| 0x4F       | GET CHIP ID                                               | 7      |
| U          | ART Configuration (Control Transfers)                     |        |
| 0x50       | GET / SET UART CONFIG                                     | 9      |
| 0x51       | SET TRANSMIT LINE BREAK                                   | 2      |
| 0x52       | SET STOP LINE BREAK                                       | 2      |
| 0x53       | GET / SET SW FLOW CTRL<br>CONFIG                          | 3      |
| 0x54       | GET / SET ADDR MATCH CONFIG                               | 3      |
| 0x55       | GET / SET LOOPBACK MODE                                   | 2      |
| 0x56       | GET / SET IR MODE                                         | 2      |
| 0x57       | GET / SET XCVR EN DELAY                                   | 2      |
| 0x58       | GET / SET FLOW CTRL<br>THRESHOLD                          | 3      |
| 0          | TP Customization (Control Transfers)                      |        |
| 0x47       | GET / SET OTP LOCK BYTE                                   | 3      |

Table 4: XR21B1421 HID Reports

| Report ID | Report Name                | Size   |
|-----------|----------------------------|--------|
| 0x60      | GET / SET USB CONFIG       | 11     |
| 0x61      | GET / SET VENDOR STRING 1  | 4 - 64 |
| 0x62      | GET / SET VENDOR STRING 2  | 2 - 64 |
| 0x63      | GET / SET PRODUCT STRING 1 | 4 - 64 |
| 0x64      | GET / SET PRODUCT STRING 2 | 2 - 64 |
| 0x65      | GET / SET SERIAL STRING    | 4 - 64 |
| 0x66      | GET / SET PIN CONFIG       | 20     |
| 0x67      | GET / SET LANG ID          | 3      |
| 0x68      | GET / SET GLOBAL LOCK      | 2      |

# **HID Report Descriptions**

All of the functionality of the XR21B1421 device is controlled via HID reports. Some of these reports will program the onchip OTP memory. All of the HID reports in the OTP customization section (reports 0x47 and 0x60 through 0x67) will permanently program the on-chip OTP. All other HID reports do not program the OTP. The SET\_GPIO\_CONFIG (report 0x49) dynamically configures the GPIO pins, but does not program the OTP as does the SET\_PIN\_CONFIG report.

#### **SET TRANSMIT DATA**

Transfer Type: Interrupt Out Transfer Size: 2 - 64 bytes

The SET\_TRANSMIT\_DATA report transmits up to 63 bytes of data to the UART per transfer.

| Field     | Offset | Size | Value       | Description                                                                                                                       |
|-----------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Report ID | 0      | 1    | 0x01 - 0x3F | Indicates the size of the data transfer to be sent to the device from 1 (0x01) to 63 (0x3F) bytes excluding the report ID itself. |
| Data      | 1      | 1-63 |             | Data from USB host to UART                                                                                                        |

## **GET\_RECEIVE\_DATA**

Transfer Type: Interrupt In Transfer Size: 2 - 64 bytes

The GET\_RECEIVE\_DATA report receives up to 63 bytes of data from the UART per transfer. This report is returned when the USB host polls the Interrupt-In endpoint at 1 ms intervals.

| Field     | Offset | Size | Value       | Description                                                                                                                       |
|-----------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Report ID | 0      | 1    | 0x01 - 0x3F | Indicates the size of the data transfer to be sent to the device from 1 (0x01) to 63 (0x3F) bytes excluding the report ID itself. |
| Data      | 1      | 1-63 |             | Data from USB host to UART                                                                                                        |

#### SET DEVICE RESET

Transfer Type: Control Out
Transfer Size: 2 bytes

The SET\_DEVICE\_RESET report performs a software reset of the XR21B1421 device that resets the USB interface and clears the UART RX and TX FIFOs, but does not change any UART configuration settings or change any pin configurations. Any changes to on-chip OTP will not be reflected following the software reset. During software reset, the internal pull-up on the USBD+ pin will be disabled to signal the USB host that a detach event has occurred. Following reset, the pull-up resistor will be enabled to signal an attach event to the USB host.

| Field     | Offset | Size | Value | Description                   |
|-----------|--------|------|-------|-------------------------------|
| Report ID | 0      | 1    | 0x40  | Force device hardware reset   |
| Value     | 1      | 1    |       | Set of any value forces reset |

## **GET / SET\_UART\_ENABLE**

Transfer Type: Control In / Out

Transfer Size: 2 bytes

The GET / SET\_UART\_ENABLE report gets or sets the UART enable (default is disabled). Disable the UART and reenable before sending or receiving UART data.

| Field     | i   | Offset | Size | Value        | Description                       |
|-----------|-----|--------|------|--------------|-----------------------------------|
| Report ID |     | 0      | 1    | 0x41         | Enable / disable UART             |
| UART Ena  | ble | 1      | 1    | 0x00<br>0x01 | Disable(d)<br>Enable(d) - default |

# **GET\_UART\_STATUS**

Transfer Type: Control In Transfer Size: 7 bytes

The GET\_UART\_STATUS report returns the break and error status of the UART and number of bytes in RX and TX FIFOs. The TX and RX FIFOs hold a maximum of 512 bytes.

| Field        | Offset | Size | Value        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|--------|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Report ID    | 0      | 1    | 0x42         | Get status of historical error and status and RX and TX FIFO fill                                                                                                                                                                                                                                                                                                                                                                                                                         |
| TX FIFO MSB  | 1      | 1    |              | Number of bytes in transmit FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TX FIFO LSB  | 2      | 1    |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RX FIFO MSB  | 3      | 1    |              | Number of bytes in receive FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RX FIFO LSB  | 4      | 1    |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Error Status | 5      | 1    | Error Status | Receive Error / Break status Error Status indicates parity, overrun, and frame errors as well as break status for received data. Any error / break status will be latched until the status is read using the Get_UART_Status report. These bits will cleared when read.  Bit 0 - parity error - '1' indicates parity error Bit 1 - overrun error - '1' indicates overrun Bit 2 - framing error - '1' indicates framing error Bit 3 - break status - '1' indicates break condition occured |
| Break Status | 6      | 1    | 0x00<br>0x01 | Receive - No Line Break<br>Receive - Line Break Active                                                                                                                                                                                                                                                                                                                                                                                                                                    |

# SET\_CLEAR\_FIFOS

Transfer Type: Control Out

Transfer Size: 2 bytes

The SET\_CLEAR\_FIFOS report clears the selected FIFO buffers.

| Field     | Offset | Size | Value | Description                                                                                        |
|-----------|--------|------|-------|----------------------------------------------------------------------------------------------------|
| Report ID | 0      | 1    | 0x43  | Clear FIFO buffers                                                                                 |
| Clear     | 1      | 1    | Value | Clears FIFOs Bit 0 - '1' clears TX FIFO (self-clearing) Bit 1 - '1' clears RX FIFO (self-clearing) |

# **GET\_GPIO\_STATE**

Transfer Type: Control In

Transfer Size: 3 bytes

The GET\_GPIO\_STATE report gets the actual state of the GPIO or flow control pins configured as either inputs or outputs.

| Field     | Offset | Size | Value | Description             |
|-----------|--------|------|-------|-------------------------|
| Report ID | 0      | 1    | 0x44  | Get status of GPIO pins |
| State MSB | 1      | 1    |       | See Table 5             |
| State LSB | 2      | 1    |       |                         |

**Table 5: Get State Bit Positions** 

| Bit | GPIO/Pin | Pin Name    |
|-----|----------|-------------|
| 15  |          | Reserved    |
| 14  | S1       | USB_STAT1   |
| 13  | 9        | GPIO9/DSR#  |
| 12  | 8        | GPIO8/DTR#  |
| 11  | 7        | GPIO7/RI#   |
| 10  | 6        | GPIO6/CD#   |
| 9   |          | Reserved    |
| 8   | S2       | USB/STAT2   |
| 7   | 5        | GPIO5/RXT   |
| 6   | 4        | GPIO4/TXT   |
| 5   | RX       | RX          |
| 4   | TX       | TX          |
| 3   | 3        | GPIO3/RS485 |
| 2   | 2        | GPIO2/CTS#  |
| 1   | 1        | GPIO1/RTS#  |
| 0   | 0        | GPIO0/CLK   |

# SET\_GPIO\_STATE

Transfer Type: Control Out Transfer Size: 5 bytes

The SET\_GPIO\_STATE report sets the state of pins configured as either GPIO or flow control outputs. Each bit position in the state value will be asserted to the specified '1' or '0' on the GPIO pin output if the direction for that IO pin is set to output and if the corresponding bit position in the mask is set to a '1'.

| Field     | Offset | Size | Value | Description                   |
|-----------|--------|------|-------|-------------------------------|
| Report ID | 0      | 1    | 0x45  | Set status of GPIO pins       |
| State MSB | 1      | 1    |       | See Table 6                   |
| State LSB | 2      | 1    |       |                               |
| Mask MSB  | 3      | 1    |       | Mask for output state changes |
| Mask LSB  | 4      | 1    |       |                               |