Abstract
The HardwareSerial::begin() sets theg communication speed and other settings.
To meet the purpose, the HardwareSerial::begin() sets UCSR0A, UCSR0B, UCSR0C, UBRR0H and UBRR0L.
Source Code
The HardwareSerial::begin() is defined in hardware/arduino/cores/arduino/HardwareSerial.cpp as below.
|
|
The input is baud and config, their type are unsigned long and byte respectively.
The baud means communication speed in bps.
The config sets data length, parity, and stop bit. If this argument is omitted, SERIAL_8N1(8bit, no parity, stop bit 1) is used.
|
|
The baud_setting is the value to set to UBRR0H/UBRR0L. With the combination of U2X0 bit in UCSR0A, the speed is determined.
First, it calculates with U2X0 bit on.
According to the data sheet, the communication speed(baud) is defined as below.
- In case of U2X0 = 0
- URBR0 = (F_CPU / (16 * BAUD)) - 1
- In case of U2X0 = 1
- URBR0 = (F_CPU / (8 * BAUD)) - 1
But the Arduino software sets it as below.
- In case of U2X0 = 0
- UBRR0 = (F_CPU / 8 / baud - 1) / 2
- In case of U2X0 = 1
- UBRR0 = (F_CPU / 4 / baud - 1) / 2
So it would become 0.5 greater than specification, but the UBRR0 is an integer, it would be the same.
|
|
If F_CPU is 16000000(16MHz) and baud is 57600, or baud_setting is greater than 4095(when the baud is less than or equal to 488), sets the U2X0 to 0 and calculate it again.
|
|
Sets the calculated baud_setting to UBRR0. Upper 4 bits to UBRR0H and lower 8 bits to UBRR0L.
Then sets the _written to false. Once we write data to the transmit buffer, it becomes true. The value is used in HardwareSerial::flush().
|
|
Next, sets config to UCSR0C. It is the register to set parity , stop bit and so on.
|
|
Finally sets UCSR0B register. sbi() is a function to set the second argument bit of the first argument to 1. cbi() sets to 0.
Version
Arduino AVR Boards 1.8.6
Last Update
August 25, 2019