15288

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

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

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

Налагодження програми мовою Асемблер з використанням підпрограм Лабораторні роботи № 15 16 Тема: Технологія та прийоми програмування мовою Асемблер. Мета роботи: Набути навичок роботи з підпрограмами. Навчитися передавати параметри з осно...

Украинкский

2013-06-11

104 KB

5 чел.

PAGE  3

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

Лабораторні роботи № 15, 16

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

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

  

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

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

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

Підпрограма може бути оформлена у вигляді процедури, і тоді ім'я цієї процедури служитиме точкою входу в підпрограму:

drawline proc ;Підпрограма-процедура

. . . ;Тіло підпрограми

ret ;Команда повернення в основну програму

drawline endp 

З таким же успіхом можна обійтися без процедури, просто помітивши перший рядок програми деякою міткою:

drawline: ;Підпрограма, що починається з мітки

. . . ;Тіло підпрограми

ret ;Команда повернення в основну програму

. . . ;Продовження основної програми або

;інші підпрограми 

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

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

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

ORG 100h; Основна програма

cld

mov CX, 3; В завданні число m

lea si, a1

mov aa1, si

lea si, a2

mov aa2, si

nc: push CX

CALL load

CALL delay

pop CX

loop nc

ret

a1 dw 2,4,6

a2 dw 1,3,5

aa1 dw 0

aa2 dw 0

delay proc;   Підпрограма затримки

mov Cx, BX      ; Лічильник зовнішнього циклу

outer: push CX      ; Збережемо його в стеку

mov Cx, AX            ; Лічильник внутрішнього циклу

inner: loop inner  ; loop внутрішнього циклу

pop CX                ; Відновимо зовнішній лічильник

loop outer          ; loop зовнішнього циклу

ret

delay endp

load proc; Підпрограма завантаження параметрів зовнішнього та внутрішнього циклів підпрограми затримки

mov SI, aa1

LODSW

MOV aa1, SI

mov BX, AX

mov SI, aa2

LODSW

MOV aa2, SI

ret

load endp

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

  1.  Використовуючи середовище емулятора скласти лістинг програми (табл..1)

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

Зміщення

Код (Hex)

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

К-сть байт

Коментар

100

B9

MOV CX, 00003

3

Код операції – запис числа 3 в CX

101

03

Молодший байт числа

102

00

Старший байт числа

103

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

2.4 Прибрати в тексті програми елементи процедури proc і endp, перекомпілювати проект і переконатися в його працездатності.


Таблиця 2 Результати досліджень

№ кроку

IP

Команда

SI

BX

CX

AX

DX

Коментар

H

L

H

L

H

L

H

L

0

100

MOV CX, 0003H

0000

00

00

00

00

00

00

00

00

1

103

MOV SI, 0011CH

0000

00

00

00

03

00

00

00

00

2

3

4

5


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

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

№ варіанту

m

Значення елементів

а1

Значення елементів

а2

1

3

1, 3, 5

2, 4, 6

2

4

2, 3, 4, 1

1, 2, 3, 4

3

2

4, 2

5, 6

4

3

2, 4, 6

1, 3, 5

5

4

1, 2, 3, 4

2, 4, 6, 8

6

2

3, 4

6, 5

7

3

5, 3, 1

6, 4, 2

8

4

4, 3, 2, 1

3, 4, 5, 2

9

2

2, 4

3, 5

10

3

1, 3, 2

6, 5, 4

11

4

1, 3, 2, 4

6, 5, 3, 1

12

2

5, 3

6, 8

13

3

3, 4, 2

5, 3, 1

14

4

1, 3, 2, 4

6, 2, 3, 5

15

2

2, 1

3, 0

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

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

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

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

  1.  Контрольні запитання

  1.  Яке призначення підпрограм?
    1.  Яким чином формується підпрограма в асемблер ній програмі?
    2.  Як здійснюється виклик підпрограми?
    3.  Куди повертається управління після завершення підпрограми?
    4.  Для чого використовується стек при роботі з підпрограмами?
    5.  Яким чином здійснюється передача параметрів у підпрограму?

  1.  Джерела інформації

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


 

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

