# Serial Communication (Ch. 10)

· How do digital components exchange information?



- Standard digital communication interfaces establish the function and protocol of signals used to exchange data between two (or more) digital components in a system
  - Function:
  - Protocol:

timing protocol for memory expansion interface





ECE 331, Prof. A. Mason

Serial Communication.1

# Digital Communication Interface Basics

- Two primary types of digital communication
  - Parallel
    - · multiple data lines (generally one byte worth)
    - multiple data values transmitted simultaneously
  - Serial
    - single data line
    - · bits sent in series, one bit at a time, sequentially



parallel or serial?

parallel or serial?

- Terminology
  - · bit rate bits per second
  - · bit cell time to transmit a single bit
  - BAUD rate bits per second
  - NRZ line code transmit value for entire bit cell



#### Features of Serial Interfaces

- · Synchronous vs. Asynchronous
  - synchronous = data bits read at clock edge
  - asynchronous = no clock; data read at preset interval



Synchronous or asynchronous?

- · To/from (out/in, transmit/receive) separate or shared
  - separate: data can be transmitted & received simultaneously
    - similar to "full duplex"
    - · for hardwired communication, requires multiple data lines
  - shared: data either incoming or outgoing (not both) at any given time
    - similar to "half duplex"
    - · for hardwired communication, requires only one data line



Serial Communication 3

### Common Serial Interfaces

- · Morse code telegraphy
- RS-232 (low-speed, implemented by serial ports) = SCI = UART
- · RS-422
- · RS-423
- · RS-485
- · I2C
- ·SPI
- ARINC 818 Avionics Digital Video Bus
- Universal Serial Bus (moderate-speed, for connecting peripherals to computers)
- FireWire
- · Ethernet
- Fibre Channel (high-speed, for connecting computers to mass storage devices)
- InfiniBand (very high speed, broadly comparable in scope to PCI)
- MIDI control of electronic musical instruments
- DMX512 control of theatrical lighting
- SDI-12 industrial sensor protocol
- Serial Attached SCSI
- Serial ATA
- SpaceWire Spacecraft communication network
- HyperTransport
- PCI Express (high speed serial replacement for PCI/PCI-X (parallel))



#### Common Microcontroller Serial Ports

- Universal asynchronous receiver/transmitter (UART)
  - serially transmit/receive a byte of data written to a parallel port
  - also called Serial Communications Interface (SCI)
  - RS-232 (PC serial port) is a UART "standard"
    - standard = defined voltage and timing characteristics
  - asynchronous
    - no clock signal; data read at predetermined BAUD rate
      - baud rate = the number of distinct symbol changes (signaling events) made to the transmission medium per second
    - · BAUD rate must match on both sides of the interface
    - typically use start/stop bits to mark bytes
  - full duplex = separate receive and transmit lines







ECE 331, Prof. A. Mason

Serial Communication,5

#### Common Microcontroller Serial Ports

- Serial Peripheral Interface (SPI)
  - synchronous serial data link standard introduced by Motorola
  - operates in full duplex mode using separate in/out data signals
  - devices communicate in master/slave mode
  - multiple slave devices are allowed with individual slave select (chip select) lines
  - signals
    - · SCLK —
    - · MOSI/SIMO -
    - · MISO/SOMI —
    - · 55 -
      - multiple select lines for multiple slave devices





#### SPI Variations and Controls

- · Clock Polarity and Phase
  - assign rising/falling edge of clock to reading/changing of data
  - Freescale standard: CPOL = polarity,CPHA = phase
- Independent or Daisy Chain Slaves









ECE 331, Prof. A. Mason

Serial Communication,7

#### SPI Pros and Cons

- Advantages
  - Full duplex communication
  - Higher throughput than I 2 C or SMBus
  - Complete protocol flexibility for bits transferred (no limit to word or message size)
  - Extremely simple hardware interfacing
    - Typically lower power requirements than I<sup>2</sup>C or SMBus due to less circuitry
    - No arbitration or associated failure modes
    - Slaves use the master's clock, and don't need precision oscillators
    - Slaves don't need a unique address -- unlike I<sup>2</sup>C or GPIB or SCSI
    - Transceivers are not needed
  - Uses only four pins; much less than parallel interfaces
  - At most one "unique" bus signal per device (chip select); all others are shared
  - Signals are unidirectional allowing for easy Galvanic isolation
