Поиск по сайту: |
|
По базе: |
|
Главная страница > Статьи > Средства разработки |
|
|||||||||||||||||
Реальная программаВ этом примере скомпилируем и скомпонуем один из примеров программы, поставляемый в составе пакета программ для демонстрационной платы, "STM32VLDISCOVERY firmware package". STMicroelectronics как-то не жалует GCC, например у Atmel имеется серия примеров компиляции проектов для GCC. Демонстрационные проекты Atmel могут собираться из командной строки средствами GCC, а большинство демонстрационных проектов STM рассчитаны на коммерческие среды разработки. В составе демо пакета имеется набор файлов стандарта CMSIS и файлы библиотеки SPL (Standard peripherial library). CMSIS - стандарт программного интерфейса микроконтроллеров с ядром Cortex. Этот стандарт разрабатывает и продвигает компания ARM, существует несколько версий и стандарт продолжает развиваться. В использованном в примере пакете, версия CMSIS 1.30. Стартовая программа должна соответствовать некоторым требованиям, предъявляемым к ней стандартом CMSIS. Названия системных исключений должны соответствовать CMSIS. Инициализация аппаратуры микроконтроллера (в том числе настройка синхронизации), выполняется функцией SystemInit() , из состава CMSIS. Средства CMSIS предоставляют сервисы базового уровня, эти сервисы используют средства SPL. Стартовый код на ассемблере, из предыдущих примеров необходимо доработать. Произвольные названия векторов прерывания, нужно изменить на стандартные названия. Ниже приведён образец системного исключения по сбросу:
Обработчик по сбросу задан в стартовом коде и ни где в программе не должен встречаться. Для обработчиков прочих системных исключений, применяется специальная техника. Кроме как в стартовом коде, обработчик может быть описан в другом модуле, с большим приоритетом. После компиляции, обработчики в стартовом коде будут игнорироваться, а реально выполняться обработчики, реализованные в другом модуле. Для этого существует ассемблерная директива .weak. Символ после этой директивы будет "слабым". Если в другом модуле будет объявлен символ с таким же именем, то "слабый" символ "проиграет", этот символ будет игнорироваться. Конечно, можно реализовать обработчик на ассемблере в тексте стартового модуля. В примере, обработчик NMI объявлен таким образом:
Символ NMI_Handler , задан как "слабый". Директива .thumb_set специфична для ARM. Эта директива сообщает, что NMI_Handler - это адрес функции Thumb и его значение равно значению символа Default_Handler. А обработчик Default_Handler - это простейшая ловушка цикл. В библиотеке SPL обработчики прерываний вынесены в отдельный файл stm32f10x_it.c. Если этот файл скомпилировать и скомпоновать с остальными модулями, то будут действовать обработчики из этого файла, а обработчики стартового кода будут игнорироваться. Ещё одно изменение, это необходимость вызова SystemInit() . Можно вызывать эту функцию из стартового кода, а можно из функции main. Если вызывать из стартового кода, перед вызовом main, нужно вызвать SystemInit(). Структура каталогов проекта:
Каталоги /Libraries и /Utilities скопированы без изменений из демо пакета. Из подкаталога /Project/Examples/RCC , файлы примеров скопированы в каталог Src. Для удобства компиляции файлов демо проекта, я написал скрипт командного интерпретатора bash. Вот его текст:
Одно замечание. Для управления процессом компиляции и сборки программ, имеется ряд специализированных утилит, самая известная из них, это make. Но в некоторых случаях, можно обходиться и скриптом командного интерпретатора. К тому же, при использовании скрипта, становится понятнее процесс сборки программ, и яснее назначение программы make. Скрипт компилирует файлы проекта, запуская компилятор с нужными параметрами. Для удобства, параметры компиляции сохраняются в переменных, которые подставляются в команды. Опция -I указывает компилятору имя каталога для поиска включаемых в программу заголовочных файлов. Несколько путей поиска, хранится в переменной INCL. Опция -D, позволяет задать макрос в командной строке вызова компилятора. Точно так же, как если бы код программы содержал соответствующую директиву макроопределения. Эта опция широко применяется для управления процессом компиляции из командной строки. В примере, макрос STM32F10X_MD_VL указывает конкретный тип микроконтроллера, для которого будет компилироваться код. Значения подобных макросов обычно даются в описании библиотеки, либо получаются путём анализа исходного текста. Проверка значения макроса выполняется в файле stm32f10x.h из состава CMSIS. Макрос USE_STDPERIPH_DRIVER , указывает, что в программе будут использоваться библиотеки SPL. Значение этого макроса проверяется в том же файле stm32f10x.h. Важным является файл stm32f10x._conf.h , посредством этого файла включаются заголовочные файлы библиотек. В файле STM32vldiscovery.c , функции специфичные для демо платы. Оптимизация кода отключена и указано, что нужно добавлять информацию для отладчика. Если не требуется отладка программы, то оптимизацию можно включить, флаг "-O2" или "-Os". А флаг "-g" опустить вовсе. После успешной компиляции, в каталоге Obj обнаружится набор объектных файлов. Для компоновки и создания двоичного образа применяется отдельный командный файл :
Опция -nostdlib запрещает подключение стандартных библиотек, из имеющихся в составе инструментария. После загрузки бинарного файла в микроконтроллер, светодиоды на плате должны мигать. Самодельный стартовый модуль оказался вполне работоспособен, так же как и скрипт компоновщика.
Главная - Микросхемы - DOC - ЖКИ - Источники питания - Электромеханика - Интерфейсы - Программы - Применения - Статьи |
|
Впервые? | Реклама на сайте | О проекте | Карта портала тел. редакции: +7 (995) 900 6254. e-mail:info@eust.ru ©1998-2023 Рынок Микроэлектроники |
|