Error li005 no definition for systeminit

Имеется IAR 6.50 для ARM. Тестовый проект для STM32F103VCT6 (почти пустой). В нём имеется 3 файла: main.cpp, main.h и startup_stm32f10x_hd.s. При компиляции выдаётся сообщение линкера: Error[Li005]: no definition for "SystemInit" [referenced from E:IARProjectsTestDebugObjstartup_stm32f10x_hd...

Эта тема


  • Везде

  • Эта тема
  • Этот форум

  • Расширенный поиск

Поиск

Форум РадиоКот • Просмотр темы — STM32 Первый старт

Сообщения без ответов | Активные темы

ПРЯМО СЕЙЧАС:

Автор Сообщение

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Сб авг 04, 2012 12:22:05 

Родился

Зарегистрирован: Сб авг 04, 2012 12:16:29
Сообщений: 1

Рейтинг сообщения: 0

Всем привет,

Развел тут минимальную плату для stm32f103 (usb + uart + swd). Поскольку моя предыдущая плата так и не завелась — прежде чем пускать в «производство» хотелось бы спросить у котов:

  • Ничего ли я не забыл
  • Нужен ли кварц для того, чтобы залить прошивку по UART (и на какую частоту?)

Заранее спасибо.

Вложения:


stm32front.png [16.5 KiB]

Скачиваний: 934



noname.png [56.07 KiB]

Скачиваний: 573

Вернуться наверх
 

ПрофильПрофиль

 

Реклама

romazan

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Сб авг 04, 2012 17:43:32 

Потрогал лапой паяльник
Аватар пользователя

Зарегистрирован: Чт май 21, 2009 13:54:07
Сообщений: 335
Откуда: Москва

Рейтинг сообщения: 0

рекомендую использовать выводы МК по полной — не подключенные выводы вывести хотя бы на штыревые разъемы, бывает порой нужно пару тройку, также сделать отдельные с «земляным» для интерфейсов (SPI, UART, I2C….)

Вернуться наверх
Реклама

SubDia

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс авг 05, 2012 04:26:16 

Держит паяльник хвостом
Аватар пользователя

Карма: 9

Рейтинг сообщений: 40

Зарегистрирован: Сб апр 02, 2011 17:59:22
Сообщений: 995
Откуда: Город-герой Севастополь

Рейтинг сообщения: 0

Кой-чего позабыли. =)
1. Чегой Reset в воздухе висит? Я бы туда еще и кнопочку окромя подтяжки к питанию и конденсатора повесил.
2. Питание, вроде, приходит на МК из разных точек? Тогда хорошо.
3. Земля от кварца — только к МК, и никуда более.
4. Основываясь на собственном опыте, присоединюсь к предыдущему оратору — разведите ноги по максимуму. Потом сами себе спасибо скажете.
5. Кварц не нужен, стартанет от HSI на 16 МГц. Более подробно — смотрите сорцы IAP.


_________________
pavel_cydenov: Вобще я праAVRославный человек. Но и про ислARM слышал много хорошего )
MrYuran: Самые ортодоксальные — это PICудеи )
Katz: Не, 51-ники. )
Изображение

Вернуться наверх

Satyr

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс авг 05, 2012 08:24:28 

Друг Кота
Аватар пользователя

Карма: 26

Рейтинг сообщений: 108

Зарегистрирован: Чт ноя 04, 2010 01:56:36
Сообщений: 7355
Откуда: г. Москва

Рейтинг сообщения: 0

SubDia писал(а):

5. Кварц не нужен, стартанет от HSI на 16 МГц. Более подробно — смотрите сорцы IAP.

смотри внимательнее _ там усб нужен

Вернуться наверх
Реклама

Выгодные LED-драйверы для решения любых задач

КОМПЭЛ представляет со склада и под заказ широкий выбор LED-драйверов производства MEAN WELL, MOSO, Snappy, Inventronics, EagleRise. Линейки LED-драйверов этих компаний, выполненные по технологии Tunable White и имеющие возможность непосредственного встраивания в систему умного дома (димминг по шине KNX), перекрывают практически полный спектр применений: от простых световых указателей и декоративной подсветки до диммируемых по различным протоколам светильников внутреннего и наружного освещения.

Подобрать LED-драйвер>>

SubDia

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс авг 05, 2012 13:04:13 

Держит паяльник хвостом
Аватар пользователя

Карма: 9

Рейтинг сообщений: 40

Зарегистрирован: Сб апр 02, 2011 17:59:22
Сообщений: 995
Откуда: Город-герой Севастополь

Рейтинг сообщения: 0

Блеать. 0_о
Вот и сиди ночами — сидел же еще площадку под USB разъем рассматривал.
Тады ой, конечно. :)


_________________
pavel_cydenov: Вобще я праAVRославный человек. Но и про ислARM слышал много хорошего )
MrYuran: Самые ортодоксальные — это PICудеи )
Katz: Не, 51-ники. )
Изображение

Вернуться наверх
Реклама

Реклама

LIMF – источники питания High-End от MORNSUN со стандартным функционалом на DIN-рейку

На склад Компэл поступили ИП MORNSUN (крепление на DIN-рейку) с выходной мощностью 240 и 480 Вт. Данные источники питания обладают 150% перегрузочной способностью, активной схемой коррекции коэффициента мощности (ККМ; PFC), наличием сухого контакта реле для контроля работоспособности (DC OK) и возможностью подстройки выходного напряжения. Источники питания выполнены в металлическом корпусе, ПП с компонентами покрыта лаком с двух сторон, что делает ее устойчивой к соляному туману и пыли. Изделия соответствуют требованиям ANSI/ISA 71.04-2013 G3 на устойчивость к коррозии, а также нормам ATEX для взрывоопасных зон.

Подробнее>>

metcenger

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс дек 30, 2012 14:11:06 

Зарегистрирован: Ср ноя 17, 2010 01:03:44
Сообщений: 54

Рейтинг сообщения: 0

настраиваю IAR для первого старта под плату STM32L-Discovery (STM32L152RBT6)

сразу 12 ошибок. Кто может подсказать- чего не так ему? Чего не подключил?

Вернуться наверх

SubDia

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс дек 30, 2012 14:37:05 

Держит паяльник хвостом
Аватар пользователя

Карма: 9

Рейтинг сообщений: 40

Зарегистрирован: Сб апр 02, 2011 17:59:22
Сообщений: 995
Откуда: Город-герой Севастополь

Рейтинг сообщения: 0

сделайте скриншот (с воплями IARа) и прикрепите. Ваш проект запускать и отлавливать ошибки как-то не очень интересно.


_________________
pavel_cydenov: Вобще я праAVRославный человек. Но и про ислARM слышал много хорошего )
MrYuran: Самые ортодоксальные — это PICудеи )
Katz: Не, 51-ники. )
Изображение

Вернуться наверх

metcenger

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс дек 30, 2012 15:02:37 

Зарегистрирован: Ср ноя 17, 2010 01:03:44
Сообщений: 54

Рейтинг сообщения: 0

Изображение
Изображение

может хидер он не видит? Или что-то подобное простое?

Вернуться наверх

HHIMERA

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс дек 30, 2012 15:19:56 

Карма: -18

Рейтинг сообщений: 29

Зарегистрирован: Вс дек 05, 2010 06:10:34
Сообщений: 4583
Откуда: ЮВ

Рейтинг сообщения: 0

Вернуться наверх

HHIMERA

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс дек 30, 2012 15:22:04 

Карма: -18

Рейтинг сообщений: 29

Зарегистрирован: Вс дек 05, 2010 06:10:34
Сообщений: 4583
Откуда: ЮВ

Рейтинг сообщения: 0

SubDia писал(а):

Ваш проект запускать и отлавливать ошибки как-то не очень интересно.

Понятно… пейсатые гейрои всегда идут в обход… :))) :))) :)))


_________________
«Я не даю готовых решений, я заставляю думать!»(С)

Вернуться наверх

metcenger

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс дек 30, 2012 17:00:16 

Зарегистрирован: Ср ноя 17, 2010 01:03:44
Сообщений: 54

Рейтинг сообщения: 0

HHIMERA писал(а):

SubDia писал(а):

Ваш проект запускать и отлавливать ошибки как-то не очень интересно.

Понятно… пейсатые гейрои всегда идут в обход… :))) :))) :)))

там не так просто было- вернее, я все правильно описал, как в примере.
нужно было в новой версии ИАРа подключать встроенную CMSIS и удалять файлы из проекта- в комментах к той ссылке это есть.

теперь опять затык-
откомпилировать дает, а make- ошибка
Error[Li005]: no definition for «SystemInit» [referenced from D:worksprojectsM3_testDebugObjstartup_stm32l1xx_md.o]
чего ему надо еще?

и я правильно понял, что ничего из CMSIS не надо проекту подцеплять? типа этого

stm32vldiscovery_packageLibrariesCMSISCM3CoreSupportcore_cm3.c

stm32vldiscovery_packageLibrariesCMSISCM3CoreSupportcore_cm3.h

tm32vldiscovery_packageLibrariesCMSISCM3DeviceSupportSTSTM32F10xsystem_stm32f10x.c

tm32vldiscovery_packageLibrariesCMSISCM3DeviceSupportSTSTM32F10xsystem_stm32f10x.h

Вернуться наверх

SubDia

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс дек 30, 2012 22:12:27 

Держит паяльник хвостом
Аватар пользователя

Карма: 9

Рейтинг сообщений: 40

Зарегистрирован: Сб апр 02, 2011 17:59:22
Сообщений: 995
Откуда: Город-герой Севастополь

Рейтинг сообщения: 0

HHIMERA писал(а):

SubDia писал(а):

Ваш проект запускать и отлавливать ошибки как-то не очень интересно.

Понятно… пейсатые гейрои всегда идут в обход… :))) :))) :)))

Не скалься, а? «Гей рой.» Первый же конфликт начинаешь.

metcenger писал(а):

теперь опять затык-
откомпилировать дает, а make- ошибка
Error[Li005]: no definition for «SystemInit» [referenced from D:worksprojectsM3_testDebugObjstartup_stm32l1xx_md.o]
чего ему надо еще?

А ему надо функцию «SystemInit», реализация которой находится в system_stm32l1xx.c.
Подключите этот исходник к проекту.

metcenger писал(а):

и я правильно понял, что ничего из CMSIS не надо проекту подцеплять? типа этого

Надо. Все, как описывает ТС той статьи, на которую указывает HHIMERA. Только для Вашего МК, разумеется.


_________________
pavel_cydenov: Вобще я праAVRославный человек. Но и про ислARM слышал много хорошего )
MrYuran: Самые ортодоксальные — это PICудеи )
Katz: Не, 51-ники. )
Изображение

Вернуться наверх

metcenger

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вс дек 30, 2012 22:55:23 

Зарегистрирован: Ср ноя 17, 2010 01:03:44
Сообщений: 54

Рейтинг сообщения: 0

да, подключил тот файл, кроме

stm32vldiscovery_packageLibrariesCMSISCM3CoreSupportcore_cm3.c
stm32vldiscovery_packageLibrariesCMSISCM3CoreSupportcore_cm3.h
спасибо.

теперь еще проблема- не могу прошить из ИАРа ничего. Если файл скомпилированный зашиваю через STM32 ST-LINK Utility, то зашивается и работает нормально.
(Кстати, подошел драйвер тот, что в комплекте с ИАРом шел- с сайта скаченный- висела ошибка драйвера в диспетчере устройств)

