Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Глюк на глюке...
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > Cредства разработки для МК > IAR
king2
До этого писал проект на ICCAVR7 (imagecraft). Закончился триальный срок, решил попробовать IAR, вроде все и везде его хвалят.

После изменения в проекте разных штучек типа объявления прерываний скомпилял проект и понеслась душа в рай.

То оно работает, то оно виснет. Виснет в разных местах (разное количество символов выводя на ЖК). Увеличил значение стека, вроде прошло через первый инит и зажгло светодиодик. Ура.

Дальше больше. Почему-то не работает sprintf, ни с CLIB, ни с DLIB. Увеличил CSTACK до 0x50, RSTACK до 0x40 - не помогло. Иногда на дисплейчике все же появляется то пол-строчки, то еще глюк какой, и постоянно виснет через несколько секунд или минут работы.

С ICCAVR подобного глюкалова не было, код не менялся никак..

В коде используется TIMER1 (OVF, CAPT, COMPB) и timer2_ovf, контроллер mega16.

Может я чего забыл-не учел-не узнал?

Спасибо заранее!
Alex11
Для начала полностью выключить оптимизацию - там один большой глюк, без нее, как правило, работает. Дальше можно, после того, как все заработает, увеличивать уровень оптимизации, пока не сломается. Эта зараза, мало того, что не видит сама, что переменная используется в прерываниях, так еще и игнорирует слово volatile, после чего может выкинуть половину программы в оптимизаторе.
king2
Цитата(Alex11 @ Oct 16 2006, 19:27) *
Для начала полностью выключить оптимизацию - там один большой глюк, без нее, как правило, работает. Дальше можно, после того, как все заработает, увеличивать уровень оптимизации, пока не сломается. Эта зараза, мало того, что не видит сама, что переменная используется в прерываниях, так еще и игнорирует слово volatile, после чего может выкинуть половину программы в оптимизаторе.

Оптимизация выключена. Проблема (или по крайней мере не вся проблема) не в компиляторе, потому что иногда он все-таки выводит первую часть строчки...
rezident
Функция sprintf требует для работы весьма много стека (иногда до 1,5кБайт).
king2
Цитата(rezident @ Oct 16 2006, 19:51) *
Функция sprintf требует для работы весьма много стека (иногда до 1,5кБайт).

Хм, а что, она так плохо реализована?
Почему в ICCAVR все нормально, а тут до полутора килобайт? Где я стока в меге16 возьму? smile.gif

Неужели чтобы запихнуть один байт в 16 символов нужно столько стека???
rezident
Цитата(king2 @ Oct 16 2006, 22:31) *
Неужели чтобы запихнуть один байт в 16 символов нужно столько стека???

А зачем вам в таком случае sprintf? Пишите напрямую. Побайтно. Я, например, недавно при нехватке RAM в МК писал свой putchar и выводил символы на индикацию посимвольно (побайтно), а не строкой.
P.S. В IAR есть несколько моделей sprintf, в зависимости от выбора требования к стеку разные.
king2
Цитата(rezident @ Oct 16 2006, 20:49) *
Цитата(king2 @ Oct 16 2006, 22:31) *

Неужели чтобы запихнуть один байт в 16 символов нужно столько стека???

А зачем вам в таком случае sprintf? Пишите напрямую. Побайтно. Я, например, недавно при нехватке RAM в МК писал свой putchar и выводил символы на индикацию посимвольно (побайтно), а не строкой.
P.S. В IAR есть несколько моделей sprintf, в зависимости от выбора требования к стеку разные.

Да вот чтобы как раз самому не писать.
Вне зависимости от используемой модели все равно глючит.
Охх, буду пробовать разбираться..
arttab
Цитата
Для начала полностью выключить оптимизацию - там один большой глюк, без нее, как правило, работает.


Может тогда вообще отказаться от IAR? Глюки бывают в алгоритме, в неиспользовании или неправильном использовании объявлений, ошибки в библиотеках или в нестыковки их между собой и очень редко в самом каде.
Rst7
Цитата(Alex11 @ Oct 16 2006, 18:27) *
Для начала полностью выключить оптимизацию - там один большой глюк, без нее, как правило, работает.


