4892

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

Доклад

Информатика, кибернетика и программирование

Команды передачи управления Порядок выполнения команд в процессорах 80х86 и 80х88 определяется содержимым регистра сегмента кода (CS) и счетчика команд (IP). Регистр CS содержит базовый адрес текущего сегмента кода, т.е. 64-килобайтного фрагмента па...

Русский

2012-11-28

54.5 KB

12 чел.

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

Порядок выполнения команд в процессорах 80х86 и 80х88 определяется содержимым регистра сегмента кода (CS) и счетчика команд (IP). Регистр CS содержит базовый адрес текущего сегмента кода, т.е. 64-килобайтного фрагмента памяти, из которого в данный момент извлекаются коды команд. Содержимое счетчика команд IP используется как смещение относительно начала текущего сегмента кода. Содержимое CS и IP однозначно определяет то место в памяти, из которого будет извлечена следующая команда. Команда передачи управления (команды переходов) изменяют содержимое регистров CS и IP. Всего имеется три группы команд передачи управления: команды безусловного перехода, команды условного перехода и команды управления циклами.

Команды безусловного перехода

JMP (цель)

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

При внутрисегментной непосредственной команде JMP к счетчику команд IP добавляется смещение, указанное в команде. Если компилятор обнаруживает, что целевой адрес находится на расстоянии меньшем, чем 127 байтов от команды, он автоматически генерирует двухбайтовый вариант команды, называемый коротким переходом (SHORT JMP), в противном случае генерируется ближний переход (NEAR JMP), в котором диапазон перехода составляет плюс-минус 32К.

При внутрисегментной косвенной команде JMP смещение, добавляемое к регистру IP, может быть указано в памяти или в 16-разрядном регистре. В последнем случае значение смещение берется из регистра, указанного в команде.

При межсегментной непосредственной команде JMP значения IP и CS заменяются значениями, указанными в команде.

При межсегментной косвенной команде JMP значения IP и CS могут быть заменены только значениями расположенными в памяти. При этом первое слово двойного слова содержит смещение, второе слово – сегмент.

Команды условного перехода 

Команды условного перехода выполняют или не выполняют передачу управления на указанный адрес в зависимости от состояния флагов процессора не момент выполнения команды. Эти команды (см. таблицу ниже) проверяют различные комбинации флагов и условий. Если условие истинно, осуществляется передача управления на указанный адрес. Если условие неверно, управление передается команде, следующей за командой условного перехода. Все команды условного перехода являются короткими (SHORT), так что диапазон переходов в этих командах лежит в диапазоне от -128 до +127 байтов. При этом следует иметь в виду, что команде JMP 00h соответствует переход на следующую команду.

Таблица 8 Команды условного перехода

Мнемон.

Проверяемое условие

Переход, если ...

JA/JNBE

(CF or ZF) = 0

выше/не ниже или равно

JAE/JNB

CF = 0

выше или равно/не ниже

JB/JNAE

CF = 1

ниже/не выше или равно

JBE/JNA

(CF or ZF) = 1

ниже или равно/не выше

JC

CF  = 1

перенос

JE/JZ

ZF = 1

равно/нуль

JG/JNLE

[(SF xor OF) or ZF] = 0

больше/не меньше или равно

JGE/JNL

(SF xor OF) = 0

больше или равно/не меньше

JL/JNGE

(SF xor OF) = 1

меньше/не больше или равно

JLE/JNG

[(SF xor OF) or ZF] = 1

меньше или равно/не больше

JNC

CF = 0

нет переноса

JNE/JNZ

ZF = 0

не равно/не нуль

JNO

OF = 0

не переполнение

JNP/JPO

PF = 0

нечетно

JNS

SF = 0

не знак

JO

OF = 1

переполнение

JP/JPE

PF = 1

четно

JS

SF = 1

знак

JCXZ

CX=0

CX=0

Пример 1.

cmp AX,0 ;АХ=0?

je equal ;Если да, перейти на метку equal

ja above ;Переход на метку above,

  ;если содержимое АХ как число

;без знака превышает 0

Пример 2.

test AX,1

jne label1 ;Переход, если бит 0 в АХ ;установлен

Пример 3.

test DX,0FFFFh

jz label2  ;Переход, если DX=0

Циклы

LOOP

