Обновление Прошивки из Make Скрипта

0ff02c04dfce0f7bd86cf2d4a255e77b.png

В чем проблема?

Я с удивлением узнал, что на российских предприятиях, где программируют микроконтроллеры часто у людей возникают проблемы просто с тем, чтобы банално залить прошивку в микроконтроллер. Сотрудники открывают GUI утилиту от вендора и не знают куда тыкать курсор.

У меня был случай, когда схемотехник по ошибке залил в микроконтроллер win *.rar файл в котором была прошивка, а потом жаловался мне, что моя прошивка не работает! Это как?…

1419aaed3e78fc188bbb7b7602734e43.png

В таких случаях схемотехник по 4 раза на дню приходит к программисту, чтобы программист ему пере прошил плату. Это странно хотя бы потому, что даже обычные люди без образования и то могут обновить прошивку на своем фитнес браслете. А тут сотрудники с российским высшим образованием не могут обновить прошивку. Это как? Непорядок…

Решение проблемы

Очевидно что надо сделать какой-то скрипт, который в одно касание обновит подключенное по SWD устройство.

Многим известны системы сборки для компьютерных программ. Некоторые пользуют GNU Make.

А что если я скажу, что систему сборки make можно использовать не только для сборки программ? Что если загружать прошивку тем же make скриптом? Есть только один способ это проверить…

По сути система сборки это интерпретируемый язык программирования. А значит на нём можно писать код, который может делать что полезное. Вот например можно на GNU Make написать код загрузки *.bin (аря) в микроконтроллер. Перед вами flash_target.mk скрипт для выбора алгоритма пере прошивки. Да, у нас в репозитории есть сборки под разные целевые архитектуры. Поэтому выбор «чиво-либо» происходит установкой переменных окружения во время прогона скриптов сборки.

$(info FlashTargetScript)

MAKE_SCRIPTS=$(WORKSPACE_LOC)/make_scripts

FLASH_TARGET=

ifeq ($(ARTERY), Y)
    FLASH_TARGET += flash_artery
endif

ifeq ($(CC26X2), Y)
    FLASH_TARGET += flash_cc26x2
endif

ifeq ($(ESP32), Y)
    FLASH_TARGET += flash_esp32
endif

ifeq ($(MILANDR), Y)
    FLASH_TARGET += flash_mdr32
endif

ifeq ($(NORDIC), Y)
    FLASH_TARGET += flash_nordic
endif

ifeq ($(STM), Y)
    FLASH_TARGET += flash_stm32
endif

# make flash
.PHONY: flash
flash: $(FLASH_TARGET)
	$(info FlashTargetDone)


ifeq ($(ARTERY), Y)
    include $(MAKE_SCRIPTS)/flash_artery.mk
endif

ifeq ($(CC26X2), Y)
    include $(MAKE_SCRIPTS)/flash_cc26x2.mk
endif

ifeq ($(ESP32), Y)
    include $(MAKE_SCRIPTS)/flash_esp32.mk
endif

ifeq ($(MILANDR), Y)
    include $(MAKE_SCRIPTS)/flash_mdr32.mk
endif

ifeq ($(NORDIC), Y)
    include $(MAKE_SCRIPTS)/flash_nordic.mk
endif

ifeq ($(STM), Y)
    include $(MAKE_SCRIPTS)/flash_stm32.mk
endif

Вот например, скрипт для пере прошивки Artery микроконтроллера утилитой ATLink_Console. Тут flash_artery это цель. То есть то что надо сделать, а $(FIRMWARE_BINARY_FILE) это зависимость. То есть то, что должно быть, чтобы достигнуть цели. Далее просто идут действия… Произвести физический пуск утилиты ATLink_Console.exe с нужным пучком опций. Где опции разделены пробелами. Только и всего…

$(info Flash Artery MCU Script)

FIRMWARE_BINARY_FILE=$(BUILD_DIR)\$(TARGET).bin
VENDOR_FLASH_CLI_TOOL=ATLink_Console.exe
VENDOR_FLASH_CLI_OPTIONS=
VENDOR_FLASH_CLI_OPTIONS += -device $(ARTERY_DEVICE)
VENDOR_FLASH_CLI_OPTIONS += -connect -p --dfap 
VENDOR_FLASH_CLI_OPTIONS += --depp 
VENDOR_FLASH_CLI_OPTIONS += -d --a 08000000 
VENDOR_FLASH_CLI_OPTIONS += --fn $(FIRMWARE_BINARY_FILE) 
VENDOR_FLASH_CLI_OPTIONS += --v  
VENDOR_FLASH_CLI_OPTIONS += -r

.PHONY: flash_artery
flash_artery: $(FIRMWARE_BINARY_FILE)
	$(info Flash File:$(FIRMWARE_BINARY_FILE) ...)
	$(VENDOR_FLASH_CLI_TOOL) $(VENDOR_FLASH_CLI_OPTIONS)
	$(info FlashArteryMCUTargetDone)

а это справка по опциям консольной утилиты ATLink_Console.exe

af8d27642a66c68c5b55d5dfe4e2bf7d.png

После успешной пере прошивки должен появится вот такой лог в консоли

3f6d243af412d093d8968695fcf18806.png

Достоинство прошивки из-под скриптов

++ Вы прошиваете в одно касание. По сути надо просто дзыкнуть по *.bat скрипту, который вызовет одну лишь команду: make flash. Далее всё как по волшебству произойдет само собой…

++Вы пишите только один скрипт и используете его-ещё для бесчисленного количества сборок. Причем скрипт сам поймет какой микроконтроллер нужен и вызовет нужную консольную утилиту от вендора для него.

++При составлении скрипта пере прошивки Вы контролируете каждую опцию в управлении алгоритма обновления ПО. Вы понимаете что происходит. У вас не происходит control leak (утечки управления).

++Вы никак не привязаны к своей GUI-IDE и мышке. Вы можете даже автоматизировать процесс пере прошивки на производстве.

Итоги

Удалось научиться пере прошивать микроконтроллер make кодом. В одно касание. Получился принцип одной кнопки. Вот так, просто и не затейливо.

Прошивайте микроконтроллеры из GNU Make скриптов. В этом нет ничего сложного.

Ссылки

© Habrahabr.ru