Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Проблема с асинхронным таймером в Меги16
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > AVR
MMP
Делаю проект часы на меге. Пока работал с помощью VMLAB и Протеус все было ок , часы тикали и т.д.
Как только стал шить в железо оказалось, что не тикают(то есть не входят в прерывание). Проверил в АВР студии - действительно не входят. Вот код:

//Инициализация таймера 2 на 1сек.
void timer2_init(void)
{
TCCR2 = 0x00;
ASSR = 0x08;
TCNT2 = 0x80;
OCR2 = 0x80;
TCCR2 = 0x06;
}
//Обработка прерывания по таймеру 2
#pragma interrupt_handler timer2_ovf_isr:5
void timer2_ovf_isr(void)
{
rtc_service(); //Функция обработки времени
TCNT2 = 0x80;
}
..........
void init_devices(void)
{
//stop errant interrupts until set up
CLI(); //disable all interrupts
port_init();
timer0_init();
timer2_init();
MCUCR = 0x00;
GICR = 0x00;
TIMSK = 0x41; //timer interrupt sources
SEI(); //re-enable interrupts

}
.....................

void main(void)
{

init_devices();
LCD4_Init();
LCD4_Clear();
...........
while(1);
}

Может подскажете в чем ошибка.
defunct
Цитата(MMP @ May 31 2006, 18:46) *
#pragma interrupt_handler timer2_ovf_isr:5
void timer2_ovf_isr(void)
{
rtc_service(); //Функция обработки времени
TCNT2 = 0x80;
}


Где вы взяли этот код? Выделенное специально чтоб часы точнее тикали?
Заводите таймер в режиме генерации прерываний по OCIE2.

Ну а по сабжу - с такими настройками прерывание должно генерироваться. Если только LCD4_Init(); и LCD4_Clear(); не запрещают прерывания.
Alex11
А при генерации для прошивки в железо оптимизатор не включился, порезав все не разобравшись? На IAR'е такое легко.
defunct
По поводу моей реплики насчет точности тиканья.

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

Есть два пути устранения этого:
1. режим CTC, в котором таймер сам будет обнуляться при достижении значения OCR2 (прерывание OCIE2).

2. (дался вам делитель 256?) перенастроить предделитель вместо 256 на 128 (значение TCCR2 = 5), чтобы таймер отсчитывал за полный ход ровно одну секнду и не надо было бы дергать регистр TCNT2 в прерывании. (прерывание TOIE2)
TamTam
Затри вот эту строчку и будет тебе счастье
Код
CLI(); //disable all interrupts
MMP
Господа если бы вы были повнимательней, то заметили бы в init_devices() еще и timer0_init(); так вот он как раз по прерыванию работает, т.е. дело не в CLI().

Цитата(Alex11 @ Jun 1 2006, 02:25) *
А при генерации для прошивки в железо оптимизатор не включился, порезав все не разобравшись? На IAR'е такое легко.

Можно подробнее об этом и как устранить. Правда пишу в ICC, а шью через AVRstudio

А не может быть это из-за фузов?
Перепроверил и в AVRstudio , в прерывание в программе он действительно входит и правильно обрабатывает, а на железе НЕТ.
Кстати проверяю и прошиваю через STK - 500
MMP
Все разобрался
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.