Пролог

В программировании микроконтроллеров часто Eclipse с плагинами используют потому что в нем есть плагины, которые генерируют make файлы для сборки программ на Си согласно разметке проекта в XML под названием .cproject и .project.

Эти плагины были сделаны главным образом для того, чтобы вовлечь в процесс программирования микроконтроллеров школьников и прочих специалистов без профильного IT образования и опыта.

Далее я напишу почему сборка с Eclipse плагинами для IDE не годится для промышленного программирования.

Теория сборки Си программ в IDE c плагинами

По сути, построение любого Cи кода в IDE сводится к трем простым но очень частым действиям

–1 Добавить мышкой исходник к проекту

–2 Добавить мышкой пути к папкам с кодом

–3 добавить мышкой макросы препроцессора к проекту

Всё это сваливается в файл .cproject. Этот .cproject – это авто-генеренный файл в который руками лучше не соваться. Если вы случайно там что-то поменяете и сохраните, то в один утренний день у вас просто не откроется проект! Далее Вас начнется приступ судороги, конвульсии и паралич. Нормально так да?..

Проблема №1: Ручное Прописывание Путей

Это самая больная тема при сборке при IDE c плагинами.

При сборке из-под IDE вам всегда придется вручную мышкой в настройках IDE прописывать пути к программным компонентам и к заголовочным файлам

Eclipse Сборка с Помощью ARM GCC Плагинов

"${workspace_loc:/${ProjName}/control/system}" "${workspace_loc:/${ProjName}/control}"

Но есть один трюк. Он заключается в том чтобы прописывать пути в переменную окружения INCDIR и скормить её в IDE. Можно написать *.bat скрипт.

@echo off cls echo INCDIR=[%INCDIR%]  set PROJECT_LOC=%cd% echo PROJECT_LOC=[%PROJECT_LOC%] set "PROJECT_LOC=%PROJECT_LOC:=/%" echo PROJECT_LOC=[%PROJECT_LOC%]  echo WORKSPACE_LOC=[%PROJECT_LOC%] set WORKSPACE_LOC=%PROJECT_LOC%/../.. echo WORKSPACE_LOC=[%WORKSPACE_LOC%]  set INC_DIR=-I"%WORKSPACE_LOC%/control/task"  set INC_DIR=%INC_DIR% -I"%WORKSPACE_LOC%/adt/fifo" set INC_DIR=%INC_DIR% -I"%WORKSPACE_LOC%/control/system" set INC_DIR=%INC_DIR% -I"%WORKSPACE_LOC%/adt" set INC_DIR=%INC_DIR% -I"%WORKSPACE_LOC%/boards" set INC_DIR=%INC_DIR% -I"%WORKSPACE_LOC%/adt/array"  set "INC_DIR=%INC_DIR:=/%" echo INC_DIR=[%INC_DIR%]   setx INCDIR "%INC_DIR%" echo INCDIR=[%INCDIR%]  pause

Этот скрипт надо отработать до запуска Eclipse. Тут очень важно чтобы черточка была именно такая “/” . Иначе система сборки не распознает этот путь. Далее надо прописать make переменную ${INCDIR} вот тут

Eclipse Сборка с Помощью ARM GCC Плагинов

Однако и тут всё не так гладко. Максимальная длина переменной окружения в cmd всего 8192 символа. А сохранить setx(ом) между сессиями можно и вовсе всего только 1024 символа в одной переменной окружения. Вот и получается, что так можно прописать только очень мало путей.

Проблема №2: Ручное прописывание макро определений для препроцессора

Вторая беда это ручное прописывание макросов препроцессора. Макросы прописываются вот тут Properties->C/C++ Builds-> Settings->Tool Settings -> GNU Arm Cross C Compiler -> Preprocsssor-> Define Symbol (-D)

Eclipse Сборка с Помощью ARM GCC Плагинов

тут в GUI окне вы мышкой добавляете и прописываете свои макросы один за другим. Потом нажимаете Apply and Close

Продвинутый способ передачи макроопределений

Однако можно передать файл extra_config.h с макросами опцией -include прописав строчку -include extra_config.h в настройках компилятора.

Eclipse Сборка с Помощью ARM GCC Плагинов

Как видно в логе сборки, макросы передаются успешно извне

Eclipse Сборка с Помощью ARM GCC Плагинов

Сборка проекта
Сборку можно инициировать мышкой или горячей клавишей Ctrl+B или тоже мышкой из IDE.

ПереПрошивка

Если у Вас на PC нет прав администратора чтобы изменить переменную PATH то можете каждый раз изменять переменную PATH из консоли Windows cmd вот так

set PATH=%PATH%;C:eclipse set PATH=%PATH%;C:Program Files (x86)GNU Arm Embedded Toolchain10 2021.10bin  set PATH=%PATH%;C:Artery_ATLINK_Console_Win32-x86_64_V3.0.08 set PATH=%PATH%;C:OpenOCD_Arterybin set OPEN_OCD_PATH=C:OpenOCD_Artery

После этого можно смело запускать скрипт сборки build_eclipse.bat

