Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

Лабник

.pdf
Скачиваний:
16
Добавлен:
31.03.2015
Размер:
656.87 Кб
Скачать

Варианты заданий

 

Таблица 2.1

 

 

 

 

 

№ варианта

№ Канала

Период квантования

 

 

мультиплексора

сигнала, мкс

 

1

6

440

 

2

5

400

 

3

4

380

 

4

3

340

 

5

2

300

 

6

1

280

 

7

2

200

 

8

4

320

 

9

5

240

 

10

3

420

 

11

7

260

 

12

8

300

 

13

1

340

 

14

4

200

 

15

8

400

23

Ла б о р а то р н а я р а б о та № 3

СИНХРОНИЗАЦИЯ ОПЕРАЦИЙ РЕАЛЬНОГО ВРЕМЕНИ В АВТОМАТИЗИРОВАННЫХ СИСТЕМАХ НА ОСНОВЕ ЭВМ СЕМЕЙСТВА IBM

Цель работы – изучение типовых аппаратных средств синхронизации работы устройств ввода-вывода в автоматизированной системе на основе ЭВМ семейства IBM PC и управления работой элементов системы в реальном времени.

3.1. Принципы работы программируемых интервальных таймеров

Программируемые интервальные таймеры (ПИТ) предназначены для синхронизации работы элементов автоматизированной системы во времени, формирования временных интервалов, измерения длительности импульсов, частоты и периода сигналов, деления частоты сигналов, подсчета числа импульсов за прошедшее время.

В общем случае таймер представляет собой логическое устройство с регистром, хранящим текущее значение счета, и тремя или более входами/выходами.

Обобщенная функциональная схема ПИТ (рис. 3.1.) включает регистр счетчика, 2 входа и 1 выход.

CLK

 

 

CLK

вход

 

 

 

импульсов

 

 

 

 

 

 

 

 

Регистр счетчика

OUT

синхронизации.

 

GATE

входные

GATE

 

 

 

 

 

ворота.

 

 

Рис. 3.1. Обобщенная функциональная схема ПИТ

 

 

OUT – выход ПИТ.

Импульсы на входе CLK подсчитываются счетчиком. При появлении фронта каждого входного импульса, счетчик увеличивает или уменьшает содержимое регистра счетчика. В регистр счетчика можно предварительно записать некоторое значение константы пересчета. Содержимое регистра счетчика можно прочитать и оно всегда отражает текущее число импульсов, поступившее на вход CLK.

Вход GATE служит для управления счетом: GATE=1, разрешает счет, GATE=0, запрещает счет.

Выход OUT переключается в зависимости от выбранного режима работы. Содержимое регистра счетчика уменьшается с каждым импульсом на входе CLK, выход OUT переключается, когда счетчик достигает нулевого значения. Это значение счетчика называется terminal count – конец счета.

Выход таймера OUT подключаются к устройствам ввода-вывода для

24

инициирования необходимых действий.

3.2. Техническое описание ПИТ Intel 8254 (8253)

ПИТ строятся на основе функционально ориентированных программно управляемых интерфейсных БИС, в частности на микросхемах Intel 8254 (8253).

к ШД

D7-D0

RD,

к ШУ WR

к ША

A1, A0

CS

Счетчик 0

Регистр управляющего байта CBR (8 разрядов)

Внутренний регистр состояния SR (8 разрядов)

Выходной регистр состояния SL (8 разрядов)

Входной регистр счетчика CR (16 разрядов)

CR M (8 разрядов)

CR L (8 разрядов)

 

 

Счетный элемент CE (16 разрядов)

CE M (8 Разрядов)

CE L (8 разрядов)

Выходной регистр счетчика OL (16 разрядов)

OL M (8 разрядов)

OL L (8 разрядов)

Счетчик 1

Счетчик 2

CLK 0 GATE0 OUT 0

CLK 1 GATE1 OUT 1

CLK 2 GATE2

OUT 2

Рис. 3.2. Функциональная схема программируемого интервального таймера