- Disadvantages
  - No hardware slave acknowledgment (the master could be "talking" to nothing and not know it)
  - No hardware flow control (but master can delay clock edge to slow transfer rate)
  - Requires more pins on IC packages than  $I^2C$
  - Supports only one master device
  - Generally prone to noise spikes causing faulty communication
  - Without a formal standard, validating conformance is not possible
  - \_ Only handles short distances compared to RS-232, RS-485, or CAN-bus



### Inter-Integrated Circuit Bus

ADC

Slave

Master

DAC

Slave

uC

Slave

- $\cdot$  I  $^{2}$  C is a multi-master serial single-ended computer bus
  - invented by Philips to attach low-speed peripherals to an embedded system
  - uses only two bidirectional open-drain lines
    - · Serial Data Line (SDA)
    - · Serial Clock (SCL)
    - both pulled up with resistors, typical to +5 V or +3.3 V
  - 7-bit address (with 16 reserved addresses) →
  - timing



Data transfer is initiated with the START bit (**S**) when SDA is pulled low while SCL stays high. Then, SDA sets the transferred bit while SCL is low (blue) and the data is sampled (received) when SCL rises (green). When the transfer is complete, a STOP bit (**P**) is sent by releasing the data line to allow it to be pulled up while SCL is constantly high.



ECE 331, Prof. A. Mason

Serial Communication.9

# Error Checking

- A noisy transmission medium can lead to errors in transmission
- Error detection
  - identifying if a transmission error has occurred
- Error correction
  - determine which particular bit is corrupted and fix it
- · Parity Check

- a parity bit is added to ensure that the number of bits with the value one in a set of bits is even (or odd)

- the simplest form of error detecting code
- common as 8th bit for 7-bit ASCII codes



ECE 331, Prof. A. Mason





### ASCII - American Standard Code for Information Interchange

