Сайт студентов АВТФ. ОМК КР1816ВЕ51/31

МИКРОКОНТРОЛЛЕР К1816 ВЕ51/31(INTEL 8051)

Рисунок 1 - Обобщенная структура однокристального микроконтроллера (ОМК):

Г - генератор; ССУ - схема синхронизации и управления; УР - управление режимом; СС и У - сигналы синхронизации и управления; МП - микропроцессор; РПЗУ/ППЗУ - репрограммируемое ПЗУ или программируемое ПЗУ; ОЗУ - оперативное запоминающее устройство; СА - системный адаптер; Т/С - таймер/счетчик; БОП - блок обработки прерываний; ПарПП - параллельные порты ввода/вывода; ПосПП - последовательные порты ввода/вывода; БАВВ - блок аналового ввода/вывода.

Архитектура МП реализует гарвардский принцип организации. Особенностью этой архитектуры является разделение общей памяти на память команд и память данных, при этом в ОМК используют раздельные команды для обращения к памяти и данным. Длина команды в машине фон Неймана ( принстонская организация) получается больше, т.к. используются общие способы адресации для команд и для данных. В то же время, число необходимых способов адресации для команд значительно меньше, чем для данных.

Применение раздельных команд существенно уменьшает длину каждой команды (при прочих равных условиях). Разделение памяти программ и данных при наличии двух независимых магистралей для обращения к ПЗУ программ и ОЗУ данных существенно упрощает организацию конвейерной обработки: после выборки очередной команды возможно одновременное обращение к ПЗУ за следующей командой и выборка данных из ОЗУ. В ОМК ВЕ51 раздельные магистрали не реализованы.

Рисунок 2 - Структура ОМК КР 1816 ВЕ51:

Р0-Р3 - двунаправленные восьми разрядные порты; СК - счетчик команд; РУД- регистр - указатель денных; РУС - регистр указателя стека; РА - регистр адреса; С/Т0 , С/Т1 - счетчик/таймер; ПА - последовательный адаптер; ССП - регистр слова состояния процессора; INT1, INT0 - входы внешних запросов прерываний; EA/VPP - отключение резидентной памяти программ (ЕА/РР)=0/ дополнительное питание +21В в режиме программирования резидентной памяти программ; RST/VPD - системный сброс/аварийное питание +5В в режиме пониженного энергопотребления; ALE/PROG - выход строба фиксации адреса внешней памяти / импульс программирования резидентной памяти программ; PSEN - чтение внешней памяти команд.

    Способы адресации:
  1. Резидентная память данных:
  2. Непосредственная внешняя память данных:
  3. Память команд:

Память данных.

Память данных представляет собой два независимых адресных пространства – резидентную память данных (РПД) и внешнюю память данных (ВПД), отличающиеся местом расположения и средствами доступа к данным.

Структура резидентной памяти данных.

РПД представляет собой единое адресное пространство. К каждой ячейке можно обратиться, используя прямую и косвенную адресацию. При прямой адресации в формате команды указывается непосредственный адрес ячейки; косвенная - реализуется через регистры R0, R1 каждого банка РОНов.

    РПД разделена на 3 зоны, каждая из которых имеет свои функциональные особенности:
  1. Зона блоков РОНов - состоит из 4-х банков. По сбросу активным является 0-ой банк. Номер банка устанавливается в слове состояния процессора. Достоинством этой зоны является возможность использования прямой регистровой адресации. Команды работы с регистрами 1 - байтовые и реализуются за 1 мкс;
  2. Свободная зона - особенностей по способам адресации не имеет.
  3. Зона РСФ - содержит основные регистры данных и управления:
  4. Битовая зона - особенности:

Таким образом, обращение к РПД по адресу 0Еh возможно: с использованием прямой адресации, косвенной, указав в регистре R0 или R1 любого банка этот адрес, прямой регистровой адресации, обращаясь к регистру R6 первого банка. Номер банка следует предварительно установить в PSW.

Обращение к РПД по адресу 20h возможно по прямому или косвенному адресу. Одновременно возможна обработка любого бита этой ячейки с использованием битовых команд. Адрес бита можно указать в виде 20.х, где х – номер бита или n, где n – прямой адрес битового пространства.

