Datasheet

Table Of Contents
3.6.3. UART TX
Figure 50. UART serial
format. The line is
high when idle. The
transmitter pulls the
line down for one bit
period to signify the
start of a serial frame
(the "start bit"), and a
small, fixed number of
data bits follows. The
line returns to the idle
state for at least one
bit period (the "stop
bit") before the next
serial frame can
begin.
This program implements the transmit component of a universal asynchronous receive/transmit (UART) serial peripheral.
Perhaps it would be more correct to refer to this as a UAT.
Pico Examples: https://github.com/raspberrypi/pico-examples/tree/pre_release/pio/uart_tx/uart_tx.pio Lines 7 - 17
Ê7 .program uart_tx
Ê8 .side_set 1 opt
Ê9
10 ; An 8n1 UART transmit program.
11 ; OUT pin 0 and side-set pin 0 are both mapped to UART TX pin.
12
13 pull side 1 [7] ; Assert stop bit, or stall with line in idle state
14 set x, 7 side 0 [7] ; Preload bit counter, assert start bit for 8 clocks
15 bitloop: ; This loop will run 8 times (8n1 UART)
16 out pins, 1 ; Shift 1 bit from OSR to the first OUT pin
17 jmp x-- bitloop [6] ; Each loop iteration is 8 cycles.
As written, it will:
Stall with the pin driven high until data appears (noting that side-set takes effect even when the state machine is
stalled)
Assert a start bit, for 8 SM execution cycles
Shift out 8 data bits, each lasting for 8 cycles
Return to the idle line state for at least 8 cycles before asserting the next start bit
If the state machine’s clock divider is configured to run at 8 times the desired baud rate, this program will transmit well-
formed UART serial frames, whenever data is pushed to the TX FIFO either by software or the system DMA. To extend the
program to cover different frame sizes (different numbers of data bits), the set x, 7 could be replaced with mov x, y, so
that the y scratch register becomes a per-SM configuration register for UART frame size.
The .pio file in the SDK also contains this function, for configuring the pins and the state machine, once the program has
been loaded into the PIO instruction memory:
Pico Examples: https://github.com/raspberrypi/pico-examples/tree/pre_release/pio/uart_tx/uart_tx.pio Lines 23 - 50
23 static inline void uart_tx_program_init(PIO pio, uint sm, uint offset, uint pin_tx, uint
Ê baud) {
24 // Tell PIO to initially drive output-high on the selected pin, then map PIO
25 // onto that pin with the IO muxes.
26 pio_sm_set_pins_with_mask(pio, sm, 1u << pin_tx, 1u << pin_tx);
27 pio_sm_set_pindirs_with_mask(pio, sm, 1u << pin_tx, 1u << pin_tx);
28 pio_gpio_select(pio, pin_tx);
29
30 pio_sm_config c = uart_tx_program_get_default_config(offset);
31
32 // OUT shifts to right, no autopull
33 sm_config_set_out_shift(&c, true, false, 32);
34
35 // We are mapping both OUT and side-set to the same pin, because sometimes
36 // we need to assert user data onto the pin (with OUT) and sometimes
37 // assert constant values (start/stop bit)
38 sm_config_set_out_pins(&c, pin_tx, 1);
RP2040 Datasheet
3.6. Examples 350