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

 
 
2 страниц V  < 1 2  
Reply to this topicStart new topic
> Какой-то бред..., ...с прерыванием по таймеру
defunct
сообщение Jan 2 2008, 21:39
Сообщение #16


кекс
******

Группа: Свой
Сообщений: 3 825
Регистрация: 17-12-05
Из: Киев
Пользователь №: 12 326



Цитата(HCHUNTER @ Jan 2 2008, 23:36) *
Ведь мне никто не запрещает в прерывании остановить таймер, выполнить все что мне нужно, а по выходу из прерывания снова его запустить?

Никто не запрещает.

С другой стороны, никто не запрещает также запустить таймер с одинаковыми интервалами времени. И пусть себе тикает.
В обработчике прерывания таймера - взводить флажек, сигнализирующий, что некое событие наступило.
И уже потом "в спокойной обстановке" тобиш в основном цикле программы проверить флажек и выполнить все, что требуется для обработки этого события..

Цитата
С моей точки зрения процедура-обработчик может быть сколь угодно долгой.

Конечно может, но меня например несколько раздражает когда жмешь CTRL-ALT-DEL, а системе "пофиг", т.к. некий программист решил сделать сколь угодно долгий обработчик. Если вам подходит такой стиль - то без проблем, пишите так ;>


Цитата
а как же мне тогда правильно таймер проинициализировать?
Получается
TCCR0=0x05;
TCNT0=0xFF;


Есть режим таймера CTC - очистка по сравнению. В этом режиме не надо трогать TCNT регистр, т.к. таймер сам будет сбрасываться тогда когда вы ему укажате. Правда в m8 этот режим есть только у таймера 1 и таймера 2. Если вам нужно отмерять один "тик", то на таймере 2 инициализация будет выглядеть так:

#define WGM21 3
#define OCIE2 7

OCR2 = 1;
TCCR2 = 0x07 | (1 << WGM21);
TIMSK = (1 << OCIE2);
Go to the top of the page
 
+Quote Post
HCHUNTER
сообщение Jan 2 2008, 22:08
Сообщение #17


Участник
*

Группа: Новичок
Сообщений: 19
Регистрация: 29-12-07
Пользователь №: 33 732



Цитата
Если вам нужно отмерять один "тик", то на таймере 2 инициализация будет выглядеть так:

#define WGM21 3
#define OCIE2 7

OCR2 = 1;
TCCR2 = 0x07 | (1 << WGM21);
TIMSK = (1 << OCIE2);


Да, я встречал подобную запись, когда разбирал чей-то код.
Однако работаю в CVAVR, а там такое не прокатывает... не знает он что такое WGM и OCIE2... sad.gif
Go to the top of the page
 
+Quote Post
Guest_=AVR=_*
сообщение Jan 2 2008, 22:13
Сообщение #18





Guests






Как не знает? Даже сразу после того, как ему сказали #define WGM21 и #define OCIE2?? Вот уж поистине ... - Новый год smile.gif
Go to the top of the page
 
+Quote Post
HCHUNTER
сообщение Jan 2 2008, 22:16
Сообщение #19


Участник
*

Группа: Новичок
Сообщений: 19
Регистрация: 29-12-07
Пользователь №: 33 732



э... туплю кажись... м-де... smile3046.gif
Go to the top of the page
 
+Quote Post
Dim_ON
сообщение Jan 4 2008, 17:59
Сообщение #20


Участник
*

Группа: Участник
Сообщений: 29
Регистрация: 28-09-07
Пользователь №: 30 914



Помогите плиз разобраться с таймерами
Необходимо что бы Т0 и Т1 работали на переполнение с частотой ЦПУ (это не надо объяснять), а вот Т2 от часового кварца
Подключаю часовой кварц к PC6, PC7 (ATmega16, 32), а инициализация будет, следующей?:
Код
#define TIMER_CLK_DIV8            0x02    ///< Timer clocked at 32.768KHz/8
#define TIMER_PRESCALE_MASK        0x07    ///< Timer Prescaler Bit-Mask
#define TIMER2OVERFLOW_INT        5
volatile unsigned long Timer2Reg0;

