реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> Разная компиляция в Debug и Release
SasaVitebsk
сообщение Apr 25 2008, 10:16
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 712
Регистрация: 28-11-05
Из: Беларусь, Витебск, Строителей 18-4-220
Пользователь №: 11 521



IAR AVR 5.10. Микруха м88.
В debug из под JTAG ICE MK2 прекрасно работает.
Если программирую внешним программатором, то изделие не работает.

Фузы одинаковы. Опции в проекте одинаковые на всех вкладках.

Кто сталкивался? В чём может быть дело?
Go to the top of the page
 
+Quote Post
Dir
сообщение Apr 25 2008, 11:22
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 201
Регистрация: 6-01-05
Пользователь №: 1 830



Цитата(SasaVitebsk @ Apr 25 2008, 13:16) *
IAR AVR 5.10. Микруха м88.
В debug из под JTAG ICE MK2 прекрасно работает.
Если программирую внешним программатором, то изделие не работает.

Фузы одинаковы. Опции в проекте одинаковые на всех вкладках.

Кто сталкивался? В чём может быть дело?


В оптимизации. Вот несколько причин, когда оптимизатор кардинально ломает функционирование:
1. может соптимизировать (вообще выбросить) переменную, которая ошибочно не была объявлена как volatile
2. может переставить порядок следования команд при инициализации периферии, что ведет к их неправильной работе
3. может выбросить несколько подряд следующих команд в функции, например, задержки, что приводит к неправильному функционированию времязадающих функций.
4. редко (но вполне возможно) может быть просто глюк оптимизатора.

Резюме. Не обольщайтесь, что у вас в Debug-е программа вроде бы работает. Оптимизатор - мощная штука не только для уменьшения объема используемой памяти и скорости выполнения, но и для вывления скрытых (неочевидных) ошибок программиста. Так что ищите и найдете wink.gif

PS. Ну, это все если я правильно понял ваш вопрос и Debug с Release отличаются уровнем оптимизации.
Go to the top of the page
 
+Quote Post
vmp
сообщение Apr 25 2008, 11:24
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 426
Регистрация: 20-01-05
Из: Зеленоград
Пользователь №: 2 070



Сравнить листинги, карту распределения памяти (.map-файл линкера), результат компиляции (поставив одинаковые форматы файлов).
Как вариант - шьется файл не в том формате (например, hex-файл зашивается как двоичный).
Прочитать зашитый через MK2 кристалл внешним программатором и сравнить.

Может быть в программе не инициализируется какая-нибудь периферия. Отладчик ее инициализирует, а программа - нет. Если зашитый через МК2 кристалл включить без отладчика, то он работает?
Go to the top of the page
 
+Quote Post
sKWO
сообщение Apr 25 2008, 11:52
Сообщение #4


Местный
***

Группа: Участник
Сообщений: 355
Регистрация: 27-03-07
Из: Україна, Чуднів
Пользователь №: 26 530



Цитата(Dir @ Apr 25 2008, 14:22) *
PS. Ну, это все если я правильно понял ваш вопрос и Debug с Release отличаются уровнем оптимизации.

Да если внимательно поссмотреть то можно увидеть
Фузы одинаковы. Опции в проекте одинаковые на всех вкладках

А с минимальным уровнем оптимизации не пробовали?
Внешний программатор испытанный?


--------------------
нельзя недооценивать предсказуемость глупости
Go to the top of the page
 
+Quote Post
singlskv
сообщение Apr 25 2008, 12:39
Сообщение #5


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



Цитата(Dir @ Apr 25 2008, 15:22) *
2. может переставить порядок следования команд при инициализации периферии, что ведет к их неправильной работе
Не имеет права, весь доступ к портам объявлен как volatile.
Go to the top of the page
 
+Quote Post
Dir
сообщение Apr 25 2008, 14:58
Сообщение #6


Местный
***

Группа: Свой
Сообщений: 201
Регистрация: 6-01-05
Пользователь №: 1 830



Цитата(singlskv @ Apr 25 2008, 15:39) *
Не имеет права, весь доступ к портам объявлен как volatile.


Точно не имеет права? volatile это ведь говорит только о том, что переменная на чтение меняется когда хочет. Момент записи volatile не регламентирует. Сам я на всякий случай процедуру инициализации провожу с прагмами no optimize или no code motion
Go to the top of the page
 
