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

 
 
> Как определить где зависает?, без отладчика
troy97
сообщение Oct 4 2010, 15:29
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 20
Регистрация: 12-01-09
Из: Донецк, Украина
Пользователь №: 43 218



В общем, где-то год назад было сделано устройство на ATmega168, которое нормально работает, но вот обнаружилось, что оно периодически (до 5 раз в день) программно зависает и перезагружается по сторожевому таймеру. Как определить где именно зависает? Устройство имеет светодиод, но им отлаживать, учитывая частоту зависания, не хочется. Есть выход в локальную сеть для передачи UDP-пакетов, в режиме прерывания по watchdog всё вполне работоспособно, как узнать в каком месте зависает? Программа написана на CVAVR. Заранее спасибо.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
xelax
сообщение Oct 6 2010, 06:41
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 370
Регистрация: 7-11-06
Пользователь №: 22 035



Можно также при зависании, в прерывании по вачдогу, сливать весь стек и регистры... Далее пишите какой-нибудт скриптик например на питоне, который получает на вход слитый стек и дизасм вашего проекта и по процессорному стеку разматывает стек вызовов функций.... 99% найдёте место зависания. Мы таким образом все jump на NULL отловили в своём коде.
Go to the top of the page
 
+Quote Post
king2
сообщение Oct 10 2010, 17:02
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 255
Регистрация: 17-08-06
Из: Москва
Пользователь №: 19 646



Все тупо, но придется много писать. smile.gif
Заводите две глобальные переменные, пусть будет trace_fn и trace_cp.

На входе в функцию:
unsigned int old_tfn = trace_fn;
unsigned int old_tcp = trace_cp;
trace_fn = <номер_функции>;

Внутри функции:
trace_cp = 1;
trace_cp = 2;
и так далее.

На выходе из функции восстанавливаете значения из переменных old.
Внутри функции watchdog отправляете на отладку обе глобальные переменные и видите, какой checkpoint в какой функции был последним.
Там поблизости и ищите...

Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 15:13
Рейтинг@Mail.ru


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