nRF52840 Dongle
Overview
The nRF52840 Dongle (PCA10059) hardware provides support for the Nordic Semiconductor nRF52840 ARM Cortex-M4F CPU and the following devices:
ADC
CLOCK
FLASH
GPIO
I2C
MPU
NVIC
PWM
RADIO (Bluetooth Low Energy and 802.15.4)
RTC
SPI
UART
USB
WDT
More information about the board can be found at the nRF52840 Dongle website [1]. The nRF52840 Dongle guide [2] contains the processor’s information and the datasheet.
Hardware
The nrf52840dongle/nrf52840
has two external oscillators. The frequency of
the slow clock is 32.768 kHz. The frequency of the main clock
is 32 MHz.
Supported Features
The nrf52840dongle
board supports the hardware features listed below.
- on-chip / on-board
- Feature integrated in the SoC / present on the board.
- 2 / 2
-
Number of instances that are enabled / disabled.
Click on the label to see the first instance of this feature in the board/SoC DTS files. -
vnd,foo
-
Compatible string for the Devicetree binding matching the feature.
Click on the link to view the binding documentation.
Type |
Location |
Description |
Compatible |
---|---|---|---|
CPU |
on-chip |
ARM Cortex-M4F CPU1 |
|
ADC |
on-chip |
Nordic Semiconductor nRF family SAADC node1 |
|
ARM architecture |
on-chip |
Nordic UICR (User Information Configuration Registers)1 |
|
on-chip |
Nordic EGU (Event Generator Unit)6 |
||
on-chip |
Nordic nRF family ACL (Access Control List)1 |
||
on-chip |
Nordic nRF family MWU (Memory Watch Unit)1 |
||
Audio |
on-chip |
Nordic PDM (Pulse Density Modulation interface)1 |
|
Clock control |
on-chip |
Nordic nRF clock control node1 |
|
Comparator |
on-chip |
Nordic nRF COMP (analog COMParator)1 |
|
Counter |
on-chip |
Nordic nRF timer node5 |
|
Cryptographic accelerator |
on-chip |
Nordic ECB (AES electronic codebook mode encryption)1 |
|
on-chip |
Nordic nRF family CCM (AES CCM mode encryption)1 |
||
on-chip |
ARM TrustZone CryptoCell 3101 |
||
Debug |
on-chip |
ARMv7 instrumentation trace macrocell1 |
|
Flash controller |
on-chip |
Nordic NVMC (Non-Volatile Memory Controller)1 |
|
on-chip |
Properties defining the interface for the Nordic QSPI peripheral1 |
||
GPIO & Headers |
on-chip |
NRF5 GPIOTE1 |
|
on-chip |
NRF5 GPIO2 |
||
I2C |
on-chip |
||
I2S |
on-chip |
Nordic I2S (Inter-IC sound interface)1 |
|
IEEE 802.15.4 |
on-chip |
Nordic nRF IEEE 802.15.4 node1 |
|
Input |
on-board |
Group of GPIO-bound input keys1 |
|
Interrupt controller |
on-chip |
ARMv7-M NVIC (Nested Vectored Interrupt Controller)1 |
|
LED |
on-board |
Group of GPIO-controlled LEDs1 |
|
on-board |
Group of PWM-controlled LEDs1 |
||
Miscellaneous |
on-chip |
Nordic FICR (Factory Information Configuration Registers)1 |
|
on-chip |
Nordic nRF family PPI (Programmable Peripheral Interconnect)1 |
||
MTD |
on-chip |
Flash node1 |
|
on-board |
Fixed partitions of a flash (or other non-volatile storage) memory1 |
||
Networking |
on-chip |
Nordic nRF family RADIO peripheral1 |
|
on-chip |
Nordic nRF family NFCT (Near Field Communication Tag)1 |
||
Pin control |
on-chip |
The nRF pin controller is a singleton node responsible for controlling pin function selection and pin properties1 |
|
Power management |
on-chip |
Nordic nRF power control node1 |
|
PWM |
on-chip |
||
on-chip |
nRFx S/W PWM1 |
||
Regulator |
on-chip |
Nordic nRF5X regulator (fixed stage of the core supply)1 |
|
on-chip |
Nordic nRF52X regulator (high voltage stage of the main supply)1 |
||
Retained memory |
on-chip |
Nordic GPREGRET (General Purpose Register Retention) device2 |
|
RNG |
on-chip |
Nordic nRF family RNG (Random Number Generator)1 |
|
RTC |
on-chip |
Nordic nRF RTC (Real-Time Counter)3 |
|
Sensors |
on-chip |
Nordic nRF family TEMP node1 |
|
on-chip |
Nordic nRF quadrature decoder (QDEC) node1 |
||
Serial controller |
on-chip |
||
SPI |
on-chip |
||
on-chip |
Nordic nRF family SPIM (SPI master with EasyDMA)2 |
||
SRAM |
on-chip |
Generic on-chip SRAM1 |
|
Timer |
on-chip |
ARMv7-M System Tick1 |
|
USB |
on-chip |
Nordic nRF52 USB device controller1 |
|
Watchdog |
on-chip |
Nordic nRF family WDT (Watchdog Timer)1 |
See nRF52840 Dongle website [1] and nRF52840 Dongle Hardware description [3] for a complete list of nRF52840 Dongle board hardware features.
Connections and IOs
LED
LED0 (green) = P0.6
LED1 (red) = P0.8
LED1 (green) = P1.9
LED1 (blue) = P0.12
Programming and Debugging
The nrf52840dongle
board supports the runners and associated west commands listed below.
flash | debug | rtt | attach | debugserver | |
---|---|---|---|---|---|
jlink | ✅ | ✅ (default) | ✅ | ✅ | ✅ |
nrfjprog | ✅ | ||||
nrfutil | ✅ (default) | ||||
pyocd | ✅ | ✅ | ✅ | ✅ | ✅ |
Applications for the nrf52840dongle/nrf52840
board configuration can be
built in the usual way (see Building an Application for more details).
Flashing
The board supports the following programming options:
Using the built-in bootloader only
Using MCUboot in serial recovery mode
Using an external debug probe
These instructions use the west tool and assume you are in the root directory of your west installation.
Option 1: Using the Built-In Bootloader Only
The board is factory-programmed with Nordic’s bootloader from Nordic’s nRF5 SDK. With this option, you’ll use Nordic’s nrfutil [5] program to create firmware packages supported by this bootloader and flash them to the device. Before proceeding make sure:
nrfutil
is installed.The
nrf5sdk-tools
command is installed withinnrfutil
.
Reset the board into the Nordic bootloader by pressing the RESET button.
The push button is on the far side of the board from the USB connector. Note that the button does not face up. You will have to push it from the outside in, towards the USB connector:
The red LED should start a fade pattern, signalling the bootloader is running.
Compile a Zephyr application; we’ll use Blinky.
west build -b nrf52840dongle/nrf52840 zephyr/samples/basic/blinky
Package the application for the bootloader using
nrfutil
:nrfutil nrf5sdk-tools pkg generate \ --hw-version 52 \ --sd-req=0x00 \ --application build/zephyr/zephyr.hex \ --application-version 1 \ blinky.zip
Flash it onto the board. Note
/dev/ttyACM0
is for Linux; it will be something likeCOMx
on Windows, and something else on macOS.nrfutil nrf5sdk-tools dfu usb-serial -pkg blinky.zip -p /dev/ttyACM0
When this command exits, observe the green LED on the board blinking, instead of the red LED used by the bootloader.
For more information, see Nordic Semiconductor USB DFU [4].
Option 2: Using MCUboot in Serial Recovery Mode
It is also possible to use the MCUboot bootloader with this board to flash Zephyr applications. You need to do some one-time set-up to build and flash MCUboot on your board. From that point on, you can build and flash other Zephyr applications using MCUboot’s serial recovery mode. This process does not overwrite the built-in Nordic bootloader, so you can always go back to using Option 1 later.
Install nrfutil [5] and mcumgr [7] first, and make sure MCUboot’s imgtool
is
available for signing your binary for MCUboot as described on Signing Binaries.
Next, do the one-time setup to flash MCUboot. We’ll assume you’ve cloned
the MCUboot [6] repository into the directory mcuboot
, and that it is next
to the zephyr repository on your computer.
Reset the board into the Nordic bootloader as described above.
Compile MCUboot as a Zephyr application.
west build -b nrf52840dongle/nrf52840 -d build/mcuboot mcuboot/boot/zephyr
Package the application for the bootloader using
nrfutil
:nrfutil nrf5sdk-tools pkg generate \ --hw-version 52 \ --sd-req=0x00 \ --application build/mcuboot/zephyr/zephyr.hex \ --application-version 1 \ mcuboot.zip
Flash it onto the board. Note
/dev/ttyACM0
is for Linux; it will be something likeCOMx
on Windows, and something else on macOS.nrfutil nrf5sdk-tools dfu usb-serial -pkg mcuboot.zip -p /dev/ttyACM0
You can now flash a Zephyr application to the board using MCUboot’s serial recovery mode. We’ll use the SMP server sample since it’s ready to be compiled for chain-loading by MCUboot (and itself supports firmware updates over Bluetooth).
Boot into MCUboot serial recovery mode by plugging the board in with the SW1 button pressed down. See above for a picture showing where SW1 is.
Do not press RESET; that will run the Nordic bootloader, which is different than MCUboot.
A serial port will enumerate on your board. On Windows, “MCUBOOT” should appear under “Other Devices” in the Device Manager (in addition to the usual
COMx
device). On Linux, something like/dev/serial/by-id/usb-ZEPHYR_MCUBOOT_0.01-if00
should be created.If no serial port appears, try plugging it in again, making sure SW1 is pressed. If it still doesn’t appear, retry the one-time MCUboot setup.
Compile
smp_svr
.west build -b nrf52840dongle/nrf52840 -d build/smp_svr zephyr/samples/subsys/mgmt/mcumgr/smp_svr
Sign
smp_svr
for chain-loading by MCUboot.west sign -t imgtool --bin --no-hex -d build/smp_svr \ -B smp_svr.signed.bin -- --key mcuboot/root-rsa-2048.pem
Flash the application to the MCUboot serial port using
mcumgr
:mcumgr --conntype=serial --connstring='dev=/dev/ttyACM0,baud=115200' \ image upload -e smp_svr.signed.bin
Reset the device:
mcumgr --conntype=serial --connstring='dev=/dev/ttyACM0,baud=115200' reset
You should now be able to scan for Bluetooth devices using a smartphone or
computer. The device you just flashed will be listed with Zephyr
in its
name.
Note
This board supports building other Zephyr applications for flashing with
MCUboot in this way also. Just make sure CONFIG_BOOTLOADER_MCUBOOT
is set when building your application. For example, to compile blinky for
loading by MCUboot, use this:
west build -b nrf52840dongle/nrf52840 -d build/blinky zephyr/samples/basic/blinky -- -DCONFIG_BOOTLOADER_MCUBOOT=y
You can then sign and flash it using the steps above.
Option 3: Using an External Debug Probe
If you have one, you can also use an external debug probe to flash and debug Zephyr applications, but you need to solder an SWD header onto the back side of the board.
For Segger J-Link debug probes, follow the instructions in the Nordic nRF5x Segger J-Link page to install and configure all the necessary software. Further information can be found in Flashing.
Locate the DTS file: boards/nordic/nrf52840dongle/nrf52840dongle_nrf52840.dts. This file requires a small modification to use a different partition table. Edit the include directive to include “fstab-debugger” instead of “fstab-stock”.
In addition, the Kconfig file in the same directory must be modified by setting
BOARD_HAS_NRF5_BOOTLOADER
to be default n
, otherwise the code will be
flashed with an offset.
Then build and flash applications as usual (see Building an Application and Run an Application for more details).
Here is an example for the Blinky application.
# From the root of the zephyr repository
west build -b nrf52840dongle/nrf52840 samples/basic/blinky
west flash
Observe the LED on the board blinking.
Debugging
The nrf52840dongle/nrf52840
board does not have an on-board J-Link debug IC
as some nRF5x development boards, however, instructions from the
Nordic nRF5x Segger J-Link page also apply to this board, with the additional step
of connecting an external debugger.