USART Serial Port in AVR Microcontrollers: (Chapter 11 of The Mazidi's Book)

Download as pdf or txt
Download as pdf or txt
You are on page 1of 37

Microprocessors, Lecture 6:

USART Serial Port in AVR Microcontrollers


(Chapter 11 of the Mazidis book)

Contents
Serial communication
Serial communication programming in C

University of Tehran 2

Serial ports in AVR

University of Tehran 3

Serial ports in AVR


USART: and old and widely used
standard (pins 14 and 15 of
ATmega32)
SPI: very high-speed (~ two
orders of magnitude faster than
USART) synchronous serial port
For example for high-speed
data transfer to EPROM
Pins 5,6,and 7 of Atmega32
I2C (Inter IC)
Connection using a shared bus
connecting up to 128 devices
Pins 22 and 23 of ATmega32
University of Tehran 4

Data transmission

Data transmission between AVR and peripheral


devices like sensors is straightforward
Connect the device to one of the AVR ports and read
the port

Data transmission between two AVRs or an AVR


and a PC is more complex
Requires a communication protocol

Communication Protocol: a set of standards and


rules that orchestrates data communication
between two or more devices

University of Tehran 5

RS232

An old standard for serial communication


Still used in many devices like PCs
Is used in serial port (COM port) of PCs

PCs used to have 2 COM ports, but


today PCs have one port or no port
Replaced with USB ports

University of Tehran 6

RS232
Requires 3 pins:
RXD= receive, TXD: transmit, GND= ground
The RXD and TXD pins are cross-connected

University of Tehran 7

COM ports

COM = communication port


Find it at the back of your PC case!
Pins 2,3,and 5 are TXD,RXD, and GND,
respectively.

University of Tehran 8

Serial communication in AVR


USART: a standard IC that provides both synchronous and
asynchronous communication
A peripheral IC of the AVR microcontrollers
Connected to RXD and TXD pins of Atmega32

University of Tehran 9

USART
USART: Universal Synchronous/Asynchronous
Receiver Transmitter
An standard IC that can provide both
synchronous and asynchronous communication
It is controlled by some AVR registers

University of Tehran 10

USART block diagram in AVR

University of Tehran 11

USART

The control registers specify:

The mode of operation: synchronous or asynchronous


Parity bit: odd or even
Information unit: 5,6,7,8, or 9 bits
Information unit separation: how to specify the
transmission of a word starts and stops?
Transmission rate
.

University of Tehran 12

Parity bit
A way to detect error during data transmission
Due to external noises

Even parity= the number of 1s must be an even


number
Add an extra bit to the 8-bit data, called parity bit
How does it work?
if the number of 1s is already even, set it to 0,
otherwise to 1
Send the parity bit with data
If the other side detects odd number of 1s, there is
something wrong

University of Tehran 13

Transmission rate

Baud rate vs bit rate


Baud rate: the number signal changes in a second
Bit rate: the number of bits transmitted per second
Baud rate is not necessarily equal to bit rate
Each signal may carry several bits!

A signal with 8 levels can carry 3 bits

If baud rate=x, bit rate=3x


In USART, baud rate= bit rate
The bit rate of both devices connected to the same
serial port must be the same

University of Tehran 14

AVR serial port programming

Setting different registers


5 registers are associated with serial port:
UDR: USART data register
UCSRA, UCSRB, UCSRC: USART control and
status register
UBRR: USART baud rate register

University of Tehran 15

UDR

USART data register


Actually two registers: one for the transmit
direction, the other for receive direction
Share the same address and name
When UDR is read, the data received from the
serial line is returned
When a data is written to UDR, it is directed to
the transmit line

University of Tehran 16

UDR

University of Tehran 17

UCSR

USART control and status register


Three 8-bit registers to control the USART
operation

University of Tehran 18

UCSRA

University of Tehran 19

UCSRA- continue

University of Tehran 20

UCSRA- continue

University of Tehran 21

UCSRB

University of Tehran 22

UCSRB- continue

University of Tehran 23

UCSRC

Note on bit7: UCSRC and UBBR share the


same address due to some technical issue. Set
URSEL=1 when you want the data to be written
to UCSRC, otherwise set URSEL=0 to write to
UBBR
University of Tehran 24

UCSRC- continue

University of Tehran 25

UCSR
Character size of the transmitted and received
data- is same for both directions

University of Tehran 26

UBRR

USART Baud Rate Register


12 bits
The most significant byte has a shared address
with UCSRC!

X= UBBR[0-11]
University of Tehran 27

USART baud rate

University of Tehran 28

Sampling

Sampling rate: 16 times faster than baud rate


2 out of 3 majority voting in cycles 8 to 9

University of Tehran 29

USART in Tx mode

University of Tehran 30

USART in Rx mode

University of Tehran 31

Synchronous mode

Work in master-slave mode


The master send clock signal to slave

University of Tehran 32

Synchronous mode

UCPOL: bit 7 in UCSRC


Baud rate= fosc/(2(UBBR+1))
University of Tehran 33

USART programming in C
Send a sequence of numbers started from 0
every 350ms to TXD pin
Check RXD pin and if the received number is
0x55 set PD.6 (bit 6 of port D) to 1
0x66 set PD.6 to 0

1 stop bit, no parity, 8 bit, asynchronous

University of Tehran 34

Code vision configuration

University of Tehran 35

USART programming in C
main()
{
int a=0;
DDRD.6=1;
UCSRA=0x0;
UCSRB=0x98; //10011000 (RXIE=1, RXEN=1, TXEN=1)
UCSRC=0x86;// 10000110 (URSEL=1,asynch, no parity, one stop bit, 8 bit)
UBRRH=0;// just set a rate that guarantees the data transfer can be completed before 350ms
UBRRL=0x08;
Interrupt [USART_RXC] usart_rx_isr()
#asm(sei);
{
while(1)
char data;
{
data=UDR;
UDR= a++;
if(data==0x55)
delay_ms(350);
PORTD.6=1;
if(data==0x66)
}
PORTD.6=0;
}
}
University of Tehran 36

USART in PCs

Implemented by the 8251 IC

University of Tehran 37

You might also like