From 7bb5232792b473d7f2ee923b29b9f054bdf8e24f Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Tue, 13 Dec 2022 09:38:18 +0100 Subject: [PATCH 1/5] makefiles/tools/openocd-adapters: add XDS110 support This adds the configuration to allow choosing the XDS110 used in cc13xx-launchpad and cc26xx-launchpad boards via the `OPENOCD_DEBUG_ADAPTER` variable. --- makefiles/tools/openocd-adapters/xds110.inc.mk | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 makefiles/tools/openocd-adapters/xds110.inc.mk diff --git a/makefiles/tools/openocd-adapters/xds110.inc.mk b/makefiles/tools/openocd-adapters/xds110.inc.mk new file mode 100644 index 0000000000..035404d417 --- /dev/null +++ b/makefiles/tools/openocd-adapters/xds110.inc.mk @@ -0,0 +1,6 @@ +# TI XDS110 debug adapter (available both as embedded debugger e.g. in the +# cc13xx-launchpad and cc26xx-launchpad boards or standalone version) + +OPENOCD_TRANSPORT ?= jtag + +OPENOCD_ADAPTER_INIT ?= -c 'source [find interface/xds110.cfg]' From c4ff80b6b9e70e6f8253ad463d645b46ced7a13a Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Tue, 13 Dec 2022 09:39:37 +0100 Subject: [PATCH 2/5] boards/cc{13xx,26xx}: clean up OpenOCD config Place common OpenOCD configs for the different cc13xx and cc26xx families in boards/common/cc26xx_cc13xx/dist and automatically select the correct one based on the (prefix of the) value of `$(CPU_MODEL)`, if `OPENOCD_CONFIG` was not specified and no custom `openocd.cfg` is located in the board's `dist` folder. The `cc2650-launchpad` and `cc2650stk` have been adapted to use the common config instead. --- boards/cc2650-launchpad/Makefile.include | 2 - boards/cc2650-launchpad/dist/openocd.cfg | 43 ------------------- boards/cc2650stk/Makefile.include | 2 - boards/cc2650stk/dist/openocd.cfg | 43 ------------------- boards/common/cc26xx_cc13xx/Makefile.include | 27 +++++++++++- boards/common/cc26xx_cc13xx/dist/openocd.cfg | 11 ----- .../cc26xx_cc13xx/dist/openocd_cc13x0.cfg | 1 + .../cc26xx_cc13xx/dist/openocd_cc13x2.cfg | 1 + .../cc26xx_cc13xx/dist/openocd_cc26x0.cfg | 1 + .../cc26xx_cc13xx/dist/openocd_cc26x2.cfg | 1 + 10 files changed, 30 insertions(+), 102 deletions(-) delete mode 100644 boards/cc2650-launchpad/dist/openocd.cfg delete mode 100644 boards/cc2650stk/dist/openocd.cfg delete mode 100644 boards/common/cc26xx_cc13xx/dist/openocd.cfg create mode 100644 boards/common/cc26xx_cc13xx/dist/openocd_cc13x0.cfg create mode 100644 boards/common/cc26xx_cc13xx/dist/openocd_cc13x2.cfg create mode 100644 boards/common/cc26xx_cc13xx/dist/openocd_cc26x0.cfg create mode 100644 boards/common/cc26xx_cc13xx/dist/openocd_cc26x2.cfg diff --git a/boards/cc2650-launchpad/Makefile.include b/boards/cc2650-launchpad/Makefile.include index 6453ba1dd5..3533a21c86 100644 --- a/boards/cc2650-launchpad/Makefile.include +++ b/boards/cc2650-launchpad/Makefile.include @@ -1,6 +1,4 @@ XDEBUGGER = XDS110 -OPENOCD_CONFIG ?= $(BOARDDIR)/dist/openocd.cfg - # configure the flash tool include $(RIOTBOARD)/common/cc26xx_cc13xx/Makefile.include diff --git a/boards/cc2650-launchpad/dist/openocd.cfg b/boards/cc2650-launchpad/dist/openocd.cfg deleted file mode 100644 index 0fa4600351..0000000000 --- a/boards/cc2650-launchpad/dist/openocd.cfg +++ /dev/null @@ -1,43 +0,0 @@ -# Config for Texas Instruments low power SoC CC26xx family - -adapter_khz 100 - -source [find target/icepick.cfg] -source [find target/ti-cjtag.cfg] - -if { [info exists CHIPNAME] } { - set _CHIPNAME $CHIPNAME -} else { - set _CHIPNAME cc26xx -} - -# -# Main DAP -# -if { [info exists DAP_TAPID] } { - set _DAP_TAPID $DAP_TAPID -} else { - set _DAP_TAPID 0x4BA00477 -} -jtag newtap $_CHIPNAME dap -irlen 4 -ircapture 0x1 -irmask 0xf -expected-id $_DAP_TAPID -disable -jtag configure $_CHIPNAME.dap -event tap-enable "icepick_c_tapenable $_CHIPNAME.jrc 0" - -# -# ICEpick-C (JTAG route controller) -# -if { [info exists JRC_TAPID] } { - set _JRC_TAPID $JRC_TAPID -} else { - set _JRC_TAPID 0x1B99A02F -} -jtag newtap $_CHIPNAME jrc -irlen 6 -ircapture 0x1 -irmask 0x3f -expected-id $_JRC_TAPID -ignore-version -# A start sequence is needed to change from cJTAG (Compact JTAG) to -# 4-pin JTAG before talking via JTAG commands -jtag configure $_CHIPNAME.jrc -event setup "jtag tapenable $_CHIPNAME.dap" -jtag configure $_CHIPNAME.jrc -event post-reset "ti_cjtag_to_4pin_jtag $_CHIPNAME.jrc" - -# -# Cortex M3 target -# -set _TARGETNAME $_CHIPNAME.cpu -target create $_TARGETNAME cortex_m -chain-position $_CHIPNAME.dap diff --git a/boards/cc2650stk/Makefile.include b/boards/cc2650stk/Makefile.include index 6453ba1dd5..3533a21c86 100644 --- a/boards/cc2650stk/Makefile.include +++ b/boards/cc2650stk/Makefile.include @@ -1,6 +1,4 @@ XDEBUGGER = XDS110 -OPENOCD_CONFIG ?= $(BOARDDIR)/dist/openocd.cfg - # configure the flash tool include $(RIOTBOARD)/common/cc26xx_cc13xx/Makefile.include diff --git a/boards/cc2650stk/dist/openocd.cfg b/boards/cc2650stk/dist/openocd.cfg deleted file mode 100644 index 0fa4600351..0000000000 --- a/boards/cc2650stk/dist/openocd.cfg +++ /dev/null @@ -1,43 +0,0 @@ -# Config for Texas Instruments low power SoC CC26xx family - -adapter_khz 100 - -source [find target/icepick.cfg] -source [find target/ti-cjtag.cfg] - -if { [info exists CHIPNAME] } { - set _CHIPNAME $CHIPNAME -} else { - set _CHIPNAME cc26xx -} - -# -# Main DAP -# -if { [info exists DAP_TAPID] } { - set _DAP_TAPID $DAP_TAPID -} else { - set _DAP_TAPID 0x4BA00477 -} -jtag newtap $_CHIPNAME dap -irlen 4 -ircapture 0x1 -irmask 0xf -expected-id $_DAP_TAPID -disable -jtag configure $_CHIPNAME.dap -event tap-enable "icepick_c_tapenable $_CHIPNAME.jrc 0" - -# -# ICEpick-C (JTAG route controller) -# -if { [info exists JRC_TAPID] } { - set _JRC_TAPID $JRC_TAPID -} else { - set _JRC_TAPID 0x1B99A02F -} -jtag newtap $_CHIPNAME jrc -irlen 6 -ircapture 0x1 -irmask 0x3f -expected-id $_JRC_TAPID -ignore-version -# A start sequence is needed to change from cJTAG (Compact JTAG) to -# 4-pin JTAG before talking via JTAG commands -jtag configure $_CHIPNAME.jrc -event setup "jtag tapenable $_CHIPNAME.dap" -jtag configure $_CHIPNAME.jrc -event post-reset "ti_cjtag_to_4pin_jtag $_CHIPNAME.jrc" - -# -# Cortex M3 target -# -set _TARGETNAME $_CHIPNAME.cpu -target create $_TARGETNAME cortex_m -chain-position $_CHIPNAME.dap diff --git a/boards/common/cc26xx_cc13xx/Makefile.include b/boards/common/cc26xx_cc13xx/Makefile.include index d084a98107..2b6ab2ad2b 100644 --- a/boards/common/cc26xx_cc13xx/Makefile.include +++ b/boards/common/cc26xx_cc13xx/Makefile.include @@ -13,5 +13,30 @@ PROGRAMMERS_SUPPORTED += openocd uniflash # embedded debugger of these launchpad boards. TTY_BOARD_FILTER := --model XDS110 --iface-num 0 -OPENOCD_CONFIG ?= $(RIOTBOARD)/common/cc26xx_cc13xx/dist/openocd.cfg UNIFLASH_CONFIG ?= $(RIOTBOARD)/common/cc26xx_cc13xx/dist + +OPENOCD_DEBUG_ADAPTER ?= xds110 + +ifneq (,$(filter cc13x0%,$(CPU_MODEL))) + DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc13x0.cfg +endif +ifneq (,$(filter cc13x2%,$(CPU_MODEL))) + DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc13x2.cfg +endif +ifneq (,$(filter cc26x0%,$(CPU_MODEL))) + DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc26x0.cfg +endif +ifneq (,$(filter cc26x2%,$(CPU_MODEL))) + DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc26x2.cfg +endif + +# if no openocd specific configuration file, check for default locations: +# 1. Using the default dist/openocd.cfg (automatically set by openocd.sh) +# 2. Using the common cpu specific config file +ifeq (,$(OPENOCD_CONFIG)) + # if no openocd default configuration is provided by the board, + # use the default cc26xx / cc13xx config + ifeq (0,$(words $(wildcard $(BOARDDIR)/dist/openocd.cfg))) + OPENOCD_CONFIG := $(DEFAULT_OPENOCD_CONFIG) + endif +endif diff --git a/boards/common/cc26xx_cc13xx/dist/openocd.cfg b/boards/common/cc26xx_cc13xx/dist/openocd.cfg deleted file mode 100644 index 64d69c2f33..0000000000 --- a/boards/common/cc26xx_cc13xx/dist/openocd.cfg +++ /dev/null @@ -1,11 +0,0 @@ -source [find interface/xds110.cfg] - -transport select jtag -gdb_memory_map enable -gdb_flash_program enable - -source [find target/ti_cc26x2.cfg] - -adapter_nsrst_assert_width 250 -adapter_nsrst_delay 400 -adapter_khz 1000 \ No newline at end of file diff --git a/boards/common/cc26xx_cc13xx/dist/openocd_cc13x0.cfg b/boards/common/cc26xx_cc13xx/dist/openocd_cc13x0.cfg new file mode 100644 index 0000000000..aca2d1c06f --- /dev/null +++ b/boards/common/cc26xx_cc13xx/dist/openocd_cc13x0.cfg @@ -0,0 +1 @@ +source [find target/ti_cc13x0.cfg] diff --git a/boards/common/cc26xx_cc13xx/dist/openocd_cc13x2.cfg b/boards/common/cc26xx_cc13xx/dist/openocd_cc13x2.cfg new file mode 100644 index 0000000000..cea0d04a9c --- /dev/null +++ b/boards/common/cc26xx_cc13xx/dist/openocd_cc13x2.cfg @@ -0,0 +1 @@ +source [find target/ti_cc13x2.cfg] diff --git a/boards/common/cc26xx_cc13xx/dist/openocd_cc26x0.cfg b/boards/common/cc26xx_cc13xx/dist/openocd_cc26x0.cfg new file mode 100644 index 0000000000..1a86f0bc99 --- /dev/null +++ b/boards/common/cc26xx_cc13xx/dist/openocd_cc26x0.cfg @@ -0,0 +1 @@ +source [find target/ti_cc26x0.cfg] diff --git a/boards/common/cc26xx_cc13xx/dist/openocd_cc26x2.cfg b/boards/common/cc26xx_cc13xx/dist/openocd_cc26x2.cfg new file mode 100644 index 0000000000..3d7bfff7cf --- /dev/null +++ b/boards/common/cc26xx_cc13xx/dist/openocd_cc26x2.cfg @@ -0,0 +1 @@ +source [find target/ti_cc26x2.cfg] From 5c163180ad782d437a0ba628a10ad2688d044931 Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Fri, 16 Dec 2022 15:50:26 +0100 Subject: [PATCH 3/5] boards/cc{13xx,26xx}: add JLink support Add the required variables to support flashing with `PROGRAMMERS=jlink`. --- boards/common/cc26xx_cc13xx/Makefile.include | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/boards/common/cc26xx_cc13xx/Makefile.include b/boards/common/cc26xx_cc13xx/Makefile.include index 2b6ab2ad2b..f365cc17c5 100644 --- a/boards/common/cc26xx_cc13xx/Makefile.include +++ b/boards/common/cc26xx_cc13xx/Makefile.include @@ -19,15 +19,19 @@ OPENOCD_DEBUG_ADAPTER ?= xds110 ifneq (,$(filter cc13x0%,$(CPU_MODEL))) DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc13x0.cfg + DEFAULT_JLINK_DEVICE := CC13xx endif ifneq (,$(filter cc13x2%,$(CPU_MODEL))) DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc13x2.cfg + DEFAULT_JLINK_DEVICE := CC13xx endif ifneq (,$(filter cc26x0%,$(CPU_MODEL))) DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc26x0.cfg + DEFAULT_JLINK_DEVICE := CC26xx endif ifneq (,$(filter cc26x2%,$(CPU_MODEL))) DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc26x2.cfg + DEFAULT_JLINK_DEVICE := CC26xx endif # if no openocd specific configuration file, check for default locations: @@ -40,3 +44,6 @@ ifeq (,$(OPENOCD_CONFIG)) OPENOCD_CONFIG := $(DEFAULT_OPENOCD_CONFIG) endif endif + +JLINK_DEVICE ?= $(DEFAULT_JLINK_DEVICE) +JLINK_IF ?= jtag From 3e1dcf31cb877c78fa3d489cd21a02e182f133a8 Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Wed, 21 Dec 2022 23:17:13 +0100 Subject: [PATCH 4/5] tools/openocd: Allow specifying a custom halt command 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. --- dist/tools/openocd/openocd.sh | 6 ++++-- makefiles/tools/openocd.inc.mk | 5 +++++ 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/dist/tools/openocd/openocd.sh b/dist/tools/openocd/openocd.sh index d23e36d299..5bfebd1632 100755 --- a/dist/tools/openocd/openocd.sh +++ b/dist/tools/openocd/openocd.sh @@ -113,6 +113,8 @@ : ${OPENOCD_DBG_EXTRA_CMD:=} # command used to reset the board : ${OPENOCD_CMD_RESET_RUN:="-c 'reset run'"} +# command used to halt the board +: ${OPENOCD_CMD_RESET_HALT:="-c 'reset halt'"} # Select core on multi-core processors. : ${OPENOCD_CORE:=} # Set to any value to skip verifying after flashing. @@ -241,7 +243,7 @@ _flash_list_raw() { ${OPENOCD_EXTRA_RESET_INIT} \ -c 'init' \ -c 'targets' \ - -c 'reset halt' \ + ${OPENOCD_CMD_RESET_HALT} \ -c 'flash probe 0' \ -c 'flash list' \ -c 'shutdown'" 2>&1 && return @@ -366,7 +368,7 @@ do_flash() { -c 'gdb_port 0' \ -c 'init' \ -c 'targets' \ - -c 'reset halt' \ + ${OPENOCD_CMD_RESET_HALT} \ ${OPENOCD_PRE_FLASH_CMDS} \ -c 'flash write_image erase \"${IMAGE_FILE}\" ${IMAGE_OFFSET} ${IMAGE_TYPE}' \ ${OPENOCD_PRE_VERIFY_CMDS} \ diff --git a/makefiles/tools/openocd.inc.mk b/makefiles/tools/openocd.inc.mk index bf572f2832..537275348c 100644 --- a/makefiles/tools/openocd.inc.mk +++ b/makefiles/tools/openocd.inc.mk @@ -38,6 +38,11 @@ ifneq (,$(OPENOCD_CMD_RESET_RUN)) $(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)) From c78c0056ea885f031bcaf06c57882464e0af640f Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Wed, 21 Dec 2022 23:19:50 +0100 Subject: [PATCH 5/5] boards/common/cc26xx_cc13xx: Fix flashing with upstream OpenOCD This adds a work around that allows flashing with upstream OpenOCD, most of the time. --- boards/common/cc26xx_cc13xx/Makefile.include | 7 +++ cpu/cc26xx_cc13xx/doc.txt | 52 +++++++++++++++----- 2 files changed, 46 insertions(+), 13 deletions(-) diff --git a/boards/common/cc26xx_cc13xx/Makefile.include b/boards/common/cc26xx_cc13xx/Makefile.include index f365cc17c5..4296ef3c8b 100644 --- a/boards/common/cc26xx_cc13xx/Makefile.include +++ b/boards/common/cc26xx_cc13xx/Makefile.include @@ -16,6 +16,13 @@ TTY_BOARD_FILTER := --model XDS110 --iface-num 0 UNIFLASH_CONFIG ?= $(RIOTBOARD)/common/cc26xx_cc13xx/dist OPENOCD_DEBUG_ADAPTER ?= xds110 +# Work around a bug in the CC26xx / CC13xx that is triggered by 'reset halt'. +# This results in the CC26xx / CC13xx being flash-able again, but it may race +# against the target firmware installing IRQ handlers that may trigger while +# the device is being flashed, which is bound to cause unpleasantness. But +# flashing working fine most of the time is better than flashing working not +# at all... +OPENOCD_CMD_RESET_HALT ?= -c 'halt' ifneq (,$(filter cc13x0%,$(CPU_MODEL))) DEFAULT_OPENOCD_CONFIG := $(RIOTBASE)/boards/common/cc26xx_cc13xx/dist/openocd_cc13x0.cfg diff --git a/cpu/cc26xx_cc13xx/doc.txt b/cpu/cc26xx_cc13xx/doc.txt index 07751192a9..55970e5e18 100644 --- a/cpu/cc26xx_cc13xx/doc.txt +++ b/cpu/cc26xx_cc13xx/doc.txt @@ -68,11 +68,29 @@ that provides programming, flashing and debugging capabilities. It can either use proprietary Texas Instruments tools for programming, or OpenOCD. -### Using OpenOCD +### Using Upstream OpenOCD -To use OpenOCD with the XDS110 you need to use the an special version of -OpenOCD made by TI (upstream version is not _yet_ compatible). You can -clone and compile it from source: +OpenOCD is the default programmer and debugger. Hence, flashing can be done +by navigating to the application directory and running: + +``` +make flash BOARD= +``` + +@warning A reliable and robust sequence to reset the CC26xx / CC13xx from + upstream OpenOCD is not yet implemented. As a result, OpenOCD will + halt the MCU for flashing without reset. This may result in IRQ + handlers being already set up and responding to IRQs that trigger + while flashing. Hence, flashing is likely not 100% reliable. + +@note By default the XDS110 debug adapter is used, which is the debugger + TI integrates into is developments boards. This can be overwritten + by setting `OPENOCD_DEBUG_ADAPTER` to a different debugger. + +### Using TI's OpenOCD Fork + +TI maintains an outdated fork of OpenOCD that contains patches and special +handling that have not upstreamed yet. It can be build using: ``` # Clone into the openocd-ti folder @@ -87,17 +105,25 @@ make sudo make install ``` -@note Sometimes OpenOCD may stop working when the firmware on the XDS110 -is updated (when using Uniflash, happens without user intervention). With that -in mind, it's encouraged to either enable the ROM bootloader backdoor to enable -serial programming or the installation of TI Uniflash as a fallback. See -[Using Uniflash](#cc26xx_cc13xx_uniflash) +@warning Sometimes OpenOCD may stop working when the firmware on the XDS110 + is updated (when using Uniflash, happens without user intervention). + With that in mind, it's encouraged to either enable the ROM + bootloader backdoor to enable serial programming or the + installation of TI Uniflash as a fallback. See + [Using Uniflash](#cc26xx_cc13xx_uniflash) -#### Setting up the environment +@note With `OPENOCD_CMD_RESET_HALT="-c 'reset halt'"` the default reset + sequence can be restored. This may work with TI's OpenOCD fork. -To flash a board using OpenOCD you can use do it so by setting the `PROGRAMMER` -environment variable directly in the make command line or in your shell -nitialization +Otherwise, usage is identical with the upstream version of OpenOCD. + +### using J-Link + +By passing (or exporting) `PROGRAMMER=jlink` J-Link can be used to flash the +board. This requires a J-Link compatible programmer / debugger. Since the +XDS110 that TI's development boards use is not compatible, an external +programmer has to be used. The upside is that flashing appears to be reliable +with that. ### Using Uniflash