|                          |     | ASCII CI | HARACTE | R SET (7 | -Bit Code   | <del>)</del> |     |       |
|--------------------------|-----|----------|---------|----------|-------------|--------------|-----|-------|
| MS<br>Dig.<br>LS<br>Dig. | 0   | 1        | 2       | 3        | 4           | 5            | 6   | 7     |
| 0                        | NUL | DLE      | SP      | 0        | @<br>A<br>B | Р            | ,   | р     |
| 1 1                      | SOH | DC1      | 1       | 1        | Α           | a            | а   | q     |
| 2                        | STX | DC2      | "       | 2        | В           | R            | Ь   | r     |
| 3                        | ETX | DC3      | #       | 3        | С           | R            | C   | s     |
| 4                        | EOT | DC4      | \$      | 4        |             | Т            | d   | t     |
| 5                        | ENQ | NAK      | %       | 5        | D<br>E<br>F | U            | l e | u     |
| 6                        | ACK | SYN      | &       | 6        | F           | l v          | l f | l v l |
| 7                        | BEL | ETB      | ,       | 7        | G           | w            | g   | w     |
| 8                        | BS  | CAN      | (       | 8        | н           | х            | ĺй  | x     |
| 9                        | HT  | . EM     | · )     | 9        | 1           | Υ,           | i   | l y l |
| A                        | LF  | SUB      | #       | :        | J ·         | Z.           | i   | l ź l |
| • в                      | VT  | ESC      | +       | ;        | K           | l f          | k   | {     |
| l c                      | FF  | FS       | ,       | <        | L           | Ì            | 1   | lil   |
| D .                      | CR  | GS       | _       | =        | ·M          | ı,           | m   | 1 ; 1 |
| E                        | so  | RS       |         | >        | N           | Á            | n   | l     |
| F                        | SI  | US       | /       | ?        | 0           | _            | 0   | DEL   |

ASCII CHART



ECE 331, Prof. A. Mason

Serial Communication.11

#### HC12/S12 Serial Interfaces

- HC12: Multiple Serial Interface (MSI)
  - two SCI channels and one SPI channel
- · HCS12
  - two 2-pin SCI
  - two 4-pin SPI
  - one  ${\bf I}^2{\bf C}$  port
  - several CAN ports
    - standard common in automotive industry



 Parallel ports can be used for additional SPI slave select signals



### HC12 SCI Hardware

Transmitter

· Receiver





Serial Communication.13

# HC12 SCI Registers

- SCI Baud Rate Control Registers
- SCI Control Registers 1, 2
- SCI Status Registers 1, 2
- · SCI Data Registers High/Low

| Desired<br>SCI Baud Rate | BR Divisor for<br>M = 4.0 MHz | BR Divisor for<br>M = 8.0 MHz |
|--------------------------|-------------------------------|-------------------------------|
| 110                      | 2273                          | 4545                          |
| 300                      | 833                           | 1667                          |
| 600                      | 417                           | 833                           |
| 1200                     | 208                           | 417                           |
| 2400                     | 104                           | 208                           |
| 4800                     | 52                            | 104                           |
| 9600                     | 26                            | 52                            |
| 1 4400                   | 17                            | 35                            |
| 19200                    | 13                            | 26                            |
| 38400                    |                               | 13                            |

| 7        | 6    | 5    | 4                 | 3                  | 2     | 1                 | n    |
|----------|------|------|-------------------|--------------------|-------|-------------------|------|
| BTST     | BSPL | BRLD | SBR12             | SBR11              | SBR10 | SBR9              | SBR8 |
|          |      | 9    | 20                |                    | n     |                   |      |
| Reset: 0 | 0    | 0    | 0                 | 0                  | U     | U                 | 0    |
|          |      |      | 0<br>legister (SC | U<br>OBDL/SC1      |       | U<br>Address: \$0 |      |
|          |      |      | 100 100 000000    | U<br>OBDL/SC1<br>3 |       | Address: \$0      |      |

|       | Rese      | t 0     | 0             | 0        | 0       | 0 :  |
|-------|-----------|---------|---------------|----------|---------|------|
|       |           |         |               |          |         |      |
| Regis | ster: SCI | Data Re | gister High ( | SCODRH/  | SCIDRH) |      |
|       | 7         | 6       | 5             | 4        | 3       | 2    |
|       | R8        | T8      | 0             | 0        | 0       | 0    |
| Rese  | t: -      | -       | 0             | 0        | 0       | 0    |
| Regis | ster: SCI | Data Re | gister Low (S | SCODRL/S | CIDRL)  |      |
|       | 7         | 6       | 5             | 4        | 3       | 2    |
| F     | R7T7      | R6T6    | R5T5          | R4T4     | R3T3    | R2T2 |
| Rese  | t: -      | -       |               |          | _       |      |
|       |           |         |               |          |         |      |





s: \$00C7/\$00CF

# SCI Programming





ECE 331, Prof. A. Mason

Serial Communication.15

# SCI Example

Write a subroutine to initialize the SCI. Assume the MCLK = 8 MHz and the data rate is 9600 BAUD. SCI Initialization Example

- · Configure SC1BDL, BDH
- Configure SC1CR1
- · Configure SC1CR2
- · Clear the TDRE flag in SC1SR1
  - Read SC1SR1
  - Write to SC1DR

Solution:

SC1BDH, SC1BDL:

SC1BDH = \$00

SC1BDL = \$34

SC1CR1:

M=0, (1 start, 1 stop,

8 data bits)

SC1CR2:

TE = 1



| ;define register locations and masks |                               |  |  |  |  |
|--------------------------------------|-------------------------------|--|--|--|--|
| SC1BDH = \$00C8                      | ; Baud Register High location |  |  |  |  |
| SC1BDL = \$00C9                      | ; Baud Register Low location  |  |  |  |  |
| BAUD_HI = \$00                       | ; Baud Register High mask     |  |  |  |  |
| BAUD_LOW = \$34                      | ; Baud Register Low mask      |  |  |  |  |
| SC1CR1 = \$00CA                      | ; Control Register 1 location |  |  |  |  |
| SC1_CONT = \$00                      | ; Control Register 1 mask     |  |  |  |  |
| SC1CR2 = \$00CB                      | ; Control Register 2 location |  |  |  |  |

 SC1CR1 = \$00CA
 ; Control Register 1 location

 SC1\_CONT = \$00
 ; Control Register 1 mask

 SC1CR2 = \$00CB
 ; Control Register 2 location

 SC1\_MASK = \$08
 ; Control Register 2 mask

 SC1SR1 = \$00CC
 ; Status Register 1 location

 SC1DRL = \$00CF
 ; Data Register Low location

JSR sci\_ini : :

| ;sci_init: initio | alizes SCI system |           |                     |
|-------------------|-------------------|-----------|---------------------|
| sci_init::        | LDAA              | #BAUD_LOW | ;set BAUD rate      |
|                   | STAA              | SC1BDL    |                     |
|                   | LDAA              | #BAUD_HI  |                     |
|                   | STAA              | SC1BDH    |                     |
|                   | LDAA              | #SCI_CONT | ;set MODE           |
|                   | STAA              | SC1CR1    |                     |
|                   | LDAA              | #SC1_MASK | ;enable transmitte  |
|                   | STAA              | SC1CR2    |                     |
|                   | LDAA              | SC1SR1    | ;clear TDRE bit - i |
|                   |                   |           |                     |

