Описанное выше применение таймеров/счетчиков микроконтроллеров AVR справедливо также и для таймеров микроконтроллеров PIC. Здесь используются аналогичные принципы измерения ширины и частоты импульсов, а также широтно-импульсной модуляции, режимов сравнения и захвата.
В микроконтроллерах PIC могут использоваться три таймера: TMR0, TMR1 и TMR2.
TMR0
TMR0 (рис. 4.9) – это 8-разрядный таймер/счетчик. Таким образом, счет для него ограничен диапазоном 0-255. Его тактирование реализуется от внешнего источника или на основании такта системной синхронизации.
Рис. 4.9. Схема таймера/счетчика TMR0
Для управления работой таймера TMR0 используются следующие разряды регистра OPTION_REG:
-разряд 5 – T0CS – определяет выбор источника синхроимпульсов (0 – внутренний; 1 – внешний на входе TOCKI);
-разряд 4 – T0SE – определяет выбор фронта, по которому происходит увеличение содержимого счетного регистра TMR0 (0 – по нарастающему; 1 – по ниспадающему фронту тактового сигнала);
-разряд 3 – PSA – использование предварительного делителя частоты (0 – делитель используется для управления таймером TMR0; 1 – для управления сторожевым таймером);
-разряды 0-2 – PS0, PS1, PS2 – выбор коэффициента деления частоты входного тактового сигнала (табл. 4.6).
Таблица 4.6. Назначение разрядов PSO - PS2 регистра OPTIONJREG
PS2 | PS1 | PSO | Коэффициент деления частоты входного тактового сигнала |
0 | 0 | 0 | 2 |
0 | 0 | 1 | 4 |
0 | 1 | 0 | 8 |
0 | 1 | 1 | 16 |
1 | 0 | 0 | 32 |
1 | 0 | 1 | 64 |
1 | 1 | 0 | 128 |
1 | 1 | 1 | 256 |
Для управления прерываниями от таймера TMR0 используются следующие разряды регистра INTCON:
-разряд 2 – TOIF – флаг прерывания при переполнении TMR0;
-разряд 5 – TOIE – флаг разрешения прерывания при переполнении TMR0;
-разряд 7 – GIE – флаг общего разрешения прерываний.
TMR1
TMR1 (рис. 4.11) – это 16-разрядный таймер/счетчик, который может использоваться для формирования запросов на прерывание, подобно TMR0, или же работать в режимах захвата, сравнения и ШИМ.
Тактирование таймера TMR1 осуществляется от сигнала системной синхронизации или от специального генератора, предназначенного для работы с относительно медленными программными приложениями. Как правило, используется кварцевый резонатор частотой 32,768 кГц.
Для управления таймером TMR1 используется регистр T1CON (рис. 4.12). Назначение отдельных разрядов регистра T1CON:
-TMRION – подключение таймера (0 – отключен, 1 – включен);
-TMR1CS – выбор источника тактирующих сигналов (0 – такт системной синхронизации; 1 – генератор 32,768 кГц);
-Tl SYNC – включение/отключение синхронизация специального генератора с генератором импульсов системной синхронизации (0 – включена; 1 – отключена);
-T10SCEN – разрешение/запрет тактирования таймера TMR1 от специального генератора (0 – генератор отключен; 1 – тактирование разрешено);
T1CKPS0, T1CKPS1 – выбор коэффициента деления частоты (табл. 4.7).
Рис. 4.11. Схема таймера/счетчика TMR1
7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
– | – | T1CKPS1 | T1CKPS0 | T10SCEN | T1SYNC | TMR1CS | TMR1ON |
Рис. 4.12. Регистр T1CON микроконтроллеров PIC
Таблица 4.7. Назначение разрядов T1CKPS0 - T1CKPS1 регистра T1CON
T1CKPS1 | T1CKPS0 | Коэффициент деления частоты тактового сигнала |
0 | 0 | 1 |
0 | 1 | 2 |
1 | 0 | 4 |
1 | 1 | 8 |
Счетный регистр таймера TMR1 представляет собой регистровую пару TMR1H, TMR1L, а управление прерываниями осуществляется с помощью разрядов регистров PIR1 и РIЕ1:
Регистр PIR1:
-разряд 0 – TMR1IF – флаг переполнения TMR1;
-разряд 2 – ССР 1 IF – флаг прерывания при возникновении захвата по входу/
Регистр PIE1:
-разряд 0 – TMR1IE – флаг разрешения прерывания при переполнении TMR1;
-разряд 2 – ССР НЕ – флаг разрешения прерывания при возникновении захвата по" входу.
TMR2
Назначение таймера TMR2 (рис. 4.13) – измерение временных интервалов для реализации ШИМ, обеспечения определенной скорости обмена по последовательному порту и т.п. В этом смысле он подобен таймеру TMR0.
Таймер TMR2 тактируется импульсами, следующими с частотой такта системной синхронизации, деленной на четыре. Каждый раз, когда содержимое счетного регистра TMR2 совпадает с содержимым регистра PR2, таймер автоматически сбрасывается в исходное (нулевое) состояние.
Рис. 4.13. Схема таймера/счетчика TMR2
При каждом совпадении TMR2 и PR2 генерируется запрос на прерывание, частоту возникновения которого можно также масштабировать с помощью выходного делителя частоты.
Для управления таймером TMR2 используется регистр T2CON (рис. 4.14).
7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
– | TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 |
Рис. 4.14. Регистр T2CON микроконтроллеров PIC
Назначение отдельных разрядов регистра T2CON:
-T2CKPS0-T2CKPS1 –управление предварительным делителем частоты (табл. 4.8);
-TMR20N – подключение таймера (0 – отключен, 1 – включен);
-TOUTPS0-TOUTPS3 – выбор коэффициента деления частоты запросов на прерывание при TMR2::=:PR2 (табл. 4.9).
Таблица 4.8. Назначение разрядов T2CKPS0 - T2CKPS1 регистра T2CON
T1CKPS1 | T1CKPS0 | Коэффициент деления частоты тактового сигнала |
0 | 0 | 1 |
0 | 1 | 4 |
1 | X | 16 |
Таблица 4.9. Назначение разрядов TOUTPS0 - TOUTPS3 регистра T2CON
TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | Коэффициент деления частоты запросов |
0 | 0 | 0 | 0 | 1 |
0 | 0 | 0 | 1 | 2 |
0 | 0 | 1 | 0 | 3 |
0 | 0 | 1 | 1 | 4 |
0 | 1 | 0 | 0 | 5 |
о | 1 | 0 | 1 | 6 |
0 | 1 | 1 | 0 | 7 |
0 | 1 | 1 | 1 | 8 |
0 | 0 | 0 | 9 | |
0 | 0 | 1 | 10 | |
0 | 1 | 0 | 11 | |
0 | 1 | 1 | 12 | |
1 | 0 | 0 | 13 | |
1 | 0 | 1 | 14 | |
1 | 1 | 0 | 15 | |
1 | 1 | 1 | 16 |
Для организации прерываний используются разряды TMR2JE (флаг разрешения) и TMR2IF (флаг прерывания) регистров PIE1 и PIR1 соответственно.
Для того чтобы эффективно использовать таймер TMR2, используются следующие формулы:
где Т – требуемая временная задержка, К1 – коэффициент деления предварительного делителя частоты; К2 – коэффициент деления делителя частоты запросов на прерывание; PR2 – содержимое регистра PR2; F – частота системной синхронизации.
Модуль ССР
Таймеры TMR1 и TMR2 микроконтроллеров PIC применяются в составе модуля сравнения/захвата/ШИМ – ССР (Compare-Capture-PWM). Таких модулей может быть два: ССР1 и ССР2, – управление которыми реализовано с помощью регистров CCPxCON (рис. 4.15),
7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
– | – | DC1BX1 | DC1BX0 | CCP1M3 | CCP1M2 | CCP1M1 | CCP1M0 |
Рис. 4.15. Регистр CCPxCON микроконтроллеров PIC
Назначение отдельных разрядов регистра CCPxCON:
ССР1М0 – ССР1МЗ – выбор режима захвата/сравнения (табл. 4.9) DC1ВХ0 – DC1ВХ1 – два младших разряда 10-разрядной ШИМ.
Таблица 4.9. Назначение разрядов ССР1М1 -ССР1МЗ регистра CCPxCON
ССР1МЗ | ССР1М2 | ССР1М1 | ССР1М0 | Значение |
0 | 0 | X | X | Модуль ССР отключен |
0 | 1 | 0 | 0 | Захват по каждому ниспадающему фронту |
0 | 1 | 0 | 1 | Захват по каждому нарастающему фронту |
0 | 1 | 1 | 0 | Захват по каждому 4-му нарастающему фронту |
0 | 1 | 1 | 1 | Захват по каждому 16-му нарастающему фронту |
1 | 0 | 0 | 0 | В случае совпадения на выходе – высокий уровень |
1 | 0 | 0 | 1 | В случае совпадения на выходе – низкий уровень |
1 | 0 | 1 | 0 | В случае совпадения – запрос на прерывание |
1 | 0 | 1 | 1 | Особый случай режима сравнения |
1 | 1 | X | X | Режим ШИМ |
В режиме захвата (то есть, фиксации значения таймера в момент появления определенного условия) используются регистры CCPR1H, CCPR1L (в случае TMR1) или CCPR2H, CCPRL (в случае TMR2). В таком режиме таймер выполняет функции счетчика тактовых импульсов, и при наступлении условия захвата его содержимое переписывается в регистровую пару CCPRx.
В режиме сравнения модуль ССР формирует сигнал на выходе ССРх в том случае, когда содержимое счетного регистра становится равным значению, записанному в регистровой паре CCPRxL, CCPRxH. Этот режим обычно используется для выдачи сигналов на внешние устройства по истечении некоторого временного интервала.
В режиме ШИМ таймер работает как делитель частоты, формирующий период ШИМ-сигнала. Его значение постоянно сравнивается с содержимым регистра PR2, и при совпадении компаратор сбрасывает таймер в исходное состояние, после чего цикл повторяется. Параллельно организован контур сравнения, включающий в себя таймер, второй компаратор и регистр CCPRxH. Выходы обоих компараторов управляют RS-триггером, выход которого соединен с выводом ССРх.
Вначале триггер устанавливается в "1" по сигналу сброса таймера, а по сигналу компаратора контура сравнения – сбрасывается в "О". Таким образом, на выходе RS-триггера формируется сигнал с периодом, определяемым содержимым регистров PR2 и CCPRxH.
Сторожевой таймер
Сторожевой таймер (watchdog timer) – встроенный таймер, тактируемый внутренним RC-осциллятором, который автоматически сбрасывает микроконтроллер при переполнении своего счетного регистра. В частности, он используется для предотвращения перехода микроконтроллера в режим бесконечного цикла, когда на него невозможно повлиять извне. Обобщенная структурная схема сторожевого таймера показана на рис. 5.1.
В микроконтроллерах AVR и PIC управление сторожевым таймером несколько отличается. Так, в микроконтроллерах AVR для этого используется регистр управления WDTCR (адрес в области ввода/вывода – 0x21, адрес SRAM – 0x41) (рис. 5.2).
Рис. 5.1. Структурная схема сторожевого таймера
7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
– | – | – | WDTOE | WDE | WDP2 | WDP1 | WDP0 |
Рис. 5.2. Регистр WDTCR микроконтроллеров AVR
Назначение отдельных разрядов регистра WDTCR:
-WDP0-WDP2 – выбор коэффициента деления частоты следования сигналов сброса (при этом период до наступления сброса зависит от рабочего напряжения процессора – табл. 5.1);
-WDE – включение/отключение сторожевого таймера (1 – включен);
-WDTOE – если сторожевой таймер должен быть отключен, следует установить этот разряд в лог. 1. После установки этого разряда он в течение четырех периодов такта системной синхронизации остается в состоянии лог. 1, а затем аппаратно сбрасывается в лог. 0. Программа пользователя имеет возможность отключить сторожевой таймер посредством записи лог. 0 в разряд WDE только во время этих четырех тактов системной синхронизации.
Таблица 5.1 Назначение разрядов WDP0 - WDP2 регистра WDTCR
WDP2 | WDP1 | WDPP | Коэффициент деления | Период до сброса (при Vcc в 5 В) | Период до сброса (при Vcc = 3 В) |
0 | 0 | 0 | 1 | 16 мс | 47 мс |
0 | 0 | 1 | 2 | 32 мс | 94 мс |
0 | 1 | 0 | 4 | 64 мс | 190 мс |
0 | 1 | 1 | 8 | 128 мс | 380 мс |
1 | 0 | 0 | 16 | 256 мс | 750 мс |
1 | 0 | 1 | 32 | 512 мс | 1,5с |
1 | 1 | 0 | 64 | 1 с | Зс |
1 | 1 | 1 | 128 | 2,1 с | 6с |
В системе команд AVR сторожевой таймер сбрасывается в исходное состояние по команде wdr. В микроконтроллерах PIC для управления сторожевым таймером предназначен рассмотренный выше регистр OPTION. Для этого разряд PSA должен быть установлен в лог. 1, чтобы предварительный делитель частоты был переключен на использование совместно со сторожевым таймером, а не с TMR0. Коэффициент деления выбирается с помощью разрядов PS2-PS0 (табл. 5.2). В отличие от микроконтроллеров AVR, в микроконтроллерах PIC отсутствует возможность включать/отключать сторожевой таймер с помощью регистра управления. Единственный способ предотвратить сброс от сторожевого таймера – периодически выполнять ассемблерную команду clrwdt.
Таблица 5.2. Выбор коэффициента деления частоты следования сигналов сброса от сторожевого таймера в микроконтроллерах PIC
PS2 | PS1 | PS0 | Коэффициент деления | Период до сброса |
0 | 0 | 0 | 1 | 18 мс |
0 | 0 | 1 | 2 | 36 мс |
0 | 1 | 0 | 4 | 72 мс |
0 | 1 | 1 | 8 | 144 мс |
1 | 0 | 0 | 16 | 288 мс |
1 | 0 | 1 | 32 | 576 мс |
1 | 1 | 0 | 64 | 1,2 с |
1 | 1 | 1 | 128 | 2,3 с |
Дата: 2019-05-28, просмотров: 348.