mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 01:12:44 +01:00
163 lines
9.1 KiB
Plaintext
163 lines
9.1 KiB
Plaintext
|
/**
|
||
|
@defgroup boards_waveshare_nrf52840_eval_kit Waveshare nRF52840 Eval Kit
|
||
|
@ingroup boards
|
||
|
@brief Support for the Waveshare nRF52840 Eval Kit
|
||
|
@author Gunar Schorcht <gunar@schorcht.net>
|
||
|
|
||
|
## Overview
|
||
|
|
||
|
The [Waveshare nRF52840 Eval Kit]
|
||
|
(https://www.waveshare.com/NRF52840-Eval-Kit.htm) is an evaluation board
|
||
|
for the nRF52840 SoC with the following on-board components:
|
||
|
|
||
|
1. Arduino headers for connecting Arduino shields
|
||
|
2. Raspberry Pi GPIO header for connecting Raspberry Pi HATs
|
||
|
3. USB TO UART interface
|
||
|
4. USB port of nRF52840
|
||
|
5. 4PIN SWD debugging interface for connecting ARM Debugger to program / debug
|
||
|
6. 3.3V/5V power input/output provides power output OR powered from external
|
||
|
power supply
|
||
|
7. Waveshare Core52840: nRF52840 core module
|
||
|
8. CP2102: USB TO UART converter
|
||
|
9. Buzzer
|
||
|
10. RT9193-33: 3.3V voltage regulator
|
||
|
11. Optical sensor
|
||
|
12. RESET and USER KEY
|
||
|
13. 4 User LEDs
|
||
|
14. Power switch: USB powered - OFF - Battery powered
|
||
|
15. NFC antenna connector
|
||
|
16. TF card slot
|
||
|
17. CR2032 battery holder
|
||
|
|
||
|
![Waveshare nRF52840 Eval Kit]
|
||
|
(https://www.waveshare.com/img/devkit/accBoard/NRF52840-Eval-Kit/NRF52840-Eval-Kit-intro.jpg)
|
||
|
|
||
|
Using the onboard Arduino and Raspberry Pi compatible headers, both Arduino
|
||
|
shields and Raspberry Pi HATs can be used at the same time.
|
||
|
|
||
|
## Hardware:
|
||
|
|
||
|
| MCU | NRF52840 |
|
||
|
|:---------- |:------------------------------------ |
|
||
|
| Family | ARM Cortex-M4 |
|
||
|
| Vendor | Nordic Semiconductor |
|
||
|
| RAM | 256 kByte |
|
||
|
| Flash | 1 MByte |
|
||
|
| Frequency | 64 MHz |
|
||
|
| FPU | yes |
|
||
|
| GPIOs | 48 |
|
||
|
| Timers | 5 x 32-bit counter |
|
||
|
| RTC | 3 x Real Time Counter |
|
||
|
| ADCs | 1 x 12-bit 200 ksps with 8 channels |
|
||
|
| UARTs | 2 |
|
||
|
| SPIs | 1 x QSPI, 3 x SPI master/slave |
|
||
|
| I2Cs | 2 |
|
||
|
| I2S | 1 |
|
||
|
| PWM | 4 * 4 Channels |
|
||
|
| Crypto | AES-128, SHA1/2, RSA, Chacha20/Poly1305, ECC |
|
||
|
| Radio | 2.4 GHz transceiver, Bluetooth 5, IEEE 802.15.4 |
|
||
|
| Vcc | 1.7V - 5.5V |
|
||
|
| Datasheet | [Datasheet](https://www.nordicsemi.com/Products/Low-power-short-range-wireless/nRF52840) |
|
||
|
| Reference Manual | [Reference Manual](https://infocenter.nordicsemi.com/pdf/nRF52840_PS_v1.1.pdf) |
|
||
|
| Board Manual | [Board Manual](https://www.waveshare.com/w/upload/7/71/NRF52840_Eval_Kit_User_Manual_EN.pdf) |
|
||
|
| Board Schematic | [Board Schematic](https://www.waveshare.com/w/upload/f/f2/NRF52840-Eval-Kit-Schematic.pdf) |
|
||
|
|
||
|
## Pin Layout / Configuration
|
||
|
|
||
|
The following table shows the connection of the on-board components with the
|
||
|
MCU pins. All these connections are jumpered and can be removed.
|
||
|
|
||
|
| MCU Pin | MCU Peripheral | RIOT Peripheral | Board Function | Arduino Header | Rasperry Pi (*) |
|
||
|
|:------|:-----------|:--------------------|:----------------------|:-----------|:-----------|
|
||
|
| P0.02 | ADC | ADC_LINE(0) | | AREF | |
|
||
|
| P0.03 | ADC | ADC_LINE(1) | | A0 | P26 (32) |
|
||
|
| P0.04 | ADC | ADC_LINE(2) | | A1 | P27 (36) |
|
||
|
| P0.05 | ADC | ADC_LINE(3) | Optical sensor (LDR) | | P7 (7) |
|
||
|
| P0.06 | UARTE0 RX | UART_DEV(0) RX | UART RX | | P21 (29) |
|
||
|
| P0.07 | UARTE0 CTS | UART_DEV(0) CTS | UART CTS | | P6 (22) |
|
||
|
| P0.08 | UARTE0 TX | UART_DEV(0) TX | UART TX | | P3 (15) |
|
||
|
| P0.09 | | | NFC Antenna Connector | | P1 (12) |
|
||
|
| P0.10 | | | NFC Antenna Connector | | P25 (37) |
|
||
|
| P0.11 | | BTN0 | Button KEY1 | | P2 (13) |
|
||
|
| P0.12 | | SPI_DEV(1) CS | SD Card CS | | CIE1 (26) |
|
||
|
| P0.13 | PWM | PWM_DEV(1).0 / LED1 | LED1 | | P24 (35) |
|
||
|
| P0.14 | | PWM_DEV(1).1 / LED2 | LED2 | | P23 (33) |
|
||
|
| P0.15 | | PWM_DEV(2).0 | Buzzer | | P22 (31) |
|
||
|
| P0.16 | | PWM_DEV(1).3 / LED4 | LED4 | | ID_SD (27) |
|
||
|
| P0.17 | SPI1 SCK | SPI_DEV(1) SCK | SD Card SCLK | | SCLK (23) |
|
||
|
| P0.18 | | BTN1 | Button RESET | | |
|
||
|
| P0.19 | | | | | TXD0 (8) |
|
||
|
| P0.20 | SPI1 MISO | SPI_DEV(1) MISO | SD Card MISO | | MISO (21) |
|
||
|
| P0.21 | | | | | RXD0 (10) |
|
||
|
| P0.22 | I2C0 SCL | I2C_DEV(1) SCL | | | SCL (5) |
|
||
|
| P0.23 | | | | | CIE0 (24) |
|
||
|
| P0.24 | SPI1 MOSI | SPI_DEV(1) MOSI | SD Card MOSI | | MOSI (19) |
|
||
|
| P0.25 | UARTE0 RTS | UART_DEV(0) RTS | UART RTS | | P0 (11) |
|
||
|
| P0.26 | I2C1 SDA | I2C_DEV(0) SDA | I2C SDA | SDA | |
|
||
|
| P0.27 | I2C1 SCL | I2C_DEV(0) SCL | I2C SCL | SCL | |
|
||
|
| P0.28 | ADC | ADC_LINE(4) | | A2 | P28 (38) |
|
||
|
| P0.29 | ADC | ADC_LINE(5) | | A3 | P29 (40) |
|
||
|
| P0.30 | ADC | ADC_LINE(6) | | A4 | |
|
||
|
| P0.31 | ADC | ADC_LINE(7) | | A5 | |
|
||
|
| P1.00 | I2C0 SDA | I2C_DEV(1) SDA | | | SDA (3) |
|
||
|
| P1.01 | UARTE1 RX | UART_DEV(1) RX | | D0 / RX | |
|
||
|
| P1.02 | UARTE1 TX | UART_DEV(1) TX | | D1 / TX | |
|
||
|
| P1.03 | | | | D2 | |
|
||
|
| P1.04 | | PWM_DEV(0).0 | | D3 / PWM | |
|
||
|
| P1.05 | | | | D4 | |
|
||
|
| P1.06 | | PWM_DEV(0).1 | | D5 / PWM | |
|
||
|
| P1.07 | | PWM_DEV(0).2 | | D6 / PWM | |
|
||
|
| P1.08 | | | | D7 | |
|
||
|
| P1.09 | | PWM_DEV(1).2 / LED3 | LED3 | | ID_SC (28) |
|
||
|
| P1.10 | | | | D8 | |
|
||
|
| P1.11 | | PWM_DEV(0).3 | | D9 / PWM | |
|
||
|
| P1.12 | | | | D10 / SS | |
|
||
|
| P1.13 | SPI0 MOSI | SPI_DEV(0) MOSI | | D11 / MOSI | |
|
||
|
| P1.14 | SPI0 MISO | SPI_DEV(0) MISO | | D12 / MISO | |
|
||
|
| P1.15 | SPI0 SCK | SPI_DEV(0)SCK | | D13 / SCK | |
|
||
|
|
||
|
**(*)** Raspberry Pi header pins are given by the labels as used on the board.
|
||
|
These labels correspond to the pins and names as used by the 'WiringPi'
|
||
|
library. For detailed information on how these numbers are mapped to the GPIOs
|
||
|
of the BCM SoCs, see [this document](https://pinout.xyz/pinout/wiringpi).
|
||
|
The numbers in the brackets are the pin numbers of the 40-pin header.
|
||
|
|
||
|
## Flash the board
|
||
|
|
||
|
See the `Flashing` section in @ref boards_common_nrf52.
|
||
|
|
||
|
The easiest way is to use a Segger J-Link and connect it to the SWD header of
|
||
|
the board as follows:
|
||
|
|
||
|
- Segger J-Link Pin 7 with SWD Header pin `DIN`
|
||
|
- Segger J-Link Pin 9 with SWD Header pin `CLK`
|
||
|
|
||
|
## Accessing STDIO via UART
|
||
|
|
||
|
The `stdio` is directly accessible via the on-board CP2102 USB to UART bridge.
|
||
|
On a Linux host, this interface is mapped to `/dev/ttyUSB<n>` where `<n>` is
|
||
|
the index of the UART interface which is 0 by default.
|
||
|
|
||
|
Use the `term` target to connect to the board serial port using `/dev/ttyUSB0`:
|
||
|
```
|
||
|
make BOARD=waveshare-nrf52840-eval-kit -C examples/hello-world term
|
||
|
```
|
||
|
If the UART interface index of board's USB to UART bridge is not 0, use
|
||
|
the following command to connect to the board serial port:
|
||
|
```
|
||
|
make BOARD=waveshare-nrf52840-eval-kit -C examples/hello-world PORT=/dev/ttyUSB<n> term
|
||
|
```
|
||
|
|
||
|
## RESET Pin Configuration
|
||
|
|
||
|
On nRF52840 boards, the RESET pin is not configured out-of-the box.
|
||
|
This means, that simply nothing happens if the RESET button is pressed. To
|
||
|
change this, RIOT provides a little tool in `dist/tools/nrf52_resetpin_cfg`:
|
||
|
```
|
||
|
RESET_PIN='GPIO_PIN\(0,18\)' make BOARD=waveshare-nrf52840-eval-kit -C dist/tools/nrf52_resetpin_cfg/ flash
|
||
|
```
|
||
|
Simply compile, flash, and run that tool on your board, and the reset pin should
|
||
|
work for the time being.
|
||
|
|
||
|
*/
|