Пролог
В программировании микроконтроллеров часто Eclipse с плагинами используют потому что в нем есть плагины, которые генерируют make файлы для сборки программ на Си согласно разметке проекта в XML под названием .cproject и .project.
Эти плагины были сделаны главным образом для того, чтобы вовлечь в процесс программирования микроконтроллеров школьников и прочих специалистов без профильного IT образования и опыта.
Далее я напишу почему сборка с Eclipse плагинами для IDE не годится для промышленного программирования.
Теория сборки Си программ в IDE c плагинами
По сути, построение любого Cи кода в IDE сводится к трем простым но очень частым действиям
–1 Добавить мышкой исходник к проекту
–2 Добавить мышкой пути к папкам с кодом
–3 добавить мышкой макросы препроцессора к проекту
Всё это сваливается в файл .cproject. Этот .cproject – это авто-генеренный файл в который руками лучше не соваться. Если вы случайно там что-то поменяете и сохраните, то в один утренний день у вас просто не откроется проект! Далее Вас начнется приступ судороги, конвульсии и паралич. Нормально так да?..
Проблема №1: Ручное Прописывание Путей
Это самая больная тема при сборке при IDE c плагинами.
При сборке из-под IDE вам всегда придется вручную мышкой в настройках IDE прописывать пути к программным компонентам и к заголовочным файлам
"${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} вот тут
Однако и тут всё не так гладко. Максимальная длина переменной окружения в cmd всего 8192 символа. А сохранить setx(ом) между сессиями можно и вовсе всего только 1024 символа в одной переменной окружения. Вот и получается, что так можно прописать только очень мало путей.
Проблема №2: Ручное прописывание макро определений для препроцессора
Вторая беда это ручное прописывание макросов препроцессора. Макросы прописываются вот тут Properties->C/C++ Builds-> Settings->Tool Settings -> GNU Arm Cross C Compiler -> Preprocsssor-> Define Symbol (-D)
тут в GUI окне вы мышкой добавляете и прописываете свои макросы один за другим. Потом нажимаете Apply and Close
Продвинутый способ передачи макроопределений
Однако можно передать файл extra_config.h с макросами опцией -include прописав строчку -include extra_config.h в настройках компилятора.
Как видно в логе сборки, макросы передаются успешно извне
Сборка проекта
Сборку можно инициировать мышкой или горячей клавишей 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
Вот лог успешной перепрошивки
Либо, как вариант, можно добавить настройку генерировать бинарный файл как Post-build-steps. Находится это поле по следующему GUI-IDE адресу в GUI: Рroperties -> C/C++ Build -> Settings -> Build Steps -> Post-build-steps
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 плагинами из-под 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/