mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-22 17:26:34 +11:00
Fix UART init code
Set uartlcr_h before enabling the UART. Writing uartlcr_h while the UART is enabled is forbidden by the datasheet. Details can be found here: https://developer.arm.com/documentation/ddi0183/g/programmers-model/register-descriptions/line-control-register--uartlcr-h?lang=en (As referenced from the Datasheet)
This commit is contained in:
parent
73431a847b
commit
b1dc9aec8c
1 changed files with 6 additions and 7 deletions
|
@ -221,6 +221,12 @@ impl<D: UartDevice> UartPeripheral<Disabled, D> {
|
|||
|
||||
let effective_baudrate = configure_baudrate(&mut device, &config.baudrate, &frequency)?;
|
||||
|
||||
device.uartlcr_h.write(|w| {
|
||||
w.fen().set_bit();
|
||||
set_format(w, &config.data_bits, &config.stop_bits, &config.parity);
|
||||
w
|
||||
});
|
||||
|
||||
// Enable the UART, both TX and RX
|
||||
device.uartcr.write(|w| {
|
||||
w.uarten().set_bit();
|
||||
|
@ -229,13 +235,6 @@ impl<D: UartDevice> UartPeripheral<Disabled, D> {
|
|||
w
|
||||
});
|
||||
|
||||
device.uartlcr_h.write(|w| {
|
||||
w.fen().set_bit();
|
||||
|
||||
set_format(w, &config.data_bits, &config.stop_bits, &config.parity);
|
||||
w
|
||||
});
|
||||
|
||||
device.uartdmacr.write(|w| {
|
||||
w.txdmae().set_bit();
|
||||
w.rxdmae().set_bit();
|
||||
|
|
Loading…
Add table
Reference in a new issue