mirror of
https://github.com/ferrous-systems/embedded-trainings-2020.git
synced 2025-01-10 08:15:36 +00:00
Merge pull request #201 from ferrous-systems/fix_serial_term
Add pyserial and change uarte setup
This commit is contained in:
commit
3a4acd3543
4 changed files with 33 additions and 20 deletions
|
@ -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 {
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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.
|
|
@ -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.
|
|
Loading…
Reference in a new issue