15281

Застосування асемблерних команд передачі управління. Алгоритми їх виконання

Лабораторная работа

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

Лабораторна робота № 6 Тема: Команди і директиви мови Асемблер. Мета роботи: Набути навичок застосування асемблерних команд передачі управління. Засвоїти алгоритми їх виконання. Короткі теорет

Украинкский

2013-06-11

110.5 KB

12 чел.

PAGE  7

Лабораторна робота № 6

Тема: Команди і директиви мови Асемблер.

Мета роботи: Набути навичок застосування асемблерних команд передачі управління. Засвоїти  алгоритми їх виконання.                                  

 

  1.  Короткі теоретичні відомості

  1.  Команди передачі управління

До цієї групи відносяться команди, які дозволяють контролювати процес виконання програми. Це команди переходів. Розрізняють команди безумовного переходу і команди переходу за умовою.

Безумовний перехід. Базовою командою, що передає керування в іншу точку програми, є команда JMP. Команда має наступний синтаксис:

JMP label,

де label -  це мітка, яка позначається іменем і знаком “:” після нього.

Ім’я мітки – це набір знаків, проте, ім’я  не може починатися з цифри. Нижче приведені приклади  правильних імен міток

label1:
label2:
a:

Мітка може записуватися в окремій стрічці тексту програми або перед командою, наприклад

x1:
MOV AX, 1

x2: MOV AX, 2

Команда JMP забезпечує передачу керування як вперед так і назад. Проте, перехід (стрибок) може здійснюватися тільки в межах сегменту (65,535 байт).

 Короткий перехід за умовою. На відміну від команди JMP, що забезпечує безумовний перехід, є команди, що забезпечують перехід тільки при виконанні певної умови. Такі команди поділяються на три групи. До першої груп відносяться команди, що аналізують один прапорець регістру стану. До другої групи відносяться команди, що порівнюють числа як знакові, і до третьої групи відносяться команди, що порівнюють числа як беззнакові.  

В табл..1 наведені команди першої групи.

Треба відмітити, що є деякі команди, які мають різні назви, проте дизасемблюються в один і той самий машинний код, наприклад, команда JE дизасемблюється як JZ,  команда JC дизасемблюється як JB. Різні назви використовують для кращого розуміння тексту програми.

Таблиця 1 – Команди переходу за умовою, що тестують один прапорець

Команда

Опис

Стан прапорця

Протилежна команда

JZ , JE

Перехід, якщо нуль (Zero) (рівно (Equal))

 ZF = 1

JNZ, JNE

JC , JB, JNAE

Перехід, якщо перенос (Carry) (менше (Below), не більше рівно (Not Above Equal))

 CF = 1

JNC, JNB, JAE

JS

Перехід, якщо знак (Sign)

 SF = 1

JNS

JO

Перехід, якщо переповнення (Overflow)

 OF = 1

JNO

JPE, JP

Перехід, якщо паритет парний (Parity Even)

 PF = 1

JPO

JNZ , JNE

Перехід, якщо не нуль (Not Zero) (не рівно (Not Equal))

 ZF = 0

JZ, JE

JNC, JNB, JAE

Перехід, якщо не перенос (NotCarry) (не менше (Not Below), більше рівно (Above Equal))

 CF = 0

JC, JB, JNAE

JNS

Перехід, якщо не знак (Not Sign)

 SF = 0

JS

JNO

Перехід, якщо не переповнення (Not Overflow)

 OF = 0

JO

JPO, JNP

Перехід, якщо паритет непарний (Parity Odd) (немає паритету (No Parity))

 PF = 0

JPE, JP

В табл.2 представлені команди переходів для знакових чисел.

Таблиця 2 – Команди переходів для знакових чисел

Команда

Опис

Стан прапорця

Протилежна команда

JE , JZ

Перехід, якщо рівно (Equal) (=)
Перехід, якщо нуль (Zero)

ZF = 1

JNE, JNZ

JNE , JNZ

Перехід, якщо не рівно (Not Equal) (<>)
Перехід, якщо не нуль (Not Zero)

ZF = 0

JE, JZ

JG , JNLE

Перехід, якщо більше (Greater) (>)
Перехід, якщо не менше рівно (Not Less or Equal) (not <=).

ZF = 0
and
SF = OF

JNG, JLE

JL , JNGE

Перехід, якщо менше (Less) (<).
Перехід, якщо не більше рівно (Not Greater or Equal) (not >=).

SF <> OF

JNL, JGE

JGE , JNL

Перехід, якщо більше рівно (Greater or Equal) (>=).
Перехід, якщо не менше (Not Less) (not <).

SF = OF

JNGE, JL

JLE , JNG

Перехід, якщо менше рівно (Less or Equal) (<=).
Перехід, якщо не більше (Not Greater) (not >).

ZF = 1
or
SF <> OF

JNLE, JG

Примітка: <> - цей знак означає «не рівно».

В табл. 3 представлені команди переходів для беззнакових чисел.

Таблиця 3 – Команди переходів для беззнакових чисел