ошибки IAR выдает такие:

Fatal error: ST-Link Connection error Session aborted!
Failed to load flash loader: D:program filesIAR SystemsARM_Embedded Workbench 6.5armconfigflashloaderST
FlashSTM32L15xxB.flash

Вернуться наверх

wellcom

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Пн дек 31, 2012 21:40:56 

Нашел транзистор. Понюхал.
Аватар пользователя

Зарегистрирован: Чт фев 24, 2011 13:00:49
Сообщений: 190

Рейтинг сообщения: 0

С новым годом всех! Хороших паяльников и живучих чипов!
….и как всегда Нужна помощь. Чип STM32F103C4, хочу использовать порт PB3, однако по даташиту, табл 5 стр.27 у чипа как main function (после сброса) — функция JTDO. В колонке Default пусто. Как это понимать?…..я не смогу использовать PB3 на выводе 39? Как включить выход порта PB3 на выводе 39. Спасибо.


_________________
:solder: 32-х ядерный процессор из П213В

Вернуться наверх

HHIMERA

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вт янв 01, 2013 02:51:28 

Карма: -18

Рейтинг сообщений: 29

Зарегистрирован: Вс дек 05, 2010 06:10:34
Сообщений: 4583
Откуда: ЮВ

Рейтинг сообщения: 0

Отключите JTAG… типа…

Код:

AFIO->MAPR |= AFIO_MAPR_SWJ_CFG_JTAGDISABLE;  /*!< JTAG-DP Disabled and SW-DP Enabled */

и настройте PB3 как обычно…


_________________
«Я не даю готовых решений, я заставляю думать!»(С)

Вернуться наверх

wellcom

Не в сети

Заголовок сообщения: Re: STM32 Первый старт

СообщениеДобавлено: Вт янв 01, 2013 13:35:17 

Нашел транзистор. Понюхал.
Аватар пользователя

Зарегистрирован: Чт фев 24, 2011 13:00:49
Сообщений: 190

Рейтинг сообщения: 0

Спасибо, еще нужно включить этот AFIO

Код:

   RCC->APB2ENR |= RCC_APB2ENR_AFIOEN; //*!< Alternate Function I/O clock enable */
   AFIO->MAPR |= AFIO_MAPR_SWJ_CFG_JTAGDISABLE;  /*!< JTAG-DP Disabled and SW-DP Enabled */


_________________
:solder: 32-х ядерный процессор из П213В

Вернуться наверх

Кто сейчас на форуме

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 7

Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

SergeyYe

8 / 8 / 0

Регистрация: 09.02.2019

Сообщений: 35

1

01.11.2021, 23:06. Показов 1046. Ответов 7

Метки нет (Все метки)


Таким образом инициализирую TIM4 и пытаюсь обработать прерывание.

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
void TIM4_Init(void)                        // Инициализация ТIM4 с IRQ.
{
  TIM4 -> PSC = 2000 - 1;                   // F = 2'000 Hz. T = 0,5 mS.
  TIM4 -> ARR = 40000;                      // Время переполнения: 20 Sec.
  TIM4 -> CR1 |= TIM_CR1_URS;               // Запретить IRQ при генерации события.
  TIM4 -> EGR |= TIM_EGR_UG;                // Сгенерировать событие, bit UG.
  TIM4 -> CR1 |= TIM_CR1_OPM;               // Режим одиночного импульса.
  TIM4 -> DIER |= TIM_DIER_UIE;             // Разрешаем генерацию IRQ.
  NVIC_EnableIRQ (TIM4_IRQn);               // Разрешаем IRQ в NVIC.
  TIM4 -> CR1 |= TIM_CR1_CEN;               // Запускаем таймер.
}
 
void TIM4_IRQHandler (void)
{
  NVIC_ClearPendingIRQ(TIM4_IRQn);          // Cбрасываем флаг прерывания в NVIC.
  TIM4 -> SR &= ~TIM_SR_UIF;                // Cбрасываем флаг прерывания TIM4.
  if (HC273 & TFT_LightOn)
    PortD_Set (0, TFT_LightOff);            // Выключаем подсветку дисплея.
  TIM4 -> CR1 |= TIM_CR1_CEN;               // Запускаем таймер.
}

Но IAR отказывается его компилировать. Имя обработчика отсутствует в *.map файле проекта. Поэтому при наступлении прерывания улетаю в HardFault_Handler. А оттуда, как известно, возврата нет. Странно и то, что обработчик не компилируется даже как обычная функция. Возможно, у меня не подключен к проекту файл с таблицей прерываний. Но я не знаю, в каком файле она находится.
Попробовал сделать это-же на SysTick — всё прекрасно прерывается.
Чертовщина какая-то, однако.

__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь



0



Programming

Эксперт

94731 / 64177 / 26122

Регистрация: 12.04.2006

Сообщений: 116,782

01.11.2021, 23:06

Ответы с готовыми решениями:

Stm32 в IAR на C++
Добрый вечер! Такой у меня есть вопросик: написал программу-мигалку для stm32f303 в iar на си, все…

STM32 + IAR
Здравствуйте!

Подскажите, пожалуйста, как подключить STM32 через jtag порт к IAR?

Использую…

stm32 iar прерывания
добрый день, ув. форумчае
пытаюсь настроить ацп, посмотрел вот этот видео урок…

STM32 + SSD1963 + IAR
Доброго времени суток все! неделю маюсь уже с дисплеем на контроллере ssd1963. в общем не могу…

7

206 / 159 / 36

Регистрация: 15.11.2012

Сообщений: 762

02.11.2021, 01:24

2

скачайте библиотеку stmcube (не программу) для вашего контроллера (они по сериям), там найдите файлы с расширением .s.
Нужный добавьте в ваш проект. Если использовать его без изменения, нужно добавить в программу функцию SystemInit (иначе проект не соберется). Либо уберите вызов этой функции из обработчика вектора Reset_Handler.



1



SergeyYe

8 / 8 / 0

Регистрация: 09.02.2019

Сообщений: 35

02.11.2021, 11:09

 [ТС]

3

Цитата
Сообщение от alexey6689
Посмотреть сообщение

скачайте библиотеку stmcube

И где её взять? На http://st.com не нашёл.
IAR отказывается компилировать потому, что TIM4_IRQHandler () не используется ни одной функцией. Чтобы эту функцию использовать как обработчик прерывания от TIM4, её нужно привязать к вектору с адресом 0xB8. Как это сделать я и не знаю. А ассемблерные файлы *.s директивой

C#
1
#include

не подключаются.



0



38 / 31 / 9

Регистрация: 29.03.2019

Сообщений: 345

02.11.2021, 12:30

4

SergeyYe,

https://www.st.com/en/embedded… ges.html#2
В зависимости, какой у вас контроллер
В принципе и куб установить можно, сгенирировать проект и оттуда стартап файл взять, но так проще



1



206 / 159 / 36

Регистрация: 15.11.2012

Сообщений: 762

02.11.2021, 12:41

5

Цитата
Сообщение от SergeyYe
Посмотреть сообщение

не подключаются

его нужно не через include подключать, а добавлять в проект (Project — Add Files…).
Так же как и любой .c или .s файл.



1



8 / 8 / 0

Регистрация: 09.02.2019

Сообщений: 35

02.11.2021, 14:13

 [ТС]

6

Цитата
Сообщение от northcitizen
Посмотреть сообщение

оттуда стартап файл взять

Стартап у меня есть. Я его не правильно в проект включал (директивой #include).
Спасибо Алексею, направил на путь истинный:

Цитата
Сообщение от alexey6689
Посмотреть сообщение

его нужно не через include подключать, а добавлять в проект (Project — Add Files…).

После сборки обработчик в проекте появился. Но появилась ещё одна проблемка — компилятор ругается на строку EXTERN SystemInit в начале файла startup_stm32f103xb.s. Говорит,что: Error[Li005]: no definition for «SystemInit» [referenced from C:STM32_ProjectsBrain_IARDebugObjstartup_stm3 2f103xb.o].
Видимо не хватает ещё какого-то файла с определением этого EXTERN SystemInit?



0



206 / 159 / 36

Регистрация: 15.11.2012

Сообщений: 762

02.11.2021, 14:15

7

Лучший ответ Сообщение было отмечено SergeyYe как решение

Решение

Цитата
Сообщение от SergeyYe
Посмотреть сообщение

EXTERN SystemInit

Так я же написал все уже. Либо определить функцию SystemInit, либо убрать ее вызов в .s файле.



1



8 / 8 / 0

Регистрация: 09.02.2019

Сообщений: 35

02.11.2021, 14:23

 [ТС]

8

Цитата
Сообщение от alexey6689
Посмотреть сообщение

Либо определить функцию SystemInit, либо убрать ее вызов

Вы правы. Из опухшей головы через правое ухо вылетело.
Спасибо, победа!



0



IT_Exp

Эксперт

87844 / 49110 / 22898

Регистрация: 17.06.2006

Сообщений: 92,604

02.11.2021, 14:23

Помогаю со студенческими работами здесь

IAR для stm32
Добрый день! Вопрос может и глупый, но уже несколько часов тыкаюсь и ничего не получается) пишу в…

Прерывание: IAR+STM32+EXTI0
Не получается обработать прерывание EXTI0. При наступлении события улетаю в никуда и там зависаю….

STM32 + IAR + FreeRTOS, писать на C или C++
Пишу для STM32 на IAR. Всегда писал на чистом С, т.к. учился в основном на примерах в интернете, а…

«Наложение» переменных. STM32, IAR, возможно?
Использую IAR. После дополнения программы (различными буферами и переменными) для STM32F100C8, мое…

STM32 independent watchdog и дебаг в IAR
Подскажите пожалуйста с одним вопросом.

Как я понимаю independent watchdog, однажды заведенный,…

Среда программирования IAR Embedded Workbench для STM32. Ошибка при запуске
Доброго всем времени суток.
Прошу помогите, нам.
Именно нам.
Товарищ подошел с рядом…

stm32 и IAR
Если у моего контроллера на порты B кроме диодов подключены таймер, цап, нужно ли как-то его при…

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:

8

Error li005 no definition

На этой страничке решил собрать ошибки, возникающие при компиляции, линковке, отладке в IDE IAR Embedded Workbench for ARM, и методы их устранения.

Ошибка произошла из-за того, что я вынес в отдельный файл pins.c определения составных переменных:

Ошибка [Pe070] возникала потому, что макрос PIO_LISTSIZE не мог вычислить sizeof(list). Решение: в pins.h указать размер массива. Связано с неудобствами — нужно следить за синхронизировать pins.c и pins.h. Устранение ошибки:

//[Файл pins.h]
extern const Pin pinsCol [ 4 ] ;

На языке C одиночный оператор может состоять из нескольких строк текста. Принято, что не последняя строка такого оператора должна завершаться обратным слешем ().

Многострочные операторы часто используют для задания массивов символов, и при этом легко допустить ошибку, нечаянно пропустив в одной из строк обратный слеш (причем такую ошибку бывает трудно обнаружить). Компилятор выдаст примерно следующее сообщение об ошибках:

