1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

boards/nrf52840dongle: enable automatic reset to bootloader

This commit is contained in:
Benjamin Valentin 2020-06-10 23:07:40 +02:00 committed by Benjamin Valentin
parent 97fa42c329
commit b20f98e99b
4 changed files with 49 additions and 10 deletions

View File

@ -5,13 +5,12 @@ endif
ifeq (,$(filter-out stdio_cdc_acm,$(filter stdio_% slipdev_stdio,$(USEMODULE)))) ifeq (,$(filter-out stdio_cdc_acm,$(filter stdio_% slipdev_stdio,$(USEMODULE))))
# Use stdio_cdc_acm only if no other stdio is requested explicitly. # Use stdio_cdc_acm only if no other stdio is requested explicitly.
USEMODULE += stdio_cdc_acm USEMODULE += stdio_cdc_acm
# This does not *really* hinge on the choice of stdio, but this ensures
# compatibility with the test suite that uses stdio_null and would conflict
# with bootloader_nrfutil.
# (Having the feature in is generally a good thing because as an indicator
# that it the resulting program is meant to be flashed using nrfutil).
FEATURES_REQUIRED += bootloader_nrfutil
endif endif
# ... and fall back to the UART-based stdio
# enable bootloader reset over USB, requires USB bootloader to be used
ifneq (,$(filter stdio_cdc_acm,$(USEMODULE)))
FEATURES_REQUIRED += bootloader_nrfutil
USEMODULE += usb_board_reset
endif
include $(RIOTBOARD)/common/nrf52/Makefile.dep include $(RIOTBOARD)/common/nrf52/Makefile.dep

View File

@ -18,6 +18,8 @@ ifeq (nrfutil,$(PROGRAMMER))
FLASHDEPS += $(HEXFILE).zip FLASHDEPS += $(HEXFILE).zip
FLASHER = nrfutil FLASHER = nrfutil
FFLAGS = dfu usb-serial --port=${PORT} --package=$(HEXFILE).zip FFLAGS = dfu usb-serial --port=${PORT} --package=$(HEXFILE).zip
include $(RIOTMAKE)/tools/usb_board_reset.mk
endif endif
%.hex.zip: %.hex %.hex.zip: %.hex

View File

@ -28,9 +28,14 @@ The board is flashed using its on-board boot loader; the
be installed. That can turn the binary into a suitable zip file and send it to the be installed. That can turn the binary into a suitable zip file and send it to the
bootloader. bootloader.
The process is automated in the usual `make flash` target. For that process to The process is automated in the usual `make flash` target.
complete, you need to enter the bootloader manually by pressing the board's
reset button. Readiness of the bootloader is indicated by LD2 pulsing in red. If RIOT is already running on the board, it will automatically reset the CPU and enter
the bootloader.
If some other firmware is running or RIOT crashed, you need to enter the bootloader
manually by pressing the board's reset button.
Readiness of the bootloader is indicated by LD2 pulsing in red.
#### nrfutil installation #### nrfutil installation

View File

@ -0,0 +1,33 @@
/*
* Copyright (C) 2020 Benjamin Valentin
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @ingroup boards_nrf52840dongle
* @{
* @file
* @brief Allows reboot into bootloader via hardware reset
*
* @author Benjamin Valentin <benjamin.valentin@ml-pa.com>
*
* @}
*/
#ifdef MODULE_USB_BOARD_RESET
#include "periph/gpio.h"
/* P0.19 is connected to the RESET line */
#define BSP_SELF_PINRESET_PIN GPIO_PIN(0, 19)
void usb_board_reset_in_bootloader(void)
{
gpio_init(BSP_SELF_PINRESET_PIN, GPIO_OUT);
gpio_clear(BSP_SELF_PINRESET_PIN);
}
#endif /* MODULE_USB_BOARD_RESET */