+Quote Post
singlskv
сообщение Apr 25 2008, 15:17
Сообщение #7


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



Цитата(Dir @ Apr 25 2008, 18:58) *
Точно не имеет права?
Точнее не бывает! smile.gif
Цитата
volatile это ведь говорит только о том, что переменная на чтение меняется когда хочет. Момент записи volatile не регламентирует.
Факт volatile доступа, говорит о том что в этот момент обязательно будет "sequence points",
sequence points менять местами НЕЛЬЗЯ !!!
Так что момент volatile доступа вполне регламентирован...

Почитайте стандарт насчет sequence points и side effects, все станет на свои места.
Go to the top of the page
 
+Quote Post
SasaVitebsk
сообщение Apr 25 2008, 20:27
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 2 712
Регистрация: 28-11-05
Из: Беларусь, Витебск, Строителей 18-4-220
Пользователь №: 11 521



Оптимизация и там и там выставлена по максимуму. Я с другими уровнями и не работаю. Не вижу смысла.
Проблема в чём-то другом. Пока исследую. Скорее всего в программе, только почему-то проявляется в режиме автомата. В режиме debug она останавливается, и возможно это на что-то влияет.

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

Всем ответившим - спасибо. smile.gif
Go to the top of the page
 
+Quote Post
singlskv
сообщение Apr 25 2008, 20:32
Сообщение #9


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



Цитата(SasaVitebsk @ Apr 26 2008, 00:27) *
.....
Без кода телепатить как всегда не просто,
а у Вас случайно многобайтовых volatile переменных нету ?
Go to the top of the page
 
+Quote Post
Igor26
сообщение Apr 29 2008, 12:14
Сообщение #10


Знающий
****

Группа: Свой
Сообщений: 521
Регистрация: 10-02-05
Пользователь №: 2 544



Цитата
а у Вас случайно многобайтовых volatile переменных нету ?

Даже если и есть, к чему это приведет?
Go to the top of the page
 
+Quote Post
ARIM
сообщение Apr 29 2008, 13:45
Сообщение #11


Частый гость
**

Группа: Свой
Сообщений: 94
Регистрация: 14-04-05
Из: Россия
Пользователь №: 4 130



Цитата(SasaVitebsk @ Apr 25 2008, 14:16) *
Фузы одинаковы.

Кто сталкивался? В чём может быть дело?

DWEN (debugWIRE Enable) запрещаете?
Go to the top of the page
 
+Quote Post
singlskv
сообщение Apr 29 2008, 18:21
Сообщение #12


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



Цитата(Igor26 @ Apr 29 2008, 16:14) *
Даже если и есть, к чему это приведет?
Примерно так:
http://electronix.ru/forum/index.php?showtopic=46565
но могут быть и более веселые варианты... smile.gif
не такие легкие для ловли...
Go to the top of the page
 
+Quote Post
Freeze Anti
сообщение May 7 2008, 09:13
Сообщение #13


Частый гость
**

Группа: Новичок
Сообщений: 153
Регистрация: 29-03-07
Из: Саратов
Пользователь №: 26 613



У меня похожая проблема... в дебаггере запускается, а зашивает чего-то не то... как будто вообще программы нет...

Переделывал проект из ИАРа 1.x (не помню точную версию), написанный в командной строке... В коде переделал только совсем простые вещи навроде __tiny вместо tiny и

#pragma vector=VECTOR
__interrupt void function(void)

вместо interrupt [VECTOR] void function(void)

в 1-ом нормально компилился, файл получался нормальный... а в 5-ом - не хочет... может где-то я напутал?.. но только где?..

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

Сообщение отредактировал Freeze Anti - May 7 2008, 09:34


--------------------
!!! All you need is LOVE !!!
Go to the top of the page
 
+Quote Post
Freeze Anti
сообщение May 7 2008, 12:18
Сообщение #14


Частый гость
**

Группа: Новичок
Сообщений: 153
Регистрация: 29-03-07
Из: Саратов
Пользователь №: 26 613



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

p.s. сорри за оффтоп, сначала подумал, что это подобная ошибка, потом понял, что нет, а новую тему создавать посчитал за моветон...


--------------------
!!! All you need is LOVE !!!
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 20th July 2025 - 17:58
Рейтинг@Mail.ru


Страница сгенерированна за 0.01459 секунд с 7
ELECTRONIX ©2004-2016