Error[Pe008]: missing closing quote C:папкамодуль.c 19
Error[Pe007]: unrecognized token C:папкамодуль.c 23
Error[Pe065]: expected a «;» C:папкамодуль.c 23

Пример оператора с ошибкой и без ошибки:

Пропущенный слеш нужно искать в строке перед второй ошибкой.

[Случай 1]

Долго не мог разобраться, почему возникала ошибка Error[Pe147]: declaration is incompatible with «TParams const __data папка_проектаvars.c 22 paramDefault» (declared at line 22). У меня была задана структура TParams как тип:

Грешил даже на то, что структура назначалась как переменной, так и константе:

Оказалось все проще (хотя сразу не разобрался потому, что компилятор не указывал на это место) — я просто забыл ключевое слово const в хедере, где предварительно объявлялись param и paramDefault. Было там так (это ошибочно):

А для исправления ошибки должно быть так:

[Случай 2]

При портировании проекта BIGTREETECH TFT35 V3.0 из среды Visual Studio Code (VSC, VSCode) на IAR столкнулся с ошибкой несовместимости определений в iccarm_builtin.h и core_cm3.h:

1. Удалить файл core_cm3.h, либо переименовать его вcore_cm3.h.old.
2. Зайти в свойства проекта, в разделе General Optoins -> закладка Library Configuration поставить галочку «Use CMSIS».

Иногда после продолжительных правок трудно найти место, где пропустили точку с запятой. Например, компилятор неожиданно выдает ошибки на синтаксис в файле kbmatrix.h, который Вы даже не исправляли:

Remark[Pe082]: storage class is not first C:asmtestprojectincludekbmatrix.h 25
Error[Pe065]: expected a «;» C:asmtestprojectincludekbmatrix.h 25
Error[Pe757]: variable «KeyEventCallback» is not a type name C:asmtestprojectincludekbmatrix.h 54
Error[Pe757]: variable «KeyEventCallback» is not a type name C:asmtestprojectincludekbmatrix.h 67
Error while running C/C++ Compiler

Для того, чтобы найти действительное место ошибки, нужно найти все включения файла kbmatrix.h — перед ним наверняка будут другие включаемые заголовки, в которых допущена ошибка. Запускаем общий поиск по всему проекту, для чего жмем Ctrl+F и в строке поиска указываем kbmatrix.h. Переключатель «Look in» должен стоять на «Project files and all include files».

После поиска получим список файлов, которые включают директивой #include файл kbmatrix.h:

C:asmtestprojectkbmatrix.c 4 #include «kbmatrix.h»
C:asmtestprojectincludepins.h 3 #include «kbmatrix.h»
C:asmtestprojectpins.c 6 #include «kbmatrix.h»
———-
Found 3 instances. Searched in 270 files.

В одном из этих найденных файлов (kbmatrix.c, pins.h, pins.c), перед #include «kbmatrix.h» включаются другие файлы, в которых допущена ошибка. Теперь место пропущенной точки с запятой найти легко. В моем примере ошибка была в исправленном файле mytypes.h. Вот содержимое файла pins.h (он был в списке найденных), где добавлялся заголовок mytypes.h с ошибкой:

#include «settings.h»
#include «mytypes.h»
#include «kbmatrix.h»
..

Просмотрев список включаемых файлов, перед #include «kbmatrix.h», я увидел файл, который исправлял — mytypes.h, в нем как раз и была ошибка (пропущена точка с запятой после определения типа структуры).

[Причина 1]

Возможно, что пропущено словечко void в параметрах при определении функции. Пример:

Исправить нужно так:

Пример лога ошибок:

Определение FILE находится в заголовочном файле stdlib.h, поэтому нужно подключить его директивой #include. Однако иногда этого недостаточно, потому что поддержка FILE присутствует только в варианте выбора библиотек Full, но может быть выбран другой вариант — None или Normal с целью экономии памяти встраиваемых систем. Чтобы использовать FILE, необходимо переключиться на полный вариант стандартных библиотек это делается опцией командной строки компилятора —dlib full. Либо можно это настроить в диалоге свойств проекта (Options. ) -> General Options -> Library Configuration -> Library: поставьте Full:

Имейте в виду, что полный вариант стандартных библиотек (Full) приведет к намного большему объему кода. Поэтому если Вы используете FILE только для печати диагностических сообщений в stderr, то лучше использовать какой-нибудь другой способ вывода сообщений.

[Причина 2]

Если в свойствах проекта, раздел C/C++ Compiler -> C dialect стоит галочка «Require prototypes», то для не переопределенных weak-функций это будет гарантированно вызвать ошибку.

Снимите эту галочку, и ошибка Pa045 пропадет.

Проблема в том, что в блоке памяти [0x00100000-0x001002db] находится код, до которого не могут достать ассемблерные команды короткого перехода, находящиеся в ассемблерном коде (обычно в других модулях). В этом случае нужно править ассемблерный код, чтобы переходы были длинными, либо переписать код с ассемблера на C (тогда компилятор сам подставит нужные команды). Другое решение указать компилятору генерировать код для режима процессора не thumb, а arm (Свойства проекта (Options. ) -> General Options -> C/C++ Compiler -> Processor mode -> Arm).

Чтобы сгенерировать карту памяти и статистику линковки (это поможет найти проблему), откройте свойства проекта (Options. ) -> General Options -> Linker -> List -> Поставьте галочки на «Generate linker map file» и на «Generate log file», а также все галочки ниже на опциях лог-файла. Лог-файл см. в файле имя_конфигурацииListимя_проекта.log, а карту распределения памяти в файле имя_конфигурацииListимя_проекта.map.

Предупреждение возникало при попытке вызвать из кода на C функцию abs, пример:

Дело в том, что на простом C (не C++) нельзя распознать прототип функции abs по типу переменной. Только для C++ можно автоматически подставить нужный прототип abs (для разных типов аргументов на C++ имеются разные реализации abs). В данном случае в параметре была переменная типа float, а определение abs подразумевало в параметре целый тип. На самом деле на C нужно напрямую вызывать abs с нужным функционалом по отдельному имени, здесь подойдет fabsf:

Пример кода, который генерирует предупреждение Pa091:

Причина ошибки в том, что оператор инверсии

делает приведение типа unsigned char к типу signed int перед инверсией. Для того, чтобы пропало предупреждение, нужно перед инверсией дополнительно вставить ключевое слово unsigned:

Такая ошибка возникает при логических операциях с константами из перечисления (которые определены через enum). Вот пример кода, который генерирует предупреждение Pe188:

Причина предупреждения в том, что результатом логической операции будет целочисленный тип, а не тип enum. Исправить можно, если явно указать, что результат операции будет иметь тип перечисления:

Когда 2 заголовочных файла ссылаются друг на друга директивой #include, то могут возникнуть ошибки Error[Pe020]: identifier «имя_идентификатора» имя_файла.h номер строки is undefined (упомянутый идентификатор не найден). К примеру, в заголовочный файл headerA.h подключен файл headerB.h, и также к файлу headerB.h подключен файл headerA.h — тогда блок защиты от повторного включения заголовка [2] не даст видимости всех нужных имен, определенных в первом подключенном заголовке.

Для того, чтобы исправить эту ситуацию, требуется создать третий заголовок headerC.h, который будет содержать общие для headerA.h и headerB.h определения, и подключить headerC.h в headerA.h и headerB.h, чтобы они не ссылались друг на друга.

Постоянно достают предупреждения компилятора IAR о неправильной строке форматирования (printf, sprintf, sscanf): «IAR EWB ARM: Remark[Pe181]: argument is incompatible with corresponding format string conversion».

Избавиться от таких предупреждений поможет правильный выбор опции форматирования вывода printf. Для подробной информации см. [3].

  • Функция printf, аргумент u8 (unsigned char), строка формата %u -> надо поменять формат на %i.
  • Функция printf, аргумент u16 (unsigned short), строка формата %u -> надо поменять формат на %i.
  • Функция sscanf, аргумент u8 (unsigned char), строка формата %u или %i -> надо поменять формат на %hu, а тип аргумента на u16 (unsigned short).

Ошибка может возникнуть, если неправильно определена переменная структуры, например:

Исправить предупреждение Pe1000 можно, если правильно указать экземпляр переменной структуры:

[140110]

Вопрос: мне нужно кастомизировать вывод на собственное устройство отображения (LCD). Все сделал, как написано в документации IAR — определил внешнюю функцию MyLowLevelPutchar, раскомментировал функцию __write, но почему-то при вызовах printf и putchar вывод на LCD не происходит. Функция __write не вызывается, и код, который я написал в теле функции MyLowLevelPutchar, не работает. В чем проблема?

Ответ: Вы все сделали правильно, но кроме этого в некоторых версиях IAR (например 4.20) необходимо особым образом выбрать конфигурацию библиотек DLIB. Это делается через свойства проекта General Options -> Library Configuration -> Library. Попробуйте из выпадающего списка выбрать вариант Normal, и если не заработает, то попробуйте выбрать Full. У меня иерархия вызовов в IAR версии 4.20 работала почему-то следующим образом: если выбрать Full, то последовательность вызова получается printf -> .. -> putchar -> fputc, и в этом варианте ничего не работало (код в MyLowLevelPutchar не вызывается). Если выбрать Normal, то тогда цепочка вызовов printf -> .. -> putchar -> __write, и в этом случае перенаправление вывода работает (потому что в функция __write вызывает пользовательский код из MyLowLevelPutchar).

[140312]

Такая ошибка возникает, когда Вы перенесли проект в другую папку, но перед запуском отладки не сделали очистку и не перекомпилировали проект. В отладочных файлах запомнились старые абсолютные пути до фалов исходного кода, которые теперь не соответствуют реальным. Чтобы исправить ошибку, выберите пункт меню Project -> Clean, после чего запустите отладку. Проект скомпилируется заново, и теперь отладка запустится без ошибки.

[140515]

Для больших проектов время компиляции может составлять большую проблему. Есть несколько советов, как можно уменьшить время компиляции.

1. Убедитесь, что в каждом заголовочном файле у Вас есть защитные заголовки, например:

Подробнее про защитные заголовки см. [4]. Кроме того, проверьте файлы исходного кода на лишние подключения заголовков директивой #include. Этот фактор значительно влияет на скорость компиляции.

2. Создайте предварительно скомпилированные библиотеки, куда поместите редко изменяемые модули: BSP (Board Support Package, пакет поддержки платы разработчика), стеки протоколов и т. д. Это нужно делать периодически для кода, который остается неизменным, и который не нужно перекомпилировать каждый раз, когда что-то меняется в коде приложения. Подробнее см. [5].

3. Запретите генерацию файлов листинга компилятора (Options -> C/C++ Compiler -> List).

4. Если некоторые файлы находятся на сетевом диске (даже если это RAM-диск на сервере), попробуйте сделать их локальными, т. е. скопировать на жесткий диск рабочей станции, и компилировать оттуда. Если это ускорит компиляцию, то значит имелись проблемы, связанные с сетевой файловой системой (NFS/Samba).

5. Если совет 4 помог (при использовании локального диска компиляция ускорилась), то может помочь размещение на локальном диске только объектных файлов и файлов листинга. Для этого измените настройки Project -> Options -> General Options -> Output. Сконфигурируйте пути «Object files» и «List files» так, чтобы они были размещены не на сети, а локально.

