Формат регистра IE управления масками прерывания

Символ Позиция Имя и назначение
ЕА IE.7 Снятие блокировки прерывания. Сбрасывается, программно для запрета всех прерываний независимо от состояний IE.4–IE.0
  IE.6 Не используется
  IE.5 Не используется
ES IE.4 Бит разрешения прерывания, от приемопередатчика Установка/сброс программой для разрешения/запрета прерываний от флагов TI или RI
ЕТ1 IE.3 Бит разрешения прерывания от таймера. Установка/сброс программой для разрешения/запрета прерываний от таймера 1
ЕХ1 IE.2 Бит разрешения внешнего прерывания 1. Установка/сброс программой для разрешения/запрета прерывания 1
ЕТО IE.1 Бит разрешения прерывания от таймера 0. Установка/сброс программой для разрешения/запрета прерываний от таймера 0
ЕХО IE.0 Бит разрешения внешнего прерывания 0. Установка/сброс программой для разрешения/запрета прерывания 0

Во встроенной области памяти данных с адреса 08h по начальному сбросу процессора размещается стек (ячейки стека адресуются восьмиразрядным указателем SP, который может быть загружен программно иным требуемым адресом размещения стековой области).

В шестнадцати ячейках встроенной области памяти данных (с адреса 20h по 2Fh) предусмотрена прямая битовая адресация.

Адресная область 80h-FFh занята встроенными, специализированными по назначению, регистрами с прямой адресацией доступа, а для части регистров и прямой адресацией доступа к их битам. Регистры специализированы по назначению для внешнего обмена данными (порты), для адресации ячеек дополнительной внешней памяти (в процессоре предусмотрены команды, инициирующие управление передачу и приём для работы дополнительной внешней памятью данных), для управления внутренними настройками процессора. Специализированные регистры ОМЭВМ разработчиками процессора названы «регистрами специальных функций (РСФ)». Знаком «*» на рис. 9.3 отмечены РСФ с битовой адресацией.

Встроенная память программ ОМЭВМ i80´51 имеет объём 4kб. Предусмотрены технические возможности блокировки обращений во встроенную память программ и разрешения выборки из внешней дополнительной памяти программ. В ОМЭВМ К1816ВЕ31 (отечественный аналог ОМЭВМ i80´31) стенда УС-51 встроенная память программ отсутствует и ОМЭВМ в составе стенда работает с внешней совмещенной оперативной памятью для команд программ и данных. Адресное пространство совмещённой памяти учебного стенда представлено областью 1000h-17FFh, 1800h-1FFFh для хранения программ и данных пользователя и областью 0000-0FFFh, занятой программой «Монитор» и другими служебными программами стенда.

В работе учитывается спецификация векторов прерывания базового процессора i8051, показанная на рис. 9.4.

Формат регистра IE управления масками прерывания - student2.ru

Рис. 9.4. Спецификация прерываний процессора i8051

Области прерываний с векторами 0003h и 0013h используются в стенде для собственных нужд, а области прерываний с векторами 000Вh, 001Вh, 0023 доступны для применения в программах приложений разрабатываемых пользователями стенда.

Подпрограмма обслуживания прерывания с входа INT0 (вектор 0003h) от встроенных кнопок имитации внешних прерываний I0,T0 размещена с адреса 26h нулевой страницы памяти программ.

Подпрограмма обслуживания прерывания с входа INT1 (вектор 0013h) от встроенного контроллера клавишного модуля и сегментного дисплея ОЭВМ размещена с адреса 02F1h.

Так как адресное пространство 0000-0FFFh, занято программой «Монитор» и другими служебными программами стенда, то начальные адреса программ обслуживания прерываний с векторами 000Вh, 001Вh, 0023 (от таймеров и встроенного модуля последовательного обмена данными с внешними устройствами) для программирования задач пользователя стенда переадресованы в область ОЗУ программ пользователя в следующем соответствии:

– прерывания со входа TF0 (000Bh на адрес 1753h);

– прерывания со входа TF1 (001Bh на адрес 1759h);

– прерывания со входа T1, R1 (0023h на адрес 175Ch).

Адрес области обработчика прерывания со входа TF0 соответствуют прерыванию от таймера T/C0 и, с учётом указанной выше переадресовки, начало программы обслуживания этого прерывания должно размещаться с адреса 1753h.

При подготовке программ учитывается специфика размещения кодов в ячейках памяти. Архитектурой процессора i8051 предусмотрено размещение трёхбайтовых команд в памяти программ последовательностью «код операции – старший байт числа команды – младший байт числа команды» (в отличие от принятой в для процессоров i8080, i8085, i8086 и их развитий). Принятая для стенда УС-51 спецификация приоритетов прерываний при подготовке программы управления по заданию не изменялась.

Программа управления