Подобные возможности позволяют минимизировать как длину кода программ, так и время их выполнения. Стек ВЕ51 располагается только в РПД. После сброса в SP записывается 7, а затем стек следует переопределить, чтобы освободить зону РОНов. Обычно стек реализуется в свободной зоне. Стек возрастающий. Автоматически в стек записывается или читается только счетчик адреса команд при работе с подпрограммами и выполнении процедуры обработки прерываний. В стек можно записать только содержимое РПД или РСФ . Если необходимо сохранить содержимое внешней памяти, его необходимо предварительно записать в РПД.

Структура памяти команд.

Пространство резидентной памяти команд (РПК) и внешней памяти едино. Обращение к внешнему ПЗУ осуществляется автоматически, если адрес больше чем 4К. Предусмотрена возможность отключения РПК подачей уровня логического 0 на вход EA/VPP.Этот режим обычно используется при отладке программного обеспечения.

Система команд.

1. Команды пересылки.

Команды этой группы не модифицируют признаки результата за исключением команды загрузки PSW и пересылок, в которых приемником результата является аккумулятор А. В этом случае устанавливается бит паритета и аппаратно формируется признак равенства 0 – Z=1, который можно использовать для выполнения команд условного перехода JZ (JNZ).

2. Команды обращения к ВПД.

Обращение к ВПК и ВПД осуществляется через регистр - указатель DPTR. Обращение к регистру возможно с помощью команды MOV DPTR,#d16, старший (DPH) и младший (DPL) байты этого регистра доступны через зону РСФ.

Обращение к памяти команд:

3. Арифметические операции.

При умножении старший байт результата записывается в регистр-расширитель В, а младший - в А. Если содержимое А>256, то формируется флаг арифметического переполнения OV. Бит С всегда сбрасывается.

При делении частное записывается в А, а остаток - в В. Флаги переноса C и арифметического переполнения OV сбрасываются. Если (А)<(В), то флаг дополнительного переноса (АС) не сбрасывается. При делении на 0 устанавливается флаг OV.

4. Логические команды.

5. Битовые команды (БК).

При выполнении БК бит С выполняет функции аккумулятора.

При работе с битами используется только прямая адресация.

6. Команды передачи управления.

Длинный безусловный переход и обращение к подпрограмме:

Абсолютные переходы:

Косвенные переходы:

Условные переходы:

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

При программировании в объектном коде адрес перехода вычисляется как:

rel:= адрес перехода - адрес команды перехода + длина команды перехода.

Битовые переходы:

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

Семафор представляет собой флаг, расположенный в памяти, информирующий о состоянии связанного с ним ресурса: 1 – свободен, 0 – занято. Захват ресурса допускается только в том случае, если он свободен. Затем семафор должен быть переведен в состояние "Занято". Ресурс – всякий объект, распределяемый системой.

В ОМК отсутствуют команды ввода-вывода. Обращение к внешним устройствам осуществляется как к ячейкам внешней памяти данных.

Признаки результата операций фиксируются в слове состояния процессора PSW. В этом слове содержатся поля , определяющие номер текущего банка РОНов, и флаг, функции которого определяются пользователем.

Таблица 1 - Формат слова состояния процессора:

7

6

5

4

3

2

1

0

C

АC

F0

RS1

RS0

OV

X

P

С - бит переноса (заема), устанавливается и сбрасывается аппаратно или программно при выполнении арифметических и логических операций; АС - бит вспомогательного переноса (заема) из третьего бита в четвертый; F0 - флаг пользователя, устанавливается, сбрасывается или проверяется программно; RS1,RS0 - выбор банка регистров; OV- бит арифметического переполнения; Р - бит паритета (четности).

Параллельные порты.

Порты Р0-Р3 предназначены для ввода или вывода байтовой информации и обеспечивают обмен с внешними устройствами: памятью программ и данных, контроллерами различного назначения, периферийными устройствами. Каждый из портов состоит из 8-разрядного регистра -защелки (РЗ) , выходного драйвера транзистора Т1, входных цепей и схемы Д1 с открытым коллектором. Схемотехника портов несколько отличается, так как они выполняют разные функции. Однако в упрощенном варианте её можно рассмотреть на примере рисунке 3.

