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

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

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





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




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


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


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


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

Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...

Краткая психологическая характеристика возрастных периодов.Первый критический период развития ребенка — период новорожденности Психоаналитики говорят, что это первая травма, которую переживает ребенок, и она настолько сильна, что вся последую­щая жизнь проходит под знаком этой травмы...

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

Ситуация 26. ПРОВЕРЕНО МИНЗДРАВОМ   Станислав Свердлов закончил российско-американский факультет менеджмента Томского государственного университета...

Различия в философии античности, средневековья и Возрождения ♦Венцом античной философии было: Единое Благо, Мировой Ум, Мировая Душа, Космос...

Характерные черты немецкой классической философии 1. Особое понимание роли философии в истории человечества, в развитии мировой культуры. Классические немецкие философы полагали, что философия призвана быть критической совестью культуры, «душой» культуры. 2. Исследовались не только человеческая...

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