Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Release & Debug
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > Cредства разработки для МК > IAR
VladimirYU
Почему map файлы для Release и для Debug при одних и тех же настройках в проекте отличаются по размерам кода и данных (IAR EWAVR). Где почитать?
Сергей Борщ
Цитата(VladimirYU @ Jul 13 2007, 08:57) *
Почему map файлы для Release и для Debug при одних и тех же настройках в проекте отличаются по размерам кода и данных (IAR EWAVR). Где почитать?
Потому что настройки все же разные. Читать в заголовках .lst и .map - там перечислены ключи, с которыми вызывались компилятор и линкер. Сравнивая заголовки, можно найти отличие и уже дальше искать какая галочка за это отличие отвечает - ее вы и не заметили.
VladimirYU
Цитата(Сергей Борщ @ Jul 13 2007, 10:34) *
Потому что настройки все же разные. Читать в заголовках .lst и .map - там перечислены ключи, с которыми вызывались компилятор и линкер. Сравнивая заголовки, можно найти отличие и уже дальше искать какая галочка за это отличие отвечает - ее вы и не заметили.


Спасибо, идею понял, проверю. Но всвязи с этим другой вопрос, может ли это быть причиной подводных камней в функционировании одного и того же устройства прошитого из Debug JTAG-ом или из Release, например, AVReal-ом. Вопрос для меня не только теоретичесий, две партии приборов ведут себя по разному, прошиты были, как сказано выше.
Сергей Борщ
Цитата(VladimirYU @ Jul 13 2007, 09:59) *
Но всвязи с этим другой вопрос, может ли это быть причиной подводных камней в функционировании одного и того же устройства прошитого из Debug JTAG-ом или из Release, например, AVReal-ом
Да, может (даже если не считать возможность различной установки Fuses). Поскольку одни и те же строчки строчки исходника компилируются по-разному, не совсем корректные конструкции при определенных установках могут дать работоспособный код. Не исключается и ошибка компилятора, но это настолько ничтожный процент... Мне за 8 лет работы с ИАРом попались только две.
Посколько программатор обычно проверяет за собой - думаю что программатор из списка подозреваемых можно исключить. Ну а поскольку Fuses не являются частью исходника, то если разница в них - виноват программист, который их неверно перечислил в .bat-файле для AvReAl.
rezident
Цитата(VladimirYU @ Jul 13 2007, 12:59) *
может ли это быть причиной подводных камней в функционировании одного и того же устройства прошитого из Debug JTAG-ом или из Release, например, AVReal-ом. Вопрос для меня не только теоретичесий, две партии приборов ведут себя по разному, прошиты были, как сказано выше.

Конечно может! Debug и Realese с установками "по-умолчанию" отличаются как минимум уровнем оптимизации исходного когда. А при максимальном уровне оптимизации иногда такие чудеса начинаются, что ой-ёй-ёй! wacko.gif Особенно, когда программист на Си не знает про квалификатор volatile wink.gif
VladimirYU
Цитата(rezident @ Jul 13 2007, 11:17) *
Конечно может! Debug и Realese с установками "по-умолчанию" отличаются как минимум уровнем оптимизации исходного когда. А при максимальном уровне оптимизации иногда такие чудеса начинаются, что ой-ёй-ёй! wacko.gif Особенно, когда программист на Си не знает про квалификатор volatile wink.gif


Фузы выставлены одинаково, с volatile, конечно, знаком. Но вспоминается EW IARAVR 3.20C там налетел на глюк, пока не апгрейдил до D. Буду искать причину. Объем кода 30К, отличие кода Release oт Debug 28 байт, по данным 1 байт (2677 и 2676). Спасибо всем откликнувшимся.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.