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.


 

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

49228. Проектирование транзисторных широкодиапазонных передатчиков 348.61 KB
  В данном варианте курсовой работы применяется схема автогенератора с кварцевым резонатором в цепи обратной связи. В такой схеме кварцевый резонатор используется как высокодобротный последовательный контур.
49229. Проектирование транзисторных широкодиапазонных передатчиков 347.5 KB
  Автогенераторы являются первичными источниками колебаний, амплитуда и частота которых определяются только собственными параметрами схемы и должны в очень малой степени зависеть от внешних условий. В составе автогенератора обязательно должны быть генераторный прибор и колебательная система.
49230. Механические часы, показывающие текущее время 160.41 KB
  Целью работы также является проведение сравнительного анализа языков программирования. Сравнить языки потребуется как в общем, так и применительно поставленной задаче. Одной из подзадач является создание описание алгоритма программы и составление математической модели.
49231. Разработка программы ускоренных эквивалентных испытаний для подтверждения назначенного ресурса газотурбинных установок 70.86 KB
  Обоснование применения выбранного метода испытаний ГТУ. Расчет коэффициентов ускорения испытаний и времени испытаний. Программа испытаний на малоцикловую усталость.
49232. Гидравлический расчёт трубопровода 226.48 KB
  АЛЕКСЕЕВА НАЧНООБРАЗОВАТЕЛЬНЫЙ ИНСТИТУТ ЯДЕРНОЙ ЭНЕРГЕТИКИ И ТЕХНИЧЕСКОЙ ФИЗИКИ Кафедра ЯРиЭУ Гидравлический расчёт трубопровода наименование проекта ПОЯСНИТЕЛЬНАЯ ЗАПИСКА к курсовой работе КОНСУЛЬТАНТЫ: РУКОВОДИТЕЛЬ Содержание курсовой работы Теоретическая часть Заданная схема трубопровода 6 Исходные значения Выбор и...
49233. Игра “Зенитная установка” 191.25 KB
  Цель выполнения курсовой работы формирование представления о взаимосвязи различных стадий единого процесса проектирования сложных систем. В результате выполнения работы необходимо получить практические навыки реализации основных стадий разработки: системного анализа проектирования программирования и тестирования. В результате выполнения работы были реализованы основные стадии разработки программного средства имеющего признаки сложной системы : системный анализ ;...
49234. 20 разрядный аналого-цифровой преобразователь, изготовленный по технологии КМОП 0,9 пм 873.5 KB
  Традиционные конструкции аналого-цифровых преобразователей АЦП использовали параллельную архитектуру и биполярные технологии для получения 8битного разрешения для преобразования с частотой 20 выборок с. Для более чем 8битной конструкции АЦП параллельной архитектуры требуют больших запрещенных районов и большей потребляемой мощности. Несмотря на то что биполярные технологии используются для самых быстрых преобразований для создания многоступенчатого АЦП были так же использованы БиКМОП технологии которые обеспечивают...
49235. Застосування комп’ютерних технологій в управлінні кадрами підприємства для організації ефективної роботи служби управління персоналом 437.33 KB
  Отже питання продуманого управління персоналом повинні займати одне з ключових місць у загальній стратегії розвитку підприємства. Важлива роль в оптимізації управління співробітниками підприємства належить автоматизованим системам управління персоналом так званим Humn Resource systems. Розвиток ринкових відносин у країнах світового економічного співтовариства свідчить що успіх роботи підприємств визначається розробкою всіх компонентів їх систем управління одним з яких є управління персоналом. Одним із найбільш складних але й...
49236. Обход Шахматной Доски Конем 206.97 KB
  Для решения этой задачи на компьютере необходимо разработать правила, в соответствии с которыми компьютер будет выбирать ход. В принципе, очередной ход можно выбирать случайным образом