- •Введение
- •1. Архитектура однокристальных микроконтроллеров семейства мк-51
- •1.1. Структура микроконтроллера мк-51
- •1.2. Организация памяти
- •Рассмотрим организацию памяти подробнее на примере мк к1816ве51.
- •Память данных
- •1.3.Система прерываний
- •1.4. Блок таймеров/счетчиков
- •1.5. Блок последовательного интерфейса
- •1.6 .Система команд микроконтроллера мк-51
- •2. Описания лабораторных работ работа 1. Принципы работы битового процессора в составе мк-51
- •Введение
- •Постановка задачи и варианты ее решения
- •Варианты заданий
- •Работа 2. Организация ввода-вывода информации в микроконтроллере
- •Введение
- •Постановка задачи и варианты ее решения
- •Порядок подготовки к лабораторной работе
- •Порядок выполнения лабораторной работы
- •Пример подготовки к выполнению лабораторной работы
- •Варианты заданий
- •Работа 3. СистеМа прерываНия
- •Введение
- •Постановка задачи и варианты ее решения
- •Порядок подготовки к лабораторной работе
- •Порядок выполнения лабораторной работы
- •Пример подготовки к выполнению лабораторной работы
- •Варианты заданий
- •Работа 4. Реализация времязадающих функций. Формирование временной диаграммы логических сигналов
- •Введение
- •Постановка задачи и варианты ее решения
- •Порядок подготовки к лабораторной работе
- •Порядок выполнения лабораторной работы
- •Пример подготовки к выполнению лабораторной работы
- •Wait1: mov th0,#0d8h ;настройка таймера на отсчет 10 мс
- •Варианты заданий
- •Работа 5. Реализация времязадающих
- •Варианты заданий
- •Работа 6. Микроконтроллер в системе управления
- •Введение
- •Постановка задачи и варианты ее решения
- •Порядок подготовки к лабораторной работе
- •Порядок выполнения лабораторной работы
- •Пример подготовки к выполнению лабораторной работы
- •Работа 7. Использование блока последовательного интерфейса в работе Микроконтроллера
- •Введение
- •Постановка задачи и варианты ее решения
- •Порядок подготовки к лабораторной работе
- •Порядок выполнения лабораторной работы
- •Пример подготовки к выполнению лабораторной работы
- •Варианты заданий
- •Список литератуРы
- •Содержание
- •115409 Москва, Каширское шоссе, 31
Постановка задачи и варианты ее решения
Микроконтроллер выдает на выход P0.2 значение логической функции f(x,y) от аргументов x и y, поступающих по линиям P0.1 и P0.0 соответственно. Опрос значения аргументов производится каждые T мкс.
При поступлении сигнала прерывания на вход INT0 микроконтроллер через последовательный порт обменивается массивом данных с внешним устройством. Во время обмена обработка логических переменных не производится. Обмен информацией сопровождается контролем по четности каждого передаваемого байта. Контрольный разряд представляет собой дополнение до нечетного числа единиц в байте.
В режимах 0 и 1 при выводе контрольный разряд должен формироваться программно по значению семи младших разрядов байта и записываться в старший бит передаваемого байта. При вводе проводится проверка правильности каждого принятого байта путем сравнения формируемого программно контрольного разряда с 7-м битом принятого байта.
В режимах 2 и 3 для хранения контрольного разряда используются биты TB8 и RB8 регистра SCON.
При обнаружении ошибки в принятой информации микроконтроллер выдает на линию P0.3 сигнал высокого уровня и блокирует запрос по входу INT0 на обмен.
Вид и скорость обмена, режим работы последовательного интерфейса, длина и начальный адрес передаваемого массива, период опроса значений x и y, а также вид вычисляемой логической функции задаются в индивидуальном варианте задания.
В режимах 1 и 3 реализация стандартных скоростей обмена может быть достигнута программированием таймера/счетчика T/C1 согласно таблице.
Реализация стандартных скоростей обмена
Скорость обмена, Кбод |
fBQ, МГц |
SMOD |
Разряды TMOD |
TH1 |
Примеч. | ||
C/T |
M1 |
M0 | |||||
62,5 |
12 |
1 |
0 |
1 |
0 |
FFh |
|
19,2 |
11,059 |
1 |
0 |
1 |
0 |
FDh |
|
9,6 |
11,059 |
0 |
0 |
1 |
0 |
FDh |
|
4,8 |
11,059 |
0 |
0 |
1 |
0 |
FAh |
|
2,4 |
11,059 |
0 |
0 |
1 |
0 |
EAh |
|
1,2 |
11,059 |
0 |
0 |
1 |
0 |
E8h |
|
0,1375 |
11,986 |
0 |
0 |
1 |
0 |
18h |
|
0,110 |
6 |
0 |
0 |
1 |
0 |
72h |
|
0,110 |
12 |
0 |
0 |
0 |
1 |
FEh |
TL1=EBh |
Порядок подготовки к лабораторной работе
Изучить пример подготовки к выполнению работы.
Составить программу на языке ассемблера МК-51.
Порядок выполнения лабораторной работы
Отладить подготовленную программу.
Продемонстрировать работу отлаженной программы преподавателю.
Ответить на вопросы преподавателя.
Пример подготовки к выполнению лабораторной работы
Подготовку к лабораторной работе разберем на примере двух вариантов заданий.
Вариант 27. Согласно варианту микроконтроллер каждые 120 мкс считывает значения X и Y и вычисляет логическую функцию ^Xv^Y. По сигналу прерывания INT0 микроконтроллер выводит в 3-м режиме массив информации длиной четыре байта, расположенный в памяти данных, начиная с адреса 70H. Скорость вывода – 110 бод.
Так как основная задача микроконтроллера – вычисление значения логической функции через определенный интервал времени, то отсчет этого интервала проводится с помощью таймера/счетчика T/C0, работающего в режиме 2 (автозагрузка). При этом состояние его флага переполнения анализируется программно. В режиме 3 работы последовательного порта скорость передачи определяется частотой переполнения таймера/счетчика T/C1. Особенностью данного варианта является то, что необходимая частота синхронизации не может быть обеспечена таймером/счетчиком T/C1, работающим в режиме автозагрузки, если микроконтроллер работает при максимальной допустимой частоте внешней синхронизации fBQ = 12 МГц. Поэтому восстановление состояния T/C1 проводится программно в обработчике прерывания от этого таймера/счетчика.
Разработаем требуемую программу. Ее текст с необходимыми комментариями приведен ниже.
Программа
.ORG 0H
AJMP START
.ORG 03H
AJMP SBRINT0
.ORG 1BH
AJMP SBRTC1
.ORG 30H
;разрешение прерываний от INT0 и TC1, запрет всех прерываний
START: MOV IE,#00001001b
;сбpос флагов, останов Т/С, INT0 по срезу
MOV TCON,#00000001b
MOV TMOD,#00010001b ;настройка Т/С0
MOV TL0,#136 ;256-120=136
MOV TH0,#136
; настройка Т/С1 для обеспечения скорости передачи 110 бод
MOV TL1,#0EBH
MOV TH1,#0FEH
ANL PCON,#01111111b ;SMOD=0
MOV P0,#00000011b
SETB EA ;pазpешение пpеpываний
ORL TCON, #01010000b ;запуск таймеров/счетчиков
; вычисление логической функции
CYCL: JNB TF0,$ ; задержка на 120 мкс
CLR TF0
MOV C,P0.0
CPL C
ORL C,/P0.1
MOV P0.2,C
AJMP CYCL
; обработчик прерывания на вывод массива
SBRINT0: MOV R0,#70H ;начальный адрес массива
MOV R1,#4 ;длина массива
OUT: MOV A,@R0
MOV C,P
CPL C
MOV TB8,C
JNB TI,$
CLR TI
MOV SBUF,@R0
INC R0
DJNZ R1,OUT
RETI
; обработчик прерывания от T/C1
SBRTC1: MOV TL1,#0EBH ;восстановление настройки T/C1
MOV TH1,#0FEH
RETI
.END
Вариант 28. Согласно варианту микроконтроллер каждые 200 мкс считывает значения X и Y и вычисляет логическую функцию ^X/^Y. По сигналу прерывания INT0 микроконтроллер вводит в 1-м режиме массив информации длиной два байта в память данных, начиная с адреса 20 H. Скорость вывода – 62500 бод.
Текст программы данного варианта с необходимыми комментариями приведен ниже.
Программа
.ORG 0H
AJMP START
.ORG 03H
AJMP SBRINT0
.ORG 30H
;разрешение прерываний от INT0, запрет всех прерываний
START: MOV IE,#0000001b
;сбpос флагов, останов Т/С, INT0 по срезу
MOV TCON,#00000001b
;T/C1 в режиме 2, T/C0 в режиме 2
MOV TMOD,#00100010b
MOV TL0,#56 ;256-200=56
MOV TH0,#56
; настройка на скорость передачи 62500 бод
MOV TL1,#0FFH
MOV TH1,#0FFH
ORL PCON,#10000000B ;SMOD=1
MOV P0,#00000011b
SETB REN ;разрешение ввода по RxD
SETB EA ;pазpешение пpеpываний
ORL TCON, #01010000b ; запуск таймеров/счетчиков
; вычисление логической функции
CYCL: JNB TF0,$ ; задержка на 200 мкс
CLR TF0
MOVC,P0.0
CPL C
ANL C,/P0.1
CPL C
MOV P0.2,C
AJMP CYCL
; обработчик прерывания на ввод массива
SBRINT0: MOV R0,#20 ;начальный адрес массива
MOV R1,#2 ;длина массива
IN: JNB RI,$
MOV A,SBUF
JB P,M `;переход, если ошибки нет
SETB P0.2
M: MOV @R0,A
CLR RI
INC R0
DJNZ R1,IN
RETI
.END