mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
3e1dcf31cb
Typically, OpenOCD is already performing a reset on connect. A `reset halt` to bring the target to a `halt` state for flashing will result in the device going through a second reset cycle. This can be problematic with some device, such as the CC26xx MCUs. For these devices, an `OPENOCD_CMD_RESET_HALT := -c 'halt'` will avoid the second reset that is causing the issues.
79 lines
2.7 KiB
Makefile
79 lines
2.7 KiB
Makefile
FLASHER ?= $(RIOTTOOLS)/openocd/openocd.sh
|
|
DEBUGGER ?= $(RIOTTOOLS)/openocd/openocd.sh
|
|
DEBUGSERVER ?= $(RIOTTOOLS)/openocd/openocd.sh
|
|
RESET ?= $(RIOTTOOLS)/openocd/openocd.sh
|
|
|
|
FLASHFILE ?= $(ELFFILE)
|
|
FFLAGS ?= flash $(FLASHFILE)
|
|
DEBUGGER_FLAGS ?= debug $(DEBUG_ELFFILE)
|
|
DEBUGSERVER_FLAGS ?= debug-server
|
|
RESET_FLAGS ?= reset
|
|
|
|
ifneq (,$(OPENOCD_DEBUG_ADAPTER))
|
|
include $(RIOTMAKE)/tools/openocd-adapters/$(OPENOCD_DEBUG_ADAPTER).inc.mk
|
|
OPENOCD_ADAPTER_INIT += -c 'transport select $(OPENOCD_TRANSPORT)'
|
|
endif
|
|
|
|
OPENOCD_CONFIG ?= $(BOARDDIR)/dist/openocd.cfg
|
|
|
|
OPENOCD_TARGETS = debug% flash% reset
|
|
|
|
# Export GDB_PORT_CORE_OFFSET to required targets
|
|
$(call target-export-variables,$(OPENOCD_TARGETS),GDB_PORT_CORE_OFFSET)
|
|
|
|
# Export OPENOCD_CONFIG to required targets
|
|
$(call target-export-variables,$(OPENOCD_TARGETS),OPENOCD_CONFIG)
|
|
|
|
# Export OPENOCD_CORE to required targets
|
|
$(call target-export-variables,$(OPENOCD_TARGETS),OPENOCD_CORE)
|
|
|
|
# Export OPENOCD_ADAPTER_INIT to required targets
|
|
$(call target-export-variables,$(OPENOCD_TARGETS),OPENOCD_ADAPTER_INIT)
|
|
|
|
# Export OPENOCD_RESET_USE_CONNECT_ASSERT_SRST to required targets
|
|
$(call target-export-variables,$(OPENOCD_TARGETS),OPENOCD_RESET_USE_CONNECT_ASSERT_SRST)
|
|
|
|
ifneq (,$(OPENOCD_CMD_RESET_RUN))
|
|
# Export OPENOCD_CMD_RESET_RUN only to the reset target
|
|
$(call target-export-variables,reset,OPENOCD_CMD_RESET_RUN)
|
|
endif
|
|
|
|
ifneq (,$(OPENOCD_CMD_RESET_HALT))
|
|
# Export OPENOCD_CMD_RESET_HALT only to the flash targets
|
|
$(call target-export-variables,flash%,OPENOCD_CMD_RESET_HALT)
|
|
endif
|
|
|
|
OPENOCD_DEBUG_TARGETS = debug debugr debug-server
|
|
|
|
ifneq (,$(OPENOCD_DBG_EXTRA_CMD))
|
|
# Export OPENOCD_DBG_EXTRA_CMD only to the flash/flash-only target
|
|
$(call target-export-variables,$(OPENOCD_DEBUG_TARGETS),OPENOCD_DBG_EXTRA_CMD)
|
|
endif
|
|
|
|
OPENOCD_FLASH_TARGETS = flash flash-only flashr
|
|
|
|
ifneq (,$(IMAGE_OFFSET))
|
|
# Export IMAGE_OFFSET only to the flash/flash-only target
|
|
$(call target-export-variables,$(OPENOCD_FLASH_TARGETS),IMAGE_OFFSET)
|
|
endif
|
|
|
|
ifneq (,$(OPENOCD_PRE_VERIFY_CMDS))
|
|
# Export OPENOCD_PRE_VERIFY_CMDS only to the flash/flash-only target
|
|
$(call target-export-variables,$(OPENOCD_FLASH_TARGETS),OPENOCD_PRE_VERIFY_CMDS)
|
|
endif
|
|
|
|
ifneq (,$(OPENOCD_SKIP_VERIFY))
|
|
# Export OPENOCD_SKIP_VERIFY only to the flash/flash-only target
|
|
$(call target-export-variables,$(OPENOCD_FLASH_TARGETS),OPENOCD_SKIP_VERIFY)
|
|
endif
|
|
|
|
ifneq (,$(OPENOCD_PRE_FLASH_CMDS))
|
|
# Export OPENOCD_PRE_FLASH_CMDS only to the flash/flash-only targets
|
|
$(call target-export-variables,$(OPENOCD_FLASH_TARGETS),OPENOCD_PRE_FLASH_CMDS)
|
|
endif
|
|
|
|
ifneq (,$(OPENOCD_PRE_FLASH_CHECK_SCRIPT))
|
|
# Export OPENOCD_PRE_FLASH_CHECK_SCRIPT only to the flash/flash-only targets
|
|
$(call target-export-variables,$(OPENOCD_FLASH_TARGETS),OPENOCD_PRE_FLASH_CHECK_SCRIPT)
|
|
endif
|