Не согласен. Отличный оптимизатор.

Цитата
Дальше можно, после того, как все заработает, увеличивать уровень оптимизации, пока не сломается.


Весь свой софт пишу сразу с установками макс. оптимизации (обычно по скорости). Проблем не было, если все грамотно писать.

Цитата
Эта зараза, мало того, что не видит сама, что переменная используется в прерываниях, так еще и игнорирует слово volatile, после чего может выкинуть половину программы в оптимизаторе.


Приведите пожалуйста пример. По моему опыту, volatile надежно решает проблемы (иногда даже слишком, в смысле лишнего кода)...
dxp
Цитата(Rst7 @ Oct 17 2006, 11:45) *
Цитата(Alex11 @ Oct 16 2006, 18:27) *

Для начала полностью выключить оптимизацию - там один большой глюк, без нее, как правило, работает.


Не согласен. Отличный оптимизатор.

Цитата
Дальше можно, после того, как все заработает, увеличивать уровень оптимизации, пока не сломается.


Весь свой софт пишу сразу с установками макс. оптимизации (обычно по скорости). Проблем не было, если все грамотно писать.

Цитата
Эта зараза, мало того, что не видит сама, что переменная используется в прерываниях, так еще и игнорирует слово volatile, после чего может выкинуть половину программы в оптимизаторе.


Приведите пожалуйста пример. По моему опыту, volatile надежно решает проблемы (иногда даже слишком, в смысле лишнего кода)...

Присоединяюсь! cheers.gif Всегда использовал и использую максимальный уровень оптимизации на IAR'е, никогда проблем не встречал. На деле больше проблем, как раз, при средних и низких уровнях оптимизации.
king2
Цитата(arttab @ Oct 17 2006, 05:39) *
Цитата
Для начала полностью выключить оптимизацию - там один большой глюк, без нее, как правило, работает.


Может тогда вообще отказаться от IAR? Глюки бывают в алгоритме, в неиспользовании или неправильном использовании объявлений, ошибки в библиотеках или в нестыковки их между собой и очень редко в самом каде.

Да похоже, что все к тому и идет.
По поводу ошибок в объявлениях и прочем - тот же самый код, один в один, кроме формата объявления прерываний, записи nop, sei и cli и имени инклудов - чудесно и надежно работает при компилежке его при помощи ICCAVR. Так что оно может конечно ошибка и в коде, но не настолько же...
IgorKossak
Цитата(king2 @ Oct 17 2006, 13:23) *
Да похоже, что все к тому и идет.

Если Вы так уверены, то не стоит колебаться. ("Никогда не повторяйте удачный эксперимент" закон Мерфи)
Цитата(king2 @ Oct 17 2006, 13:23) *
По поводу ошибок в объявлениях и прочем - тот же самый код, один в один, кроме формата объявления прерываний, записи nop, sei и cli и имени инклудов - чудесно и надежно работает при компилежке его при помощи ICCAVR.

Не аргумент.
Вы могли и не заметить того, что используете недостатки компилятора, сами того не подозревая.
Цитата(king2 @ Oct 17 2006, 13:23) *
Так что оно может конечно ошибка и в коде, но не настолько же...

Уж поверьте на слово, бывает и не только "настолько же", а и похлеще.
SasaVitebsk
Простите, но не верю что дело в компиляторе. Может не совсем в компиляторе?

У меня прога 6К несколько прерываний. В том числе вложенных. Структуры и файлы. Применял разные виды оптимизации. Прямых глюков не заметил. Интересное поведение на JTAG - действительно было. Но с IARом явно не связано. Как только впрямую заливаешь - всё класс. Ну ладно я, но пользователей данного компилятора по миру - море. И если бы такие хомуты, - буча была бы.

А может проблема в каких-нибудь переменных. Ну например в прерывании. Тот компилятор в лоб сохранял всё, а этот только используемые. Короче ищите како-то хомут.

Да ещё с EEPROM работаете? А в прерывании?
Георгий
Да, действительно, нужно глянуть в доках как компиляторы передают переменные в функции, может набор регистров разный, и используется тот, который вы вручную используете или еще что нибудь подобное.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.