
- •В.А. Афанасьев
- •Часть 1 Лабораторный практикум
- •Предисловие
- •1. Краткая характеристика операционной среды ms-dos в компьютерах с операционной системой Windows
- •2. Составные части ms-dos и её инициализация
- •3. Взаимодействие Ассемблерной программы с ms-dos и аппаратными средствами Компьютера
- •4. Сегментированная организация памяти в реальном режиме. Виды памяти в среде ms-dos
- •Распределение первого мегабайта памяти компьютера
- •Содержание некоторых полей области данных bios
- •5. Программная модель 32-разрядных процессоров i80x86
- •Назначения сегментных регистров
- •6.2.2. Путь выполнения команды
- •6.2.3. Трансляция программы. Опции командной строки
- •6.2.4. Структура программы для .Exe- и .Com-файлов. Образ программы в памяти
- •Сегменты упрощенной модели памяти Small
- •%Title "Имя exe-файла программы"
- •%Title "Имя com – файла программы"
- •6.2.5. Работа с отладчиком Turbo Debugger (td)
- •6.2.6. Форматы машинных команд и их кодирование
- •Определение эффективного адреса
- •Косвенные виды адресации
- •6.2.6.2. Использование 32-битных регистров
- •6.2.7. Работа над синтаксическими ошибками при ассемблировании программы
- •6.3. Задание к работе. Порядок выполнения
- •6.4. Контрольные вопросы
- •Приложения к лабораторной работе № 1 п.1.1. Машинные коды команд базового процессора i8086
- •Машинные коды команд базового процессора i8086
- •П.1.2. Демонстрационные файлы
- •П.1.3. Форматы исполняемых файлов .Exe и .Com на диске
- •А) Листинг prog_com. Lst
- •Содержимое префикса программы psp
- •А) Листинг prog_exe.Lst
- •Б) Машинный код исполняемого файла prog_exe.Exe на диске объёмом 624 байта
- •Формат заголовка исполняемого .Exe – файла на диске
- •7.2.2. Ввод с клавиатуры символьной информации
- •7.2.2.1. Буфер ввода данных с клавиатуры
- •7.2.2.2. Системные функции dos ввода данных с клавиатуры
- •Сравнительная характеристика функций dos ввода с клавиатуры
- •7.2.3. Функции dos вывода данных на экран
- •7.2.4. Расширенные коды ascii и управление программой с клавиатуры
- •Расширенные коды для функциональных клавиш
- •7.2.5. Строковые команды. Общая характеристика
- •Команды обработки строк
- •7.3. Задания к работе. Подготовка и выполнение
- •7.4. Контрольные вопросы
- •Приложения к лабораторной работе № 2 Приложение п.2.1. Примеры реализаций типового задания
- •Приложение п.2.2. Esc-последовательности
- •Параметры Esc-последовательности
- •Приложение п.2.3. Таблица символов в кодировке ascii
- •8.2.2. Прямое программирование видеобуфера в текстовом режиме
- •8.2.3. Справочные данные по функциям bios
- •8.2.3.1. Прерывание int 10h. Видеофункции bios
- •Текстовые видеорежимы и страницы в стандарте vga, поддерживаемые современными видеоконтроллерами
- •8.2.3.2. Рекомендации по использованию видеосервиса bios
- •8.2.3.3. Прерывание int 16h
- •8.2.3.4. Задержка программных операций
- •Int 15h, функция 86h
- •8.3. Варианты индивидуального задания
- •8.4. Контрольные вопросы
- •Приложения к работе № 3 Примеры реализаций типовых заданий п.3.1. Листинг 3.4. Программа получения скан-кодов клавиш клавиатуры
- •П.3.2. Листинг 3.5. Демонстрационная программа использования функций bios для работы с экраном и клавиатурой
- •9.2.1. Представление знаковых и беззнаковых чисел в 16-разрядном компьютере
- •Представление чисел в 16- разрядном компьютере
- •9.2.2. Преобразование ascii-кодов чисел с произвольным основанием в двоичное число
- •9.2.3. Преобразование двоичного числа в ascii-строку числа по произвольному основанию
- •9.2.4. Задание к работе. Порядок выполнения
- •Варианты заданий 1-7
- •Варианты заданий 8-14
- •9.2.5. Вопросы построения многомодульных программ
- •9.2.6. Ассемблирование и компоновка отдельных модулей в программу. Создание библиотеки объектных модулей
- •9.3. Контрольные вопросы
- •Список использованной и рекомендуемой Литературы
- •Оглавление
Определение эффективного адреса
|
Поле md |
||||
Поле r/m |
11 |
00 |
01 |
10 |
|
|
w=0 |
w=1 |
|
|
|
000 |
al |
ax |
bx+si |
bx+si+d8 |
bx+si+d16 |
001 |
cl |
cx |
bx+di |
bx+di+d8 |
bx+di+d16 |
010 |
dl |
dx |
bp+si |
bp+si+d8 |
bp+si+d16 |
011 |
bl |
bx |
bp+di |
bp+di+d8 |
bp+di+d16 |
100 |
ah |
sp |
si |
si+d8 |
si+d16 |
101 |
ch |
bp |
di |
di+d8 |
di+d16 |
110 |
dh |
si |
d16)* |
bp+d8 |
bp+d16 |
111 |
bh |
di |
bx |
bx+d8 |
bx+d16 |
Когда операнд находится в памяти, то поле md определяет вариант использования внутрикомандного смещения disp (Displacement), находящегося в 3-м и в 4-м байтах:
md=00, disp=0;
md=01, disp =disp L-знаковое 8-битовое смещение (D8), расширяющееся со знаком до 16 бит при вычислении эффективного адреса ЕА;
md=10, disp =disp H, disp L- знаковое 16-битовое смещение (D16).
При этом кодировка поля reg второго операнда или поля r/m первого операнда при md = 11 определяет тип регистра в зависимости от значения параметра w. При md 11 реализуются косвенные виды адресации памяти, что и отражено в табл. 1.3 (исключение составляет случай прямой адресации при r/m = 110 и md = 00). Таким образом, в процессоре i8086 реализовано 24 варианта (8*3) вычисления эффективного адреса ЕА.
Таблица 1.3
Косвенные виды адресации
Тип адресации |
Способ вычисления EA |
Число тактов |
Косвенная Базовая, или индексная Базовая индексная без смещения
Базовая индексная со смещением
|
[BX], [BP], [SI], [DI] [BX+ , BP+ , SI+ , DI+disp] [BP+DI], [BX+SI] [BP+SI], [BX+DI] [BP+DI+disp] [BX+SI+disp] [BP+SI+disp] [BX+DI+disp] |
5 6 7 8 11 11 12 13 |
Замечание. Подчеркнём смысловое различие двух случаев употребления термина смещение. Смещение disp, содержащееся в команде, интерпретируется как знаковое число, которое участвует в вычислении эффективного адреса EA. С другой стороны, из-за сегментной организации памяти эффективный адрес EA является смещением OFFSET относительно базового адреса сегмента и интерпретируется как беззнаковое число при вычислении физического адреса (см. рис. 2, п. 4).
При вычислении физического адреса эффективный адрес (или смещение Offset) сегментируется регистром ds (сегмент данных) во всех случаях кроме тех, когда в формировании EA участвует сегментный регистр bp. Использование регистра bp в формировании EA предопределяет сегментирование адреса по регистру ss (сегмент стека). Чтобы изменить, указанное по умолчанию (см. также табл. 3, § 5) сегментирование адресов, предусмотрена специальная однобайтная команда-префикс замены сегмента:
001 Sreg 110 – формат команды префикса замены.
Если команде предшествует префикс замены, то при обращении к данным в процессе исполнения команды участвует сегментный регистр из префикса. Кодировка поля Sreg в префиксе: 00 – es, 01 – cs, 00 – ss, 11 – ds.
На рис. 1.6 б представлен формат двухоперандной команды с непосредственным операндом. В этом формате отсутствует необходимость в адресации второго операнда и поле reg отдано для расширения поля COP. Отсутствует также бит направления d, т.к. результат операции размещается на месте первого операнда. Место бита d занял бит s, функции которого определяются следующим образом:
sw = X0, data = data L -один байт данных;
sw = 01, data = dataH,dataL – два байта данных;
sw = 11, data = dataL – один байт данных, который расширяется со знаком до двух байт.
Постбайтовая адресация является универсальной адресацией и позволяет адресовать как общие регистры, так и ячейки памяти. Однако при адресации только регистров или аккумулятора Acc постбайт оказывается излишним, если поле reg разместить в первом байте команды или использовать неявную адресацию. Эта возможность реализуется в специальных укороченных форматах, которые содержат минимальное число байтов и, выбираются Turbo Assembler в процессе ассемблирования.
Двоичное кодирование ассемблерных команд, рекомендуется выполнять в следующей последовательности:
находим обобщённое представление команды, соответствующее одной из альтернативных записей команды в справочном списке команд (Приложение П. 1.1);
для выбранного обобщённого представления команды выписываем из таблицы её формат;
принимая во внимание формат данных, способ кодирования регистров и тип адресного выражения для операнда, находящегося в памяти (табл. 1.2) , определяем двоичный код для обозначенных в команде полей;
записываем структурированный по байтам машинный код команды с использованием 16-теричных символов. Полученный код должен совпадать с машинным кодом соответствующей команды из окна CPU Turbo Debugger для рассматриваемого файла.
В качестве примера ниже рассматривается машинная кодировка трёх ассемблерных команд, взятых из файла mov.asm. В качестве источника проверки машинного кода было использовано окно CPU Turbo Debugger.
Dataseg
w_x dw 8,16,32,64 ;Offset w_x = 0004h
Codeseg
cs:000C – BB0400 mov bx,offset w_x ;непосредственная адресация
cs:0014 – 8B160400 mov dx,[w_x] ;прямая адресация
cs:002C – C747021800 mov [word bx+2],24 ;базовая адресация
Команда: mov bx,offset w_x. В регистр bx занести offset переменной w_x.
1) Справочные данные команды:
mov r16,d16 ←→ 1011-w-reg dataL (dataH)
2) Кодировка обозначенных полей команды в пп. 1:
– w = 1, так как формат данных типа word;
– операнд-приёмник: reg = code(bx )= 011;
– операнд – источник: data H:dataL = offset w_x = 00h:04h – 16-битный адрес переменной w_x в сегменте данных. Этот адрес может быть легко вычислен путём просмотра списка переменных в памяти данных файла mov.asm.
3) Машинный код, таким образом, равен: 04h 00h = BB 04 00h
Команда: mov dx,[w_x]. В регистр dx занести значение переменной w_x.
1) Справочные данные команды:
mov r16,r16/m16 ←→ 1000101-w md-reg-r/m (dispL dispH)
2) Кодировка обозначенных полей команды в пп. 1
– w = 1, так как формат данных типа word;
– операнд-приёмник: reg = code(dx) =010;
– операнд-источник: содержимое ссылки на адрес переменной w_x. Прямая адресация с адресным выражением, обозначенным как D16 {m d= 00, r/m = 110} в табл. 1.2. Значение адреса D16 = dispH:dispL = offset w_x = 00h:04h определяется из просмотра списка переменных в памяти данных файла mov.asm.
3) Машинный код, таким образом, равен:
1000101-1 00-010-110 04h 00h = 8B 16 04 00h
Команда: mov [word bx+2],24. В ячейку памяти по адресу [bx+2], занести константу 24, зарезервировав под неё два байта (word).
1) Справочные данные команды:
mov r16/m16,d16 ↔ 1100011-w md-000-r/m (dispL dispH) dataL dataH
2) Кодировка обозначенных полей команды в пп. 1:
– w = 1, так как формат данных типа word;
– операнд-приёмник: ячейка памяти, определяемая адресным выражением [word dx + 2] = [d x+ d8], что определяет поля постбайта как: md = 01, r/m = 111;
– внутрикомандное смещение d8 = dispL = 02h, поле dispH исключается;
– операнд-источник константа 24 = 00 18h, так как формат данных типа word.
3) Машинный код, таким образом, равен:
1100011-1 01-000-111 02 18 00 = C7 47 02 18 00 h