diff --git a/tools/rp2040/Config.mk b/tools/rp2040/Config.mk index 2d3faa7fd8..51bafdf6f4 100644 --- a/tools/rp2040/Config.mk +++ b/tools/rp2040/Config.mk @@ -26,17 +26,33 @@ # POSTBUILD -- Perform post build operations -ifeq ($(CONFIG_RP2040_UF2_BINARY),y) -ifdef PICO_SDK_PATH -define POSTBUILD - $(Q)echo "Generating: nuttx.uf2"; \ +PICOTOOL_BIN_PATH?=$(PICO_SDK_PATH)$(DELIM)_deps$(DELIM)picotool$(DELIM)picotool - picotool$(HOSTEXEEXT) uf2 convert --quiet -t elf nuttx nuttx.uf2; - $(Q)([ $$? -eq 0 ] && echo nuttx.uf2 >> nuttx.manifest && echo "Done.") -endef -else -define POSTBUILD - $(Q) echo "PICO_SDK_PATH must be specified for flash boot" +define GEN_PICO_UF2 + $(Q)echo "Generating: nuttx.uf2"; \ + + $(Q)$1 uf2 convert --quiet -t elf nuttx nuttx.uf2; + $(Q)([ $$? -eq 0 ] && echo nuttx.uf2 >> nuttx.manifest && echo "Done.") endef -endif + +ifeq ($(CONFIG_RP2040_UF2_BINARY),y) + ifneq ($(shell which picotool),) + define POSTBUILD + $(call GEN_PICO_UF2, picotool) + endef + else ifdef PICO_SDK_PATH + define POSTBUILD + $(Q)(if ! $(PICOTOOL_BIN_PATH) help >&/dev/null; then \ + echo "Building: picotool"; \ + cd $(PICO_SDK_PATH); \ + cmake . >&/dev/null; \ + make picotoolBuild >&/dev/null; \ + fi;) + $(call GEN_PICO_UF2, $(PICOTOOL_BIN_PATH)) + endef + else + define POSTBUILD + $(Q) echo "PICO_SDK_PATH/picotool must be specified/installed for flash boot" + endef + endif endif