- •Министерство образования российской федерации ижевский государственный технический университет
- •1. Методика выполнения лабораторных работ
- •2. Основные сведения об ассемблере
- •2.1. Регистры процессора
- •2.2. Команды ассемблера
- •2.3. Прерывания ассемблера
- •4. Режимы адресации команд
- •5. Байт способа адресации
- •6. Режимы адресации переходов
- •7. Система команд
- •7.1. Команды пересылки
- •7.1.1. Общие команды пересылки данных
- •7.1.1.2. Xchg - перестановка
- •7.1.1.3. Xlat - перекодировка
- •7.1.1.7. Команда lahf - загрузка флагов в регистр ан
- •7.1.1.8. Sahf - установка флагов из регистра ан
- •7.1.2. Команды пересылки данных с использованием стека (стековые команды)
- •7.1.3. Команды ввода - вывода
- •1.4. Команды пересылки цепочек байт или слов (цепочечные команды)
- •7.1.4.1. Movs - пересылка строки байтов или слов
- •7.1.4.2. Movsb/movsw - пересылка строки байтов или слов
- •7.1.4.3. Lods - загрузка строки байтов или слов
- •7.1.4.8. Cmpsb/cmpsw - сравнение строки байтов или слов
- •7.1.4.9. Scas - сканирование строки байтов или слов
- •7.1.4.10. Scasb/scasw - сканирование строки байтов или слов
- •7.2. Арифметические команды
- •7.2.1. Команды сложения
- •7.2.2. Команды вычитания
- •7.2.3. Команды сравнения
- •7.2.4. Команды умножения
- •7.2.4.2. Imul - умножение знаковых величин
- •7.2.5. Команды деления
- •7.2.5.2. Idiv - деление знаковых величин
- •7.3. Логические команды
- •7.4. Команды сдвигов
- •7.5. Команды переходов (передачи управления)
- •7.5.1. Команды безусловных переходов
- •7.5.2. Команды условных переходов
- •7.5.3. Команды вызовов (подпрограммы)
- •7.5.4. Команды возвратов (из подпрограмм)
- •7.5.5. Команды управления циклами
- •7.5.6. Команды прерываний
- •7.6. Команды управления микропроцессором
- •8. Примеры выполнения лабораторных работ
- •9. Учебно-методическая литература
- •Описание команд отладчика debug
- •Команды процессора 8086
- •1. Команды пересылки данных
- •1.1. Общие команды пересылки данных
- •Xlat Перекодировка
- •Xchg Перестановка
- •1.2. Стековые команды
- •1.3. Команды ввода-вывода
- •In Ввод байта или слова из порта
- •1.4. Команды пересылки цепочек
- •2. Арифметические команды
- •2.1. Команды сложения
- •Inc Инкремент
- •2.2. Команды вычитания
- •2.3. Команды сравнения
- •2.4. Команды умножения
- •Imul Целое умножение знаковых величин
- •2.5. Команды деления
- •Idiv Целое деление знаковых величин
- •3. Логические команды
- •Xor Исключающее или
- •4. Команды сдвигов
- •5. Команды передачи управления
- •5.1. Команды вызова процедуры
- •5.2. Команды прерываний
- •Int Прерывание
- •Into Прерывание по переполнению
- •Iret Возврат из обработки прерывания
- •5.3. Команды условных переходов
- •5.4. Команды безусловных переходов
- •5.5. Команды управления циклами
- •6. Команды управления процессором
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