
- •28 Структура и система команд микроконтроллера 0k01816вм51 ( Intel 08051)0 Структурная организация и система команд микроконтроллера км1816ве51
- •3.1. Структурная схема mk51
- •3.1.1. Арифметическо- логическое устройство
- •3.1.2. Резидентная память
- •3.1.3. Устройство управления и синхронизации
- •3.2. Порты ввода/вывода информации
- •Т а б л и ц а 3.3. Альтернативные функции порта 3
- •3.3. Доступ к внешней памяти
- •3.5. Последовательный интерфейс
- •3.5.1. Регистр управления/статуса uart
- •3.5.2. Работа uart в мультимикроконтроллерных системах
- •3.5.4. Особенности работы uart в различных режимах
- •3.6. Система прерываний
- •3.7. Особые режимы работы mk51
- •3.7.1. Режим загрузки и верификации прикладных программ
- •3.7.2. Работа мк51 в пошаговом режиме
- •3.7.3. Сброс, режим холостого хода и режим пониженного энергопотребления
- •3.8. Система команд mk51
- •3.8.1. Общие сведения о системе команд
- •3.8.2. Группа команд передачи данных
- •3.8.3. Группа команд арифметических операций
- •3.8.4. Группа команд логических операций
- •3.8.5. Группа команд операций с битами
- •3.8.6. Группа команд передачи управления
3.8.2. Группа команд передачи данных
Большую часть команд данной группы (табл. 3.12) составляют команды передачи и обмена байтов. Команды пересылки бит представлены в группе команд битовых операций. Все команды данной группы не модифицируют флаги результата, за исключением команд загрузки PSW и аккумулятора (флаг паритета).
Структура информационных связей. В зависимости от способа адресации и места расположения операнда можно выделить девять типов операндов, между которыми возможен информационный обмен. Граф возможных операций передачи данных показан на рис. 3.22. Аккумулятор (А) представлен на этом графе отдельной вершиной, так как многие команды используют неявную (подразумеваемую) адресацию.
Аккумулятор. В отличие от МК48 обращение к аккумулятору может быть выполнено в МК51 с использованием неявной и прямой адресации.
В зависимости от способа адресации аккумулятора применяется одно из символических имен: А или ACC (прямой адрес). При прямой адресации обращение к аккумулятору производится как к одному из РСФ, и его адрес указывается во втором байте команды.
Использование неявной адресации аккумулятора предпочтительнее, однако не всегда возможно. например при обращении к отдельным битам аккумулятора.
Обращение к внешней памяти данных. Режим косвенной адресации ВПД, имеющийся в МК48, реализован также и в МК51. При использовании команд MOVX @Ri обеспечивается доступ к 256 байтам внешней памяти данных.
Существует также режим обращения к расширенной ВПД, когда для доступа используется 16-битный адрес, хранящийся в регистре-указателе данных (DPTR). Команды MOVX @DPTR обеспечивают доступ к 65 536 байтам ВПД.
3.8.3. Группа команд арифметических операций
Данную группу образуют 24 команды (табл. 3.13), выполняющие операции сложения, десятичной коррекции, инкремента/декремента байтов. Дополнительно по сравнению с МК48 введены команды вычитания, умножения и деления байтов.
Команды ADD и ADDC аналогичны командам сложения МК48, но допускают сложение аккумулятора с большим числом операндов. Аналогично командам ADDC существуют четыре команды SUBB, что позволяет более просто, чем в МК48, производить вычитание байтов и многобайтных двоичных чисел. В МК51 реализуется расширенный (по сравнению с МК48) список команд инкремента/декремента байтов, введена команда инкремента 16-битного регистра-указателя данных.
3.8.4. Группа команд логических операций
Данную группу образуют 25 команд (табл. 3.14), реализующих те же логические операции над байтами, что и в МК48. Однако в МК51 значительно расширено число типов операндов, участвующих в операциях. В отличие от МК48 имеется возможность производить операцию "исключающее ИЛИ" с содержимым портов. Команда XRL может быть эффективно использована для инверсии отдельных бит портов.
3.8.5. Группа команд операций с битами
Отличительной особенностью данной группы команд (табл. 3.15) является то, что они оперируют с однобитными операндами. В качестве таких операндов могут выступать отдельные биты некоторых регистров специальных функций (РСФ) и портов, а также 128 программных флагов пользователя.
Существуют команды сброса (CLR), установки (SETB) и инверсии (CPL) бит, а также конъюнкции и дизъюнкции бита и флага переноса. Для адресации бит используется прямой восьмиразрядный адрес (bit). Косвенная адресация бит невозможна.