Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лекции.doc
Скачиваний:
288
Добавлен:
20.06.2014
Размер:
1.06 Mб
Скачать
          1. Устройство сравнения таймера t0

Структура устройства сравнения приведена на рис.

Рис. Структура устройства сравнения

8-битный компаратор непрерывно сравнивает счетный регистр TCNT0 с регистром OCR0 (Output Compare Register). Флаг OCF0 (Output Compare Flag) устанавливается в следующем такте после того, как значения TCNT0 и OCR0 станут равны. Если I=1 и OCIE0=1, OCF0 генерирует соответствующее прерывание. Флаг OCF0 сбрасывается после перехода к обработчику прерывания. Также он может быть сброшен программно записью в него логической единицы.

Генератор сигнала использует сигнал совпадения для генерации сигнала на выходе в соответствии с режимом генерации сигнала, заданным битами WGM01:0, и режимом работы выхода, заданным битами COM01:0 (Compare Output mode).

В режимах, отличных от ШИМ, выход OC0 может быть принудительно активирован установкой бита FOC0 (Force Output Compare) регистра TCCR0. При этом флаг OCF0 не устанавливается, таймер не сбрасывается и не перезапускается.

Запись процессором регистра TCNT0 блокирует сравнение на один такт, даже если таймер остановлен. Это позволяет инициализировать OCR0 тем же значением, что и TCNT0.

Рис. Схема формирования сигнала на выходе OC0

Бит OC0 должен быть предварительно настроен на вывод с помощью регистра направления порта B DDRB.

Режимы работы определяются комбинацией битов WGM01:0 (Waveform Generation mode) и COM01:0 (Compare Output mode) регистра TCCR0.

        1. Режимы работы таймера t0

          1. Режим Normal

Самый простой режим — Normal (WGM01:0 = 0). В этом режиме счетчик считает вверх и никогда не сбрасывается. Счетчик просто переходит через максимальное значение 0xFF к 0x00 и начинает счет заново. В этом режиме флаг переполнения TOV0 будет установлен в такте, когда TCNT0 станет равным нулю. Новое значение TCNT0 может быть записано в него в любой момент. Использовать сравнение для генерации сигнала в нормальном режиме не рекомендуется, поскольку это занимает слишком много процессорного времени.

          1. Режим ctc

В режиме CTC (рис.) (Clear Timer on Compare, сброс при совпадении) (WGM01:0 = 2) регистр OCR0 используется для управления разрешением счетчика, поскольку задает максимальное значение счета. В этом режиме TCNT0 сбрасывается, когда его значение становится равным OCR0. Этот режим удобен для управления частотой выходного сигнала и подсчета внешних событий.

Рис. Временная диаграмма режима CTC.

Горизонтальные штрихи на рисунке иллюстрируют совпадение значений регистров OCR0 и TCNT0.

При совпадении TCNT0 и OCR0 устанавливается флаг OCF0 и генерируется соответствующее прерывание. Обработчик прерывания может изменить значение OCR0.

Частота сигнала определяется следующей формулой:

,

где N — коэффициент деления частоты: 1, 8, 64, 256 или 1024.

Период сигнала может изменяться.

Прерывание по переполнению в этом режиме генерируется, если счетчик переходит максимальное значение.

Пример.

;осуществляется подсчет событий по входу T0

.include "m8535def.inc"

.equ cnt = 0x04

.org 0x000

rjmp RESET

.org 0x013

rjmp TIM0_COMP

.org 0x015

RESET: clr r17

ldi r18, 0x01

ser r16

out DDRB, r16

out DDRC, r16

ldi r16, low(RAMEND)

out spl, r16

ldi r16, high(RAMEND)

out sph, r16

ldi r16, cnt

out OCR0, r16

ldi r16, (1<<OCIE0)

out TIMSK, r16

ldi r16, 0x1E

out TCCR0, r16

sei

main: rjmp main

TIM0_COMP: in r19, SREG

out SREG, r18

rol r17

in r18, SREG

out PORTC, r17

out SREG, r19

reti