6. Если при компиляции бывают случаи, что процесс сильно замедляется или среда IAR зависает, то возможно, что в этот момент происходит сканирование рабочих файлов антивирусом. Такой случай может привести также к сообщениям о запрещенном доступе (denied permission), об истечении таймаута.

Для того, чтобы исключить проверку антивирусом папок IAR, нужно добавить в исключения антивируса следующие папки:

• Инсталляционный каталог IAR (например, это может быть папка C:Program FilesIAR SystemsEmbedded Workbench 5.4).
• C:Program FilesCommon FilesIAR Systems
• C:Documents and Settings USERNAME Application DataIAR Embedded Workbench

Здесь USERNAME означает имя (логин пользователя), под которым Вы работаете в системе Windows. Полное имя до этой папки может зависеть от версии операционной системы Windows.

7. Создайте RAM-диск, и попробуйте компилировать проект на нем. Будьте осторожны, поскольку при пропадании питания или зависании компьютера вся Ваша работа потеряется! Как промежуточный вариант, можно на RAM-диск сохранять только объектные файлы, файлы листинга и выходные файлы, для этого в свойствах проекта General Options -> Output поменяйте пути до выходных рабочих директорий Output directories.

Самое простое средство для создания RAM диска — бесплатная программа SoftPerfect RAM Disk site:softperfect.com.

[161019]

При попытке компиляции выскакивают совершенно неожиданные ошибки — невозможно удалить файл, который либо вообще не используется в проекте, либо находится в каталоге установки IAR. Например, у меня появлялась вот такая ошибка, когда я попробовал сменить конфигурацию Release на Debug:

Очевидно, что это полный бред — зачем очистке понадобилось вдруг удалять файл wchar.h, который относится к стандартным библиотекам, да и еще находится в каталоге установки среды разработки IAR Embedded Workbench.

Причина ошибки заключается в том, что произошла рассинхронизация конфигураций Release и Debug. Конфигурация Debug давно не использовались, в то время как конфигурацию Release вносились изменения. Похоже, что глючит обработчик списка зависимостей, причем могут происходить даже еще более неприятные глюки, вплоть до удаления рабочих заголовочных файлов проекта (поэтому чаще делайте бэкапы!).

Решение проблемы заключается в просмотре обоих конфигураций и внесение корректных изменений в конфигурацию, где происходит эта ошибка. Особенно внимательно следует проверить дополнительные пути поиска подключаемых файлов, а также наличие предварительно определенных переключающих макросимволов (Project -> Options -> C/C++ Compiler -> Preprocessor).

Довольно часто появляющаяся ошибка в разных версиях IAR. Разработчики борются с этой ошибкой, и с переменным успехом. Обычно проблема решается, если несколько раз выполнить операцию очистки (Project -> Clean). Иногда помогает перезапуск IAR + выполнение очистки проекта.

Еще одна из причин такой ошибки — в проекте имеется 2 подключенных исходных файла, компиляция которых приводит к генерации одного и того же объектного файла. Например, есть две версии одного и того же модуля — один на языке C (с расширением *.c), и другой оптимизированный, на ассемблере (с тем же именем, но с расширением *.s). Решение проблемы очевидно — нужно исключить из процесса компиляции один из этих файлов.

Чтобы переименовать workspace, но сохранить при этом в нем те же самые имена проектов, что и были раньше, просто переименуйте файл *.eww.

Поскольку среда разработки IAR EWB не предоставляет прямого функционала для специального переименования проекта, требуется обходной путь для этого действия. Когда я переименовываю workspace и связанный с ним проект, то поступаю следующим образом:

1. Делаю копию Template.ewp (это файл проекта) и переименовываю копию, скажем, в NewProject.ewp.
2. Открываю файл workspace Template.eww.
3. Выбираю Project -> Add Existing Project.
4. Выбираю NewProject.ewp и кликаю Open.
5. Выбираю закладку «Template» в нижней части списка файлов Workspace (соответствует старому проекту).
6. Делаю правый клик на старом проекте и выбираю Remove.
7. Закрываю IAR EWB, он запросит сохранить workspace, сохраняю.
8. Переименовываю файлы старого workspace *.eww, *.ewd в NewProject.eww, NewProject.ewd (и также файл *.dep, если он у Вас есть).
9. Удаляю Template.ewp.

После этого Вы сможете открыть NewProject.eww как полностью переименованное workspace и полностью переименованный проект. Если Вы хотите только переименовать проект, и оставить старое имя для workspace, то выполните только шаги 1..7.

[170621]

Заголовочный файл lib_AT91SAM7X256.h, в IAR 6.50 выскакивают ошибки на код с операторами __inline:

Проблема в том, что для встраиваемых функций поменялся синтаксис: замените __inline на inline, и ошибка исчезнет.

На языке C, в отличие от C++, нет определения булевого типа. Поэтому либо подключите в коде C заголовочный файл stdbool.h:

Либо добавьте в общий заголовочный файл (например types.h) следующее определение:

Это глюк, связанный с файлами нулевой длины. Найдите файл, на который указывает сообщение, и удалите его.

[171204]

Неожиданный глюк, который начал происходить без видимых причин (наблюдалось на IAR 6.50.3 и Windows 7). При попытке компиляции выскакивает ошибка «General exception during build», которая сопровождается ошибкой очистки «General exception during clean». Причем в конфигурации Debug проект компилируется нормально, а в конфигурации Release происходит ошибка.

Ресурс по известным проблемам IAR [6] советует выполнить переустановку IAR в другой каталог на диске, или переименовать папку текущей инсталляции: «Install another copy of your IAR Embedded Workbench product in a different location or rename the directory of your current installation».

Мне помогло следующее — полностью удалил с диска корневую папку проекта, и восстановил её копированием из архива бекапа. После этого ошибка волшебным образом исчезла.

Замечание, сигнализирующее о возможной логической ошибке в операторе switch. Вот пример из библиотеки EFSL, генерирующий такое предупреждение компилятора (Pe1814 на строке 40):

Это пример не очень аккуратного кодирования: оператор swith проверяет переменную value, и эта же переменная проверяется оператором if в default-блоке того же оператора swith. Очевидно, что здесь скорее всего используется не только ненужная проверка if, но и блок else этого оператора if никогда не выполнится.

В TN43262 [7] объясняется, как нужно работать с абсолютно размещаемыми переменными. Проблема с такими переменными заключается в том, что в некоторых ситуациях разработчик получает сообщение об ошибке линкера «переменная не определена». Это может быть связано с тем, что такая переменная должна быть определена специальным, не интуитивно понятным способом.

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

[Дополнительная информация]

Переменные, которые размещаютсы по абсолютному адресу, ведут себя немного не так, как обычные не автоматические переменные C/C++. Абсолютно размещамеые переменные находятся в абсолютном сегменте, таком как ABSOLUTE или xxxx_AN. Абсолютный сегмент не представлен файле линкера, поскольку переменные уже размещены во время компиляции.

Другие (обычные) не автоматические переменные, находящиеся в модуле исходного кода, размещаются в перемещаемый сегмент, который описывается в файле линкера как обычно. Поэтому разрешение адреса осуществляется во время линковки.

Не очевидное поведение: каждое определение абсолютно размещенной переменной в действительности локально для текущей компилируемой единицы (файла исходного кода), поэтому Вы можете (и должны) иметь определение этой переменной для каждого элемента компиляции (модуля исходного кода). Несколько таких одновременных определений не приведут к ошибке во время линковки или ошибке во время выполнения (если Вы идентично определили абсолютную переменную во всех местах, где она используется). Если Вы не используете абсолютно размещенную переменную, то она выбрасывается из единциы компиляции. Если же Вы должны её использовать, то она должна быть представлена в выходном файле по двум причинам. Во-первых, переменная используется, поэтому она должна требовать своего абсолютного размещения на этапе линковки. Во-вторых, это позволяет линкеру проверить, что эти определения соответствуют друг другу во всех модулях.

Другими словами, для абсолютной переменной Вы должны разместить в заголовочном файле определение (не декларацию, как это обычно делается), если используете переменную в нескольких файлах. Пример такого заголовочного файла setup.h:

После этого просто добавьте подключение файла setup.h во все файлы исходного кода, где должна использоваться переменная.

Один из способов запомнить — думать об этом как о наличии #define для описания размещения в памяти, с добавлением наличия способности линкера проверить его непротиворечивость.

[Другой способ абсолютного размещения переменной]

Если Вы вместо этого поместите объект в именованный сегмент:

то должен быть определен сегмент SETUP, и он должен быть размещен в файле линкера. Переменные, размещенные в сегменте, ведут себя как обычные переменные языка C, для них поместите следующую декларацию в файл заголовка:

И затем Вам нужно поместить определение в один (и только в один) исходный файл:

Если Вам не нравится @-синтаксис, есть его эквивалент, который можно использовать альтернативно:

Источник

I am having a strange problem. I am trying to integrate the spi module from Nordic Semiconductors peripherals examples with the Central BLE Uart project.

There is a library of component common to all the examples. So what I did is add the spi_slave file nrf_drv_spis.c to my project, and added the path to that component in the preprocessor paths of the project.

$PROJ_DIR$..............componentsdriversnrf_spi_slave is in my preprocessor paths and this is where nrf_drv_spis.c and nrf_drv_spis.h are.

However, when I compiled the code, I get this error

Error[Li005]: no definition for "nrf_drv_spis_init" [referenced from D:Repoble_projectsnRF5_SDK_12.3.0examplesble_centralble_app_uart_cpca10028s130iar_buildmain.o] 

nrf_drv_spis_init is a function found in nrf_drv_spis.c and the prototype is in nrf_drv_spis.h. The odd thing as well is that when I right click on nrf_drv_spis_init and «go to the definition», it always bring me to the prototype in the header file. Normally, IAR presents me with either the prototype or the definition of the function and I need to click either the declaration or the prototype.

So it does shows me that for whatever reason, the file nrf_drv_spis.c doesn’t seem to be in the project, but I don’t know what to do to fix this.

Any help would be appreciated.
Thanks.

Теги:  IAR  Li005  __iar_program_start

вперед из:http://www.51hei.com/stm32/3615.html

Error[Li005]: no definition for «__iar_program_start» [program entry]

IAR 6.3 Стандартная библиотека STM32 3.5. После компиляции вы не можете изменить проверку ошибки. Вам необходимо изменить следующие настройки.

Использовать нормальный или полный

Это должно быть отмечено


Интеллектуальная рекомендация

указатель-события: нет; решить проблему сбоя клика

На работе сделал выпадающий список. Фон стрелки вниз добавляется к form-select :: after, но при нажатии стрелки событие раскрывающегося списка не может быть запущено. Так что добавьтеpointer-events: n…

Как идея соединяет MySQL?

1. Открытая идея 2. Справа есть база данных, щелкните 3. Нажмите » +» 4. Продолжайте нажимать 5. Выберите MySQL 6. Введите, где находится база данных, имя пользователя, пароль, тестовое соед…

CSRF и SSRF