cls echo off  set project_name=Some_Project set project_dir=%cd% echo project_dir=%project_dir%  set ide_tool=eclipsec.exe set workspace_dir=%project_dir%...... echo workspace_dir=%workspace_dir%  call %ide_tool% -nosplash -application org.eclipse.cdt.managedbuilder.core.headlessbuild -data %workspace_dir%  -build %project_name%/Debug  -cleanBuild %project_name%/Debug | tee build_log.txt 

При этом Eclipse откажется собирать проект если вы не сделаете refresh вручную из-под IDE. Как сделать авто refresh из командной строки не ясно. Это ещё один гвоздь в крышку гроба Eclipse ARM плагинов.

Проблема №3: Проблема с генерацией артефактов

К сожалению Eclipse c ARM плагинами не может одновременно сгенерировать *.hex и *.bin артефакты. Либо *.hex либо *.bin. Поэтому пришлось прописать синтез *.bin отдельно в скрипте перепрошивки утилитой arm-none-eabi-objcopy

Вот скрипт файла flash_bin.bat

echo off cls  set project_name=RTOS_BoardName_Project set project_dir=%cd% echo project_dir=%project_dir%  set artefact_elf=%project_dir%Debug%project_name%.elf  set artefact_bin=%project_dir%Debug%project_name%.bin echo artefact_bin=%artefact_bin%  arm-none-eabi-objcopy -O binary -S %artefact_elf% %artefact_bin%  ::set flash_tool=ATLink_Console.exe set flash_tool=ATLink_Console.exe set options=-device AT32F437ZMT7 -connect -p --dfap --depp -d --a 08000000 --fn %artefact_bin% --v  -r %flash_tool% %options% pause 

Вот лог успешной перепрошивки

Eclipse Сборка с Помощью ARM GCC Плагинов

Либо, как вариант, можно добавить настройку генерировать бинарный файл как Post-build-steps. Находится это поле по следующему GUI-IDE адресу в GUI: Рroperties -> C/C++ Build -> Settings -> Build Steps -> Post-build-steps

Eclipse Сборка с Помощью ARM GCC Плагинов

arm-none-eabi-objcopy.exe -O binary -S RTOS_BoardName_Project.elf RTOS_BoardName_Project.bin

Причем если взять один и тот же проект и на разных компах добавить этот Post-build-steps, то .cproject будет на 30% разный! Хотя оба User(a) IDE мышкой выполнили одни и те же действия . Вот так…

Пошаговая отладка

В принципе пошаговой отладке всё равно какая IDE. Пошаговой отладке нужен только специально подготовленный GDB сервер, GDB клиент и *.elf файл. Далее можно хоть из консоли код по строчкам проходить.

Eclipse Сборка с Помощью ARM GCC Плагинов

Минусы сборки Eclipse плагинами из-под IDE

1–конфиги внутри cproject не отсортированы. Хотя IDE могла бы это и сделать. У двух похожих проектов diff .cproject огромный.

2–Высокие накладные расходы на создание ещё одной сборки. Создавать отдельные сборки для конкретных плат User(ам) IDE лень. В итоге у всех одна сборка – Франкенштейн сразу для всех плат.

3—Eclipse плагины не позволяют менять код во время компиляции. Программа может собираться долго. И ваша работа парализована на время сборки.

4—Eclipse плагины собирают всё что лежит в папке. Как то что нужно так и то что не нужно. Это провоцируют путаницу и ошибки.

5—Много мышко возни. Вы конечно можете открыть файл настроек проекта .cproject и дополнять его в текстовом редакторе. Однако эти действия не легальный как бы. При этом если вы случайно измените там в ненужном месте лишний символ, то у вас перестанет собираться сборка. Весь проект на помойку. Вас же при этом от страха застигнут судороги, конвульсии и паралич. Оно вам надо? Может всё-таки лучше самим писать скрипты сборки?
У вас уйдет один день чтобы просто прописать макросы в GUI IDE

Достоинства сборки из под Eclipse c плагинами

Отсутствуют.

Вывод
Крайне не рекомендую собирать проекты ARM плагинами Eclipse. Лучше пишите сами make скрипты сборки. Вот методичка https://habr.com/ru/articles/792590/.

Плюсов в сборке из-под IDE я не нахожу. Одни только проблемы. Темпы разработки очень низкие. Новые сборки создавать трудно, предстоит полное дублирование конфигов, поддерживать прежние сборки тоже проблематично. Файл настройки .cproject у всех разный даже если конфиги логический одинаковые.

Eclipse c плагинами крайне непригоден для сборки из-под командной строки. Eclipse c плагинами – это только соло разработка. Только ручные сборки.

Что делать?
Пишите сами скрипты сборки. Вариантов масса: Make, Ninja, Cmake.

Links

Развертывание среды разработки для STM32 https://bravikov.wordpress.com/tag/gnu-arm-eclipse/
https://mcuoneclipse.com/2014/09/12/building-projects-with-eclipse-from-the-command-line/

ToolChain: Настройка сборки прошивок для микроконтроллеров Artery из Makefile https://habr.com/ru/articles/792590/