Студопедия — Косвенные виды адресации
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Косвенные виды адресации






Тип адресации Способ вычисления 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]  

 

Замечание. Подчеркнём смысловое различие двух случаев употребления термина смещение. Смещение disp, содержащееся в команде, интерпретируется как знаковое число, которое участвует в вычислении эффективного адреса EA. С другой стороны, из-за сегментной организации памяти эффективный адрес EA является смещением OFFSET относительно базового адреса сегмента и интерпретируется как беззнаковое число при вычислении физического адреса (см. рис. 2, п. 4).

При вычислении физического адреса эффективный адрес (или смещение Offset) сегментируется регистром ds (сегмент данных) во всех случаях кроме тех, когда в формировании EA участвует сегментный регистр bp. Использование регистра bp в формировании EA предопределяет сегментирование адреса
по регистру ss (сегмент стека). Чтобы изменить, указанное по умолчанию
(см. также табл. 3, § 5) сегментирование адресов, предусмотрена специальная однобайтная команда-префикс замены сегмента:

001 S reg 110 – формат команды префикса замены.

Если команде предшествует префикс замены, то при обращении к данным в процессе исполнения команды участвует сегментный регистр из префикса. Кодировка поля S reg в префиксе: 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







Дата добавления: 2014-11-10; просмотров: 684. Нарушение авторских прав; Мы поможем в написании вашей работы!



Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...

Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Аальтернативная стоимость. Кривая производственных возможностей В экономике Буридании есть 100 ед. труда с производительностью 4 м ткани или 2 кг мяса...

Вычисление основной дактилоскопической формулы Вычислением основной дактоформулы обычно занимается следователь. Для этого все десять пальцев разбиваются на пять пар...

Огоньки» в основной период В основной период смены могут проводиться три вида «огоньков»: «огонек-анализ», тематический «огонек» и «конфликтный» огонек...

Упражнение Джеффа. Это список вопросов или утверждений, отвечая на которые участник может раскрыть свой внутренний мир перед другими участниками и узнать о других участниках больше...

Влияние первой русской революции 1905-1907 гг. на Казахстан. Революция в России (1905-1907 гг.), дала первый толчок политическому пробуждению трудящихся Казахстана, развитию национально-освободительного рабочего движения против гнета. В Казахстане, находившемся далеко от политических центров Российской империи...

МЕТОДИКА ИЗУЧЕНИЯ МОРФЕМНОГО СОСТАВА СЛОВА В НАЧАЛЬНЫХ КЛАССАХ В практике речевого общения широко известен следующий факт: как взрослые...

СИНТАКСИЧЕСКАЯ РАБОТА В СИСТЕМЕ РАЗВИТИЯ РЕЧИ УЧАЩИХСЯ В языке различаются уровни — уровень слова (лексический), уровень словосочетания и предложения (синтаксический) и уровень Словосочетание в этом смысле может рассматриваться как переходное звено от лексического уровня к синтаксическому...

Плейотропное действие генов. Примеры. Плейотропное действие генов - это зависимость нескольких признаков от одного гена, то есть множественное действие одного гена...

Studopedia.info - Студопедия - 2014-2024 год . (0.009 сек.) русская версия | украинская версия