Подключение ПИТ к автоматизированной системе (рис.3.2.) осуществляется по общим правилам подключения интерфейсных БИС к системной магистрали микропроцессорной системы.

Назначение выводов микросхемы:

-D7–DO двунаправленные трех стабильные (с тремя состояниями) выводы данных. Подключаются к шине данных ЭВМ для приема управляющей информации от процессора и передачи статусной информации процессору.

-RD, ⌐WR – входы сигналов управления чтение, запись, активный уровень сигнала – низкий. Подключаются к линиям ввод (⌐IOR), вывод

25

(⌐IOW) для приема от ЦП сигналов чтения, записи регистров ПИТ.

-⌐CS – вход, выбор кристалла 0/1– разрешает/запрещает связь ПИТ с системной шиной. CS подключается к ША посредством дешифратора адреса.

-A1,A0 – адресные входы подключаются к соответствующим адресным линиям магистрали для адресации внутренних регистров ПИТ.

Каналы счетчика таймера подключаются к внешним устройствам при помощи трех линий (CLK, GATE, OUT):

-CLK0–CLK2 – входы тактовых сигналов каждого из каналов используются для управления счетным элементом CE и определяют скорость счета. Фронт сигнала приводит к уменьшению содержимого счетного элемента на единицу;

-GATE0–GATE2 – управляющие входы запуска, останова и перезапуска счета для 3-х каналов ПИТ, в соответствии с установленным режимом работы;

-OUT0OUT2 – выходы счетчиков переключаются при достижении счетчиком значения 0.

Технические характеристики ПИТ

1.Число независимых каналов – 3.

2.Число режимов каждого канала – 6.

3.Разрешение каждого канала – 16 бит с диапазоном счета от 65535 до 0.

4.Максимальная частота счета – 8 МГц (2 МГц для Intel 8253).

5.Формат счета импульсов – двоичный или двоично-десятичный.

3.3.Назначение регистров и методика управления таймером

Карта программно доступных регистров ПИТ, тип доступа ЦП к регистрам, их разрядность и относительные адреса (относительно базового) приведены в табл. 3.1.

Таблица 3.1.

Название регистра

 

Разряд

Тип

Относительный адрес

 

 

ность

доступ

Канал

Канал

Канал

 

 

 

а

0

1

2

Входной регистр счетчика

CR

16

запись

0

1

2

Выходной регистр счетчика

OL

16

чтение

0

1

2

Выходной регистр состояния

SL

8

чтение

0

1

2

Регистр управляющего байта CBR

8

запись

3

3

3

На магистрали автоматизированной системы ПИТ занимает 4 адреса.

Регистр управляющего байта (адрес 3) CBR (Control Byte Register),

определяет режим работы канала таймера. CBR доступен ЦП для записи, для любого канала. Номер канала должен задаваться в самом формате

26

управляющего байта. Формат регистра CBR (Табл. 3.2.):

Таблица 3.2.

Номер бита

7

6

5

4

3

2

 

1

0

Назначение бита

SC

RW

 

MODE

 

BCD

Поле BCD (binary coded decimal) определяет формат счета счетного элемента: 0 – двоичный, 1 – двоично-десятичный. В двоичном формате константа задается в диапазоне 0 – 65535, в двоично-десятичном – в диапазоне 0-9999. Значение константы счета N=0 во всех режимах интерпретируется как 216 или 104 в зависимости от формата счета.

Поле MODE определяет режим работы канала:

-000 – (режим 0) прерывание от таймера (Interrupt on Terminal Count),

-001 – (режим 1) программируемый ждущий мультивибратор

(Programmable One-Shot),

-Х10 – (режим 2) импульсный генератор частоты (Rate Generator),

-Х11 – (режим 3) генератор меандра (Square Wave Generator),

-100 – (режим 4) программно запускаемый одно вибратор

(Software Triggering Strobe),

-101 – (режим 5) аппаратно запускаемый одно вибратор

(Hardware Triggering Strobe).