18276. ОПЕРАЦІЯ НАД МНОЖИНАМИ 256.5 KB
  Лекція 3 ОПЕРАЦІЯ НАД МНОЖИНАМИ Поняття про операції. Операції перерізу обєднання доповнення підмножини до множини і доповнення. Зображення результатів операцій за допомогою кругів Ейлера. Закони операції над множинами. Число елементів у обєднанні ...
18277. ВІДНОШЕННЯ МІЖ ЕЛЕМЕНТАМИ ДВОХ МНОЖИН 53 KB
  Лекція 4 ВІДНОШЕННЯ МІЖ ЕЛЕМЕНТАМИ ДВОХ МНОЖИН Відношення між елементами двох множин та його основні характеристики: області відправлення і прибуття; графи відношення області визначення і значення повні образи і прообрази елементів. Операції над відношення...
18278. ВІДНОШЕННЯ НА МНОЖИНІ 121.5 KB
  Лекція 5 ВІДНОШЕННЯ НА МНОЖИНІ Відношення на множині та його основні характеристики. Особливості графа відношення на множині. Способи задання відношень на множині. Основні властивості відношень на множині: рефлективність і антирефлексивність симетричність ...
18279. ФУНКЦІЇ ВІДОБРАЖЕННЯ 260.5 KB
  Лекція 6 ФУНКЦІЇ ВІДОБРАЖЕННЯ Поняття функції та її основні характеристики. Способи задання функцій. Відображення і їх види. Рівнопотужні множини. Потужність множини. Теорема про обєднання рівно потужних множин. Питання на самостійне опрацю
18280. АЛГЕБРАЇЧНІ ОПЕРАЦІЇ І АЛГОРИТМИ 72.5 KB
  Лекція 7 АЛГЕБРАЇЧНІ ОПЕРАЦІЇ І АЛГОРИТМИ Бінарні алгебраїчні операції та їх основні характеристики. Асоціативний і комутативний закони операції. Дистрибутивні закони що повязують дві операції. Операція обернена даній. Питання на самостійне опр...
18281. ЛОГІКА ВИСЛОВЛЕНЬ 143.5 KB
  Лекція 8 ЛОГІКА ВИСЛОВЛЕНЬ Поняття про твердження. Математичні твердження та їх види. Висловлювання логічне значення висловлення. Логічні сталі. Прості і складні висловлення. Пропозиційні змінні. Операції заперечення конюнкції дизюнкції та еквіва
18282. ЛОГІКА ПРЕДИКАТІВ 172.5 KB
  Лекція 9 ЛОГІКА ПРЕДИКАТІВ Поняття про зміну в математиці. Предикат висловлювальна форма та його основні характеристики. Тотожно істинні тотожно хибні і рівносильні предикати. Операції логіки висловлень над предикатами. Області істинності результат
18283. МІРКУВАННЯ ТА ПЕРЕВІРКА ЇХ ПРАВИЛЬНОСТІ 87.5 KB
  Лекція 10 МІРКУВАННЯ ТА ПЕРЕВІРКА ЇХ ПРАВИЛЬНОСТІ Поняття про міркування. Правильні і неправильні міркування. Перевірка правильності міркувань за допомогою кругів Ейлера або наведення контрприкладу. Теореми і їх будова. Твердження що повязані з даною те
18284. РІЗНІ ПІДХОДИ ДО ПОБУДОВИ МНОЖИНИ ЦІЛИХ НЕВІД’ЄМНИХ ЧИСЕЛ 70 KB
  Лекція 11 РІЗНІ ПІДХОДИ ДО ПОБУДОВИ МНОЖИНИ ЦІЛИХ НЕВІДЄМНИХ ЧИСЕЛ Короткі історичні відомості про виникнення натурального числа і нуля. Різні підходи до побудови множини цілих невідємних чисел. Скінченні множини та їх властивості: а Теоретикомн