- •Архитектура пэвм
- •Пользовательские регистры
- •Регистры общего назначения
- •Сегментные регистры
- •Регистры состояния и управления
- •Регистры защищенного режима:
- •Организация памяти (реальный режим)
- •Элементы синтаксиса Ассемблера
- •Операторы
- •Директивы сегментации
- •Модели памяти
- •Идентификаторы, создаваемые директивой Model:
- •Этапы создания программы на ассемблере
- •2. Создание объектного модуля (трансляция программы)
- •3. Создание загрузочного модуля (компоновка программы)
- •4. Отладка программы
- •Определение простых типов данных:
- •Способы адресации Регистровая адресация
- •Непосредственная адресация
- •Способы адресации памяти
- •Переопределение сегмента
- •Особенности пересылки данных
- •Xch ax, bx ; команда двунаправленного обмена
- •Команды работы с адресами и указателями
- •Команды сдвига
- •Команды линейного сдвига
- •Команды циклического сдвига
- •Команды сдвига двойной точности
- •Примеры работы с битовыми полями
- •Команды преобразования данных
- •Xor ax, ax ; очистка регистра ax
- •Int 21h ;ожидание вода с клавиатуры
- •Команды обработки строк
- •Команды пересылки строк
- •Команды сравнения строк
- •Пример.
- •Сканирование строки
- •Загрузка элемента строки в аккумулятор
- •Перенос элемента из аккумулятора в строку
- •Ввод элемента цепочки из порта в строку
- •Вывод элемента цепочки в порт
- •Пример использования вложенных циклов
- •Массивы
- •Логические команды
- •Xor операнд1,операнд2
- •Логические команды поиска
- •Структуры
- •Описание шаблона структуры:
- •Заполнение шаблона:
- •Работа с полями структуры
- •Пример:
- •Шаблон записи:
- •Xor bl, mask i2 ; обнуление
- •Команды передачи управления
- •Безусловные переходы
- •Межсегментные переходы
- •Второй сегмент
- •Команды условного перехода
- •Команды условного перехода и флаги
- •Процедуры
- •Процедура в начале кодового сегмента
- •Процедура в конце кодового сегмента
- •Процедура в теле сегмента
- •Вызов процедуры
- •Ret [число]
- •Способы вызова процедуры
- •Прямой ближний вызов
- •Прямой дальний вызов
- •Косвенный ближний вызов
- •Косвенный дальний вызов процедуры
- •Организация интерфейса между процедурами, расположенными в разных модулях
- •Передачи параметров в процедуру через регистры
- •Фрагмент модуля 2
- •Возврат результата из процедуры
- •Макрокоманды и макроопределения
- •Особенности трансляции при получении объектного модуля
- •Где можно разместить макроопределение?
- •Связь Assembler с языками высокого уровня
- •Операторы типа inline
- •Ассемблерные вставки
- •Внешние процедуры Операторы типа inline
- •Ассемблерные вставки
- •Требования к программе на языке Assembler
- •Требования к программе на языке Pascal
- •Передача параметров из Pascal-программы в программу на ассемблере
- •Использование директивы model для организации взаимодействия программ
- •Int 10h; вывод символа
- •Возврат данных в вызывающую программу
- •Пример взаимодействия программ
- •Особенности com-программы
- •Пример программы типа .Com
- •Резидентные программы
- •Формат резидентной программы
- •Собственно программу.
- •Функцию записи в оп адреса точки входа программы для последующего вызова.
- •Функцию, которая оставляет программу резидентной.
- •Пример резидентной программы типа .Com
- •Iret ;возврат из процедуры
- •Int 27h ; оставляем программу резидентной
- •Вызов резидентной программы
- •Запись адреса резидентной программы в область межзадачных связей
- •Iret ;возврат из процедуры
- •Int 27h ; оставляем программу резидентной
- •Вызов резидентной программы через область межзадачных связей
- •Передача параметров в резидентную программу
- •Замена существующего вектора прерывания
- •Динамическое распределение памяти
- •Пример выделения и освобождения блока памяти
- •Int 21h ;блока памяти
- •Дочерние процессы
- •Особенности структуры материнской программы
- •Активизация дочернего процесса
- •Пример материнской программы
- •; Запуск дочернего процесса
- •Int 21h ; запуск дочернего процесса
- •Int 21h ; выход в ос (завершение программы)
- •Получение и анализ кода возврата в материнской программе
- •Int 21h ; код возврата передается через регистр al
- •Передача кода возврата из дочерней программы
- •Прерывания
- •Программируемый контроллер прерываний
- •Прохождение запроса на прерывание через контроллер
- •Программирование контроллера прерываний
- •Формат приказов icw
- •Формат приказов ocw
- •И f спользование таймера в программах на Assembler
- •Формирование задержки
- •Использование прерываний 8h для управления запуском программ
- •Программирование коммуникационного порта (com)
- •Микросхема uart 8250
- •Инициализация порта
- •Пример программы инициализации порта
- •Регистр статуса линии (порта)
- •Работа порта без использования механизма прерываний
- •Получение данных
- •Передача данных
- •Алгоритм работы программы приема /передачи без прерываний
- •Текст программы
- •Работа com – порта в режиме прерываний
- •Регистр разрешения прерываний
- •Регистр идентификации прерывания
- •Вызов обработчика прерывания
- •Управление модемом через порт
- •Пример установления связи через порт и модем
- •Защищенный режим микропроцессора
- •2. Регистры отладки
- •3. Регистры управления Регистры системных адресов
- •Структура дескрипторных таблиц
- •Локальная дескрипторная таблица (ldt)
- •Структура дескриптора:
- •Структура байта ar
- •Обработка прерываний в защищенном режиме
- •Особенности обработки ловушек
- •Шлюз задачи
- •Дескриптор tss
- •Структура шлюза вызова
-
Регистры состояния и управления
Регистры содержат информацию как о состоянии самого микропроцессора, так и программы, которая загружена в данный момент. К этим регистрам относятся регистр флагов и регистр указателя команд IP.
Регистр флагов
EFLAGS/FLAGS
31..19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
AC VM RF 0 NT IOPL OF DF IF TF SF ZF 0 AF 0 PF 1 CF
CF – флаг переноса. Арифметическая операция произвела перенос из старшего бита (есть перенос – 1, нет – 0).
PF – флаг паритета. Проверка четности количества единиц в младшем байте. Если четное количество единиц – записывается 1, если нечетное - 0.
AF – вспомогательный флаг переноса, который используется в операциях с BCD – числами.
ZF – флаг нуля. Если нулевой результат операции, то здесь записывается 1, в противном случае – 0.
SF – флаг знака. Отражает состояние старшего бита результата (7, 15, 31, 63 и т.д. – старшие биты).
OF – флаг переполнения. Используется для фиксирования факта потери значащего бита при выполнении арифметической операции (1- потеря, 0 – нет).
IOPL – два соседних разряда (12 и 13) – уровень привилегий ввода/вывода. Используется в защищенном режиме для контроля доступа к командам ввода/вывода в зависимости от привилегированности задачи.
NT – флаг вложенности задачи. Используется в защищенном режиме для фиксации того факта, что одна задача вложена в другую.
TF – флаг трассировки, предназначен для пошагового выполнения работы микропроцессора.
IF – флаг разрешения прерываний (1- аппаратные прерывания разрешены, 0 – запрещены).
RF – флаг возобновления. Используется при обработке прерываний от регистра отладки.
VM – флаг виртуального МП 8086 (1- процессор работает в режиме виртуального МП 8086, 0 – процессор работает в защищенном или реальном режиме).
AC – флаг выравнивания.
DF – флаг управления при использовании цепочных команд (0 - направления от начала к концу (возрастание адресов), 1 – строка обрабатывается по убыванию (от конца к началу строки)).
Существует 2 команды: STD – установить флаг DF, CLD – сбросить флаг DF.
IP – счетчик команд.
-
Регистры защищенного режима:
TR, LDTR, GDTR, IDTR
-
Организация памяти (реальный режим)
Особенности организации памяти в реальном режиме
-
Память сегментирована. Каждый сегмент может занимать до 64 Кбайт оперативной памяти.
-
Весь диапазон оперативной памяти – 1Мбайт.
-
Для обращения к конкретному физическому адресу в ОП необходимо определить адрес начала сегмента и смещения внутри сегмента.
Недостатки такой адресации:
-
Сегменты не защищены
-
Программа может обращаться по любым адресам. Сегменты имеют максимальный размер 64 Кбайт.
-
Сегменты могут перекрываться с другими сегментами.
Формирование физического адреса:
Эффективный адрес Линейный адрес
Смещение
Страничное
BX BP ∑ ∑ преобразование.
SI DI x16
Физический адрес
15 0
CS
DS
SS
(*)
FS
ES
GS
Каждый сегмент начинается на границе параграфа. При вычислении эффективного адреса участвует один из сегментных регистров. Каждый сегментный регистр имеет 16 разрядов. Умножение на 16 эквивалентно добавлению четырех младших разрядов к адресу сегмента. Таким образом, мы получим 20 разрядов и адресное пространство 1Мбайт. Если устройство страничного преобразования не используется, то физический адрес равен линейному.
Пример:
DS=015FH, Смещение=2845H
Эффективный адрес операнда в памяти:
015F0H
+ 2845H
03E35H