15285

Налагодження програми мовою Асемблер з використанням циклів та розгалужень

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

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

Налагодження програми мовою Асемблер з використанням циклів та розгалужень Тема: Технологія та прийоми програмування мовою Асемблер. Мета роботи: набути навичок з реалізації задач мовою Асемблер що містять цикли та розгалуження. Ко...

Украинкский

2013-06-11

102.5 KB

12 чел.

PAGE  6

Налагодження програми мовою Асемблер з використанням циклів та розгалужень

Тема: Технологія та прийоми програмування мовою Асемблер.

Мета роботи: набути навичок з реалізації задач мовою Асемблер, що містять цикли та розгалуження.

 

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

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

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

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

JMP label,

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

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

label1:
label2:
a:

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

x1: 
MOV AX, 1

або


x2: MOV AX, 2

Нижче наведений приклад використання команди JMP:

org    100h

mov    ax, 5          ; set ax to 5.

mov    bx, 2          ; set bx to 2.

jmp    calc           ; go to 'calc'.

back:  jmp stop       ; go to 'stop'.

calc:

 add    ax, bx         ; add bx to ax.

jmp    back           ; go 'back'.

stop:

ret                   ; return to operating system.

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

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

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

  1.  Цикли

Алгоритмічна структура " цикл", як відомо, забезпечує виконання деякої послідовності дій, яка називається тілом циклу.

Виділяється три типи циклів: цикл " ДЛЯ", цикл " ДОКИ", цикл " ДО". Один від одного різні типи циклів відрізняються в основному лише способом перевірки закінчення циклу. Вказані типи циклів ілюструє рис.1.

Рисунок 1 Типи циклів

Система команд мови Асемблер дозволяє організувати циклічне виконання деякого фрагменту програми за алгоритмами, що представлені на рис.1, приміром, використовуючи команди умовної передачі управління або команду безумовного переходу JMP.

ЦиклДОКИ: While X>0 do S

Мовою Асемблер:

A1: CMP CX, 0

 JLE A2

S; тіло циклу

JMP A1

A2: …

 ЦиклДО: Repeat S until X>0

Мовою Асемблер:

A: S; тіло циклу

 CMP CX, 0

JLE A

 

ЦиклДЛЯ: For I=1 to N do S

Мовою Асемблер:

 MOV CX, N

A: S; тіло циклу

 DEC CX

CMP CX, 0

 JNE A

Як і в мові Паскаль, в Асемблері існує спеціальна команда, яка дозволяє скорочувати лістинг циклічної програми. Це команда

LOOP <мітка>.

Ця команда виконує наступні функції:

  •  Автоматично зменшує значення лічильника;
  •  Виконує перевірку на вихід з циклу;
  •  Виконує перехід на початок тіла циклу.

Команда LOOP може бути використана лише у разі циклу з відомим числом повторень, тобто циклу "ДЛЯ". Кількість повторень циклу має бути присвоєна регістру СХ до початку циклу.

Цикл “ДЛЯ з використанням команди  LOOP буде програмуватися наступним чином:

 MOV CX, N

A: S; тіло циклу

LOOP A

Таким чином, команда LOOP замінила три команди:

  •  DEC CX
  •  CMP CX , 0
  •  JNE A2

  1.  Вкладені цикли

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

При необхідності організувати вкладені цикли у програмі, написаній мовою Асемблер, для збереження лічильника зовнішнього циклу на час виконання внутрішнього зручно скористатися стеком.

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

  1.  Використовуючи середовище емулятора МП і8086, створити і налагодити проект асемблерної програми відповідно до індивідуального завдання і результатів виконання практичної роботи №3 зі складання програми для розв’язання  задачі: знайти числа A, B, C для яких виконується умова – A*B*C=A+B+C. Знайдені числа розмістити в трьох масивах – відповідно для чисел А, чисел В і чисел С.
    1.  Використовуючи середовище емулятора скласти лістинг програми (табл..1)

Таблиця 1 Лістинг програми

Зміщення

Код (Hex)

Мнемокод команди

К-сть байт

Коментар

100

C7

MOV w.[00136H], 0000 

6

Код операції – запис числа 0 в комірку памяті [00136H]

101

06

102

36

Молодший байт адреси

103

01

Старший байт адреси

104

00

Молодший байт операнду

105

00

Старший байт операнду

106

01

MOV CX, 0004H

3

Запис числа 4h в CX

107

04

Молодший байт операнду

108

00

