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

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

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






Тип адресации Способ вычисления 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; просмотров: 686. Нарушение авторских прав; Мы поможем в написании вашей работы!



Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...

Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...

Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...

Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

Анализ микросреды предприятия Анализ микросреды направлен на анализ состояния тех со­ставляющих внешней среды, с которыми предприятие нахо­дится в непосредственном взаимодействии...

Типы конфликтных личностей (Дж. Скотт) Дж. Г. Скотт опирается на типологию Р. М. Брансом, но дополняет её. Они убеждены в своей абсолютной правоте и хотят, чтобы...

Гносеологический оптимизм, скептицизм, агностицизм.разновидности агностицизма Позицию Агностицизм защищает и критический реализм. Один из главных представителей этого направления...

Тема: Изучение фенотипов местных сортов растений Цель: расширить знания о задачах современной селекции. Оборудование:пакетики семян различных сортов томатов...

Тема: Составление цепи питания Цель: расширить знания о биотических факторах среды. Оборудование:гербарные растения...

В эволюции растений и животных. Цель: выявить ароморфозы и идиоадаптации у растений Цель: выявить ароморфозы и идиоадаптации у растений. Оборудование: гербарные растения, чучела хордовых (рыб, земноводных, птиц, пресмыкающихся, млекопитающих), коллекции насекомых, влажные препараты паразитических червей, мох, хвощ, папоротник...

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