- •Часть 1
- •302030, Г. Орел, ул. Московская, 65
- •Содержание
- •Введение
- •1 Используемое оборудование и программное обеспечение
- •2 Общая подготовка к выполнению лабораторных работ
- •3 Общий ход выполнения и защиты лабораторных работ
- •4 Основные теоретические положения по программированию на языке ассемблера
- •4.1 Организация памяти для хранения программ
- •4.2 Режимы адресации данных микропроцессора Intel 8086
- •4.3 Режимы адресации переходов микропроцессора Intel 8086
- •4.4 Слово состояния микропроцессора Intel 8086
- •4.5 Список сокращений и условных обозначений
- •4.6 Общий формат ассемблерной команды
- •4.7 Определение данных
- •4.8 Регистры процессора Pentium.
- •4.9 Команды языка ассемблера
- •4.9.1 Команды передачи данных
- •4.9.2 Команды двоичных сложений и вычитаний
- •4.9.3 Однооперандные команды двоичной арифметики и команды сравнения
- •4.9.4 Команды умножения и деления двоичных чисел
- •4.9.5 Логические команды
- •4.9.6 Команды сдвигов и циклических сдвигов
- •4.9.7 Команды передачи управления
- •1) Безусловные переходы.
- •1.1) Команда безусловного перехода
- •1.2) Обращение к процедурам
- •2) Условные переходы
- •4.9.8 Команды циклов
- •4.9.9 Стековые команды
- •1) Организация стека
- •2) Использование стека для передачи параметров
- •4.9.10 Работа с устройствами ввода-вывода
- •5 Процесс ассемблирования и выполнения программы
- •5.1 Получение исполняемого модуля
- •5.2 Работа с отладчиком программ turbo debugger
- •6 Программа на языке ассемблера
- •6.1 Структура программы
- •6.2 Примеры программ
- •7 Лабораторная работа № 1. Арифметические операции над байтами и словами. Линейное исполнение программ
- •7.1 Цель работы
- •7.2 Контрольные вопросы
- •7.3 Задание на лабораторную работу
- •8 Лабораторная работа № 2. Логические операции и операции сдвига над данными
- •8.1 Цель работы
- •8.2 Контрольные вопросы
- •8.3 Задание на лабораторную работу
- •9 Лабораторная работа № 3. Команды условного и безусловного переходов. Организация ветвлений и циклов в программе
- •9.1 Цель работы
- •9.2 Контрольные вопросы
- •9.3 Задание на лабораторную работу
- •10 Лабораторная работа № 4. Использование стека и подпрограмм. Организация внутрисегментных и межсегментных переходов
- •10.1 Цель работы
- •10.2 Контрольные вопросы
- •10.3 Задание на лабораторную работу
- •11 Лабораторная работа № 5. Использование стека и подпрограмм. Организация передачи параметров через стек
- •11.1 Цель работы
- •11.2 Контрольные вопросы
- •11.3 Задание на лабораторную работу
- •12 Лабораторная работа № 6. Организация взаимодействия с устройствами компьютера. Использование портов
- •12.1 Цель работы
- •12.2 Контрольные вопросы
- •12.3 Задание на лабораторную работу
- •13 Содержание отчетов по лабораторным работам
- •14 Список рекомендуемой литературы
- •Приложение а (обязательное) Образец титульного листа отчета по лабораторной работе для студентов специальности 220301, обучающихся по основной программе
- •Приложение б (обязательное) Образец титульного листа отчета по лабораторной работе для студентов специальности 220301, обучающихся по ускоренной программе
- •Приложение в (обязательное) Образец титульного листа отчета по лабораторной работе для студентов направления 220300.62
8.2 Контрольные вопросы
1) Основные логические операции и принципы их выполнения.
2) Правила формирования масок для установки и сброса битов.
3) Каким образом выполняются логические команды над словами?
4) Команды линейного логического и арифметического сдвигов. В чем заключается разница их выполнения?
5) Особенности выполнения команд циклического сдвига. Сферы применения этих команд.
6) Что указывает директива ASSUME в программе?
7) Как оформляется начало выполнения программы?
8.3 Задание на лабораторную работу
1) Написать программу на языке ассемблера, которая выполняет логические операции и операции сдвига над данными.
1.1) В сегменте данных определить однобайтовое число в двоичной системе счисления.
1.2) Переписать его в регистр, установить 2 любых бита в единицу, инвертировать все, сбросить 3 любых бита.
1.3) Полученный результат продублировать в другом регистре, сложить получившиеся значения по модулю два.
1.4) Выполнить проверку, является ли полученный результат четным числом. Если да, то переписать его в регистр DH, иначе – в регистр DL.
1.5) Используя команды линейного сдвига, умножить сначала значение регистра DH или DL, в зависимости от результата предыдущей операции, на 4, а потом разделить на 2.
1.6) Используя команды циклического сдвига, в регистре BL получить значение третьего бита полученного числа, а в регистре BH – значение пятого бита.
2) На основе исходной программы получить исполняемый файл. Выполнить программу по шагам с помощью отладчика TURBO DEBUGGER, описать изменение состояния регистров и ячеек памяти при выполнении программы. Обратить особое внимание на следующие моменты:
2.1) Чему равна маска для установки двух битов в единицу и почему?
2.1) Чему равна маска для сброса трех битов в ноль?
2.3) В каком регистре будет находиться сначала результат умножения на 4, а потом результат деления на 2 при выполнении операций линейного сдвига? Чему равны полученные результаты в десятичной системе счисления?
2.4) Чему равны третий и пятый биты анализируемого числа и какую позицию они занимают в регистрах BL и BH, соответственно?
2.5) Где находятся биты числа, подвергнутые циклическому сдвигу и чему они равны?
9 Лабораторная работа № 3. Команды условного и безусловного переходов. Организация ветвлений и циклов в программе
9.1 Цель работы
Цели лабораторной работы:
1) изучение принципов функционирования памяти и микропроцессора компьютера при выполнении ветвлений и циклов;
2) приобретение навыков использования команд условного и безусловного переходов, циклов при написании ассемблерных программ;
3) получение представления об особенностях обработки данных, команд и режимах доступа к данным при организации ветвлений и циклов.
9.2 Контрольные вопросы
1) Ветвления в алгоритмах. Реализация ветвлений на языке ассемблера.
2) Флаги процессора и их использование в условиях.
3) Циклы в алгоритмах. Организация циклов на языке ассемблера.
4) В каком регистре находится во время выполнения программы смещение кода?
5) Какую принципиальную роль играет оператор безусловного перехода JMP при организации ветвлений?
6) Что означает корректное завершение программы?