mirror of
https://github.com/ferrous-systems/embedded-trainings-2020.git
synced 2025-01-25 15:28:07 +00:00
add step by step solution
This commit is contained in:
parent
14d76fb10e
commit
3afc29ca72
1 changed files with 44 additions and 0 deletions
|
@ -0,0 +1,44 @@
|
||||||
|
# Write the Button Implementation
|
||||||
|
## Step-by-Step Solution
|
||||||
|
|
||||||
|
1. Read the docs!
|
||||||
|
Read docs, section 8.7 for info about pins and pin configuration related to the buttons. Note down the pins that the buttons are connected to.
|
||||||
|
The pins need to be configured as input pins with an internal pull-up. The pins as well as the configurations are defined as types in the `nrf-hal` in the `gpio` peripheral. Add the following imports: `Input` and `PullUp`.
|
||||||
|
|
||||||
|
2. Add the structs that represent the buttons as a group and a generic single button.
|
||||||
|
|
||||||
|
Add the struct that represents the single button. It has only one field, `inner`. The type of this button is the pin configuration: `Pin<Input<PullUp>>`
|
||||||
|
|
||||||
|
Add the `struct` that represents the group of buttons has four fields, one for each button. The field name contains the number that corresponds to the button numeration on the board. The of type of each field is the struct that represents the generic single button.
|
||||||
|
|
||||||
|
Add doc comments for every struct and field!
|
||||||
|
|
||||||
|
Building this code should return a warning: field `inner` is never read
|
||||||
|
<!-- Solution Code Snippet -->
|
||||||
|
|
||||||
|
1. Implement the button function.
|
||||||
|
|
||||||
|
Add an `impl` block for the `struct Button`. Add a method `is_pushed` that takes in the struct as `&self` and returns a bool, if the button is pushed.
|
||||||
|
|
||||||
|
Now remember, the pins the buttons are connected to are configured as active low. For buttons this means, that the pin is pulled low, when the button is pushed.
|
||||||
|
|
||||||
|
In the `nrf-hal` you can find a method to check if a single pin is low. To use it, you have to add the following line to your `nrf52840_hal` imports: `prelude::InputPin`.
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Solution Code Snippet -->
|
||||||
|
|
||||||
|
4. Bring up the pins!
|
||||||
|
|
||||||
|
Go to `pub fn init()`, the function that initializes the board's peripherals. Get your notes for the pin numbers that are reserver for the buttons. Configure each pin as degraded, pull-up input pin and bind it to a variable that makes it clear what button number it is connected to.
|
||||||
|
|
||||||
|
Building this code brings up warnings about unused variables.
|
||||||
|
<!-- Solution Code Snippet -->
|
||||||
|
|
||||||
|
5. Add everything to the board struct.
|
||||||
|
|
||||||
|
In the definition of the board struct add a field for the `struct Buttons`
|
||||||
|
In the pub `fn init()` function. Add the button field to the instantiation of the Board struct, assigning the pins you defined earlier to the respective buttons.
|
||||||
|
|
||||||
|
<!-- Solution Code Snippet -->
|
||||||
|
|
||||||
|
6. Run the example!
|
Loading…
Reference in a new issue