void timer2Init(void)
{
    // initialize timer 2
    outb(TCCR2, (inb(TCCR2) & ~TIMER_PRESCALE_MASK) | TIMER_CLK_DIV8); // count 32.768KHz/8
    outb(TCNT2, 0);                    // reset TCNT2
    sbi(TIMSK, TOIE2);                // enable TCNT2 overflow
    sbi(ASSR, AS2);                    // switch to asynchronous input (32KHz crystal)
    Timer2Reg0 = 0;                    // initialize time registers
    // attach service to real-time clock interrupt
    // rtcService() will be called at ((32768/8)/256) = 16Hz
    timerAttach(TIMER2OVERFLOW_INT, rtcService);
    sei();
}
Go to the top of the page
 
+Quote Post
zltigo
сообщение Jan 4 2008, 18:45
Сообщение #21


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Часть ветки перенесена сюда: http://electronix.ru/forum/index.php?showtopic=41484&hl=


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Aesthete Animus
сообщение Jan 4 2008, 22:20
Сообщение #22


Местный
***

Группа: Свой
Сообщений: 222
Регистрация: 9-06-07
Пользователь №: 28 317



Цитата(Dim_ON @ Jan 4 2008, 20:59) *
Помогите плиз разобраться с таймерами
Необходимо что бы Т0 и Т1 работали на переполнение с частотой ЦПУ (это не надо объяснять), а вот Т2 от часового кварца
Подключаю часовой кварц к PC6, PC7 (ATmega16, 32), а инициализация будет, следующей?:


Разрешите приведу код из doc2505 небольшими изменениями для иициализации часового кварца
Код
void init_Ex3(void)
{
    ASSR= 1<<AS2; // Enable asynchronous
                  // mode
                  // Clear timer on compare match / Timer Clock =
                  // system clock / 1024
    TCCR2 = (1<<CTC2)|(1<<CS22)|(1<<CS21)|(1<<CS20);
    TIFR= 1<<OCF2; // Clear OCF2/ Clear
                   // pending interrupts
    TIMSK= 1<<OCIE2; // Enable Timer2 Output
                     // Compare Match Interrupt
    OCR2= 31; // Set Output Compare
              // Value to 32
    DDRB= 0xFF; // Set Port B as output
    while (ASSR&(1<<OCR2UB)); // Wait for registers to update
}

В этом случае, прерывание по сравнению таймера №2 (SIG_OUTPUT_COMPARE2) будет вызываться раз в секунду.

Хочу заметить, что в документации для регистра OCR2 задано неверное значение, у них вместо 31 написано 32.
Go to the top of the page
 
+Quote Post
Dim_ON
сообщение Jan 5 2008, 09:04
Сообщение #23


Участник
*

Группа: Участник
Сообщений: 29
Регистрация: 28-09-07
Пользователь №: 30 914



Сори за офф, но решил не создавать новой темы, а спросить тут.
Правильно ли я понимаю функционирование таймеров/счетчиков:
Режим переполнения(overflow) - это когда таймеры считают синхроипульсы, и прерывание происходит когда MAX_COUNT-->0, при этом MAX_COUNT зависит от размерности таймера.

Режим совпадения(outcompare) - это когда в регистр OCR записывают MAX_COUNT, счетчик каждый такт сравнивает содержимое регистров OCR и TCNT, при равенстве происходит прерывание.

Режим захвата и сравнения - это когда состояние регистра TCNT сохраняется в регистре ICR по активному фронту ноги ICP, и для сравнения нам надо считывать ICR

Асинхронный режим - это когда источником синхроимпульсов является резонатор, подключенный к ногам TOSC1 и TOSC2

Режим генерации ШИМ - это отдельная тема

Режим подсчета внешних событий - это когда содержимое регистра TCNT увеличивается при...??
Не пойму, можно ли настраивать что бы работали на инкремент или декремент?
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 19th July 2025 - 04:42
Рейтинг@Mail.ru


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