Циклическое выполнение, пока содержимое СХ не равно нулю. Команда LOOP выполняет декремент содержимого регистра СХ и если оно не равно 0 осуществляет переход на указанную метку вперед или назад в том же программном сегменте в диапазоне –128…+127 байт. Содержимое регистра СХ рассматривается как целое число без знака, поэтому максимальное число повторений последовательности команд в цикле составляет 65536.

Пример 1. Заполнение массива нулями

В сегменте данных:

mas DW 4096 dup(?)  ;Массив из 4096 слов

В сегменте кодов:

mov  BX, offset mas  

mov CX, 4096

mov AX,0

nulmas:

mov [BX], AX  

inc BX

inc BX

loop nulmas

Пример 2.

xor CX,CX

begin:…

loop begin

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

Пример.

mov CX, 10 ;Внешний счетчик повторений

outer:

push CX  ;Сохраним его в стеке

mov CX,0 ;64К шагов во внутреннем цикле

inner:

loop inner ;Тело внутреннего цикла

pop CX  ;Восстановим СХ перед командой loop

loop outer

LOOPE/LOOPZ

Команда выполняет декремент содержимого регистра СХ и если оно не равно 0 и флаг ZF установлен осуществляет переход на указанную метку вперед или назад в том же программном сегменте в диапазоне –128…+127 байт. Содержимое регистра СХ рассматривается как целое число без знака, поэтому максимальное число повторений последовательности команд в цикле составляет 65536.

LOOPNE/LOOPNZ

Команда выполняет декремент содержимого регистра СХ и если оно не равно 0 и флаг ZF сброшен осуществляет переход на указанную метку вперед или назад в том же программном сегменте в диапазоне –128…+127 байт. Содержимое регистра СХ рассматривается как целое число без знака, поэтому максимальное число повторений последовательности команд в цикле составляет 65536.


 

А также другие работы, которые могут Вас заинтересовать

8489. Поперечная рама стального каркаса здания 1.09 MB
  Поперечная рама стального каркаса здания Задание на курсовой проект Стальной каркас производственного здания Запроектировать поперечную раму стального каркаса одноэтажного здания по следующим исходным данным: длина здания L = 78 м...
8490. Автоматизированные информационные системы в экономике 2.03 MB
  Учебно-методическое пособие Автоматизированные информационные системы в экономике предназначено для студентов экономических специальностей высших учебных заведений. Рассматриваются информационные процессы в экономике, их состав и особенности функцио...
8491. Расчет электрических фильтров 2.56 MB
  Расчет электрических фильтров В задании предусмотрен расчет полосового фильтра для выделения главного лепестка спектра периодических радиоимпульсов. Фильтр рассчитывается в двух вариантах: пассивный LC-фильтр и активный RC-фильтр. Задание составлено...
8492. Программирование микроконтроллеров MCS-51 1007.5 KB
  Программирование микроконтроллеров MCS-51 Приведены технические характеристики и функциональные возможности популярных микроконтроллеров семейства MCS-51, выпускаемых ведущими компаниями мира. Рассмотрены особенности программной модели микроконтролл...
8493. Экономика и управление предприятием: Конспект лекций 2.45 MB
  Экономика и управление предприятием: Конспект лекций СОДЕРЖАНИЕ Тема 1. Предмет и задачи курса. Предмет курса. Задачи курса Тема 2. Место и роль организации (фирмы) в обществе. Роль организации (фирмы) в современном обществе. Производст...
8494. Материаловедение. Шпаргалка. Межатомное взаимодействие 2.4 MB
  Межатомное взаимодействие. Между двумя атомами действует сила притяжения. Природе является кулоновской, следовательно, она убывает обратно пропорционально квадрату расстояния между атомами. Помимо силы притяжения, между атомами действует и сила...
8495. Начертательная геометрия. Курст лекций 541.5 KB
  Введение в курс. Курс лекций Начертательная геометрия в которой рассматриваются следующие основные вопросы : 1) Построение изображений или чертежей предметов 2) Решение геометрических задач в пространстве при помощи чертежей на плоскости. Нач...
8496. Административно - правовая охрана общественной безопасности личности и общественного порядка 295.5 KB
  Административно - правовая охрана общественной безопасности личности и общественного порядка Введение Современные проблемы обеспечения административно-правовой охраны общественного порядка и общественной безопасности личности имеют комплексный, мног...
8497. Исследование P-N перехода 2.3 MB
  Исследование p-n перехода Методические указания содержат три основных раздела: теорию, описание экспериментальной установки и порядок выполнения работы. В теоретической части изложены: зонная теория электропроводности твердого тела, выпрямляющее дей...