Поле RW определяет порядок загрузки констант в регистр CR через однобайтовый порт, порядок считывания содержимого регистра OL, а также команду фиксации текущего содержимого счетного элемента CE:

-01 – запись (чтение) младшего байта,

-10 – запись (чтение) старшего байта (константа задается одним байтом – младшим или старшим),

-11 - запись (чтение) младшего, затем старшего байта,

-00 – команда CLO (Counter Latch Operation) фиксация текущего значения счетного элемента CE в выходном регистре счетчика OL.

Формат команды CLO (Табл. 3.3.):

Номер бита

7

6

5

4

3

2

1

0

Назначение бита

SC

0

0

Х

Х

Х

Х

Здесь 00 – код команды CLO, SC – канал, биты – Х не используются. Поле SC (Select Counter) определяет номер канала, для которого предназначено управляющее слово или команду чтения состояния

таймера:

-00 – канал 0, - 01 – канал 1, - 10 – канал 2,

-11– команда чтение состояния таймера RBC (read backward count) для Intel 8254, запрещено для Intel 8253.

Информация из выходного регистра счетчика OL может быть считана процессором без приостановки счета в любое время.

27

Формат команды чтение состояния таймера RBC:

Номер

7

6

5

4

3

2

1

0

Значение

1

1

Count

Status

CNT2

CNT1

CNT0

0

Биты:

-7,6 - код команды чтение состояния RBC,

-Count - указывает, должны ли защелкиваться выходные регистры счетчиков: 0/1 – защелкнуть / не защелкивать,

-Status - определяет необходимость защелкивания выходных регистров состояния: 0/1 – защелкнуть / не защелкивать,

-CNT2, CNT1, CNT0 - задают каналы таймера, для которых выполняется защелкивание выходных регистров: 1/0 – выполнить / не выполнять операцию.

Внутренний регистр состояния SR (Status Register), хранит режим работы канала таймера, состояние выхода OUT и состояние счетчика. Регистр 8 разрядный, для ЦП не доступен.

Выходной регистр состояния SL (Status Latch), 8 разрядный,

процессору доступен для чтения, предназначен для чтения текущего состояния таймера (только в Intel 8254). Информация из SR может переписываться в SL по команде чтение состояния таймера RBC. Формат байта состояния канала (только в Intel 8254):

Номер

7

6

5

 

4

3

2

1

0

Значение

OUT

Count

 

RW

 

Mode

 

BCD

Биты:

-OUT – определяет состояние выхода канала таймера: 1/0 – высокий/низкий уровень.

-Count – описывает состояние счетчика: 0/1 – выходной регистр счетчика отражает текущее значение счетного элемента канала / неопределенное состояние (например, когда счет в канале не выполняется).

-Остальные биты – аналогичны соответствующим битам, задаваемым в управляющем байте при инициализации канала.

Входной регистр счетчика CR (Count Register), 16 разрядный,

доступен ЦП для записи, предназначен для хранения начального значения счетчика канала – константы пересчета. Содержимое CR может загружаться в CE для счета, если это требуется в текущем режиме работы таймера.

Счетный элемент CE (Counting Element) 16 разрядов, процессору не доступен, работает в режиме вычитания. Содержимое СЕ уменьшается по заднему фронту сигнала CKL при условии, что на входе GATE установлен уровень логической 1. Счетный элемент CE может загружаться из входного регистра счетчика CR и считываться посредством передачи его содержимого в выходной регистр счетчика OL. В зависимости от режима

28

работы ПИТ, при достижении счетным элементом нуля тем или иным образом изменяется выходной сигнал OUT.

Выходной регистр счетчика OL (Output Latch), 16 разрядный,

всегда доступен ЦП для чтения, сопровождает счетный элемент при работе канала. Выходной регистр счетчика может использоваться для запоминания текущего содержимого счетного элемента CE без остановки процесса счета.

Режимы работы таймера разделяются на три группы по правилам загрузки счетного элемента CE содержимым входного регистра счетчика CR.