В соответствии с заданием на работу подготовлена программа управления, листинг которой представлен (алгоритм функционирования исполнители работы должны представить самостоятельно в отчёте).

Входными параметрами программы являются коды первого числа Х1=74h, которое должно быть набрано на переключателях SA8–SA1 стенда в прямом коде до запуска программы на исполнение и второго числа
Х2 = (принято 11h), которое должно быть установлено в течение первой паузы (в программе 10 с).

Выходными параметрами программы являются состояния индикаторов HL8–HL1 в соответствии с условиями задания.

Для достижения указанной длительности паузы таймер настраивается на 50000 счётных операций при длительности одной операции 2 мкс, что соответствует длительности счёта 0,1 с. Для счёта до 50000 в регистры TH0, TL0 следует загрузить число 1553610 (3CB0h). В программе в строке 5 установлен счётчик повтора таймерного цикла 100 раз. Настройка режима таймера, загрузка его счётчиков числом счётных операций, запуск счёта, разрешение прерывания от выбранного таймера и проверка завершения счёта таймерных циклов выполнены в основной программе управления. Обслуживание таймера сводится к перезагрузке счётчиков таймера и коррекции декрементом содержимого счётчика числа таймерных циклов.

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

Настройка режима таймера TMOD–11h. Статус TCON – битовая операция – «Разрешить счёт (set TR0)» / «Блокировать счёт (clr TR0)». Управление прерываниями – битовая операция – «Разрешить прерывание (set ET0)» / «Блокировать прерывание (clr ET0)». Загрузка старшего байта счёта в таймере -3C. Загрузка младшего байта счёта в таймере – B0.

Листинг программы:

1000 75 90 FF mov P1,# FF ; очистка буфера порта P1

1003 E5 90 mov A, P1 ; ввод с порта P1

1005 B4 76 3D cjne A,#76, 3D ;проверка Х1=74

1008 75 90 01 mov P1,#01 ; включение HL1

100b 74 64 mov A,#64 ; настройка числа повторов циклов

таймера в первой паузе

100d 75 89 11 mov TMOD, #11 ; таймер 0 в режим 1

1010 75 8C 3C mov TH0,# 3C ; загрузка таймера 0

1013 75 8A B0 mov TL0,# B0 ;

1016 D2 8C set TR0 ; разрешение счёта таймера 0

1018 D2 A9 set ET0 ; разрешение прерываний от таймера 0

101a B4 00 fd cjne A,#00, FD ; контроль завершения первой паузы 10 сек

101d C2 8C clr TR0 ; блокировка счёта импульсов в таймер 0

101f C2 A9 clr ET0 ; блокировка прерывания от таймера

1021 75 90 FF mov P1,# FF ; очистка буфера порта

1024 E5 90 mov A, P1 ; ввод с порта

1026 B4 11 27 cjne A,#11, 27 ; проверка Х2=11

1029 F 5 90 mov P1,A ; вывод Х2 для индикации

102b 74 C0 mov A,#C0 ; настройка числа циклов

; таймера 0 во второй паузе

102d 75 8C 3С mov TH0,# 3С ; загрузка таймера 0

1030 75 8A B0 mov TL0,# B0 ;

1033 D2 8C set TR0 ; разрешение счёта

1035 D2 A9 set ET0 ; разрешение прерываний от таймера 0

1037 B4 00 FD cjne A,#00, FD ; контроль завершения второй паузы 12 сек

103a C2 8C clr TR0 ; блокировка счёта импульсов в таймере 0

103c C2 A9 clr ET0 ; блокировка прерывания от таймера

103e 75 90 80 mov P1,#80 ; включение HL8 (оба числа опознаны)

1041 02 10 41 ljmp 1041 ; «пустой» цикл

1045 75 90 40 mov P1,#40 ; включение HL7 (неправильный набор Х1)

1048 02 10 48 ljmp 1048 ; «пустой» цикл

1050 75 90 20 mov P1,#20 ; включение HL6 (неправильный набор Х2)

1053 02 10 53 ljmp 1053 ; «пустой» цикл

1753 02 10 56 ljmp 1056 ; промежуточный переход к обработке

; прерывания от таймера Т0

Обработка прерывания:

1056 C2 8C clr TR0 ; блокировка подачи импульсов в таймер 0

1058 75 8C 3C mov TH0,# 3C ; загрузка таймера 0 (ст. байт)

105b 75 8A B0 mov TL0,# B0 ; младший байт

105e 14 dec A ; счёт повторов циклов таймера

105f D2 8C set TR0 ; разрешение счёта

1061 32 reti ; возврат из прерывания по таймеру.

Адреса программы управления и обработчика прерывания через ячейку 1753h приведены в листинге.

Объём программы – 91 байт.

Время выполнения программы определяется длительностью двух таймерных пауз.

Наши рекомендации