- •Оглавление
- •3. Лабораторная работа №2 54
- •5. Лабораторная работа №4 81
- •7. Лабораторная работа №6 117
- •1. Общие положения
- •1.1. Архитектура микропроцессора Intel 8086 с точки зрения программиста
- •1.2. Организация памяти с точки зрения мп 8086
- •1.4. Общая классификация системы команд мп 8086
- •Команды пересылки данных;
- •Арифметические команды;
- •Мнем_обозначение [операнд1[, операнд2]]
- •1.5. Физические и логические сегменты
- •1.6. Префиксы замены сегментов
- •1.7. Директивы языка ассемблера
- •Директивы управления размещением данных;
- •1.8. Структура ассемблерной программы для мп 8086
- •1.9.1. Директивы управления размещением данных
- •1.9.1.1. Директива struc
- •1.9.1.2. Директива equ
- •1.9.1.3. Директива assume
- •1.10. Пример простейшей программы на ассемблере
- •1.11. Средства компиляции программ на ассемблере и примеры их использования
- •1.11.1. Исполнимый файл типа com
- •1.11.2. Исполнимый файл типа exe
- •1.11.3. Использование транслятора Turbo Assember
- •1.11.4. Использование компоновщика Turbo Linker
- •2. Лабораторная работа №1
- •2.1. Цель работы
- •2.2. Основные теоретические положения
- •2.2.1. Команды пересылки данных
- •2.2.1.1. Команда mov
- •2.2.1.2. Команда xchg
- •2.2.1.3. Команда xlat
- •2.2.1.4. Команда lea
- •2.2.1.5. Команды lds и les
- •2.2.1.6. Команда lahf
- •2.2.1.7. Команда sahf
- •2.2.2. Арифметические команды
- •2.2.2.1. Команда add
- •2.2.2.2. Команда adc
- •Add word ptr n2, ax ; сложение младших 16 бит
- •2.2.2.3. Команда sub
- •2.2.2.4. Команда sbb
- •Sub word ptr n1, ax ; вычитание младших 16 бит
- •2.2.2.5. Команды mul и imul
- •2.2.2.6. Команды div и idiv
- •2.2.2.7. Команда inc
- •2.2.2.8. Команда dec
- •2.2.2.9. Команда neg
- •2.2.2.10. Команда cbw
- •2.2.2.11. Команда cwd
- •2.3. Задание и методические указания к выполнению лабораторной работы
- •2.3.1. Задание на лабораторную работу
- •2.3.2. Методические указания к выполнению работы
- •2.4. Контрольные вопросы
- •2.5. Варианты заданий на лабораторную работу
- •3. Лабораторная работа №2
- •3.1. Цель работы
- •3.2. Основные теоретические положения
- •3.2.1. Команда and
- •3.2.2. Команда or
- •3.2.3. Команда xor
- •3.2.4. Команда not
- •3.2.5. Команда test
- •3.2.6. Команды shl и shr
- •3.2.7. Команды sal и sar
- •3.2.8. Команды rol и ror
- •3.2.9. Команды rcl и rcr
- •3.3. Задание и методические указания к выполнению лабораторной работы
- •3.3.1. Задание на лабораторную работу
- •3.3.2. Методические указания к выполнению работы
- •3.4. Контрольные вопросы
- •3.5. Варианты заданий на лабораторную работу
- •4. Лабораторная работа №3
- •4.1. Цель работы
- •4.2. Основные теоретические положения
- •4.2.1. Цепочечные команды
- •4.2.1.1. Команды movsb и movsw
- •4.2.1.2. Команды stosb и stosw
- •4.2.1.3. Команды cmpsb и cmpsw
- •4.2.1.4. Команды scasb и scasw
- •4.2.1.5. Команды lodsb и lodsw
- •4.2.2. Префиксы повторения
- •4.2.2.1. Префикс повторения rep
- •4.2.2.2. Префиксы повторения repe и repz
- •4.2.2.3. Префиксы повторения repne и repnz
- •4.2.3. Команды условных и безусловных переходов
- •4.2.4. Способы адресации в командах переходов
- •4.2.5. Организация циклов в программах на ассемблере
- •4.2.5.5. Цикл с постусловием
- •4.3. Задание и методические указания к выполнению лабораторной работы
- •4.3.1. Задание на лабораторную работу
- •4.3.2. Методические указания к выполнению работы
- •4.4. Контрольные вопросы
- •4.5. Варианты заданий на лабораторную работу
- •5. Лабораторная работа №4
- •5.1. Цель работы
- •5.2. Основные теоретические положения
- •5.2.1. Организация системы прерываний в ibm pc
- •5.2.2. Понятие вектора прерывания
- •5.2.3. Таблица векторов прерываний
- •5.2.4. Программные прерывания
- •5.2.6. Аппаратные прерывания
- •5.2.7. Сходства и различия аппаратных и программных прерываний
- •5.2.8.Организация обработки прерываний в программах на ассемблере
- •5.2.8.1. Написание процедуры обработки программных прерываний
- •5.2.8.2. Написание процедуры обработки аппаратных прерываний
- •5.2.8.3. Установка вектора прерывания
- •5.2.9. Функции ms-dos 25h и 35h
- •5.2.9.1. Функция dos 25h
- •5.2.9.2. Функция dos 35h
- •5.3. Задание и методические указания к выполнению лабораторной работы
- •5.3.1. Задание на лабораторную работу
- •5.3.2. Методические указания к выполнению работы
- •5.4. Контрольные вопросы
- •5.5. Варианты заданий на лабораторную работу
- •6. Лабораторная работа №5
- •6.1. Цель работы
- •6.2. Основные теоретические положения
- •6.2.1. Данные в формате asciiz
- •6.2.2. Файловый номер и коды возврата
- •6.2.3. Функции dos для работы с файлами
- •6.2.3.1. Функция 3ch
- •6.2.3.2. Функция 3dh
- •6.2.3.3. Функция 3fh
- •6.2.3.4. Функция 40h
- •6.2.3.5. Функция 3eh
- •6.2.3.6. Функция 41h
- •Mov dx, offset FileName ; asciiz-строка
- •6.2.3.7. Функция 42h
- •6.2.3.8. Функция 43h
- •Mov cx, 01h ; атрибута «только для чтения»
- •6.2.3.9. Функция 56h
- •6.2.4. Примеры программ для работы с файлами
- •6.2.5. Функции для работы с каталогами
- •6.2.5.1. Функция 39h
- •6.2.5.2. Функция 3ah
- •6.2.5.3. Функция 47h
- •6.2.5.4. Функция 3bh
- •6.2.6. Поиск файлов по шаблону
- •6.2.6.1. Функция 4eh
- •6.2.6.2. Функция 4fh
- •6.2.6.3. Совместное использование функций 4eh и 4fh
- •6.2.7. Коды ошибок dos
- •6.3. Задание и методические указания к выполнению лабораторной работы
- •6.3.1. Задание на лабораторную работу
- •6.3.2. Методические указания к выполнению работы
- •6.4. Контрольные вопросы
- •6.5. Варианты заданий на лабораторную работу
- •7. Лабораторная работа №6
- •7.1. Цель работы
- •7.2. Основные теоретические положения
- •7.2.1. Определение наличия сопроцессора
- •Fstcw CrtlReg ; чтение управляющего регистра
- •7.2.2. Команды сопроцессора
- •7.2.3. Архитектура сопроцессора с точки зрения программиста
- •Регистр управления
- •Регистр состояния
- •Регистр признаков
- •7.2.3.1. Регистр управления
- •7.2.3.2. Регистр состояния
- •7.2.3.3. Регистр признаков
- •7.2.3.4. Указатель команды
- •7.2.3.5. Указатель операнда
- •7.2.4. Форматы вещественных чисел, используемые сопроцессором
- •7.2.3. Некоторые команды сопроцессора
- •7.2.3.1. Команды пересылки данных и загрузки констант сопроцессора
- •Команда fxch
- •7.2.3.2. Арифметические команды сопроцессора
- •Команда fsqrt
- •Команда fscale
- •Команда fabs
- •Команда fchs
- •Команда fprem
- •7.2.3.3. Команды трансцендентных функций
- •Команда fpatan
- •Команда fptan
- •Команда f2xm1
- •Команда fyl2x
- •Команда fylpxp1
- •7.2.3.4. Команды сравнения данных
- •7.2.3.5. Команды управления сопроцессором
- •Команда finit
- •Команда fstsw
- •Команда fldcw
- •Команда fstcw
- •Fldcw cw ; загрузка регистра управления Команда fclex
- •Команда fsave
- •Команда frstore
- •Команда ffree
- •Команда fnop
- •7.2.4. Примеры решения типовых вычислительных задач
- •7.2.4.1. Вычисление интеграла функции
- •7.2.4.2. Вычисление суммы степенного ряда
- •7.2.4.3. Нахождение корня уравнения методом Ньютона
- •7.3. Задание и методические указания к выполнению лабораторной работы
- •7.3.1. Задание на лабораторную работу
- •7.3.2. Методические указания к выполнению работы
- •7.4. Контрольные вопросы
- •7.5. Варианты заданий на лабораторную работу
- •8. Курсовая работа
- •8.1. Цель работы
- •8.2. Основные теоретические положения
- •8.2.1. Структура резидентной программы
- •8.2.1.1. Стек резидентной части
- •8.2.1.2. Процедура загрузки резидентной части
- •Old_vec dd ? ; здесь будет храниться старое значение
- •8.2.1.3. Примеры простейших резидентных программ типа com
- •8.2.1.4. Примеры простейших резидентных программы типа exe
- •8.2.1.5. Вызов старого обработчика прерывания
- •8.2.1.6. Связь с резидентной частью
- •8.2.1.7. Процедура выгрузки резидентной части
- •Int 21h ; освобождение блока памяти
- •8.2.1.8. Процедура обработки ключей командной строки
- •8.2.2. Пример резидентной программы
- •8.2.3. Функции ms-dos
- •8.2.3.1. Функции ввода-вывода
- •Функция 01h
- •Функция 02h
- •Функция 05h
- •Функция 06h
- •Функция 07h
- •Функция 09h
- •Функция 0ah
- •Функция 0bh
- •Функция 0ch
- •8.2.3.2. Функции управления памятью
- •Функция 48h
- •Функция 49h
- •Mov es, bx ; сегмент блока памяти находится в bx
- •Функция 4ah
- •8.2.3.3. Функции управления процессами
- •Функция 31h
- •Функция 4bh
- •Функция 4bh, подфункция 00h
- •Функция 4bh, подфункция 01h
- •Функция 4bh, подфункция 03h
- •Функция 4ch
- •Функция 4dh
- •Функция 50h
- •Функция 51h
- •8.2.3.4. Функции настройки даты/времени
- •Функция 2ah
- •Функция 2bh
- •Mov dl, 13 ; 13-е число
- •Функция 2сh
- •Функция 2dh
- •8.2.4. Прерывания bios
- •8.2.4.1. Прерывание bios 10h
- •Функция 00h
- •Функция 02h
- •Функция 03h
- •Функция 08h
- •Функция 09h
- •Функция 0ch
- •Функция 0dh
- •Функция 0fh
- •8.2.4.2. Прерывание bios 13h
- •Функция 00h
- •Функция 02h
- •Buf db 512 dup (?) ; буфер для чтения сектора
- •Функция 03h
- •Функция 04h
- •8.2.4.3. Прерывание bios 16h
- •Функция 00h
- •Функция 01h
- •Функция 02h
- •Функция 03h
- •Функция 05h
- •8.2.4.4. Коды ошибок bios
- •8.3. Задание и методические указания к выполнению курсовой работы
- •8.3.1. Задание на курсовую работу
- •8.3.2. Методические указания к выполнению курсовой работы
- •8.4. Содержание отчета
- •8.5. Контрольные вопросы
- •8.6. Варианты заданий на курсовую работу
- •9. Список литературы
3.2.8. Команды rol и ror
Команды ROL и ROR являются командами циклического сдвига – они сдвигают свои операнды, и биты, которые при этом вышли за разрядную сетку слева (для команды ROL) или справа (для команды ROR), заносятся в освободившиеся биты справа или слева соответственно. Команда ROL сдвигает биты своего операнда влево, а команда ROR – вправо. Синтаксис и требования к операндам у команд ROL и ROR – такие же, как и для команд SHL и SHR.
Пример использования команд ROL и ROR:
X DB 11010111B
. . .
MOV CL, 4
ROL X, CL ; X = 01111101B
ROR X, 1 ; X = 10111110B
3.2.9. Команды rcl и rcr
Команды RCL и RCR аналогичны командам ROL и ROR, но выполняют циклические сдвиги через флаг переноса. Это означает, что при сдвиге операнда на 1 бит, тот бит, который вышел за разрядную сетку, заносится во флаг CF, а значение флага CF перед этим, в свою очередь заносится в освободившийся бит. При сдвиге операнда на несколько бит описанная операция повторяется CL раз. Команда RCL сдвигает биты операнды влево, а RCR – вправо.
Пример использования команд RСL и RСR (предполагается, что флаг CF установлен):
MOV BL, 01011100B
RCL BL, 1 ; BL = 10111001B, CF сброшен
MOV CL, 3
RCR BL, CL ; BL = 11001010B, CF установлен
3.3. Задание и методические указания к выполнению лабораторной работы
3.3.1. Задание на лабораторную работу
написать программу на ассемблере, вычисляющую значение выражения с использованием арифметических и логических команд (сложение, вычитание, умножение, деление, конъюнкция, дизъюнкция, сложение по модулю 2, отрицание);
проверить работу программы в отладчике.
3.3.2. Методические указания к выполнению работы
Порядок выполнения лабораторной работы №2 соответствует порядку выполнения лабораторной работы №1.
При написании программы следует учесть приоритеты выполнения арифметических и логических операций. Приоритеты операций представлены в таблице 3.1. Приоритеты и знаки операций в таблице соответствуют языку C.
Таблица 3.1 – приоритеты операций.
Приоритет |
Операция |
1 |
! , унарный – |
2 |
* , / |
3 |
+ , – |
4 |
& |
5 |
^ |
6 |
| |
3.4. Контрольные вопросы
Какие логические команды существуют для МП 8086?
Чем отличаются действия команд NOT и NEG?
Какими арифметическими и логическими командами можно заменить действие команды NEG?
В каких случаях выполнение команды OR дает такие же результаты, как выполнение команды ADD?
Какими способами можно обнулить регистр общего назначения?
3.5. Варианты заданий на лабораторную работу
(a | 5) + !b / (2 – (c & 7)) * (d ^ 10) – 1
((a ^ 2) – (b | 3)) / (2 + (c & 8)) * !d
(a & 3) * (b ^ 8) / (!c * (d | 3)) – 5
!a – (b | 2) * (c ^ 2) * (3 + d & 3) + 2
(a – 4 & 2) / (!b + (c ^ 5)) – !d
((a & 5) – (b ^ 7)) / (!c + (d | 1) * 2)
(a ^ 4) * 5 – (!b + (c & 5 + d)) / 2 | 3
(a | 3 – (b ^ 4) * (c & 9)) / (!d + 5)
((a + b | 1) ^ 5) / !c – (d * 5 & 3) + 1
(a & 5) / ((3 * b | 3) – !c) + (d ^ 1)
(a ^ 5 – (b | 3)) / 2 + (!c + !d) / 3 & 7
(a + 1 | 5) / ((b ^ 9) – 1) + !c * (d & 3)
(!a – (b | 6) * (c & 9 – (d ^ 8))) / 4
–a | 7 * (b & 3) + ((c ^ 4) – 1) / !d + 1
(a ^ 3) / ((b | 9) * (!c + 1)) – (d & 2)
(a | 5 + b & 9) * ((c ^ 2) + 3) / (!d – 1)
(a & 4 – (b + c | 8) * 2) / !((d ^ 1) + 5)
(!a – ((b | 6) / c ^ 3)) * (!d – 3) + 1
(a ^ 9) + 2 * (b | 3) – (3 * (c – !d) & 8)
(a | 4) * (3 + b & 5) – 2 * !(c ^ 5 + d)