1) Режимы 0, 4 - однократное выполнение функций.

При GATE=1 константы из CR передаются в CE по первому тактовому импульсу CLK. С приходом последующих импульсов на вход CLK происходит уменьшение содержимого CE. Если во время счета на вход GATE подать 0, то это приведет к останову счета. Новый положительный сигнал GATE (не вызывает перезагрузку счетного элемента, а только) разрешает продолжение счета. По окончании счета выполнение действий заканчивается. При необходимости повторения функции требуется новое программирование – загрузка новой константы пересчета. После достижения нулевого значения счет не прекращается, а продолжается с переходом через 0 (т.е. 65535) Далее содержимое счетчика уменьшается на 1 на каждом такте CLK.

2) Режимы 1, 5 - работа с перезапуском.

Для них характерна возможность повторения запрограммированных функций без перепрограммирования. Загруженная константа сохраняется в CR, а ее передача в CE осуществляется по переднему фронту сигнала на входе GATE независимо от завершения счета. После загрузки управляющего слова CBR на выходе OUT устанавливается высокий уровень сигнала OUT=1. Загрузка константы в счетный элемент CE выполнится при положительном фронте сигнала на входе GATE . Каждый фронт сигнала на входе GATE приводит к загрузке счетного элемента CE из входного регистра CR.

3) Режимы 2, 3 - работа с автозагрузкой.

Здесь регистр CR автоматически переписывается в регистр CE после завершения счета. Эти режимы используются для создания импульсных генераторов и генераторов меандра. При GATE=1 на выходе OUT формируются импульсы: частотой FOUT = FCLK / N, или, соответственно, с периодом TOUT = TCLK*N.

29

При GATE=0 на выходе OUT устанавливается напряжение высокого уровня и счет приостанавливается. При GATE=1 счет продолжается. Перезагрузка канала новой константой не влияет на текущий счет. Новый счет начинается по окончании предыдущего.

Управление ПИТ включает:

1.Инициализацию одного или нескольких каналов.

2.Чтение текущего значения счетного элемента канала таймера.

3.Чтение состояния таймера (только Intel 8254).

Инициализация ПИТ включает:

-Запись управляющих байтов, определяющих режимы работы каналов, в регистр управляющего байта CBR.

-Запись констант пересчета во входные регистры счетчиков CR. Управляющие слова загружаются в один тот же регистр CBR. Адрес

канала указывается в самом формате управляющего байта. Управляющие слова каналов сохраняются во все время работы до следующего программирования. Константа пересчета может быть задана одним байтом (младшим или старшим) или 16-разрядным словом, как определено в поле RW управляющего байта. Константа пересчета загружается во входной регистр счетчика CR выбранного канала. В процессе работы канала константа пересчета может загружаться многократно, если это необходимо по условиям функционирования канала.

Общие обязательные требования при инициализации канала:

1.Загрузка регистра управляющего байта CBR должна опережать загрузку константы пересчета.

2.Загрузка константы пересчета во входной регистр счетчика CR всегда

должна выполняться до конца, как это определено полем RW.

Сразу после инициализации канала, таймер начнет выполнять заданную функцию.

Чтение текущего значения счетного элемента CE.

Существуют следующие варианты чтения содержимого счетного элемента. В процессе работы ПИТ внутренний счетный элемент CE любого канала отображается в выходной регистр счетчика OL. Это означает, что содержимое выходного регистра счетчика идентично содержимому внутреннего счетного элемента. Выходной регистр счетчика можно читать в любой момент времени. При таком чтении считывается младший байт счетчика, либо старший байт (если константа задана в виде одного байта), либо сначала младший, а затем старший байты (если константа задана в виде 16-и разрядного слова), как это определено режимом чтения-записи, указанном в управляющем байте канала при его инициализации.

30

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

Рекомендуется, следующие способы чтения счетчика канала таймера: 1) Приостановка работы канала с помощью сигнала GATE=0 и

считывание значения выходного регистра счетчика OL.

