Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Методичка Программир на ассемблере.doc
Скачиваний:
8
Добавлен:
17.09.2019
Размер:
605.7 Кб
Скачать

7.5.3. Команды вызовов (подпрограммы)

Команда CALL - вызов процедуры - передает управление с автоматическим сохранение адреса возврата. При переходе к подпрограмме необходимо временно запомнить адрес команды, находящейся после команды CALL этот адрес называется адресом возврата. После того как подпрограмма закончит свои действия, завершающая ее команда RET возврат передает управление по запомненному адресу возврата. Адреса возврата хранятся в стеке.

Команда вызова может быть внутрисегментной или межсегментной.

Форматы команды CALL аналогичны JMP:

внутрисегментные вызовы

CALL disp16

CALL mem/reg

межсегментные вызовы

CALL addr

CALL mem

По воздействию на регистры IP и CS команда CALL так же соответствует команде JMP, но дополнительно она запоминает в текущем сегменте стека адрес возврата с соответствующей модификацией указателя стека SP.

Трехбайтная команда CALL disp16 производит декремент SP на 2, включает в стек содержимое IP, а затем прибавляет к IP 16-ти битное смещение, которое интерпретируется как знаковое целое.

Пример:

IP:= 3A08

SP:= 1804

SS:= A000

CALL 0A08

1) Декремент SP на 2

SP:= (SP) -2 = 1804 - 2 = 1802

2) Включение в стек содержимого IP (EA) = IP

EA = (SP) +(SS)0 = 1802 + A0000 = A1802

(A1802) = 3A08

3) Прибавление к IP 16-ти битового смещения

IP:= (IP) + disp16 = 3A08 + 0A08 = 4410

Команда CALL mem/reg осуществляет внутрисегментный косвенный вызов, причем источником адреса перехода может быть определен 16-ти битовый регистр или ячейка памяти.

Пример:

IP:= 8AAA

SP:= 0800

SS:= BBB0

AX:= A020

CALL AX

1) Декремент SP на 2

SP:= (SP) - 2 = 0800 - 2 = 07FE

2) Включение в стек содержимого IP

(EA) = IP

EA = (SP) + (SS)0 = 07FE + BBB00 = BC2FE

(BC2FE) = 8AAA

3) Источник адреса перехода

IP:= A020

Команда прямого межсегментного вызова CALL addr выполняет следующие действия:

1) Содержимое SP уменьшается на 2;

2) В адресуемую регистрами SP и SS ячейку памяти пересылается содержимое CS;

3) Содержимое SP уменьшается на 2;

4) В адресуемую регистрами SP и SS ячейку памяти записывается содержимое IP;

5) В IP загружается смещение offset

6) В CS загружается сегментный адрес seg.

Пример:

IP:= 3700

CS:= 6000

SP:= 1738

SS:= 8000

CALL 2AA0:84BC

1) SP:= (SP) - 2 = 1738 - 2 = 1736

2) (EA) = CS EA = (SP) + (SS)0 = 1736 + 80000 = 81736

(81736) = 6000

3) SP:= (SP) - 2 = 1736 - 2 =1734

4) (EA) = IP EA = (SP) + (SS)0 = 1734 + 80000 = 81734

(81734) = 3700

5) IP:= offset = A02A

6) CS:= seg = BC84

Команда CALL mem осуществляет косвенный межсегментный вызов подпрограммы через память. Текущее содержимое регистров IP и CS запоминается в стеке, после чего слово из адресуемой ячейки памяти загружается в IP, а следующее слово - в регистр CS. Если mod = 11, то операция не определена.

Пример:

IP:= 7240

CS:= 2000

SP:= 028A

SS:= 3FF0

BX:= 0400

SI:= 1200

DS:= 1800

(19600) = 8790; (19602) = A060

CALL [BX + SI]

1) SP:= (SP) - 2 = 028A - 2 = 0288

2) (EAS) = CS

EAS = (SP) + (SS)0 = 0288 + 3FF00 = 40188

(40188) = 2000

3) SP:= (SP) - 2 = 0288 - 2 = 0286

4) (EAS) = IP

EAS = (SP) + (SS)0 = 0286 + 3FF00 = 40186

(40186) = 7240

5) IP = (EAP)

EAP = (BX) + (SI) + (DS)0 = 0400 + 1200 +18000 = 19600

IP = 8790

6) CS = (EAP) + 2

CS = A060