Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
ГОС 2015 - МПС.docx
Скачиваний:
174
Добавлен:
13.03.2016
Размер:
1.28 Mб
Скачать
  1. Для микроконтроллеров к1816ве51 или st7, stm8, stm32 поясните и продемонстрируйте примерами адресацию данных и команд, адресацию стека, выполнение косвенных переходов в программе.

К1816ВЕ51:

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

При косвенном способе адресации резидентной памяти данных используются все восемь битов адресных регистров R0 и R1и шестнадцати разрядный указатель DPTR.

Рис.11.1. Карта адресуемых битов в резидентной памяти данных

Символическая адресация

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

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

Например, символическое имя пятого бита аккумулятора будет следующим: АСС.5. Символические имена являются зарезервированными словами, и их не надо определять с помощью директив ассемблера.

Рис. 11.2. Карта адресуемых битов в блоке регистров специальных функций

Обращение к ВншОЗУ выполняется с помощью косвенной адресации с использованием специального регистра DPTR и только через аккумулятор:  MOVX @DPTR, A ; A -> M[DPTR]  MOVX A, @DPTR ; M[DPTR] -> A. 

Способы адресации операндов   В системе команд ОМЭВМ К1816ВЕ51 реализованы широкие возможности по адресации операндов, при этом наряду с традиционными способами расширены возможности по способам представления форматов данных. Используются следующие форматы:  - побитовый;  - потетрадный (4 бита);  - побайтный (8 бит);  - 16-разрядный.  Кроме основных способов адресации, добавлена базово-индексная адресация – разновидность косвенной адресации, когда в команде указываются источники двух частей адреса A+PC или A + DPTR. Часть адреса, находящаяся в аккумуляторе, воспринимается как смещение адреса с учетом знака, то есть смещение на +-128. Например,  MOVC A, @A + PC ; M[A + PC] -> A,   MOVC A, @A + DPTR ; M[A + DPTR] -> A. 

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

Команда JMP @А + DPTR позволяет передавать управление по косвенному адресу. Эта команда удобна тем, что предоставляет возможность организации перехода по адресу, вычисляемому самой программой и неизвестному при написании исходного текста программы.

8-битный указатель стека (SP) может адресовать любую область RDM. Его содержимое инкрементируется прежде, чем данные будут запомнены в стеке в ходе выполнения команд PUSH и CALL. Содержимое SP декрементируется после выполнения команд POP и RET. Подобный способ адресации элементов стека называют прединкрементным/постдекрементным. В процессе инициализации микроконтроллера после сигнала RST в SP автоматически загружается код 07Н. Это значит, что если прикладная программа не переопределяет стек, то первый элемент данных в стеке будет располагаться в ячейке RDM с адресом 08Н.

Двухбайтный регистр-указатель данных DPTR обычно используется для фиксации 16-битного адреса в операциях с обращением к внешней памяти. Командами микроконтроллера регистр-указатель данных может быть использован или как 16-битный регистр, или как два независимых 8-битных регистра (DPH и DPL).

  1. 12. Для микроконтроллеров К1816ВЕ51 или ST7, STM8, STM32 поясните и продемонстрируйте примерами доступность памятей программ и данных, регистров функциональных устройств, возможность выполнения битовых операций.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]