Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Локальные переменные и возврат из функции
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > Cредства разработки для МК > IAR
drozel
Наткнулся на какой-то цирк с конями: в функции используется локальный массив из 10 байт, он ложится в стек, а при возврате программа не отбрасывает эти элементы, а прямо их засовывает с R0-R2, PC, получая, естественно, hardFault.
Код
void protocolOnRxed (uint8_t *buffer, uint32_t len)
{
gLen = len;
char test[10];
gLen = sprintf(test, "Transfer: %d", len);
cdcacm_data_tx(test, gLen);
}


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

В приложении скриншот, там видно и программу, и стек, и дизассемблер.
Obam
Цитата(drozel @ Oct 22 2015, 11:36) *
Наткнулся на какой-то цирк с конями: в функции используется локальный массив из 10 байт, он ложится в стек, а при возврате программа не отбрасывает эти элементы, а прямо их засовывает с R0-R2, PC, получая, естественно, hardFault.
Код
void protocolOnRxed (uint8_t *buffer, uint32_t len)
{
gLen = len;
char test[10];
gLen = sprintf(test, "Transfer: %d", len);
cdcacm_data_tx(test, gLen);
}


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

В приложении скриншот, там видно и программу, и стек, и дизассемблер.


А что там за Warnings на вызовы ещё двух п/п?
scifi
Какой-то трэш и угар. Что-то я не верю, что яр может нагенерить такой код. Или я что-то не понимаю...
drozel
Цитата(scifi @ Oct 22 2015, 13:56) *
Какой-то трэш и угар. Что-то я не верю, что яр может нагенерить такой код. Или я что-то не понимаю...

А я о чем! Но я же правильно локализовал проблему? Скрин убедителен?
Немного подробностей: портирую openlibcm3, возможны проблемы со стартапом, но вроде стек в норме.

Цитата(Obam @ Oct 22 2015, 13:55) *
А что там за Warnings на вызовы ещё двух п/п?

implicity declarations


---
UPD: Нет, похоже, дело в чем-то другом. Я попробовал создать еще одну функцию с локальным массивом, все выглядит так же, но возвращается нормально. Проблема где-то в другом месте, похоже
Сергей Борщ
Все гораздо проще. Под test автор выделяет 10 байт. После чего пишет туда строку "Transfer: ", которая уже сама занимает 11 байт. Надо ли говорить, куда будет записано текстовое представление переменной len? Так что стек как раз не в норме, он тщательно порушен.
drozel
Цитата(Сергей Борщ @ Oct 22 2015, 14:43) *
После чего пишет туда строку "Transfer: ", которая уже сама занимает 11 байт. Надо ли говорить, куда будет записано текстовое представление переменной len?

Черт! Напоролся, как школьник cranky.gif
k155la3
Цитата(drozel @ Oct 22 2015, 11:44) *
Черт! Напоролся, как школьник cranky.gif


пользуйте sNprintf() в котором sizeof( TargetMemArray )
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.