Команда

Опис

Стан прапорця

Протилежна команда

JE , JZ

Перехід, якщо рівно (Equal) (=)
Jump if Zero.

ZF = 1

JNE, JNZ

JNE , JNZ

Перехід, якщо не рівно (Not Equal) (<>)
Перехід, якщо не нуль (Not Zero)

ZF = 0

JE, JZ

JA , JNBE

Перехід, якщо більше (Above) (>)
Перехід, якщо не менше рівно (Not Below or Equal) (not <=).

CF = 0
and
ZF = 0

JNA, JBE

JB , JNAE, JC

Перехід, якщо менше (Below) (<).
Перехід, якщо не більше рівно (Not Above or Equal) (not >=)
Перехід, якщо перенос (Carry)

CF = 1

JNB, JAE, JNC

JAE , JNB, JNC

Перехід, якщо більше рівно (Above or Equal) (>=).
Перехід, якщо не менше (Not Below) (not <).
Перехід, якщо не перенос (Not Carry)

CF = 0

JNAE, JB

JBE , JNA

Перехід, якщо менше рівно (Below or Equal) (<=)
Перехід, якщо не більше (Not Above) (not >)

CF = 1
or
ZF = 1

JNBE, JA

  1.  Постановка завдання

  1.  Використовуючи середовище емулятора МП і8086, створити проект асемблерної програми відповідно до індивідуального завдання за нижченаведеним прикладом програми (для кожної заданої команди скористатися прикладом використання команди переходу з брошури «Система команд МП i8086»):

include 'emu8086.inc'

ORG 100h

  MOV AL, 5

  CMP AL, 5

  JZ  M1

  PRINT 'AL<>5.'

  JMP M2

M1:

  PRINT 'AL=5.'

M2:

 MOV AL, 10000000b   ; AL = -128

  OR  AL, 0           ; встановлює прапорець SF=1

  JS M3

  PRINT не знак.'

  JMP M4

M3:

  PRINT 'знак.'

M4:

   MOV AL, 2

  ADD AL, 3

  JNC  M5

  PRINT 'has carry.'

  JMP M6

M5:

  PRINT 'no carry.'

M6:

  RET

END.

  1.  Використовуючи середовище емулятора дослідити алгоритм виконання команд переходів для різних значень операндів в командах, що передують командам переходів та впливають на стан відповідних прапорців.
    1.  На основі досліджень п.2.2 скласти алгоритм виконання програми, в якому привести значення прапорців, що аналізуються відповідними командами переходів.  

Приклад складання фрагменту алгоритму вищенаведеної програми:

  1.  Варіанти індивідуальних завдань

  1.  Варіанти індивідуальних завдань до даної лабораторної роботи наведені у табл.. 4.

Таблиця 4 – Варіанти індивідуальних завдань

№ варіанту

Команди

1

2

3

4

5

6

7

1

JZ

JS

JNC

JG

JNL

JA

JNC

2

JE

JC

JNS

JL

JNZ

JBE

JNAE

3

JC

JO

JNE

JGE

JNLE

JAE

JNBE

4

JB

JP

JNZ

JE

JNGE

JA

JNE

5

JS

JZ

JNO

JLE

JNG

JB

JNA

6

JO

JB

JNGE

JG

JNLE

JA

JNA

7

JP

JE

JNS

JL

JNGE

JBE

JNC

8

JS

JB

JAE

JGE

JNG

JZ

JNAE

9

JC

JS

JNAE

JE

JNL

JA

JNBE

10

JO

JZ

JNC

JLE

JNZ

JB

JNE

11

JP

JE

JNZ

JG

JNL

JAE

JNA

12

JZ

JO

JNE

JL

JNZ

JBE

JNC

13

JB

JP

JNE

JGE

JNLE

JZ

JNAE

14

JE

JC

JNO

JL

JNGE

JA

JNBE

15

JC

JB

JNE

JLE

JNG

JE

JNC

16

JO

JE

JNZ

JG

JNLE

JAE

JNA

Примітка: для команд 4-ї та 5-ї колонок в командах, що передують їх застосуванню, треба використовувати знакові числа.

  1.  Методичні вказівки

  1.  Увійти в середовище емулятора Emu8086.
    1.  Створити новий проект типу “com” під власним іменем.
    2.  У створеному проекті набрати текст програми відповідно до п.2.1 і індивідуального завдання.
    3.  Скомпілювати створений проект.
    4.  Проаналізувати повідомлення про помилки, якщо такі мають місце. Записати повідомлення у звіт до лабораторної роботи. Пояснити причини виникнення помилок і вказати шляхи їх усунення.
    5.  Після успішного завершення процедури компілювання проекту перейти до аналізу роботи створеної програми відповідно до п.п.2.2 і 2.3.
    6.  В процесі аналізу роботи програми контролювати і записувати зміну значень прапорців при виконанні команд, що впливають на їх значення.

  1.  Зміст звіту

  1.  Назва теми.
    1.  Мета роботи.
    2.  Індивідуальне завдання.
    3.  Текст програми.
    4.  Алгоритм роботи програми відповідно до п.2.3.
    5.  Відповіді на контрольні запитання.
    6.  Висновки, в яких дати характеристику досліджуваних команд.

  1.  Контрольні запитання
    1.  Які є типи команд переходів?
    2.  В яких межах забезпечується перехід командою JMP?
    3.  Що розуміють під коротким переходом?
    4.  Яким чином виконуються команди переходів за умовою?
    5.  Наведіть приклади команд, що впливають на стан прапорців регістру F.

  1.  Джерела інформації
    1.  Ю.І. Якименко, Т.О. Терещенко, Є.І. Сокол та ін. Мікропроцесорна техніка: Підручник. – Київ. – ІВЦ «Видавництво «Політехніка». – 2004. – 439 с.
    2.  Юров В., Хорошенко С. Assembler: учебный курс – СПб: Питер Ком, 1999. – 672 с.


