# IEE2463 Sistemas Electrónicos Programables

Javier Silva Orellana jisilva8@uc.cl

GitHub: slothzilla328p



2do semestre 2020

# **UART**

# **UART**

Universal Asynchronous Receiver-Transmitter

# The four horsemen of apocalypse









Launchpad

Especificaciones Técnicas

Manual de uso

**Pinout** 

# ¿Dónde?

 La MSP430F5529 presenta un par de pines para comunicación serial.
 Estos corresponden a P3.4 (UCA0RXD) y P3.3 (UCA0TXD).



# ¿Dónde?

- La MSP430F5529 presenta un par de pines para comunicación serial.
   Estos corresponden a P3.4 (UCA0RXD) y P3.3 (UCA0TXD).
- Estos mismos pines también se encuentran directamente conectados al BoosterPack.

#### Pinout Diagram for your BoosterPack



# ¿Dónde?

- La MSP430F5529 presenta un par de pines para comunicación serial.
   Estos corresponden a P3.4 (UCA0RXD) y P3.3 (UCA0TXD).
- Estos mismos pines también se encuentran directamente conectados al BoosterPack.
- No tenemos jumpers, ¿cómo emplearemos el UART?

#### Pinout Diagram for your BoosterPack



## Revisemos el detalle del Launchpad



Figure 9. MSP430F5529 Pinout

[Página 11]

- Además de P3.3 y P3.4, la MSP430F5529 cuenta con otro par de pines para UART, P4.4 (Tx) y P4.5 (Rx).
- ¿Por qué no figuran en el pinout anterior?

## Revisemos el detalle del Launchpad



- Además de P3.3 y P3.4, la MSP430F5529 cuenta con otro par de pines para UART, P4.4 (Tx) y P4.5 (Rx).
- ¿Por qué no figuran en el pinout anterior?
- Están vinculados al conector USB del Launchpad.
- POR FAVOR REVISEN QUE LOS JUMPERS TXD y RXD ESTÉN PUESTOS.

# The four horsemen of apocalypse









Launchpad

Especificaciones Técnicas

Manual de uso

**Pinout** 

# Especificaciones de Interés

#### 8.29 USCI (UART Mode) Clock Frequency

over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted)

|                     | PARAMETER                                          | CONDITIONS                                                           | MIN | MAX                 | UNIT |
|---------------------|----------------------------------------------------|----------------------------------------------------------------------|-----|---------------------|------|
| f <sub>USCI</sub>   | USCI input clock frequency                         | Internal: SMCLK or ACLK,<br>External: UCLK,<br>Duty cycle = 50% ±10% |     | f <sub>SYSTEM</sub> | MHz  |
| f <sub>BITCLK</sub> | BITCLK clock frequency (equals baud rate in MBaud) |                                                                      |     | 1                   | MHz  |

#### 8.30 USCI (UART Mode)

over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted)

|   | PARAMETER                                                | V <sub>CC</sub> | MIN | MAX | UNIT |
|---|----------------------------------------------------------|-----------------|-----|-----|------|
|   | t <sub>t</sub> UART receive deglitch time <sup>(1)</sup> | 2.2 V           | 50  | 600 | 200  |
| ւ |                                                          | 3 V             | 50  | 600 | ns   |

(1) Pulses on the UART receive input (UCxRX) shorter than the UART receive deglitch time are suppressed. To ensure that pulses are correctly recognized, their duration should exceed the maximum specification of the deglitch time.

#### [Página 38]

# The four horsemen of apocalypse









Launchpad

Especificaciones Técnicas

Manual de uso

**Pinout** 

# Configurando UART (User's Guide Ch. 36)

# Configurando UART: Handshake



# Configurando UART: Registros

Table 36-6. USCI\_A UART Mode Registers