Введение в уязвимости CSRF CSRF (подделка межсайтовых запросов, подделка межсайтовых запросов) относится к использованию недействительной идентификационной информации жертвы (файлы cookie, сеансы и т….

Разработка управления приложениями

Получить всю информацию о приложении PackageManager Android управляет пакетами приложений через PackageManager, и мы можем использовать его для получения информации о приложениях на текущем устройстве…

Вам также может понравиться

Анализ исходного кода пула потоков -jdk1.8

openjdk адрес загрузки http://hg.openjdk.java.net/jdk8u/jdk8u/jdk/tags Логические шаги пула потоков, с которыми поставляется Java, — это, в основном, следующие шаги: Реализация псевдокода Отправить ис…

Используйте инструменты в макете XML:

В макете, если некоторые фиксированные значения атрибута не установлены, некоторое представление не будет видно, когда будет видна макет. Все, что мы можем увидеть эффект предварительного просмотра, к…

Войдите в JVM

1. Введение в JVM 1.1 Концепция JVM Введение в виртуальную машину: JVM (аббревиатура от Java Virtual Machine. Java Virtual Machine.), JVM — это настраиваемый компьютер, которого на самом деле не сущес…

пользователи Linux и группы пользователей

Пользователь категория Профиль пользователь Root (Root пользователя) Команда Советы Упорядочить #, имеет самую высокую задачу разрешения любого разрешения файла недействительно для корневого пользоват…

Котлин Базовый — класс и атрибуты

Давайте напишем простой JavaBean класса Student в Java, только с одним свойством, имя. Тот же класс в Котлин это: PUBLIC в Котлин является видимость по умолчанию, поэтому его можно опустить. Этот вид …

Статьи по теме

  • STM8 Ошибка [Li005]: Нет определения для решения XXX
  • IAR использует STLINK, чтобы загрузить решение на фатальную ошибку
  • IAR Error[Li005]: no definition for «device_info_get» [referenced from hal_uart.o(platform.a)]
  • Ошибка IAR [PE020]: идентификатор ‘файл’ является неопределенным решением
  • IAR об ошибке [Pa045]: у функции «xxx» нет прототипа
  • Ошибка отчета IAR более низкой и более поздней версии
  • Неустранимая ошибка [Lc002]: не удалось открыть файл в IAR
  • IAR компиляция внезапной ошибки при запуске линкера
  • Некоторые ошибки в отношении появления установки и использования IAR
  • IAR Получите альтернативную проблему с файлом и решение

популярные статьи

  • Кордова копировать плагин Кордова-плагин-буфер обмена
  • О дизайне Android и его значении
  • Режим программных компонентов
  • npm
  • Vue Mobile Phone Picture Component Component
  • 0,96-дюймовый OLED-дисплей Изображение
  • Информация о контенте автоматически развернута, а мышь останавливается
  • Концепция Spring и система анализа псевдонимов исходного кода (2)
  • Re -Learning Record от входа в тюрьму [7]
  • Камень-ножницы для бумаги (машинный тест)

рекомендованная статья

  • Данные сайта веб-сайта бизнес-аналитика Python Reptile
  • KVM виртуальная машина примечания конфигурации
  • 2020-07-27 Комиксы Упаковка и скачать CRAC
  • В Windows, Maven частные службы Nexus строительства и эксплуатации
  • Разделение чтения-записи конфигурации Springboot (Mybatis)
  • Работа шесть
  • Luogu p3238 [hnoi2014] дорожная блокировка
  • Установка системы Windows System —- Windows7 Enterprise Edition Невозможно установить Net.framework4.52-4.6 Версия Win7 Solutions …
  • Fiber Optic Cable vs Wireless: Which One Would You Prefer
  • Stateful Future Transformation

Связанные теги

  • IAR
  • ST-Link
  • Fatal Error
  • Использование средств разработки
  • cc2530
  • Интернет вещей
  • zigbee
  • stm
  • STM32
  • Веб-безопасность
     

Поделиться

Нашли опечатку?

Пожалуйста, сообщите об этом — просто выделите ошибочное слово или фразу и нажмите Shift Enter.

IAR EW ARM: устранение ошибок компиляции Печать

Добавил(а) microsin

  

На этой страничке решил собрать ошибки, возникающие при компиляции, линковке, отладке в IDE IAR Embedded Workbench for ARM, и методы их устранения.

Ошибка произошла из-за того, что я вынес в отдельный файл pins.c определения составных переменных:

//[Файл pio.h] 
// Вычисление размера массива элементов Pin
// Массив должен быть локальным, (не указателем),
// иначе вычисление будет некорректным.
#define PIO_LISTSIZE(list) (sizeof(list) / sizeof(Pin))
//[Файл board.h]
// Столбцы опроса клавиатуры ( захват ввода )
#define PIN_KBMATRIX_COL_0 {1 << 0, AT91C_BASE_PIOA, AT91C_ID_PIOA, PIO_INPUT, PIO_PULLUP}
#define PIN_KBMATRIX_COL_1 {1 << 1, AT91C_BASE_PIOA, AT91C_ID_PIOA, PIO_INPUT, PIO_PULLUP}
#define PIN_KBMATRIX_COL_2 {1 << 2, AT91C_BASE_PIOA, AT91C_ID_PIOA, PIO_INPUT, PIO_PULLUP}
#define PIN_KBMATRIX_COL_3 {1 << 3, AT91C_BASE_PIOA, AT91C_ID_PIOA, PIO_INPUT, PIO_PULLUP}
#define PINS_KBMATRIX_COLS PIN_KBMATRIX_COL_0, PIN_KBMATRIX_COL_1, PIN_KBMATRIX_COL_2, PIN_KBMATRIX_COL_3
//[Файл pins.c]
#include "board.h"const Pin pinsCol[] = {PINS_KBMATRIX_COLS};
//[Файл pins.h]
extern const Pin pinsCol[];
//[Файл main.c]
#include "pins.h"#include ... // Вот тут компилятор ругался на PIO_LISTSIZE, // Error [Pe070]: incomplete type is not allowed for (i=0; i < PIO_LISTSIZE(pinsCol); i++) { ...

Ошибка [Pe070] возникала потому, что макрос PIO_LISTSIZE не мог вычислить sizeof(list). Решение: в pins.h указать размер массива. Связано с неудобствами — нужно следить за синхронизировать pins.c и pins.h. Устранение ошибки:

//[Файл pins.h]
extern const Pin pinsCol[4];

На языке C одиночный оператор может состоять из нескольких строк текста. Принято, что не последняя строка такого оператора должна завершаться обратным слешем ().

Многострочные операторы часто используют для задания массивов символов, и при этом легко допустить ошибку, нечаянно пропустив в одной из строк обратный слеш (причем такую ошибку бывает трудно обнаружить). Компилятор выдаст примерно следующее сообщение об ошибках:

Error[Pe008]: missing closing quote C:папкамодуль.c 19
Error[Pe007]: unrecognized token C:папкамодуль.c 23
Error[Pe065]: expected a «;» C:папкамодуль.c 23

Пример оператора с ошибкой и без ошибки:

multistring_operator.png

Пропущенный слеш нужно искать в строке перед второй ошибкой.

[Случай 1]

Долго не мог разобраться, почему возникала ошибка Error[Pe147]: declaration is incompatible with «TParams const __data папка_проектаvars.c 22 paramDefault» (declared at line 22). У меня была задана структура TParams как тип:

typedef __packed struct _Params{
    u32 paramseed;
    u32 versionARM;
    ...
    u8 lblstate[15];
    u16 CRC;} TParams;

Грешил даже на то, что структура назначалась как переменной, так и константе:

TParams param;const TParams paramDefault = {
    0xAA55AA55,
    0x00000000,
    ...
    LABEL_DEFAULT,
    0x0000};

Оказалось все проще (хотя сразу не разобрался потому, что компилятор не указывал на это место) — я просто забыл ключевое слово const в хедере, где предварительно объявлялись param и paramDefault. Было там так (это ошибочно):

extern TParams param;extern TParams paramDefault;

А для исправления ошибки должно быть так:

extern TParams param;extern const TParams paramDefault;

[Случай 2]

При портировании проекта BIGTREETECH TFT35 V3.0 из среды Visual Studio Code (VSC, VSCode) на IAR столкнулся с ошибкой несовместимости определений в iccarm_builtin.h и core_cm3.h:

Error[Pe147]: declaration is incompatible with "__nounwind __interwork __softfp
 unsigned int __iar_builtin_REV16(unsigned int)" (declared at line 199 of
 "C:Program Files (x86)IAR SystemsEmbedded Workbench 8.1armincciccarm_builtin.h")
 M:asmBIGTREETECH-TouchScreenFirmware-masterTFTsrcLibrariescmsisCore-CM3core_cm3.h 1124

Как исправить:

1. Удалить файл core_cm3.h, либо переименовать его вcore_cm3.h.old.
2. Зайти в свойства проекта, в разделе General Optoins -> закладка Library Configuration поставить галочку «Use CMSIS».

IAR Use CMSIS

Иногда после продолжительных правок трудно найти место, где пропустили точку с запятой. Например, компилятор неожиданно выдает ошибки на синтаксис в файле kbmatrix.h, который Вы даже не исправляли:

Remark[Pe082]: storage class is not first C:asmtestprojectincludekbmatrix.h 25
Error[Pe065]: expected a «;» C:asmtestprojectincludekbmatrix.h 25
Error[Pe757]: variable «KeyEventCallback» is not a type name C:asmtestprojectincludekbmatrix.h 54
Error[Pe757]: variable «KeyEventCallback» is not a type name C:asmtestprojectincludekbmatrix.h 67
Error while running C/C++ Compiler

Для того, чтобы найти действительное место ошибки, нужно найти все включения файла kbmatrix.h — перед ним наверняка будут другие включаемые заголовки, в которых допущена ошибка. Запускаем общий поиск по всему проекту, для чего жмем Ctrl+F и в строке поиска указываем kbmatrix.h. Переключатель «Look in» должен стоять на «Project files and all include files».

missing semicolon01

После поиска получим список файлов, которые включают директивой #include файл kbmatrix.h:

C:asmtestprojectkbmatrix.c 4 #include «kbmatrix.h»
C:asmtestprojectincludepins.h 3 #include «kbmatrix.h»
C:asmtestprojectpins.c 6 #include «kbmatrix.h»
———-
Found 3 instances. Searched in 270 files.

В одном из этих найденных файлов (kbmatrix.c, pins.h, pins.c), перед #include «kbmatrix.h» включаются другие файлы, в которых допущена ошибка. Теперь место пропущенной точки с запятой найти легко. В моем примере ошибка была в исправленном файле mytypes.h. Вот содержимое файла pins.h (он был в списке найденных), где добавлялся заголовок mytypes.h с ошибкой:

#include «settings.h»
#include «mytypes.h»
#include «kbmatrix.h»
..

Просмотрев список включаемых файлов, перед #include «kbmatrix.h», я увидел файл, который исправлял — mytypes.h, в нем как раз и была ошибка (пропущена точка с запятой после определения типа структуры).

[Причина 1]

Возможно, что пропущено словечко void в параметрах при определении функции. Пример:

extern unsigned char DBGU_GetChar ();unsigned char DBGU_GetChar (){
    while ((AT91C_BASE_DBGU->DBGU_CSR & AT91C_US_RXRDY) == 0);
    return AT91C_BASE_DBGU->DBGU_RHR;}

Исправить нужно так:

extern unsigned char DBGU_GetChar (void);unsigned char DBGU_GetChar (void){
    while ((AT91C_BASE_DBGU->DBGU_CSR & AT91C_US_RXRDY) == 0);
    return AT91C_BASE_DBGU->DBGU_RHR;}

