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

 
 
> Случайное падение шедулера. Как отследить?, FreeRTOS, C++, обработка исключений, шедулер
vv_
сообщение Nov 29 2016, 12:24
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 24-06-14
Пользователь №: 82 043



Доброго времени!
Пишу проект на C++ в Keil, процессор STM32F4**, ось FreeRTOS V8.2.3, менеджер памяти heap_4. Проект сгенерирован в CubeMX.
Столкнулся с ситуацией, когда при обработке исключений на C++ происходит неопределенное поведение.
CODE

class MemTest{
public:
MemTest(){ _p = new char[10000]; }
~MemTest(){ delete _p; }
private:
char * _p;
};
class exc{
public:
exc(){}
~exc(){}
};
/* таска в которой локализую ошибку */
void exception_debug(void const * argument){
while(true){
try{
MemTest mt;
throw exc();
} catch(const exc& e){
osDelay(100);
} catch(...){
osDelay(500);
}
}
vTaskDelete(NULL);
}

Операторы new и delete выглядят так:
CODE

void *operator new(size_t size){
void *p=pvPortMalloc(size);
#ifdef __EXCEPTIONS
if (p==0)
throw std::bad_alloc();
#endif
return p;
}
void operator delete(void *p){
vPortFree( p );
}

Сценарий выполнения выглядит следующим образом:
1. некоторое количество раз (в среднем от 1 до 25) выполняется в цикле try ... catch и мы успешно падаем в блок catch(const exc& e).
2. после последнего удачного раза отработки конструкторов - деструкторов типов MemTest и exc, на следующей итерации, когда я попадаю в деструктор MemTest, выполняю операцию delete и в этот момент у меня выполнение кода передаётся на функцию HAL_TIM_IRQHandler и дальше попадаю в функции HAL для обработки сравнений итп, что касается таймера.

Вопрос такой, как определить в какую сторону копать? У меня есть предположение, что в некоторой ситуации крашится шедулер FreeRTOS. Но отловить в какой именно пока не получилось.

PS1: Я отслеживаю переполнение хипа и стека. Эти хуки не вызываются, из чего можно сделать вывод, что использование памяти не выходит за границы..
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 16th June 2025 - 13:35
Рейтинг@Mail.ru


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