Рисунок 3 - Упрощенный вариант схемотехники параллельных портов.

При чтении со входа порта Рх.Y данные через конъюнктор Д1 передаются на внутреннюю шину данных (ВШД), которая организована как "монтажное ИЛИ". Если в РЗ записана 1, то данные со входа порта без искажения передаются в приемник. Если РЗ=0, то в соответствующий разряд приемника будет записан 0 в независимости от значения сигнала.

При записи информации в порт, данные записываются в РЗ и выводятся через Т1 на выход порта. Обращение к портам возможно только по прямому адресу. Все разряды порта находятся в битовом пространстве. Порты однонаправленные. Каждый бит порта может быть настроен как на ввод, так и на вывод. По сбросу все порты устанавливаются на ввод. Для чтения данных из порта или регистра защелки используются различные команды.

Чтение РЗ осуществляется командами «чтение-модификация-запись», при выполнении которых команда считывает состояние РЗ, при необходимости модифицирует полученное значение и записывает результат обратно в РЗ:

Во всех случаях, когда операндом и регистром назначения является порт или бит порта, команды считывают информацию с выходов РЗ, а не с внешних контактов выводов порта.

Чтение информации с выходов РЗ, а не с внешних контактов позволяет исключить в ряде случаев неправильную интерпретацию уровня напряжения на выводе порта. Например, при соединении вывода порта с базой n-p-n транзистора и подаче лог. 1, транзистор открывается и чтение состояния внешнего вывода покажет лог.0, так как на контакте порта присутствует напряжение база-эммитер транзистора (0,7В). Чтение же РЗ подтвердит подачу лог. 1. Запись данных в порт осуществляется обычным способом: MOV Px,(A,Rn,@R0,#d).

Порты Р0, Р1, Р2, Р3 в зависимости от особенности применения могут реализовать разные функции. При работе с внешней памятью порт Р0 является системным портом, через который в режиме с разделением времени передаются младший байт адреса и данные. Появление младшего байта адреса сопровождается сигналом ALE , по которому он должен быть зафиксирован во внешнем регистре. Признаком работы Р0 в системном режиме является использование команд MOVX, MOVC.

При работе в качестве системного порта согласование (специальное) с нагрузкой не требуется. Если Р0 используется как порт общего назначения, то к выходу порта должен быть присоединен внешний подтягивающий резистор от источника питания +5В. Р1-Р3 имеют встроенную нагрузку.

Порт Р2 служит для вывода старшего байта адреса при работе в системном режиме. Особенностью порта Р2 является возможность мультиплексирования на выход содержимого РЗ или старшего байта адреса. При работе в режиме адресной шины содержимое РЗ сохраняется и поступает на выводы порта в тех машинных циклах, когда нет обращения к внешней памяти. При обращении к внешней памяти на выход порта выводится информация из регистра адреса DPTR или из программного счетчика РС по командам MOVC и MOVX .Исключение составляют команды MOVX A,@Ri, и MOVX @Ri,A, при которых на выходе находится содержимое регистра-защелки.

Нагрузочная способность Р0 - два входа ТТЛ, у остальных - один. Р1 - порт общего назначения и особенностей не имеет. Р3 - при записи в Р3 “1” выполняет системные функции.

Таблица 2 - Альтернетивные функции порта 3.

7

6

5

4

3

2

1

0

RD

WR

T1

T0

INT1

INT0

TxD

RxD

RD - чтение внешней памяти данных; WR- запись во внешнюю память данных; Т1,Т0 - входы таймера/счетчика; INT0, INT1 - входы запросов прерываний; TxD- выход передатчика последовательного порта; RxD - вход приемника последовательного порта.

Если в бит порта Р3 записан “0” , то на выходе порта фиксируется “0”.

При использовании порта Р3 необходимо учитывать функциональные особенности каждого входа: T1, T0, INT1, INT0 - входные линии, RD,WR, - выходные линии, сигналы на которых формируются только при выполнении команд MOVX, и так далее. Если не используются внешние прерывания и/или счетчики, то назначение этих линий определяет пользователь. Наиболее оптимально применение ВЕ51 в том случае, если отсутствуют устройства, для которых требуются внешние шины данных и адреса, так как в этом случае можно использовать произвольно порты Р0-Р2.

Счетчик/Таймер.

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

В состав ОМК входят два 16 разрядных суммирующих СТ. Счетчик состоит из регистров счетчика TL (младший байт), TH (старший байт), логики управления входными сигналами и триггера переполнения TF. Бит TF устанавливается при переходе счетчика из состояния все “1” во все “0”. Бит TF располагается в битовом пространстве и доступен по прямому адресу. Обращение к TLi, THi производится раздельно по прямым адресам.

Управление работой счетчика выполняется с помощью регистра режима работы TMOD и регистра управления - статуса TCON .

Рисунок 4 - Формат регистра режима таймера/счетчика TMOD:

GATE1, GATE0 - управление блокировкой (при GATEi=1 работа счетчика/таймера разрешается, если INT=1 и TRi=1 (см. рис.3.7.); если GATEi=0, то работа счетчика зависит только от состояния TRi; (i=1,0); С/Т1, С/Т0 - выбор режима работы (при С/Т=1 - работа в режиме счетчика от внешних сигналов на входе Ti; при С/Т=0 - работа в режиме таймера от внутреннего источника сигналов синхронизации); М1, М0 - задание основных режимов работы(см. таблицу).

В режиме таймера счетчик работает от внутреннего генератора с частотой OSC/12. При работе в режиме счетчика содержимое T/C инкрементируется под воздействием перехода из 1 в 0 внешнего сигнала, подаваемого на соответствующие входы Т0, Т1 порта Р3. Инкремент выполняется после анализа состояния “0” или ”1” на входе Тi, поэтому накладываются определенные ограничения на параметры преобразуемого сигнала: уровень 0 и 1 должен продолжаться не менее OSC/12. Максимальная преобразуемая внешняя частота - OSC / 24.

Способ запуска СТ устанавливается битом GATE: если GATE =1, то реализуется аппаратный запуск, при котором разрешение счета подается на вход INTi порта Р3 (уровень 1).

Предварительно должен быть установлен бит запуска счетчика TRi в регистре TCON.

При программном запуске GATE =0, начало счета задается установкой бита TRi =1.

Рисунок 5 - Формат регистра управления / статуса TCON:

TFi - флаги переполнения таймера, устанавливается аппаратно при переполнении счетчика/таймера, сбрасывается программно или аппаратно при обслуживании прерывания; TRi - биты управления таймером, устанавливается/сбрасывается программно для пуска/останова; ITi - биты управления видом сигнала запроса прерывания, при IТi=1прoграммируется прерывание по срезу импульса запроса, при ITi=0 - по низкому уровню; IEi - флаги запроса прерывания. Устанавливаются аппаратно от внешних запросов на входах INTi. Cбрасываются программно или аппаратно, если прерывание вызвано срезом импульса запроса( i= 0,1).

Рисунок 6 - Принцип работы счетчика/таймера в режимах “0, 1, 2”.

TL, TH - соответственно младший и старший байты счетчика; OSC/12 - выходная частота внутреннего генератора ОМК.

Режим работы каждого СТ определяется значением битов М0, М1 в регистре ТМОD. Счетчики могут быть настроены на один из 4 режимов. Режимы 0,1,2, одинаковы для обоих счетчиков и в этих режимах они полностью независимы. Работа ТС0 и ТС1 в режиме 3 различна. Режим 3 рационально использовать только для СТ0 . При этом установка СТ0 в режим 3 влияет на режим работы СТ1.

Режим 0: Режим 13-ти разрядного счетчика, состоящего из TНi и 5 младших разрядов TLi.

Режим 1: 16-ти разрядный счетчик , состоящий из THi и TLi.

Режим 2: В этом режиме СТ представляет собой 8-разрядный счетчик TLi . При каждом переполнении TLi кроме установки флага TFi происходит автоматическая загрузка содержимого THi в TLi .Требуемый коэффициент деления должен записываться одновременно в THi и TLi. В отличие от режимов 0 и 1 после установки флага переполнения коэффициент деления переписывается автоматически.

Режим 3: В этом режиме счетчик 0 функционирует как 2 независимых счетчика, а счетчик 1 заблокирован и просто сохраняет свой код (выполняет функции регистра). При этом можно настроить счетчик 1 на другие режимы. Режим 3 используется, если необходимо увеличить число действующих счетчиков до 3-х.

При работе в этом режиме ТС0 разделяется на два 8-ми разрядных счетчика, сформированных на базе регистров ТН0,ТL0. Счетчик ТН0 управляется битом ТR1 и формирует сигнал переполнения ТF1. Счетчик ТН0 может работать только в режиме таймера.

Установка ТС0 в режим 3 лишает ТС1 бита включения TR1. Поэтому ТС1 в режимах 0, 1, 2 при GATE=0 всегда включен и при переполнении в режимах 0 и 1 ТС1 обнуляется, а в режиме 2 перезагружается, не устанавливая флага, если ТС0 находится в режиме 3.

ТС1 аппаратно связан с блоком синхронизации последовательного порта. Поэтому в режимах 0,1,2 при переполнении ТС1 всегда вырабатывает импульс синхронизации последовательного порта.

Если ТС0 работает в режим 3, то ТС1 может быть настроен на режим 0,1 или 2, но при этом необходимо учитывать, что в процессе работы не формируется бит переполнения, а режим разрешения счета постоянно включен.

    Для настройки счетчика на требуемый режим необходимо:
  1. Задать требуемый коэффициент пересчета в регистры ТНi, ТLi.
  2. Задать режим работы в слове TMOD.
  3. При программном вводе-выводе замаскировать соответствующие прерывания от счетчика, а при использовании прерывания- их разрешить.
  4. Установить бит разрешения ТRi в слове TCON.

На базе СТ можно организовать преобразователи частоты, временного интервала, периода в код, генераторы и формирователи сигналов.

Однако необходимо учитывать, что TFi аппаратно недоступен, поэтому выходные сигналы следует формировать на выходах параллельных портов.

При измерении частоты методом среднего возможны два варианта формирования эталонного временного интервала Тэт. Аппаратная реализация предполагает подачу измеряемой частоты на вход Ti, а Тэт – на INTi.

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

Особенностью формирования выходных частотно-временных сигналов является отсутствие электрического выхода СТ. Поэтому сигналы формируются на свободных выходах портов Р0 – Р2 в момент установки TRi и TFi.

Последовательный порт.

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

Cтартовый бит

символ

бит паритета

стоповые биты

Обычно длина символов, бит паритета и стоповые биты задаются программно.

Достоинство такого обмена - повышеная достоверность передаваемой информации.

Недостатки:

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

При синхронном обмене информация передается посимвольно, с необязательным битом паритета. В некоторых случаях начало сообщения, его конец и адрес приемника кодируются специальными символами (символами синхронизации). Скорость синхронного обмена возрастает в 5-10 раз, по сравнению с асинхронным. Однако требуется дополнительная линия, к которой подключен ГТИ (генератор тактовых импульсов), общий для приемника и передатчика.

Последовательный порт ВЕ51 осуществляет прием/передачу информации в последовательном коде, младшими битами вперед в дуплексном режиме (одновременный прием и передача информации) или полудуплексном режимах. В состав последовательного канала входят принимающие и передающие сдвиговые регистры , специальный программно-доступный буфер SBUF, регистр управления SCON и логика управления каналом.

Запись байта в передатчик осуществляется автоматически, после того, как информация записана в SBUF. Чтение иформации выполняется из этого же регистра после установки флага готовности последовательного канала RI.

Последовательный канал может работать в следующих четырех режимах:

Режим "0" - cинхронный обмен в полудуплексном режиме с частотой OSC/12. Формат посылки - 8 бит. Данные принимаются и передаются через вход RxD, а частота синхронизации формируется на выходе TxD. В этом режиме порт работает как восьмиразрядный сдвиговый регистр.

Режим "1" - асинхронный обмен, десятибитовый кадр, состоящий из стартового (ноль), стопового (единица) битов и 8-разрядного символа. Cкорость приема и передачи определяется частотой переполнения счетчика С/ T1 . В зависимости от состояния бита SMOD регистра PCON частота, поступающая на вход схемы синхронизации последовательного канала с выхода С/Т1, может изменяться в два раза. Схема синхронизации делит эту частоту на 16 и использует её для приема/передачи последовательного кода.

При использовании этого режима следует запретить прерывание от С/Т1. При приеме стоп-бит заносится в бит RB8 регистра SCON.

Режим "2" - асинхронный 11-битовый кадр. По сравнению с режимом 1 добавлен программно устанавливаемый девятый бит.

Передаваемый девятый бит данных принимает значение бита TB8 из регистра управления SCON. Этот бит может быть программно установлен в 0 или 1. В частности, ТВ8 можно присвоить значение бита паритета Р из регистра PSW для повышения достоверности передаваемой информации. При приеме девятый бит данных поступает в бит RB8 регистра SCON. Cкорость передачи фиксирована и определяется значением бита SMOD регистра PCON: OSC/32 или OSC/64.

Режим "3" - аналогичен режиму "2", но скорость обмена задается счетчиком С/T1 как в режиме "1".

Основная настройка последовательного канала на требуемый режим работы производится в регистре SCON, в котором задается режим работы, значение 11-го бита, разрешение контроля 11-го бита (в режимах '2' и '3'), флаги готовности приемника и передатчика. Таблица 5 - Формат регистра управления/статуса универсального асинхронного приемопередатчика (УАПП) SCON.

 

7

6

5

4

3

2

1

0

SCON

SM0

SM1

SM2

REN

TB8

RB8

TI

RI

SMO,SM1 - биты управления режимом, устанавливаются/сбрасываются программно : SMO, SM1 = 00 - режим '0', SMO,SM1 = 01 - режим '1', SM0,SM1 = 10 - режим '2', SM0,SM1 = 11 - режим '3',SM2 - запрещение приема кадров с нулевым восьмым битом, в режиме '0' должен быть сброшен, устанавливается программно; RЕN - разрешения приема, устанавливается/сбрасывается программно; TB8 - восьмой бит передатчика в режимах '2' и '3'; RB8 - восьмой бит приемника в режимах '2' и '3', в режиме '1', если SM2=0, то отображает стоповый бит, в режиме '0' не используется; TI - флаг готовности передатчика, устанавливается аппаратно по окончании передачи байта, сбрасывается программно; RI - флаг готовности приемника, принцип работы аналогичен TI.

Скорость последовательного обмена в зависимости от режима работы определяется либо частотой работы ОМК ( режимы 0 и 2) либо частотой переполнения C/T1 (режимы 1 и 3).

В режимах 1-3 изменение частоты передачи информации в 2 раза обеспечивается битом SMOD регистра PCON.

В режиме '2' скорость задается частотой f=(osc/64)*2smod.

В режимах '1' и '3' - частотой f=(2smod)*fC/T1, fC/T1 - частота переполнения С/T1.

Таблица 6 - Формат регистра управления мощностью PCON.

 

7

6

5

4

3

2

1

0

PCON

SMOD

X

X

X

GF1

GF0

PD

IDL

SMOD - бит управления скоростью передачи УАПП, при SMOD = 1 скорость передачи вдвое больше, чем при SMOD = 0; GF1,GF2 - флаги общего назначения, устанавливаемые пользователем; PD - установка бита переводит ОМК в режим холостого хода.

Hаиболее удобен для использования в последовательном канале режим '2' счетчика/таймера С/Т1, если с его помощью можно обеспечить требуемую скорость передачи, так как в этом режиме не требуется перезагрузка коэффициента пересчета.

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

При реализации протоколов стандартных интерфейсов RS-232, RS-485 на выходе устанавливается специальная БИС, обеспечивающая соответствующее формирование сигнала.RS-232(-12B-'1', +12B-'0'), RS-485(5B). В качестве формирователей RS-232 можно использовать передатчики - К559ИП19, К170АП2, приемники - К559ИП20, К170УП2. Недостатком передатчиков этих схем является необходимость использования источников напряжения +/-12В. Лучшими характеристиками обладают формирователи MAX235, MAX221,242, которые питаются только от напряжения +5В и содержат в одном корпусе как приемники, так и передатчики.

Подсистема прерываний.

Рисунок 7 - Организация подсистемы прерываний.

Подсистема прерываний (ПП) реализована в виде двухуровневой подсистемы с пятью источниками запросов - 2 внешних (INT0,INT1), 2 прерывания от счетчиков TF0,TF1 и одно от последовательного канала(TI V RI ).

В качестве регистров запроса прерываний используются регистры TCON и SCON. В TCON хранятся биты переполнения счетчиков, которые сбрасываются автоматически при обращении к подпрограмме обработки прерываний, и флаги внешних прерываний. В SCON – флаги готовности последовательного порта.

Восприятие запроса по входам INTO,INT1 может быть программно установлено по уровню (ноль) или срезу (единица). Запрос по срезу предпочтительнее, так как сброс флага запроса прерываний реализуется автоматически при обращении к подпрограмме обработки прерываний; а в первом случае необходимы дополнительные программно-апппаратные средства для сброса запроса.

Последовательный порт имеет один вектор прерывания общий для TI и RI. Поэтому, в процедуре обработки прерываний, необходимо уточнять источник запроса методом поллинга. Прерывание можно вызвать также, если установить соответствующие флаги в регистрах TCON и SCON программно.

Управление подсистемой прерывания осуществляется при помощи регистра маски IE и регистра приоритетов IP.

Таблица 7- Формат регистра масок прерываний IE.

 

7

6

5

4

3

2

1

0

IE

EA

X

X

ES

ET1

EX1

ET0

EX0

EA - бит общего разрешения прерываний; ES - бит разрешения прерывания от флагов TI и RI; ETI,ET0 - биты разрешения прерываний от таймеров/счетчиков; EXI,EX0 - биты разрешения внешних прерываний INT1,INT0; 1 – прерывание разрешено, 0 – запрещено.

Каждому источнику запроса прерываний можно присвоить один из двух уровней приоритета сбросом или соответствующей установкой битов регистра IP.

Таблица 8 - Формат регистра приоритетов прерываний IP.

 

7

6

5

4

3

2

1

0

IP

X

X

X

PS

PT1

PX1

PT0

PX0

PS - бит приоритета последовательного канала; PTI,PTI0 - биты приоритета таймеров; PXI,PXO - биты приоритета внешних прерываний (1 - высший приоритет, 0 – низший).

Процедура обслуживания запроса с низким приоритетом может быть прервана запросом более высокого уровня. Прерывание отзапроса с высоким приоритетом не может быть остановлено никаким другим запросом. Для разрешения конфликтов одного уровня используется схема вторичного арбитража, устанавливающая следующие приоритеты: IE0(INT0) - высший; TF0, IE1(INT1), TF1, RI V TI - низший.

Запросы на прерывание могут быть приняты к обслуживанию в конце каждого командного цикла за исключением исполнения команды RETI и команд с любым обращением к регистрам IE и IP. Это обстоятельство гарантирует выполнение хотя бы еще одной инструкции после команд обращения к IE, IP, RETI, прежде чем возникнет новое прерывание. Эта особенность может быть использована для организации пошагового режима.

Если прерывание разрешено, то ОМК генерирует команду LCALL vect, где vect принимает значения:

IE0(INT0)

0003h

EXIT0

TF0

000Bh

TIMER0

IE1(INT1)

0013h

EXIT1

TF1

001Bh

TIMER1

RI V TI

0023h

SINT

По адресу вектора обычно располагается команда LJMP или LCALL с адресом начала подпрограммы обработки прерывания. Так как вектора располагаются в начальных адресах памяти, программы обработки прерываний следует располагать по адресам большим, чем 0026h.

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

Если число внешних источников запросов больше двух, то их можно объединить по ИЛИ на входах INT0 и INT1. Дальнейшая обработка запросов производится методом поллинга. Наиболее просто это реализуется по схеме «Монтажное ИЛИ» (открытый коллектор или открытый сток). Дополнительно потребуется регистр запросов прерывания, в качестве которого может использоваться свободный параллельный порт или его часть.

Если вместо RETI использовать RET, то повторное прерывание по этому входу не будет выполнено

Особые режимы работы.

Сброс.

Сброс осуществляется подачей лог.1 на вход RST и должен удерживаться в этом состоянии не менее 24/OSC. Под действием сброса обнуляются регистры PC, FC, PSW, DPTR, TMOD, TCON, T/C0, T/C1, IE, IP, SCON, в регистре PCON сбрасываеся только только старший бит, в регистр SP загружается код 07h, а порты P0-P3 - коды FFH. Состояние регистра SBUF неопределенное. Сигнал сброс не воздействует на содержимое РПД. Когда включается питание, состояние РПД неопределннное, за исключением операции возврата из режима пониженного энергопотребления.

Режим холостого хода.

ОМК работает в этом режиме, если бит PCON.0 установлен. При этом продолжает работать внутренний генератор, но блокируются функциональные узлы ЦП, что уменьшает энергопотребление на 15 – 30 %. Все регистры и РПД сохраняют свои значения, а на выводах ALE и PSEN формируется уровень единицы. Выйти из этого режима можно по сбросу или по прерыванию.

По любому из этих действий бит PCON.0 сбрасывается и продолжится работа ОМК с той команды, перед которой был установлен режим холостого хода.

Режим пониженного энергопотребления.

Переход в этот режим возможен, если установить бит PCON.1. В этом режиме внутренний генератор прекращает работу и сохраняется только содержимое РПД. Поэтому необходимые регистры спецфункций предварительно следует сохранять в РПД.

Резервное питание должно поступать через вывод RST/VPD. Напряжение основного источника питания может быть уменьшено до 2 В.

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

В ОМК 1830ВЕ51 при номинальном токе потребления 18 мА это значение снижается в режиме холостого хода до 4,2 мА, а в режиме пониженного энергопотребления – до 50 мкА.

Выход из режима возможен только по сигналу сброса, который должен удерживаться в активном состоянии не менее 10 мс (время восстановления работы задающего генератора). При одновременной записи PCON.0 и PCON.1 преимущество имеет PCON.1.

Режимы холостого хода и пониженного энергоптребления поддерживаются не всеми ОМК и эту ситуацию необходимо контролировать.

Защита от падения напряжения.

При немгновенных отказах электропитания ОМК можно обеспечить сохранность содержимого РПД с помощью батарейного питания, присоединенного к выводам RST/VPD. Для этого ОМК, получив сообщение о грозящем отключении, должен перезагрузить необходимые параметры в РПД и перейти в режим пониженного энергопотребления. После восстановления номинального напряжения выполняется системный сброс и источник аварийного питания может быть отключен.

Режим загрузки и верификации программ.

Под воздействием внешних электрических сигналов в ОМК может быть записано требуемое программное обеспечение. Для ПЗУ с ультрафиолетовым стиранием (УФ) информации его необходимо предварительно очистить, поместив ОМК под источник УФ с длиной волны менее 4х10-7 м. Программирование осуществляется на частоте внутреннего генератора 4 –6 МГц. Адрес, по которому осуществляется программирование, задается через порт 1 и выводы Р2.0 – Р2.3, а данные должны быть поданы на вход порта Р0. В процедуре программирования задействованы и другие выводы ОМК. В процессе программирования необходимо формировать определенную временную диаграмму и иметь дополнительный источник импульсных сигналов амплитудой 21+/-0,5 В.

В процессе программирования можно установить бит защиты, который запрещает доступ к резидентной памяти программ любыми внешними средствами. Бит защиты можно сбросить только путем полного стирания содержимого памяти под источником УФ.

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