Пример лога ошибок:

Error[Pe020]: identifier "FILE" is undefined C:myprojectprecompiled-IAR-libsat91libperipheralsdbgudbgu.c 82 
Error[Pe020]: identifier "stdout" is undefined C:myprojectprecompiled-IAR-libsat91libperipheralsdbgudbgu.c 84 
Error[Pe020]: identifier "stderr" is undefined C:myprojectprecompiled-IAR-libsat91libperipheralsdbgudbgu.c 84 
Error[Pe020]: identifier "FILE" is undefined C:myprojectprecompiled-IAR-libsat91libperipheralsdbgudbgu.c 103 
Error[Pe020]: identifier "stdout" is undefined C:myprojectprecompiled-IAR-libsat91libperipheralsdbgudbgu.c 141 
Error while running C/C++ Compiler 

Определение FILE находится в заголовочном файле stdlib.h, поэтому нужно подключить его директивой #include. Однако иногда этого недостаточно, потому что поддержка FILE присутствует только в варианте выбора библиотек Full, но может быть выбран другой вариант — None или Normal с целью экономии памяти встраиваемых систем. Чтобы использовать FILE, необходимо переключиться на полный вариант стандартных библиотек это делается опцией командной строки компилятора —dlib full. Либо можно это настроить в диалоге свойств проекта (Options…) -> General Options -> Library Configuration -> Library: поставьте Full:

IAR Library Full

Имейте в виду, что полный вариант стандартных библиотек (Full) приведет к намного большему объему кода. Поэтому если Вы используете FILE только для печати диагностических сообщений в stderr, то лучше использовать какой-нибудь другой способ вывода сообщений.

[Причина 2]

Если в свойствах проекта, раздел C/C++ Compiler -> C dialect стоит галочка «Require prototypes», то для не переопределенных weak-функций это будет гарантированно вызвать ошибку.

IAR Require prototypes

Снимите эту галочку, и ошибка Pa045 пропадет.

Проблема в том, что в блоке памяти [0x00100000-0x001002db] находится код, до которого не могут достать ассемблерные команды короткого перехода, находящиеся в ассемблерном коде (обычно в других модулях). В этом случае нужно править ассемблерный код, чтобы переходы были длинными, либо переписать код с ассемблера на C (тогда компилятор сам подставит нужные команды). Другое решение указать компилятору генерировать код для режима процессора не thumb, а arm (Свойства проекта (Options…) -> General Options -> C/C++ Compiler -> Processor mode -> Arm).

Чтобы сгенерировать карту памяти и статистику линковки (это поможет найти проблему), откройте свойства проекта (Options…) -> General Options -> Linker -> List -> Поставьте галочки на «Generate linker map file» и на «Generate log file», а также все галочки ниже на опциях лог-файла. Лог-файл см. в файле имя_конфигурацииListимя_проекта.log, а карту распределения памяти в файле имя_конфигурацииListимя_проекта.map.

Предупреждение возникало при попытке вызвать из кода на C функцию abs, пример:

Pa = ((float)valU/100000) * ((float)valI/100000) * abs(cos(RadianAngle));

Дело в том, что на простом C (не C++) нельзя распознать прототип функции abs по типу переменной. Только для C++ можно автоматически подставить нужный прототип abs (для разных типов аргументов на C++ имеются разные реализации abs). В данном случае в параметре была переменная типа float, а определение abs подразумевало в параметре целый тип. На самом деле на C нужно напрямую вызывать abs с нужным функционалом по отдельному имени, здесь подойдет fabsf:

//Pa = ((float)valU/100000) * ((float)valI/100000) * abs(cos(RadianAngle));
Pa = ((float)valU/100000) * ((float)valI/100000) * fabsf(cos(RadianAngle));

Пример кода, который генерирует предупреждение Pa091:

unsigned char lblstyle, set, clear;
 
clear = 0x80;
set   = 0x02;
lblstyle &= ~clear;   //тут предупреждение Pa091
lblstyle |= set;

Причина ошибки в том, что оператор инверсии ~ делает приведение типа unsigned char к типу signed int перед инверсией. Для того, чтобы пропало предупреждение, нужно перед инверсией дополнительно вставить ключевое слово unsigned:

unsigned char lblstyle, set, clear;
 
clear = 0x80;
set   = 0x02;//lblstyle &= ~clear;
lblstyle &= ~(unsigned)clear;
lblstyle |= set;

Такая ошибка возникает при логических операциях с константами из перечисления (которые определены через enum). Вот пример кода, который генерирует предупреждение Pe188:

typedef enum{
   MODE_MASK              = 0x00FF,
   TEST                   = 0x4000,
   MODE_INIT              = 0x2000,
   MODE_FIRMWARE          = 0x1000,
   ..
   MODE_LOAD_VARS         = 0x00FE}MODE;
 
MODE appmode = MODE_LOAD_VARS | MODE_INIT;           //Warning[Pe188]!

Причина предупреждения в том, что результатом логической операции будет целочисленный тип, а не тип enum. Исправить можно, если явно указать, что результат операции будет иметь тип перечисления:

MODE appmode = (MODE)(MODE_LOAD_VARS | MODE_INIT);   //OK

Когда 2 заголовочных файла ссылаются друг на друга директивой #include, то могут возникнуть ошибки Error[Pe020]: identifier «имя_идентификатора» имя_файла.h номер строки is undefined (упомянутый идентификатор не найден). К примеру, в заголовочный файл headerA.h подключен файл headerB.h, и также к файлу headerB.h подключен файл headerA.h — тогда блок защиты от повторного включения заголовка [2] не даст видимости всех нужных имен, определенных в первом подключенном заголовке.

////////////////////////////////////////////
// Содержимое заголовка headerA.h
#ifndef __HEADERA__
#define __HEADERA__  #include "headerB.h"//Здесь определения идентификаторов, некоторые
// из которых должны быть видны в заголовке
// headerB.h. ..
#endif //__HEADERA__////////////////////////////////////////////
// Содержимое заголовка headerB.h
#ifndef __HEADERB__
#define __HEADERB__  #include "headerA.h"  //Здесь определения идентификаторов, некоторые
// из которых должны быть видны в заголовке
// headerA.h. ..
#endif //__HEADERB__

Для того, чтобы исправить эту ситуацию, требуется создать третий заголовок headerC.h, который будет содержать общие для headerA.h и headerB.h определения, и подключить headerC.h в headerA.h и headerB.h, чтобы они не ссылались друг на друга.

////////////////////////////////////////////
//Содержимое заголовка headerA.h
#ifndef __HEADERA__
#define __HEADERA__  //#include "headerB.h"
#include "headerC.h"  //Все идентификаторы, которые должны быть видны
// в headerB.h, перенесены в заголовок headerC.h. .. #endif //__HEADERA__
////////////////////////////////////////////
// Содержимое заголовка headerB.h
#ifndef __HEADERB__
#define __HEADERB__  //#include "headerA.h"
#include "headerC.h"  //Все идентификаторы, которые должны быть видны
// в headerA.h, перенесены в заголовок headerC.h. .. #endif //__HEADERB__

Постоянно достают предупреждения компилятора IAR о неправильной строке форматирования (printf, sprintf, sscanf): «IAR EWB ARM: Remark[Pe181]: argument is incompatible with corresponding format string conversion».

Избавиться от таких предупреждений поможет правильный выбор опции форматирования вывода printf. Для подробной информации см. [3].

  • Функция printf, аргумент u8 (unsigned char), строка формата %u -> надо поменять формат на %i.
  • Функция printf, аргумент u16 (unsigned short), строка формата %u -> надо поменять формат на %i.
  • Функция sscanf, аргумент u8 (unsigned char), строка формата %u или %i -> надо поменять формат на %hu, а тип аргумента на u16 (unsigned short).

Ошибка может возникнуть, если неправильно определена переменная структуры, например:

    //Здесь будет Warning[Pe1000]: a storage class ..
    struct myStructVariable
    {
        char var1;
        int  var2;
    };

Исправить предупреждение Pe1000 можно, если правильно указать экземпляр переменной структуры:

    struct
    {
        char var1;
        int  var2;
    }myStructVariable;

[140110]

Вопрос: мне нужно кастомизировать вывод на собственное устройство отображения (LCD). Все сделал, как написано в документации IAR — определил внешнюю функцию MyLowLevelPutchar, раскомментировал функцию __write, но почему-то при вызовах printf и putchar вывод на LCD не происходит. Функция __write не вызывается, и код, который я написал в теле функции MyLowLevelPutchar, не работает. В чем проблема?

Ответ: Вы все сделали правильно, но кроме этого в некоторых версиях IAR (например 4.20) необходимо особым образом выбрать конфигурацию библиотек DLIB. Это делается через свойства проекта General Options -> Library Configuration -> Library. Попробуйте из выпадающего списка выбрать вариант Normal, и если не заработает, то попробуйте выбрать Full. У меня иерархия вызовов в IAR версии 4.20 работала почему-то следующим образом: если выбрать Full, то последовательность вызова получается printf -> .. -> putchar -> fputc, и в этом варианте ничего не работало (код в MyLowLevelPutchar не вызывается). Если выбрать Normal, то тогда цепочка вызовов printf -> .. -> putchar -> __write, и в этом случае перенаправление вывода работает (потому что в функция __write вызывает пользовательский код из MyLowLevelPutchar).

[140312]

Такая ошибка возникает, когда Вы перенесли проект в другую папку, но перед запуском отладки не сделали очистку и не перекомпилировали проект. В отладочных файлах запомнились старые абсолютные пути до фалов исходного кода, которые теперь не соответствуют реальным. Чтобы исправить ошибку, выберите пункт меню Project -> Clean, после чего запустите отладку. Проект скомпилируется заново, и теперь отладка запустится без ошибки.

[140515]

Для больших проектов время компиляции может составлять большую проблему. Есть несколько советов, как можно уменьшить время компиляции.

1. Убедитесь, что в каждом заголовочном файле у Вас есть защитные заголовки, например:

#ifndef __HFILE_H#define __HFILE_H
   /* ... */#endif

Подробнее про защитные заголовки см. [4]. Кроме того, проверьте файлы исходного кода на лишние подключения заголовков директивой #include. Этот фактор значительно влияет на скорость компиляции. 

2. Создайте предварительно скомпилированные библиотеки, куда поместите редко изменяемые модули: BSP (Board Support Package, пакет поддержки платы разработчика), стеки протоколов и т. д. Это нужно делать периодически для кода, который остается неизменным, и который не нужно перекомпилировать каждый раз, когда что-то меняется в коде приложения. Подробнее см. [5].

3. Запретите генерацию файлов листинга компилятора (Options -> C/C++ Compiler -> List).

4. Если некоторые файлы находятся на сетевом диске (даже если это RAM-диск на сервере), попробуйте сделать их локальными, т. е. скопировать на жесткий диск рабочей станции, и компилировать оттуда. Если это ускорит компиляцию, то значит имелись проблемы, связанные с сетевой файловой системой (NFS/Samba).

5. Если совет 4 помог (при использовании локального диска компиляция ускорилась), то может помочь размещение на локальном диске только объектных файлов и файлов листинга. Для этого измените настройки Project -> Options -> General Options -> Output. Сконфигурируйте пути «Object files» и «List files» так, чтобы они были размещены не на сети, а локально.