2) Чтение по команде CLO ("Защелка") позволяет прочитать состояние CE в любой момент времени без остановки счета.

После загрузки команды CLO "Защелка", операция чтения выполняется так же, как в предыдущем случае. Фактически команда CLO защелкивает выходной регистр счетчика OL и он перестает сопровождать счетный элемент. Выходной регистр счетчика OL остается в таком состоянии до тех пор, пока не будет считан или пока соответствующий канал не будет перепрограммирован. Информация из OL может быть считана в любое время. Сразу после чтения выходного регистра счетчика (одного или двух байтов), регистр автоматически расщелкивается, т.е. возвращается в состояние сопровождения внутреннего счетного элемента.

Чтение состояния таймера (только Intel 8254).

Команда позволяет прочитать следующие параметры любого канала или нескольких каналов: текущее значение регистра состояния SR, из выходного регистра состояния SL и текущее значение счетного элемента CE (еще один вариант чтения счетного элемента) из выходного регистра счетчика.

При выполнении команды чтения состояния (табл. 3.4), содержимое внутреннего регистра состояния SR заносится в выходной регистр состояния SL, а значение счетного элемента защелкивается в выходном регистре счетчика OL. Команда чтения состояния может быть выполнена для нескольких каналов одновременно.

Пример: Запись в регистр управляющего байта (табл. 3.4.) значения CEh (11001110) – защелкивает выходные регистры счетчиков и выходные регистры состояния всех каналов.

Сразу после записи в регистр управляющего байта команды чтения состояния RBC для каждого из указанных каналов таймера выполняются следующие действия:

-в выходные регистры состояния каналов заносится информация о состоянии каналов;

-в выходных регистрах счетчиков защелкиваются текущие значения счетных элементов.

Выходные регистры канала остаются в таком состоянии до тех пор, пока не будут считаны или пока соответствующий канал не будет

31

перепрограммирован.

Считывание выполняется из адреса регистра канала. Сначала считывается значение из выходного регистра состояния (если было запрошено чтение состояния), а затем из выходного регистра счетчика (если было запрошено защелкивание этого регистра).

3.4. Системный таймер ЭВМ семейства IBM PC

ВЭВМ семейства IBM PC в качестве системного таймера применена микросхема Intel 8254 (рис. 3.3).

 

 

 

 

 

 

 

“1”

 

 

 

Адрес 40h

 

 

 

 

 

 

 

GATE 0

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Генератор

 

CNT 0

 

 

 

OUT 0 На вход IR0

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

1.193182 МГц

 

 

 

 

 

 

 

CLK0

 

CLK0

 

 

 

 

 

 

 

 

 

 

 

 

GATE 1

 

Адрес 41h

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

CNT 1

 

 

 

OUT 1 Регенерация ОЗУ

 

 

 

 

 

 

 

CLK 1

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

CLK 2

 

Адрес 42h

OUT 2

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

GATE 2

 

CNT 2

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

61h

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

7

6

 

5

 

4

 

3

2

1

 

0

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Управляющий

регистр

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Рис. 3.3. Схема включения ПИТ Intel 8254 в ЭВМ семейства IBM PC

Базовый адрес ПИТ в пространстве адресов ввода-вывода ЭВМ равен 40h. Адреса регистров каналов ПИТ принимают значения: 40h – канал 0 , 41h – канал 1, 42h – канал 2, 43h CBR.

Входы CLK всех каналов подсоединены к выходу генератора импульсов F=1,193182 МГц, на входы GATE каналов 0 и 1 подан разрешающий потенциал – разрешен счет.

Выход OUT нулевого канала соединен с линией IRO программируемого контроллера прерываний и вырабатывает прерывание таймера (номер типа прерывания 8). При инициализации канала он программируется BIOS для работы в режиме 3 (или 2) с двухбайтовым начальным значением счетчика равным N=0. При таком режиме период таймера составляет Т0 ~55мс.

Канал 0 таймера используется для отсчета текущего времени в системных часах времени суток, а также для синхронизации некоторых дисковых операций.

32