Старший байт операнду

  1.  Запустити виконання програми в середовищі емулятора. Записати отримані результати виконання програми.
    1.  У випадку некоректної роботи складеної програми,  використовуючи покроковий режим роботи емулятора, виявити і усунути допущені помилки при складанні програми.

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

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

№ варіанту

Розташування чисел

Діапазон зміни чисел

A

B

C

A

B

C

1

BL

CL

mem

0…5

1…5

0…9

2

BL

CH

mem

1…9

0…5

0…9

3

BH

CL

mem

0…9

1…7

0…5

4

mem

BL

BH

0…5

1…5

0…9

5

mem

CL

CH

1…9

0…5

0…9

6

mem

BH

CH

0…9

1…7

0…5

7

AL

mem

BL

0…5

1…5

0…9

8

BH

mem

AH

1…9

0…5

0…9

9

CL

mem

AL

0…9

1…7

0…5

10

BX

CX

mem

0…5

1…5

0…9

11

mem

BX

CX

1…9

0…5

0…9

12

BX

mem

mem

0…9

1…7

0…5

13

mem

CX

mem

0…5

1…5

0…9

14

mem

mem

AX

1…9

0…5

0…9

15

mem

mem

mem

0…9

1…7

0…5

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

  1.  Назва теми.
    1.  Мета роботи.
    2.  Індивідуальне завдання.

  1.  Алгоритми реалізації завдання.
    1.  Текст програми реалізації завдання з коментарями.
    2.  Результати виконання програми.
    3.  Висновки.
    4.  Відповіді на контрольні запитання.

  1.  Контрольні запитання
    1.  Які типи циклів застосовуються у програмах, складених мовою Асемблер?  
    2.  Які групи команд Асемблера застосовуються для організації циклів?
    3.  Які групи команд Асемблера застосовуються для організації розгалужень?
    4.  Що таке вкладені цикли і як вони використовуються?

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


“ДОКИ

мова

Тіло циклу

ДО

Умова

Тіло циклу

Так

Так

Ні

Ні

ДЛЯ

Лічильник

Тіло циклу


 

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

49442. Магистральная волоконно-оптическая линия связи 1.33 MB
  Приложение Задание Спроектировать магистральную волоконно-оптическую линию связи. Одним из важнейших достижений последнего десятилетия в области связи несомненно является создание волоконно-оптических систем передачи ВОСП на базе использования волоконно-оптических линий связи ВОЛС. Использование волоконно-оптических линий связи и систем передачи информации позволяет повысить надежность помехозащищенность скрытность и пропускную способность линий связи Перспективы развития оптической связи связаны с новыми технологиями:...
49443. Мост передний ведущий МАЗ 5434-2300010-20 244 KB
  Данный мост технологичен и ремонтопригоден. Его конструкция в определённых пределах проста, узлы, по возможности, выполнены небольших габаритов и массы, при этом их число минимально. Конструкция моста обеспечивает удобство сборки, места расположения крепежных элементов доступны для сборочного инструмента.
49444. ДИСКРЕТНАЯ ОБРАБОТКА СИГНАЛОВ И ЦИФРОВАЯ ФИЛЬТРАЦИЯ 7.43 MB
  Произвести сравнение результатов вычислений: сравнить форму спектра дискретизированной последовательности со спектром исходного аналогового сигнала; установить связь между: результатом Zпреобразования и спектральной плотностью дискретизированной последовательности; спектром исходного периодического аналогового сигнала и дискретными отсчётами его спектральной плотности.2...
49445. Проект подстанции для ткацкого цеха №3 предприятия ОАО ХБК «Шуйские ситцы» 646.8 KB
  Проектируем подстанцию для ткацкого цеха № 3 ООО «Новогоркинская мануфактура». Подстанция получает питание от ГПП расположенного на расстоянии L=0.25 км. Напряжение питания – 6.3 кВ. Подстанция питает ткацкий цех площадью 4520м2, в котором установлено 385 ткацких станков АТПР-100-2У, вентиляционную установку мощностью – 210 кВт
49446. Схема замкнутой системы электропривода 786.3 KB
  Составление математического описания системы 1.1 приведена принципиальная схема замкнутой системы электропривода состоящего из: двигателя постоянного тока независимого возбуждения М; тиристорного преобразователя ТП с системой импульснофазового управления СИФУ управляемыми вентилями В и дросселем Др; операционного усилителя У1 реализующего устройство коррекции УК обеспечивая необходимый из условий статики коэффициент усиления замкнутого контура системы и заданные динамические свойства замкнутой системы; сумматора на операционном...