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

 
 
> Timer 1, CTC, mega8
Метценгерштейн
сообщение Jan 10 2015, 20:52
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 357
Регистрация: 12-04-05
Из: Петербург
Пользователь №: 4 079



настраиваю таймер1 на работу СТС, чтобы прерывался каждую и 1 мс и 100 мкс.
Код
        TCCR1B= (1<<WGM12) | (0<<CS12)|(0<<CS11) |(1<<CS10); //CTC mode, no prescaling
        TIMSK = (1<<OCIE1A) | (1<<OCIE1B);   //разрешили работу по compare A & B
        OCR1A= (OSC / 1000); // как досчитывает до этого значения- обнуляется
        OCR1B= (OSC / 10000);

        #pragma vector = TIMER1_COMPA_vect
__interrupt void overflow_timer1_A(void)
  {
    CntT1_ms++; // each ms will interrupt
  }

#pragma vector = TIMER1_COMPB_vect
__interrupt void overflow_timer1_B(void)
  {
   // CntT1_100mks++; // each 100 mks will interrupt
    cpl (test_pin);
  }


каждую 1 мс есть прерывание, а вот второе прерывание выполняется, но не так. cpl- это макрос- переворачивание ноги на противоположное сост.
в прерывание TIMER1_COMPB_vect входит, ногу переворачивает, но стабильно 1 мс на осцилле, а не 100 мкс

Чего забыл сделать или не учел?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 3)
Xenia
сообщение Jan 10 2015, 21:21
Сообщение #2


Гуру
******

Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237



Цитата(Метценгерштейн @ Jan 10 2015, 23:52) *
настраиваю таймер1 на работу СТС, чтобы прерывался каждую и 1 мс и 100 мкс.

каждую 1 мс есть прерывание, а вот второе прерывание выполняется, но не так. cpl- это макрос- переворачивание ноги на противоположное сост.
в прерывание TIMER1_COMPB_vect входит, ногу переворачивает, но стабильно 1 мс на осцилле, а не 100 мкс

Чего забыл сделать или не учел?


Вы просто не понимаете, что период задает только то событие, которое сбрасывает/обнуляет таймер. В данном случае этим событием является достижение уровня OCR1A. Именно поэтому период зависит только от значения OCR1A, но ни в коем случае не зависит от других OCR на том же таймере. Т.е. какими бы ни были OCR1B и OCR1C, на периодичности таймера они никак не сказываются, а потому на частоту генерации не влияют.

В вашем случае прерывание TIMER1_COMPB_vect будет происходить с фазовой задержкой в 100 мкс после сброса Таймера 1, но периодичность его останется по-прежнему 1 мс, т.к. при достижении уровня OCR1B таймер не сбрасывается, а продолжает повышаться дальше, пока не достигнет OCR1A.

Образно говоря, на какой бы час OCR1B вы ни завели (цифровой) будильник, звонить он будет раз в сутки, т.к. число часов в сутках задает OCR1A. А вы надеетесь, что заведя будильник на 1 час ночи, он будет звонить у вас каждый час. Не бывать этому! sm.gif

И вообще - создать две разные частоты на одном таймере невозможно. Разве что за одним редким исключением, когда одна из частот ровно вдвое чаще другой.
Go to the top of the page
 
+Quote Post
Метценгерштейн
сообщение Jan 10 2015, 22:22
Сообщение #3


Профессионал
*****

Группа: Свой
Сообщений: 1 357
Регистрация: 12-04-05
Из: Петербург
Пользователь №: 4 079



Спасибо. У меня были подозрения, т.к. топ указан ocr1a. И нигде ни слова про б.
Go to the top of the page
 
+Quote Post
AndryG
сообщение Feb 12 2015, 18:32
Сообщение #4


Частый гость
**

Группа: Свой
Сообщений: 139
Регистрация: 23-05-05
Из: UA
Пользователь №: 5 317



Цитата
И вообще - создать две разные частоты на одном таймере невозможно.

А если в обработчике по совпадению изменять значение регистра совпадения (добавлять время "а теперь совпади через 100 мкс") и не трогать сам счетчик?
Что помешает так создать по одному генератору на каждом регистре сравнения?
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 23:55
Рейтинг@Mail.ru


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