Merge pull request #201 from ferrous-systems/fix_serial_term

Add pyserial and change uarte setup
This commit is contained in:
Tanks Transfeld 2023-03-21 18:51:55 +01:00 committed by GitHub
commit 3a4acd3543
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 33 additions and 20 deletions

View file

@ -237,12 +237,12 @@ pub fn init() -> Result<Board, ()> {
let pins = hal::uarte::Pins { let pins = hal::uarte::Pins {
rxd: pins.p0_08.degrade().into_floating_input(), rxd: pins.p0_08.degrade().into_floating_input(),
txd: pins.p0_06.degrade().into_push_pull_output(Level::High), txd: pins.p0_06.degrade().into_push_pull_output(Level::High),
cts: Some(pins.p0_07.degrade().into_floating_input()), cts: None,
rts: Some(pins.p0_05.degrade().into_push_pull_output(Level::High)), rts: None,
}; };
let uarte = hal::uarte::Uarte::new(periph.UARTE1, pins, Parity::INCLUDED, Baudrate::BAUD115200); let uarte = hal::uarte::Uarte::new(periph.UARTE1, pins, Parity::EXCLUDED, Baudrate::BAUD115200);
// 🔼 --- UARTE Exercise --- 🔼 // 🔼 --- UARTE Exercise --- 🔼
Ok(Board { Ok(Board {

View file

@ -12,9 +12,6 @@ This program will not call any of the functions you are implementing, so it does
`down-the-stack/dk_bsc/src/lib_solution.rs` contains the full solution code. `down-the-stack/dk_bsc/src/lib_solution.rs` contains the full solution code.
## You will learn how to ## You will learn how to
* modify the `init()` function that brings up the board's peripherals * modify the `init()` function that brings up the board's peripherals
* how to configure pins * how to configure pins
@ -24,6 +21,7 @@ This program will not call any of the functions you are implementing, so it does
* to document and generate docs for your own library! * to document and generate docs for your own library!
## Prerequisites ## Prerequisites
* installation of `pyserial` or other serial terminal that you are familiar with.
* `impl` keyword * `impl` keyword
* methods and associated functions * methods and associated functions
* `pub` keyword * `pub` keyword

View file

@ -157,3 +157,6 @@ $ cargo install nrfdfu
(..) (..)
Installed package `nrfdfu v0.1.3` (..) Installed package `nrfdfu v0.1.3` (..)
``` ```
## pySerial for Down The Stack
If you don't have a serial terminal you're familiar with, we recommend using `pySerial`. Follow the installation instructions [here](https://pythonhosted.org/pyserial/pyserial.html#installation). This may require an update of your python installation. This is needed for the second day of the 3 day embedded training.

View file

@ -3,11 +3,13 @@
### Step 1: Check Documentation. ### Step 1: Check Documentation.
The UART protocol requires four pins, they are usually labelled: The UART protocol requires up to four pins, two are mandatory, additional two are optional. they are usually labelled:
* RXD * RXD
* TXD * TXD
* CTS * CTS (optional)
* RTS * RTS (optional)
We will only use the mandatory ones.
✅ Check the [User Guide in section 7.2](https://infocenter.nordicsemi.com/topic/ug_nrf52840_dk/UG/dk/vir_com_port.html) to find to find out which pins are reserved for these and what their configuration needs to be. ✅ Check the [User Guide in section 7.2](https://infocenter.nordicsemi.com/topic/ug_nrf52840_dk/UG/dk/vir_com_port.html) to find to find out which pins are reserved for these and what their configuration needs to be.
@ -24,6 +26,7 @@ A quick search of the document reveals where to find all of them:
* `Parity` and `Baudrate`: Re-export on line 34 * `Parity` and `Baudrate`: Re-export on line 34
✅ Add the following lines as import: ✅ Add the following lines as import:
``` ```
use hal::pac::uarte0::{ use hal::pac::uarte0::{
baudrate::BAUDRATE_A as Baudrate, config::PARITY_A as Parity}; baudrate::BAUDRATE_A as Baudrate, config::PARITY_A as Parity};
@ -53,14 +56,14 @@ pub struct Uarte {
✅ Take a closer look at the definition of the `uarte::Pins` struct in the `nrf-hal`. Compare the pin type configurations with the ones you have already imported in `lib.rs`. Add the ones you're missing. ✅ Take a closer look at the definition of the `uarte::Pins` struct in the `nrf-hal`. Compare the pin type configurations with the ones you have already imported in `lib.rs`. Add the ones you're missing.
✅ Create an instance of this struct in `fn init()` with the appropriate pins and configurations. Set the output pin's level to `Level::High`. ✅ Create an instance of this struct in `fn init()` with the appropriate pins and configurations. Set the output pin's level to `Level::High`.
Note, that the third and fourth pin are each wrapped in an `Option`. Note, that the third and fourth pin are each wrapped in an `Option`: Their type is `None` in this case.
✅ Create a Uarte driver with `hal::uarte::Uarte::new(...)` and bind it to a variable called `uarte` - we will stash this in our own `Uarte` struct later. ✅ Create a Uarte driver with `hal::uarte::Uarte::new(...)` and bind it to a variable called `uarte` - we will stash this in our own `Uarte` struct later.
Creating the Uarte driver requires four arguments: Creating the Uarte driver requires four arguments:
* The `UARTE1` instance can be found in the `periph` variable. * The `UARTE1` instance can be found in the `periph` variable.
* Your instance of the `uarte::Pins` struct. * Your instance of the `uarte::Pins` struct.
* Set parity to `Parity::INCLUDED` * Set parity to `Parity::EXCLUDED`
* set the baud rate to `Baudrate::BAUD115200`. * set the baud rate to `Baudrate::BAUD115200`.
<details> <details>
@ -70,12 +73,12 @@ Creating the Uarte driver requires four arguments:
let pins = hal::uarte::Pins { let pins = hal::uarte::Pins {
rxd: pins.p0_08.degrade().into_floating_input(), rxd: pins.p0_08.degrade().into_floating_input(),
txd: pins.p0_06.degrade().into_push_pull_output(Level::High), txd: pins.p0_06.degrade().into_push_pull_output(Level::High),
cts: Some(pins.p0_07.degrade().into_floating_input()), cts: None,
rts: Some(pins.p0_05.degrade().into_push_pull_output(Level::High)), rts: None,
}; };
let uarte = hal::uarte::Uarte::new(periph.UARTE1, pins, Parity::INCLUDED, Baudrate::BAUD115200); let uarte = hal::uarte::Uarte::new(periph.UARTE1, pins, Parity::EXCLUDED, Baudrate::BAUD115200);
``` ```
</details> </details>
@ -165,18 +168,28 @@ impl fmt::Write for Uarte {
</details> </details>
### Step 7: Connect your computer to the virtual UART ### Step 7: Connect your computer to the virtual UART
[todo!] [directions for mac present, linux and windows are missing.]
✅ Use the following command to find the address of the nRF52840-DK on your computer. ✅ Use the following command to find the address of the nRF52840-DK on your computer.
Linux:
```
$ ls /dev/ttyACM*
```
MacOS:
``` ```
ls /dev/tty.usbmodem* ls /dev/tty.usbmodem*
``` ```
✅ Run the following command to run `screen` with the nRF52840-DK with 115200 baud. Windows:
a USB Serial Device (COM port) in the Device Manager under the Ports section.
✅ Run the following command to run `miniterm` with the nRF52840-DK with 115200 baud. This includes the default settings of no parity, 8 data bits, 1 stop bit
``` ```
screen <address of mc> 115200 python3 -m serial.tools.miniterm <address> 115200
``` ```
### Step 8: Run the example. ### Step 8: Run the example.
@ -187,6 +200,5 @@ screen <address of mc> 115200
cargo run --bin uarte_print cargo run --bin uarte_print
``` ```
On your terminal window where `screen` runs, "Hello, World" should appear. On your terminal window where `miniterm` runs, "Hello, World" should appear.
You need to terminate `screen` manually.