| Offset | Acronym    | Register Name                  | Type       | Access | Reset | Section         |
|--------|------------|--------------------------------|------------|--------|-------|-----------------|
| 00h    | UCAxCTLW0  | USCI_Ax Control Word 0         | Read/write | Word   | 0001h |                 |
| 00h    | UCAxCTL1   | USCI_Ax Control 1              | Read/write | Byte   | 01h   | Section 36.4.2  |
| 01h    | UCAxCTL0   | USCI_Ax Control 0              | Read/write | Byte   | 00h   | Section 36.4.1  |
| 06h    | UCAxBRW    | USCI_Ax Baud Rate Control Word | Read/write | Word   | 0000h |                 |
| 06h    | UCAxBR0    | USCI_Ax Baud Rate Control 0    | Read/write | Byte   | 00h   | Section 36.4.3  |
| 07h    | UCAxBR1    | USCI_Ax Baud Rate Control 1    | Read/write | Byte   | 00h   | Section 36.4.4  |
| 08h    | UCAxMCTL   | USCI_Ax Modulation Control     | Read/write | Byte   | 00h   | Section 36.4.5  |
| 09h    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Ah    | UCAxSTAT   | USCI_Ax Status                 | Read/write | Byte   | 00h   | Section 36.4.6  |
| 0Bh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Ch    | UCAxRXBUF  | USCI_Ax Receive Buffer         | Read/write | Byte   | 00h   | Section 36.4.7  |
| 0Dh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Eh    | UCAxTXBUF  | USCI_Ax Transmit Buffer        | Read/write | Byte   | 00h   | Section 36.4.8  |
| 0Fh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 10h    | UCAxABCTL  | USCI_Ax Auto Baud Rate Control | Read/write | Byte   | 00h   | Section 36.4.11 |
| 11h    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 12h    | UCAxIRCTL  | USCI_Ax IrDA Control           | Read/write | Word   | 0000h |                 |
| 12h    | UCAxIRTCTL | USCI_Ax IrDA Transmit Control  | Read/write | Byte   | 00h   | Section 36.4.9  |
| 13h    | UCAxIRRCTL | USCI_Ax IrDA Receive Control   | Read/write | Byte   | 00h   | Section 36.4.10 |
| 1Ch    | UCAxICTL   | USCI_Ax Interrupt Control      | Read/write | Word   | 0000h |                 |
| 1Ch    | UCAxIE     | USCI_Ax Interrupt Enable       | Read/write | Byte   | 00h   | Section 36.4.12 |
| 1Dh    | UCAxIFG    | USCI_Ax Interrupt Flag         | Read/write | Byte   | 00h   | Section 36.4.13 |
| 1Eh    | UCAxIV     | USCI_Ax Interrupt Vector       | Read       | Word   | 0000h | Section 36.4.14 |

# Configurando UART: Baud Rate

Table 36-4. Commonly Used Baud Rates, Settings, and Errors, UCOS16 = 0

| BRCLK<br>Frequency<br>(Hz) | Baud Rate<br>(baud) | UCBRx | UCBRSx | UCBRFx | Maximum TX Error<br>(%) |      | Maximum RX Error (%) |      |
|----------------------------|---------------------|-------|--------|--------|-------------------------|------|----------------------|------|
| 32 768                     | 1200                | 27    | 2      | 0      | -2.8                    | 1.4  | -5.9                 | 2.0  |
| 32 768                     | 2400                | 13    | 6      | 0      | -4.8                    | 6.0  | -9.7                 | 8.3  |
| 32 768                     | 4800                | 6     | 7      | 0      | -12.1                   | 5.7  | -13.4                | 19.0 |
| 32 768                     | 9600                | 3     | 3      | 0      | -21.1                   | 15.2 | -44.3                | 21.3 |
| 1 000 000                  | 9600                | 104   | 1      | 0      | -0.5                    | 0.6  | -0.9                 | 1.2  |
| 1 000 000                  | 19200               | 52    | 0      | 0      | -1.8                    | 0    | -2.6                 | 0.9  |
| 1 000 000                  | 38400               | 26    | 0      | 0      | -1.8                    | 0    | -3.6                 | 1.8  |
| 1 000 000                  | 57600               | 17    | 3      | 0      | -2.1                    | 4.8  | -6.8                 | 5.8  |
| 1 000 000                  | 115200              | 8     | 6      | 0      | -7.8                    | 6.4  | -9.7                 | 16.1 |

# Configurando UART: Registros

Gran variedad de combinaciones para el formato del mensaje.

¿Cómo podemos hacer una configuración sencilla de cambiar?

# UART: Tx y Rx char a char (User's Guide Ch. 36)

# Tx/Rx: Interruption Flags

Table 36-6. USCI\_A UART Mode Registers

