From afbd533b13d4ad16d1e842dfff709526433f8580 Mon Sep 17 00:00:00 2001 From: Niklas Hauser Date: Thu, 11 Jul 2019 05:45:00 +0200 Subject: [PATCH] [openocd] Do not hardcode user options in built-in configs The modm board configurations hard-coded the programmer, which is an issue when using a different one. --- .../blink/openocd.cfg | 2 ++ .../blink/project.xml | 1 + .../blink/openocd.cfg | 2 ++ .../blink/project.xml | 1 + .../adns_9800/openocd.cfg | 2 ++ .../adns_9800/project.xml | 1 + .../blink.cmake/openocd.cfg | 2 ++ .../blink.cmake/project.xml | 1 + .../stm32f103c8t6_blue_pill/blink/openocd.cfg | 2 ++ .../stm32f103c8t6_blue_pill/blink/project.xml | 1 + .../stm32f103c8t6_blue_pill/can/openocd.cfg | 2 ++ .../stm32f103c8t6_blue_pill/can/project.xml | 1 + .../environment/openocd.cfg | 2 ++ .../environment/project.xml | 1 + .../logger/openocd.cfg | 2 ++ .../logger/project.xml | 1 + src/modm/board/black_pill/module.lb | 36 ++++++++++++++++++- src/modm/board/blue_pill/module.lb | 36 ++++++++++++++++++- src/modm/board/stm32f030f4p6_demo/module.lb | 33 ++++++++++++++++- tools/build_script_generator/module.lb | 9 +++-- tools/build_script_generator/openocd.cfg.in | 4 +++ tools/openocd/modm/stm32f030_demo_board.cfg | 3 +- tools/openocd/modm/stm32f103_blue_pill.cfg | 3 +- 23 files changed, 138 insertions(+), 10 deletions(-) create mode 100644 examples/stm32f030f4p6_demo_board/blink/openocd.cfg create mode 100644 examples/stm32f103c8t6_black_pill/blink/openocd.cfg create mode 100644 examples/stm32f103c8t6_blue_pill/adns_9800/openocd.cfg create mode 100644 examples/stm32f103c8t6_blue_pill/blink.cmake/openocd.cfg create mode 100644 examples/stm32f103c8t6_blue_pill/blink/openocd.cfg create mode 100644 examples/stm32f103c8t6_blue_pill/can/openocd.cfg create mode 100644 examples/stm32f103c8t6_blue_pill/environment/openocd.cfg create mode 100644 examples/stm32f103c8t6_blue_pill/logger/openocd.cfg diff --git a/examples/stm32f030f4p6_demo_board/blink/openocd.cfg b/examples/stm32f030f4p6_demo_board/blink/openocd.cfg new file mode 100644 index 0000000000..b157e7e432 --- /dev/null +++ b/examples/stm32f030f4p6_demo_board/blink/openocd.cfg @@ -0,0 +1,2 @@ +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] diff --git a/examples/stm32f030f4p6_demo_board/blink/project.xml b/examples/stm32f030f4p6_demo_board/blink/project.xml index a6e98994b9..8777cda2cb 100644 --- a/examples/stm32f030f4p6_demo_board/blink/project.xml +++ b/examples/stm32f030f4p6_demo_board/blink/project.xml @@ -2,6 +2,7 @@ modm:stm32f030_demo + modm:build:scons diff --git a/examples/stm32f103c8t6_black_pill/blink/openocd.cfg b/examples/stm32f103c8t6_black_pill/blink/openocd.cfg new file mode 100644 index 0000000000..b157e7e432 --- /dev/null +++ b/examples/stm32f103c8t6_black_pill/blink/openocd.cfg @@ -0,0 +1,2 @@ +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] diff --git a/examples/stm32f103c8t6_black_pill/blink/project.xml b/examples/stm32f103c8t6_black_pill/blink/project.xml index e47100bcdf..7892338a06 100644 --- a/examples/stm32f103c8t6_black_pill/blink/project.xml +++ b/examples/stm32f103c8t6_black_pill/blink/project.xml @@ -2,6 +2,7 @@ modm:black-pill + modm:build:scons diff --git a/examples/stm32f103c8t6_blue_pill/adns_9800/openocd.cfg b/examples/stm32f103c8t6_blue_pill/adns_9800/openocd.cfg new file mode 100644 index 0000000000..b157e7e432 --- /dev/null +++ b/examples/stm32f103c8t6_blue_pill/adns_9800/openocd.cfg @@ -0,0 +1,2 @@ +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] diff --git a/examples/stm32f103c8t6_blue_pill/adns_9800/project.xml b/examples/stm32f103c8t6_blue_pill/adns_9800/project.xml index de0a924ae4..62478d0f18 100644 --- a/examples/stm32f103c8t6_blue_pill/adns_9800/project.xml +++ b/examples/stm32f103c8t6_blue_pill/adns_9800/project.xml @@ -2,6 +2,7 @@ modm:blue-pill + modm:debug diff --git a/examples/stm32f103c8t6_blue_pill/blink.cmake/openocd.cfg b/examples/stm32f103c8t6_blue_pill/blink.cmake/openocd.cfg new file mode 100644 index 0000000000..b157e7e432 --- /dev/null +++ b/examples/stm32f103c8t6_blue_pill/blink.cmake/openocd.cfg @@ -0,0 +1,2 @@ +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] diff --git a/examples/stm32f103c8t6_blue_pill/blink.cmake/project.xml b/examples/stm32f103c8t6_blue_pill/blink.cmake/project.xml index 1f7ae2e388..19e5ee2ae7 100644 --- a/examples/stm32f103c8t6_blue_pill/blink.cmake/project.xml +++ b/examples/stm32f103c8t6_blue_pill/blink.cmake/project.xml @@ -2,6 +2,7 @@ modm:blue-pill + modm:build:cmake diff --git a/examples/stm32f103c8t6_blue_pill/blink/openocd.cfg b/examples/stm32f103c8t6_blue_pill/blink/openocd.cfg new file mode 100644 index 0000000000..b157e7e432 --- /dev/null +++ b/examples/stm32f103c8t6_blue_pill/blink/openocd.cfg @@ -0,0 +1,2 @@ +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] diff --git a/examples/stm32f103c8t6_blue_pill/blink/project.xml b/examples/stm32f103c8t6_blue_pill/blink/project.xml index 4c349c97e4..5f3d73dcd5 100644 --- a/examples/stm32f103c8t6_blue_pill/blink/project.xml +++ b/examples/stm32f103c8t6_blue_pill/blink/project.xml @@ -2,6 +2,7 @@ modm:blue-pill + modm:build:scons diff --git a/examples/stm32f103c8t6_blue_pill/can/openocd.cfg b/examples/stm32f103c8t6_blue_pill/can/openocd.cfg new file mode 100644 index 0000000000..b157e7e432 --- /dev/null +++ b/examples/stm32f103c8t6_blue_pill/can/openocd.cfg @@ -0,0 +1,2 @@ +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] diff --git a/examples/stm32f103c8t6_blue_pill/can/project.xml b/examples/stm32f103c8t6_blue_pill/can/project.xml index 456ea417ae..72df437b0b 100644 --- a/examples/stm32f103c8t6_blue_pill/can/project.xml +++ b/examples/stm32f103c8t6_blue_pill/can/project.xml @@ -2,6 +2,7 @@ modm:blue-pill + modm:debug diff --git a/examples/stm32f103c8t6_blue_pill/environment/openocd.cfg b/examples/stm32f103c8t6_blue_pill/environment/openocd.cfg new file mode 100644 index 0000000000..b157e7e432 --- /dev/null +++ b/examples/stm32f103c8t6_blue_pill/environment/openocd.cfg @@ -0,0 +1,2 @@ +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] diff --git a/examples/stm32f103c8t6_blue_pill/environment/project.xml b/examples/stm32f103c8t6_blue_pill/environment/project.xml index 0e008753b1..ce0a6123e1 100644 --- a/examples/stm32f103c8t6_blue_pill/environment/project.xml +++ b/examples/stm32f103c8t6_blue_pill/environment/project.xml @@ -2,6 +2,7 @@ modm:blue-pill + modm:debug diff --git a/examples/stm32f103c8t6_blue_pill/logger/openocd.cfg b/examples/stm32f103c8t6_blue_pill/logger/openocd.cfg new file mode 100644 index 0000000000..b157e7e432 --- /dev/null +++ b/examples/stm32f103c8t6_blue_pill/logger/openocd.cfg @@ -0,0 +1,2 @@ +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] diff --git a/examples/stm32f103c8t6_blue_pill/logger/project.xml b/examples/stm32f103c8t6_blue_pill/logger/project.xml index 0e988362ed..c84f2c9048 100644 --- a/examples/stm32f103c8t6_blue_pill/logger/project.xml +++ b/examples/stm32f103c8t6_blue_pill/logger/project.xml @@ -2,6 +2,7 @@ modm:blue-pill + modm:debug diff --git a/src/modm/board/black_pill/module.lb b/src/modm/board/black_pill/module.lb index 7703044a1c..c6ababd34f 100644 --- a/src/modm/board/black_pill/module.lb +++ b/src/modm/board/black_pill/module.lb @@ -22,6 +22,36 @@ Cheap and bread-board-friendly board for STM32 F1 series. Sold for less than 2 USD on well known Internet shops from China. http://wiki.stm32duino.com/index.php?title=Black_Pill +""" + descr_programming + +descr_programming = """ +## Programming + +Since the board doesn't have a programmer on-board, you need to use your +own and *specify* which one you're using in a custom `openocd.cfg` file: + +``` +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] + +# If you use the clone CKS32F103C8T6 chip you need to overwrite this ID +#set CPUTAPID 0x2ba01477 + +# To select a specific programmer you can specify its serial number +#hla_serial "\x53\x3f\x6f\x06\x50\x77\x50\x57\x12\x17\x14\x3f" +# You can discover the serial via `stlink --hla-serial` or `st-info --hla-serial`. +``` + +Then include this file in your build options like so: + +```xml + + modm:black-pill + + + + +``` """ def prepare(module, options): @@ -43,4 +73,8 @@ def build(env): env.outbasepath = "modm/openocd/modm/board/" env.copy(repopath("tools/openocd/modm/stm32f103_blue_pill.cfg"), "stm32f103_blue_pill.cfg") - env.collect(":build:openocd.source", "modm/board/stm32f103_blue_pill.cfg"); + env.collect(":build:openocd.source", "modm/board/stm32f103_blue_pill.cfg") + + # Warn the user if they forgot to set a custom openocd config + if env.has_option(":build:openocd.cfg") and not len(env.get(":build:openocd.cfg", "")): + env.log.warning("You need to provide the programmer via a custom OpenOCD config!\n" + descr_programming) diff --git a/src/modm/board/blue_pill/module.lb b/src/modm/board/blue_pill/module.lb index 079aaa8ec4..bd748752a9 100644 --- a/src/modm/board/blue_pill/module.lb +++ b/src/modm/board/blue_pill/module.lb @@ -22,6 +22,36 @@ Cheap and bread-board-friendly board for STM32 F1 series. Sold for less than 2 USD on well known Internet shops from China. http://wiki.stm32duino.com/index.php?title=Blue_Pill +""" + descr_programming + +descr_programming = """ +## Programming + +Since the board doesn't have a programmer on-board, you need to use your +own and *specify* which one you're using in a custom `openocd.cfg` file: + +``` +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] + +# If you use the clone CKS32F103C8T6 chip you need to overwrite this ID +#set CPUTAPID 0x2ba01477 + +# To select a specific programmer you can specify its serial number +#hla_serial "\x53\x3f\x6f\x06\x50\x77\x50\x57\x12\x17\x13\x3f" +# You can discover the serial via `stlink --hla-serial` or `st-info --hla-serial`. +``` + +Then include this file in your build options like so: + +```xml + + modm:blue-pill + + + + +``` """ def prepare(module, options): @@ -43,4 +73,8 @@ def build(env): env.outbasepath = "modm/openocd/modm/board/" env.copy(repopath("tools/openocd/modm/stm32f103_blue_pill.cfg"), "stm32f103_blue_pill.cfg") - env.collect(":build:openocd.source", "modm/board/stm32f103_blue_pill.cfg"); + env.collect(":build:openocd.source", "modm/board/stm32f103_blue_pill.cfg") + + # Warn the user if they forgot to set a custom openocd config + if env.has_option(":build:openocd.cfg") and not len(env.get(":build:openocd.cfg", "")): + env.log.warning("You need to provide the programmer via a custom OpenOCD config!\n" + descr_programming) diff --git a/src/modm/board/stm32f030f4p6_demo/module.lb b/src/modm/board/stm32f030f4p6_demo/module.lb index 46c9af71c4..a425dddb5c 100644 --- a/src/modm/board/stm32f030f4p6_demo/module.lb +++ b/src/modm/board/stm32f030f4p6_demo/module.lb @@ -23,6 +23,33 @@ Sold for less than 1.5 USD on well known Internet shops from China. http://www.hotmcu.com/stm32f030f4p6-minimum-systerm-boardcortexm0-p-208.html http://www.haoyuelectronics.com/Attachment/STM32F030-Dev-Board/STM32F030F4P6.pdf +""" + descr_programming + +descr_programming = """ +## Programming + +Since the board doesn't have a programmer on-board, you need to use your +own and *specify* which one you're using in a custom `openocd.cfg` file: + +``` +# Replace this with your custom programmer +source [find interface/stlink-v2.cfg] + +# To select a specific programmer you can specify its serial number +#hla_serial "\x53\x3f\x6f\x06\x51\x77\x50\x57\x12\x17\x13\x3f" +# You can discover the serial via `stlink --hla-serial` or `st-info --hla-serial`. +``` + +Then include this file in your build options like so: + +```xml + + modm:stm32f030_demo + + + + +``` """ def prepare(module, options): @@ -43,4 +70,8 @@ def build(env): env.outbasepath = "modm/openocd/modm/board/" env.copy(repopath("tools/openocd/modm/stm32f030_demo_board.cfg"), "stm32f030_demo_board.cfg") - env.collect(":build:openocd.source", "modm/board/stm32f030_demo_board.cfg"); + env.collect(":build:openocd.source", "modm/board/stm32f030_demo_board.cfg") + + # Warn the user if they forgot to set a custom openocd config + if env.has_option(":build:openocd.cfg") and not len(env.get(":build:openocd.cfg", "")): + env.log.warning("You need to provide the programmer via a custom OpenOCD config!\n" + descr_programming) diff --git a/tools/build_script_generator/module.lb b/tools/build_script_generator/module.lb index be5b1af04a..a126a85459 100644 --- a/tools/build_script_generator/module.lb +++ b/tools/build_script_generator/module.lb @@ -126,11 +126,6 @@ def prepare(module, options): def build(env): - # Append custom openocd config file to metadata - openocd_cfg = env.get(":build:openocd.cfg", "") - if len(openocd_cfg): - env.collect(":build:openocd.source", openocd_cfg) - # Append common search paths to metadata if env.has_collector(":build:path.openocd"): env.collect(":build:path.openocd", "modm/openocd") @@ -157,6 +152,10 @@ def post_build(env): "gitignore": gitignore, "elf_files": elf_files, } + # prepare custom path + openocd_cfg = env.get(":build:openocd.cfg", "") + if len(openocd_cfg): + env.substitutions["openocd_user_path"] = env.relative_outpath(openocd_cfg) env.outbasepath = "modm" # Currently a modm only feature diff --git a/tools/build_script_generator/openocd.cfg.in b/tools/build_script_generator/openocd.cfg.in index aeaeeaf2e4..346aa12e06 100644 --- a/tools/build_script_generator/openocd.cfg.in +++ b/tools/build_script_generator/openocd.cfg.in @@ -1,6 +1,10 @@ %% for path in collector_values["path.openocd"] | sort add_script_search_dir {{ path | modm.windowsify(escape_level=1) }} %% endfor +%# Include the users config before the modm config +%% if openocd_user_path is defined +source [find {{ openocd_user_path | modm.windowsify(escape_level=1) }}] +%% endif %% for file in collector_values["openocd.source"] | sort source [find {{ file | modm.windowsify(escape_level=1) }}] %% endfor diff --git a/tools/openocd/modm/stm32f030_demo_board.cfg b/tools/openocd/modm/stm32f030_demo_board.cfg index 616f2a6689..18d39baba9 100644 --- a/tools/openocd/modm/stm32f030_demo_board.cfg +++ b/tools/openocd/modm/stm32f030_demo_board.cfg @@ -8,7 +8,8 @@ # Cheap STM32F030F4P6 "Demo Board" Minimum System Development Board -source [find interface/stlink-v2.cfg] +# Must be specified by the user via `modm:build:openocd.cfg` option +#source [find interface/stlink-v2.cfg] transport select hla_swd diff --git a/tools/openocd/modm/stm32f103_blue_pill.cfg b/tools/openocd/modm/stm32f103_blue_pill.cfg index dd997977a4..c101eeaf70 100644 --- a/tools/openocd/modm/stm32f103_blue_pill.cfg +++ b/tools/openocd/modm/stm32f103_blue_pill.cfg @@ -1,6 +1,7 @@ # Cheap STM32F103C8T6 "Blue Pill" Minimum System Development Board -source [find interface/stlink-v2.cfg] +# Must be specified by the user via `modm:build:openocd.cfg` option +#source [find interface/stlink-v2.cfg] transport select hla_swd