Початок

L5

AL=5 ?

Ні

Так

Друк

AL=5

Друк

AL<>5

AL10000000b


 

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

15616. ФИЛОСОФИЯ БЕЗОПАСНОСТИ СИБИРИ И ДАЛЬНЕГО ВОСТОКА РОССИИ В СВЕТЕ БОРЬБЫ ЦИВИЛИЗАЦИЙ 66 KB
  Философия безопасности Сибири и Дальнего Востока России в свете борьбы цивилизаций Переход к легальной рыночной экономике ускорил центробежные силы разрывающие Россию. Если на юге страны использовались военные и идеологические орудия развала государства то на Дал
15617. НОВАЯ ТЕОСОФИЯ КАК ФИЛОСОФИЯ ГЛОБАЛЬНОЙ БЕЗОПАСНОСТИ РОССИИ 133 KB
  НОВАЯ ТЕОСОФИЯ КАК Философия ГЛОБАЛЬНОЙ безопасности России Землетрясения и цунами вызвавшие радиоактивную катастрофу на Японских островах в марте 2011 г. свидетельствуют о начале глобальной природнотехногенной катастрофы. Кризис индустриальной цивилизации прояв...
15618. Принципы нравственной экономики 53 KB
  Принципы нравственной экономики Потребность в новой экономике обусловлена усиливающимся цивилизационным кризисом [1]. Методологической основой для создания концепции нравственной экономики может служить нравственнорелигиозный неоинституционализм разработанны
15619. КИТАЙСКИЙ, ИНДИЙСКИЙ И ЯПОНСКИЙ ПРОЕКТЫ ДЛЯ ГЕОПОЛИТИКИ И ГЕОЭКОНОМИКИ РОССИИ 218.5 KB
  КИТАЙСКИЙ ИНДИЙСКИЙ И ЯПОНСКИЙ ПРОЕКТЫ ДЛЯ ГЕОПОЛИТИКИ И ГЕОЭКОНОМИКИ РОССИИ Переход к легальной рыночной экономике ускорил центробежные силы разрывающие Россию. Если на юге страны использовались военные и идеологические орудия развала государства то на Дальнем
15620. Культура, кризис, этика и эстетика 38 KB
  Культура кризис этика и эстетика Темы для обсуждения предложены две: насчёт того переживает ли нынешняя культура кризис и вторая об этическом и эстетическом в современной культуре. Ничего существенного я не могу сказать ни на первую тему ни на вторую. Потому что ч...
15621. Das Prinzip verum factum: seine theologische Pramisse bei Nikolaus von Kues 41.5 KB
  Das Prinzip verumfactum: seine theologische Pramisse bei Nikolaus von Kues Das Tatsachlichkeit der Wahrheit heutzutage ist etwas dass versteht sich von selbst. Dass die Wahrheit gewissermassen erzeugt ist davon man sagt seitdem am Morgen der Philosophie war klargestellt dass obgleich die Wahrheit von sich selbst existiert denn seine Stellung in die Sprache in dem Urteil von Wahrheit ist. Das bei uns aus Latein angekommende Faktum hat vor langer Zeit derUntersch...
15622. Николай Кузанский и философия эпохи культуры 58 KB
  Николай Кузанский и философия эпохи культуры слишком обширная тема если считать что эпоха культуры это всё Новое время. Я попытаюсь эскизно очертить только один сюжет из этой большой темы правда он один из главных. Речь пойдёт об истоках новоевропейского г
15623. Бог был для мира не сим одним 109.5 KB
  Бог был для мира не сим одним Бог был для мира не сим одним не причиною только бытия но сотворил как благий полезное как премудрый прекраснейшее как могущественный величайшее Василий Великий. Беседы на Шестоднев.1 Всё дальнейшее будет попыткой комментария...
15624. Время событий и событие времени 43.5 KB
  Время событий и событие времени На последней странице Онтологии времени значится учебное издание. Я бы даже сказал учебное пособие. Для меня это учебное пособие по истории философии настоящее и одно из лучших и немногих при наличии кучи учебников плохих и хор...