mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
makefiles/boards/stm32.inc.mk: improve stm32flash support
Allow issuing a reset to bootloader sequence by abusing the RTS and the DTR pins of a TTL adapter. This makes flashing via UART much more convenient, as no jumpers need to be placed to select booting to the bootloader / flash and no reset buttons need to be pressed.
This commit is contained in:
parent
ecbe686b03
commit
08d88ee557
@ -135,6 +135,27 @@ JTAG. Also JTAG requires more signal lines to be connected compared to SWD and
|
|||||||
some internal programmers only have the SWD signal lines connected, so that
|
some internal programmers only have the SWD signal lines connected, so that
|
||||||
JTAG will not be possible.
|
JTAG will not be possible.
|
||||||
|
|
||||||
|
`stm32flash` Configuration {#flashing-configuration-stm32flash}
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
It is possible to automatically boot the STM32 board into the in-ROM bootloader
|
||||||
|
that `stm32flash` communicates with for flashing by connecting the RST pin to
|
||||||
|
DTR and the BOOT pin (or BOOT0 for STM32 MCU families with BOOT0 and BOOT1 pins)
|
||||||
|
to RTS of the TTL adapter. In addition, set `STM32FLASH_RESET` to `1` via
|
||||||
|
environment or command line to actually issue a reset with BOOT (or BOOT0)
|
||||||
|
pulled high prior flashing to enter the bootloader, and a second reset with BOOT
|
||||||
|
(or BOOT0) pulled low to reboot into the application. `STM32FLASH_RESET`
|
||||||
|
defaults to `0` as of know, as with `PROGRAMMER=stm32flash STM32FLASH_RESET=1`
|
||||||
|
additional terminal flags are set, so that `make term` doesn't accidentally
|
||||||
|
keeps the reset signal pulled low or boot the board into the bootloader.
|
||||||
|
|
||||||
|
The TTL adapter this was tested with had inverted RTS and DTR signal. By setting
|
||||||
|
`STM32FLASH_RESET_INVERT` to `1` RIOT will assume RTS and DTR signals to be
|
||||||
|
inverted, by setting it to `0` non-inverted signals will be generated. As of
|
||||||
|
now, `STM32FLASH_RESET_INVERT` is by default `1`. This may change if it
|
||||||
|
becomes evident that non-inverted TTL adapters are in fact more common than
|
||||||
|
inverted adapters.
|
||||||
|
|
||||||
Handling Multiple Boards With UDEV-Rules {#multiple-boards-udev}
|
Handling Multiple Boards With UDEV-Rules {#multiple-boards-udev}
|
||||||
========================================
|
========================================
|
||||||
|
|
||||||
|
@ -36,5 +36,30 @@ ifeq (stm32flash,$(PROGRAMMER))
|
|||||||
FLASHFILE ?= $(BINFILE)
|
FLASHFILE ?= $(BINFILE)
|
||||||
PROG_BAUD ?= 57600
|
PROG_BAUD ?= 57600
|
||||||
BIN_ADDR ?= $(shell echo $$(($(ROM_START_ADDR) + $(ROM_OFFSET))))
|
BIN_ADDR ?= $(shell echo $$(($(ROM_START_ADDR) + $(ROM_OFFSET))))
|
||||||
FFLAGS = -v -b $(PROG_BAUD) -w $(FLASHFILE) -S $(BIN_ADDR) -g $(BIN_ADDR) $(PORT)
|
STM32FLASH_RESET ?= 0
|
||||||
|
STM32FLASH_RESET_INVERT ?= 1
|
||||||
|
# sequence to reset board into bootloader:
|
||||||
|
# BOOT0 --> HIGH, RST --> LOW
|
||||||
|
# BOOT0 --> HIGH, RST --> HIGH
|
||||||
|
# sequence to reset board into application
|
||||||
|
# BOOT0 --> LOW, RST --> LOW
|
||||||
|
# BOOT0 --> LOW, RST --> HIGH
|
||||||
|
# This can be done via a TTL adapter when BOOT0 is connected to RTS and
|
||||||
|
# RST is connected to DTR
|
||||||
|
ifeq (1,$(STM32FLASH_RESET))
|
||||||
|
# The TTL adapter this was tested with actually has inverted outputs. But
|
||||||
|
# we can just support both via a simple flag:
|
||||||
|
ifeq (1,$(STM32FLASH_RESET_INVERT))
|
||||||
|
FFLAGS += -i '-rts,dtr,-dtr:rts,dtr,-dtr'
|
||||||
|
# set term flags so BOOT0 is low and RST is high
|
||||||
|
MINITERMFLAGS += --rts 1 --dtr 0
|
||||||
|
PYTERMFLAGS += --set-rts 1 --set-dtr 0
|
||||||
|
else
|
||||||
|
FFLAGS += -i 'rts,-dtr,dtr:-rts,-dtr,dtr'
|
||||||
|
# set term flags so BOOT0 is low and RST is high
|
||||||
|
MINITERMFLAGS += --rts 0 --dtr 1
|
||||||
|
PYTERMFLAGS += --set-rts 0 --set-dtr 1
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
FFLAGS += -v -b $(PROG_BAUD) -w $(FLASHFILE) -S $(BIN_ADDR) -g $(BIN_ADDR) $(PORT)
|
||||||
endif
|
endif
|
||||||
|
Loading…
Reference in New Issue
Block a user