6. Если при компиляции бывают случаи, что процесс сильно замедляется или среда IAR зависает, то возможно, что в этот момент происходит сканирование рабочих файлов антивирусом. Такой случай может привести также к сообщениям о запрещенном доступе (denied permission), об истечении таймаута.

Для того, чтобы исключить проверку антивирусом папок IAR, нужно добавить в исключения антивируса следующие папки:

• Инсталляционный каталог IAR (например, это может быть папка C:Program FilesIAR SystemsEmbedded Workbench 5.4).
• C:Program FilesCommon FilesIAR Systems
• C:Documents and Settings USERNAME Application DataIAR Embedded Workbench

Здесь USERNAME означает имя (логин пользователя), под которым Вы работаете в системе Windows. Полное имя до этой папки может зависеть от версии операционной системы Windows.

7. Создайте RAM-диск, и попробуйте компилировать проект на нем. Будьте осторожны, поскольку при пропадании питания или зависании компьютера вся Ваша работа потеряется! Как промежуточный вариант, можно на RAM-диск сохранять только объектные файлы, файлы листинга и выходные файлы, для этого в свойствах проекта General Options -> Output поменяйте пути до выходных рабочих директорий Output directories.

Самое простое средство для создания RAM диска — бесплатная программа SoftPerfect RAM Disk site:softperfect.com.

[161019]

При попытке компиляции выскакивают совершенно неожиданные ошибки — невозможно удалить файл, который либо вообще не используется в проекте, либо находится в каталоге установки IAR. Например, у меня появлялась вот такая ошибка, когда я попробовал сменить конфигурацию Release на Debug:

Building configuration: guilibprj - Debug 
Updating build tree... 
Failed to delete C:Program Files (x86)IAR SystemsEmbedded Workbench 5.4 
armincwchar.h 
 
0  file(s) deleted. 
Updating build tree... 
 
Build aborted.

Очевидно, что это полный бред — зачем очистке понадобилось вдруг удалять файл wchar.h, который относится к стандартным библиотекам, да и еще находится в каталоге установки среды разработки IAR Embedded Workbench?..

Причина ошибки заключается в том, что произошла рассинхронизация конфигураций Release и Debug. Конфигурация Debug давно не использовались, в то время как конфигурацию Release вносились изменения. Похоже, что глючит обработчик списка зависимостей, причем могут происходить даже еще более неприятные глюки, вплоть до удаления рабочих заголовочных файлов проекта (поэтому чаще делайте бэкапы!).

Решение проблемы заключается в просмотре обоих конфигураций и внесение корректных изменений в конфигурацию, где происходит эта ошибка. Особенно внимательно следует проверить дополнительные пути поиска подключаемых файлов, а также наличие предварительно определенных переключающих макросимволов (Project -> Options -> C/C++ Compiler -> Preprocessor).

Довольно часто появляющаяся ошибка в разных версиях IAR. Разработчики борются с этой ошибкой, и с переменным успехом. Обычно проблема решается, если несколько раз выполнить операцию очистки (Project -> Clean). Иногда помогает перезапуск IAR + выполнение очистки проекта.

Еще одна из причин такой ошибки — в проекте имеется 2 подключенных исходных файла, компиляция которых приводит к генерации одного и того же объектного файла. Например, есть две версии одного и того же модуля — один на языке C (с расширением *.c), и другой оптимизированный, на ассемблере (с тем же именем, но с расширением *.s). Решение проблемы очевидно — нужно исключить из процесса компиляции один из этих файлов.

Чтобы переименовать workspace, но сохранить при этом в нем те же самые имена проектов, что и были раньше, просто переименуйте файл *.eww.

Поскольку среда разработки IAR EWB не предоставляет прямого функционала для специального переименования проекта, требуется обходной путь для этого действия. Когда я переименовываю workspace и связанный с ним проект, то поступаю следующим образом:

1. Делаю копию Template.ewp (это файл проекта) и переименовываю копию, скажем, в NewProject.ewp.
2. Открываю файл workspace Template.eww.
3. Выбираю Project -> Add Existing Project…
4. Выбираю NewProject.ewp и кликаю Open.
5. Выбираю закладку «Template» в нижней части списка файлов Workspace (соответствует старому проекту).
6. Делаю правый клик на старом проекте и выбираю Remove.
7. Закрываю IAR EWB, он запросит сохранить workspace, сохраняю.
8. Переименовываю файлы старого workspace *.eww, *.ewd в NewProject.eww, NewProject.ewd (и также файл *.dep, если он у Вас есть).
9. Удаляю Template.ewp.

После этого Вы сможете открыть NewProject.eww как полностью переименованное workspace и полностью переименованный проект. Если Вы хотите только переименовать проект, и оставить старое имя для workspace, то выполните только шаги 1..7.

См. также:

Renaming in IAR Embedded Work Bench site:stackoverflow.com
IAR EW ARM: как перенести проект в другую папку
Расширения файлов IAR для процессоров ARM

[170621]

Заголовочный файл lib_AT91SAM7X256.h, в IAR 6.50 выскакивают ошибки на код с операторами __inline:

__inline void AT91F_AIC_EnableIt (
	AT91PS_AIC pAic, unsigned int irq_id )
{
    pAic->AIC_IECR = 0x1 << irq_id ;
}

Проблема в том, что для встраиваемых функций поменялся синтаксис: замените __inline на inline, и ошибка исчезнет.

На языке C, в отличие от C++, нет определения булевого типа. Поэтому либо подключите в коде C заголовочный файл stdbool.h:

Либо добавьте в общий заголовочный файл (например types.h) следующее определение:

#ifndef  __cplusplus
#define bool  unsigned char
#define true  1
#define false 0
#endif

Это глюк, связанный с файлами нулевой длины. Найдите файл, на который указывает сообщение, и удалите его.

[171204]

Неожиданный глюк, который начал происходить без видимых причин (наблюдалось на IAR 6.50.3 и Windows 7). При попытке компиляции выскакивает ошибка «General exception during build», которая сопровождается ошибкой очистки «General exception during clean». Причем в конфигурации Debug проект компилируется нормально, а в конфигурации Release происходит ошибка.

Ресурс по известным проблемам IAR [6] советует выполнить переустановку IAR в другой каталог на диске, или переименовать папку текущей инсталляции: «Install another copy of your IAR Embedded Workbench product in a different location or rename the directory of your current installation».

Мне помогло следующее — полностью удалил с диска корневую папку проекта, и восстановил её копированием из архива бекапа. После этого ошибка волшебным образом исчезла.

Замечание, сигнализирующее о возможной логической ошибке в операторе switch. Вот пример из библиотеки EFSL, генерирующий такое предупреждение компилятора (Pe1814 на строке 40):

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
esint8 sd_State(hwInterface *iface)
{
   eint16 value;
 
   sd_Command(iface,13, 0, 0);
   value=sd_Resp16b(iface);
   switch(value)
   {
   case 0x000:
      return(1);
      //break;
   case 0x0001:
      DBG((TXT("Card is Locked.n")));
      break;
   case 0x0002:
      DBG((TXT("WP Erase Skip, Lock/Unlock Cmd Failed.n")));
      break;
   case 0x0004:
      DBG((TXT("General / Unknown error -- card broken?.n")));
      break;
   case 0x0008:
      DBG((TXT("Internal card controller error.n")));
      break;
   case 0x0010:
      DBG((TXT("Card internal ECC was applied, but failed to correct the data.n")));
      break;
   case 0x0020:
      DBG((TXT("Write protect violation.n")));
      break;
   case 0x0040:
      DBG((TXT("An invalid selection, sectors for erase.n")));
      break;
   case 0x0080:
      DBG((TXT("Out of Range, CSD_Overwrite.n")));
      break;
   default:
      if(value>0x00FF)
         sd_Resp8bError(iface,(euint8) (value>>8));
      else
         DBG((TXT("Unknown error: 0x%x (see SanDisk docs p5-14).n"),value)); //[Pe1814]
      break;
   }
   return(-1);
}

Это пример не очень аккуратного кодирования: оператор swith проверяет переменную value, и эта же переменная проверяется оператором if в default-блоке того же оператора swith. Очевидно, что здесь скорее всего используется не только ненужная проверка if, но и блок else этого оператора if никогда не выполнится.

В TN43262 [7] объясняется, как нужно работать с абсолютно размещаемыми переменными. Проблема с такими переменными заключается в том, что в некоторых ситуациях разработчик получает сообщение об ошибке линкера «переменная не определена». Это может быть связано с тем, что такая переменная должна быть определена специальным, не интуитивно понятным способом.

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

[Дополнительная информация]

Переменные, которые размещаютсы по абсолютному адресу, ведут себя немного не так, как обычные не автоматические переменные C/C++. Абсолютно размещамеые переменные находятся в абсолютном сегменте, таком как ABSOLUTE или xxxx_AN. Абсолютный сегмент не представлен файле линкера, поскольку переменные уже размещены во время компиляции.

Другие (обычные) не автоматические переменные, находящиеся в модуле исходного кода, размещаются в перемещаемый сегмент, который описывается в файле линкера как обычно. Поэтому разрешение адреса осуществляется во время линковки.

Не очевидное поведение: каждое определение абсолютно размещенной переменной в действительности локально для текущей компилируемой единицы (файла исходного кода), поэтому Вы можете (и должны) иметь определение этой переменной для каждого элемента компиляции (модуля исходного кода). Несколько таких одновременных определений не приведут к ошибке во время линковки или ошибке во время выполнения (если Вы идентично определили абсолютную переменную во всех местах, где она используется). Если Вы не используете абсолютно размещенную переменную, то она выбрасывается из единциы компиляции. Если же Вы должны её использовать, то она должна быть представлена в выходном файле по двум причинам. Во-первых, переменная используется, поэтому она должна требовать своего абсолютного размещения на этапе линковки. Во-вторых, это позволяет линкеру проверить, что эти определения соответствуют друг другу во всех модулях.

Другими словами, для абсолютной переменной Вы должны разместить в заголовочном файле определение (не декларацию, как это обычно делается), если используете переменную в нескольких файлах. Пример такого заголовочного файла setup.h:

__no_init struct setup configuration @ 0x100;

После этого просто добавьте подключение файла setup.h во все файлы исходного кода, где должна использоваться переменная.

Один из способов запомнить — думать об этом как о наличии #define для описания размещения в памяти, с добавлением наличия способности линкера проверить его непротиворечивость.

[Другой способ абсолютного размещения переменной]

Если Вы вместо этого поместите объект в именованный сегмент:

__no_init struct setup located_configuration @ "SETUP";

то должен быть определен сегмент SETUP, и он должен быть размещен в файле линкера. Переменные, размещенные в сегменте, ведут себя как обычные переменные языка C, для них поместите следующую декларацию в файл заголовка:

// Файл setup.h
extern __no_init struct setup located_configuration;

И затем Вам нужно поместить определение в один (и только в один) исходный файл:

__no_init struct setup located_configuration @ "SETUP";

Если Вам не нравится @-синтаксис, есть его эквивалент, который можно использовать альтернативно:

Здесь описан рецепт запуска компиляции для среды разработки IAR Embedded Workbench for ARM (перевод TN47884 [8]), однако он может быть легко модифицирован для любой другой платформы.