|        |            | <del>-</del>                   | •          |        |       |                 |
|--------|------------|--------------------------------|------------|--------|-------|-----------------|
| Offset | Acronym    | Register Name                  | Туре       | Access | Reset | Section         |
| 00h    | UCAxCTLW0  | USCI_Ax Control Word 0         | Read/write | Word   | 0001h |                 |
| 00h    | UCAxCTL1   | USCI_Ax Control 1              | Read/write | Byte   | 01h   | Section 36.4.2  |
| 01h    | UCAxCTL0   | USCI_Ax Control 0              | Read/write | Byte   | 00h   | Section 36.4.1  |
| 06h    | UCAxBRW    | USCI_Ax Baud Rate Control Word | Read/write | Word   | 0000h |                 |
| 06h    | UCAxBR0    | USCI_Ax Baud Rate Control 0    | Read/write | Byte   | 00h   | Section 36.4.3  |
| 07h    | UCAxBR1    | USCI_Ax Baud Rate Control 1    | Read/write | Byte   | 00h   | Section 36.4.4  |
| 08h    | UCAxMCTL   | USCI_Ax Modulation Control     | Read/write | Byte   | 00h   | Section 36.4.5  |
| 09h    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Ah    | UCAxSTAT   | USCI_Ax Status                 | Read/write | Byte   | 00h   | Section 36.4.6  |
| 0Bh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Ch    | UCAxRXBUF  | USCI_Ax Receive Buffer         | Read/write | Byte   | 00h   | Section 36.4.7  |
| 0Dh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Eh    | UCAxTXBUF  | USCI_Ax Transmit Buffer        | Read/write | Byte   | 00h   | Section 36.4.8  |
| 0Fh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 10h    | UCAxABCTL  | USCI_Ax Auto Baud Rate Control | Read/write | Byte   | 00h   | Section 36.4.11 |
| 11h    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 12h    | UCAxIRCTL  | USCI_Ax IrDA Control           | Read/write | Word   | 0000h |                 |
| 12h    | UCAxIRTCTL | USCI_Ax IrDA Transmit Control  | Read/write | Byte   | 00h   | Section 36.4.9  |
| 13h    | UCAxIRRCTL | USCI_Ax IrDA Receive Control   | Read/write | Byte   | 00h   | Section 36.4.10 |
| 1Ch    | UCAxICTL   | USCI_Ax Interrupt Control      | Read/write | Word   | 0000h |                 |
| 1Ch    | UCAxIE     | USCI_Ax Interrupt Enable       | Read/write | Byte   | 00h   | Section 36.4.12 |
| 1Dh    | UCAxIFG    | USCI_Ax Interrupt Flag         | Read/write | Byte   | 00h   | Section 36.4.13 |
| 1Eh    | UCAxIV     | USCI_Ax Interrupt Vector       | Read       | Word   | 0000h | Section 36.4.14 |
|        |            |                                |            |        |       |                 |

### Tx/Rx: Buffers

Table 36-6. USCI\_A UART Mode Registers

| Offset | Acronym    | Register Name                  | Type       | Access | Reset | Section         |
|--------|------------|--------------------------------|------------|--------|-------|-----------------|
| 00h    | UCAxCTLW0  | USCI_Ax Control Word 0         | Read/write | Word   | 0001h |                 |
| 00h    | UCAxCTL1   | USCI_Ax Control 1              | Read/write | Byte   | 01h   | Section 36.4.2  |
| 01h    | UCAxCTL0   | USCI_Ax Control 0              | Read/write | Byte   | 00h   | Section 36.4.1  |
| 06h    | UCAxBRW    | USCI_Ax Baud Rate Control Word | Read/write | Word   | 0000h |                 |
| 06h    | UCAxBR0    | USCI_Ax Baud Rate Control 0    | Read/write | Byte   | 00h   | Section 36.4.3  |
| 07h    | UCAxBR1    | USCI_Ax Baud Rate Control 1    | Read/write | Byte   | 00h   | Section 36.4.4  |
| 08h    | UCAxMCTL   | USCI_Ax Modulation Control     | Read/write | Byte   | 00h   | Section 36.4.5  |
| 09h    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Ah    | UCAxSTAT   | USCI_Ax Status                 | Read/write | Byte   | 00h   | Section 36.4.6  |
| 0Bh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Ch    | UCAxRXBUF  | USCI_Ax Receive Buffer         | Read/write | Byte   | 00h   | Section 36.4.7  |
| 0Dh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 0Eh    | UCAxTXBUF  | USCI Ax Transmit Buffer        | Read/write | Byte   | 00h   | Section 36.4.8  |
| 0Fh    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 10h    | UCAxABCTL  | USCI_Ax Auto Baud Rate Control | Read/write | Byte   | 00h   | Section 36.4.11 |
| 11h    |            | Reserved - reads zero          | Read       | Byte   | 00h   |                 |
| 12h    | UCAxIRCTL  | USCI_Ax IrDA Control           | Read/write | Word   | 0000h |                 |
| 12h    | UCAxIRTCTL | USCI_Ax IrDA Transmit Control  | Read/write | Byte   | 00h   | Section 36.4.9  |
| 13h    | UCAxIRRCTL | USCI_Ax IrDA Receive Control   | Read/write | Byte   | 00h   | Section 36.4.10 |
| 1Ch    | UCAxICTL   | USCI_Ax Interrupt Control      | Read/write | Word   | 0000h |                 |
| 1Ch    | UCAxIE     | USCI_Ax Interrupt Enable       | Read/write | Byte   | 00h   | Section 36.4.12 |
| 1Dh    | UCAxIFG    | USCI_Ax Interrupt Flag         | Read/write | Byte   | 00h   | Section 36.4.13 |
| 1Eh    | UCAxIV     | USCI Ax Interrupt Vector       | Read       | Word   | 0000h | Section 36.4.14 |



# **UART: Terminales**

## Recuerden: El Handshake es muchomuyimportante



# IEE2463 Sistemas Electrónicos Programables

Javier Silva Orellana jisilva8@uc.cl

GitHub: slothzilla328p