[Запуск IarBuild.exe из командной строки]

Если у Вас есть файл проекта с именем test.ewp, в которое имеется конфигурация с именем Debug, то для сборки проекта можно использовать следующую команду:

< директория инсталляции >commonbinIarBuild.exe test.ewp Debug

Примечание: запустите IarBuild.exe без параметров для получения подсказки по опциям командной строки.

Чтобы заново собрать проект, используйте следующую команду (с опцией расширения лога, чтобы увидеть все сообщения компилятора):

< директория инсталляции >commonbinIarBuild.exe test.ewp -build Debug -log all

Пример полной очистки и повторной сборки:

< директория инсталляции >commonbinIarBuild.exe test.ewp -clean Debug -log all
< директория инсталляции >commonbinIarBuild.exe test.ewp -make Debug -log all

[Компиляция и линковка из командной строки]

Вы можете запустить все .exe файлы в каталоге < директория инсталляции >armbin из командной строки. Запустите любую утилиту из этой папки без параметров, например компилятор iccarm.exe, чтобы получить список доступных опций командной строки.

Чтобы автоматизировать процесс сборки, можно создать .bat-файл, который компилирует каждый исходный файл по отдельности. Чтобы посмотреть параметры командной строки, выберите следующую опцию в среде IAR Embedded Workbench IDE: Tools -> Options -> IDE Options -> Messages -> Show build messages: ‘All’. 

Чтобы создать .bat-файл, который компилирует один исходный файл, введите полный путь до iccarm.exe, за которым должны идти параметры (скопированные из окна View -> Messages -> Build):

< директория инсталляции >armbiniccarm.exe < компилируемый файл > < опции >

Когда Вы получите команду, работающую с одним исходным файлом, Вы сможете добавить в .bat-файл еще команды для компиляции оставшихся файлов исходного кода.

Для линковки может быть полезной опция -f < файл >. Пример:

< директория инсталляции >armbinilinkarm.exe -f options.xcl

Поместите все параметры линкера из окна Build в файл options.xcl (убедитесь, что каждый параметр размещен на отдельной строке). Из-за того, что командная строка линкера может быть очень длинной, рекомендуется использовать опцию –f для того, чтобы избежать любых проблем, связанных с ограничением на длину командной строки.

Чтобы прочитать больше про сборку через командную строку, см. Help -> IDE Project Management and Building Guide, раздел Building from the command line.

[180911]

На старом проекте под IAR 4.41A неожиданно столкнулся с ошибкой ассемблера Error[54] при компиляции файла Cstartup.s79. Ругань была на строчку кода, выделенную красным цветом:

#if ((MAIN_PRJ==1) || (BOOTLOADER_PRJ==1))
  B START_ADDRESS
#endif

Это был явный глюк ассемблера, связанный с тем, что ранее в тексте этого модуля уже появлялись операторы проверки прероцессора а такими же макроопределениями. Поиск по фразе Error[54]: Expression can not be forward вывел на сайт IAR с заметкой «Technical Note 31237», которая для данного случая никак не помогла.

После плясок с бубном удалось обойти проблему следующей модификацией кода, который делал то же самое, но уже не так красиво, как раньше:

#ifdef MAIN_PRJ
  B START_ADDRESS
#endif
#ifdef BOOTLOADER_PRJ
  B START_ADDRESS
#endif

[180928]

Нечаянно оставил пробел в определении макроса, и получил ошибку:

IAR Pe969 VA ARGS

Error[Pe969]: the identifier __VA_ARGS__ can only appear in the replacement lists  display.h 32
of variadic macros

Потратил много времени, пока удалось догадаться, в чем дело. После удаления пробела за msg_at ошибка исчезла.

[190601]

IAR 5.50, перестали компилироваться проекты. Выглядит так: Project -> Rebuild All, после этого долгое ожидание, и примерно через минуту сообщение об ошибке Cp001. Проблема решается следующим образом, без переустановки IAR:

1. Закройте все окна IAR.

2. Запустите IAR Licence Manager.

3. Licence -> Install…, в окошко ввода лицензии «Licence key:» вставтье длинный текст лицензии:

… длинный набор букв и цифр …# «EWARM» version «2.1_WIN», no expiration date, exclusive

4. Кликните на кнопку Install, закройте IAR Licence Manager.

[191224]

Проблема возникла при подключении файла stm32f4xx_hal_crc.h в модуль, чтобы определить экземпляр дескриптора блока контрольной суммы CRC_HandleTypeDef. Тип HAL_StatusTypeDef определен в файле stm32f4xx_hal_def.h, а ошибка возникала в заголовке stm32f4xx_hal_rcc_ex.h, который подключал stm32f4xx_hal_def.h, и как следствие ошибки Pe020 быть не должно. Но она все-таки возникала!

Долго с этим разбирался, пока каким-то чудом не нашел решение проблемы. Оказывается, вместо заголовка stm32f4xx_hal_crc.h надо подключать stm32f4xx_hal.h.

#pragma once
 
#include "types.h"
// С подключением этого заголовка возникает ошибка Pe020:
//#include "stm32f4xx_hal_crc.h"
// С подключением этого заголовка проблема решается:
#include "stm32f4xx_hal.h"
 
CRC_HandleTypeDef hcrc;

Вывод: не подключайте отдельные заголовки HAL для каждого аппаратного блока STM32, используйте вместо этого общий заголовочный файл stm32f4xx_hal.h.

[200130]

К сожалению, причину ошибки такого рода бывает найти не так просто. Общий совет: проверьте файлы, которые подключают проблемные заголовки, и проверьте опции препроцессора.

[200130]

Проблема возникла при компиляции FreeRTOS V9.0.0 в отдельную библиотеку STM32. Конфликтовали заголовочные файлы cmsis_iar.h и intrinsics.h, в них были совпадающие по именам, но разные определения макросов для асемблерных команд:

Макрос intrinsics.h(1) cmsis_iar.h(1)
__get_PRIMASK строка 61 строка 205
__get_PSP строка 55 строка 206
__set_BASEPRI строка 85 строка 210
__set_CONTROL строка 70 строка 212
__set_FAULTMASK строка 79 строка 213
__set_FPSCR строка 342 строка 214
__set_MSP строка 52 строка 215
__set_PRIMASK строка 64 строка 217
__set_PSP строка 58 строка 218
__DMB строка 770 строка 250
__DSB строка 773 строка 251
__ISB строка 776 строка 252

Примечание (1): файлы intrinsics.h и cmsis_iar.h находились в каталоге «C:Program Files (x86)IAR SystemsEmbedded Workbench 8.1armincc».

Проблема была решена путем комментирования строки #include «cmsis_iar.h» в модуле cmsis_os.c. В любом случае для решения проблемы нужно найти в проекте модули, где одновременно подключаются оба конфликтующих заголовка, и удалить подключение одного из них. Лучший кандидат на удаление — тот заголовок, который больше устарел, или который подключается реже всего. В моем случае это был заголовок cmsis_iar.h — его подключение я удалил.

[220403]

На этот раз проблема была в макросе _SYSTEM_BUILD, который был установлен в свойствах проекта на закладке управления препроцессором:

IAR Pa181 SYSTEM BUILD

После того, как _SYSTEM_BUILD удалил из списка определяемых символов, предупреждение Pa181 исчезло.

Вероятно, что при использовании проекта со смесью кода C и C++ [10, 11] в одном из заголовочных файлов пропущено обрамление из extern «C» { и }:

#ifndef __MYHEADER__
#define __MYHEADER__
 
#ifdef __cplusplus
 extern "C" {
#endif
 
// тут код заголовка:
...
 
#ifdef __cplusplus
}
#endif
 
#endif /* __MYHEADER__ */

См. также Q032.

Причина этой ошибки может быть банальна — просто в проект не добавлен модуль, в котором определен недостающий символ. Но может быть, что символ все-таки определен в подключаемой библиотеке, но эта библиотека скомпилирована как код другого типа (например, находится в библиотеке C++, когда использующий символ код написан на C). Тогда проблему Li005 можно решить путем использования стандартного обрамления кода в заголовке из extern «C» { и }, см. выше Q031, а также [10, 11].

[200303]

При попытке скомпилировать проект IAR выполение сборки останавливалось на первом модуле, с выводом сообщения «Updating build tree…», и дальше компиляция не шла. Симптомы были одинаковые, как в графической среде, так и при компиляции из командной строки (commonbinIarBuild.exe test.ewp -build Release).

Проблема оказалась в неправильном выборе версии IAR — в IAR 5.50 наблюдалась ошибка с остановкой компиляции «Updating build tree…», а в версии IAR 6.50 компиляция проходила нормально.

[220409]

Эту ошибку компилятор IAR может выдавать на встраиваемую (inline) функцию в следующих случах:

1. Нет предварительной декларации этой функции. Например в модуль, где определена функция, не подключен заголовок, где функция декларируется.
2. В декларации inline-функции опущено ключевое слово extern.

Пример:

inline void Beep (uint16_t ms)
{
   // На следующую строку будет ошибка Pe1031:
   // "Error[Pe1031]: an entity with internal linkage cannot be
   //  referenced within an inline function with external linkage"
   beeeptime = ms;
}

Как решить проблему 1 понятно: нужно подключить в модуль заголовочный файл с декларацией inline-функции. Проблема 2 тоже легко решается, надо просто в декларации добавить ключевое extern. Однако мне показалось странным, что не встраиваемая функция не требует extern, а встраиваемая требует.

Ниже пример решения проблемы. Заголовок beeper.h:

#pragma once
#include < stdint.h>
#include < stdbool.h>
 
extern inline void Beep (uint16_t ms);

Модуль beeper.c:

#include "pins.h"
#include "beeper.h"
 
static uint16_t beeeptime = 0;
 
#define BEEPon(on) HAL_GPIO_WritePin(BEEPER_PORT,
                                     BEEPER_PIN, 
                                     on?GPIO_PIN_SET:GPIO_PIN_RESET)
 
inline void Beep (uint16_t ms)
{
   beeeptime = ms;
}

[230119]

В сложных проектах, где много директив препроцессора условной компиляции (#if, #ifdef, #elif, #else), иногда бывает трудно понять, какой код компилируется, а какой нет. Однако разобраться довольно просто: достаточно вставить директиву #error ЛЮБОЙТЕКСТ, тогда если код в этом месте компилируется, то комилятор выведет сообщение об ошибке.

[Ссылки]

1. Что такое lvalue и rvalue?
2. IAR EW ARM: применение #ifndef и #define для разрешения конфликтов включаемых файлов (#include).
3. IAR EWB ARM: форматированный вывод printf библиотеки DLIB.
4. IAR EW ARM: применение #ifndef и #define для разрешения конфликтов включаемых файлов (#include).
5. IAR: создание библиотеки.
6. IAR Embedded Workbench IDE — Known problems site:supp.iar.com.
7. Technical Note 43262 Absolute located variable site:iar.com.
8. Technical Note 47884 Build from the command line site:iar.com.
9. Какие я часто делаю ошибки в языке C.
10. Как использовать совместно код C и C++: FAQ.
11. IAR: совместное использование кода C и кода C++.

Добавить комментарий

Понравилась статья? Поделить с друзьями:
  • Error level php ini
  • Error level f 400000031
  • Error level e 400070031
  • Error level e 400030035
  • Error level analysis программа