Ассемблер и программирование для IBM PC



       

ГЛАВА 2. Выполнение программ - часть 9


A11200 MOV AX,[0012] | Адрес 04B13

то в памяти по адресу 04B13 содержится первый байт команды. Процессор получает доступ к этому байту и по коду команды (A1) oпределяет длину команды - 3 байта. Для доступа к данным по смещению [0012] процессор опреде ляет aдрес, исходя из содержимого регистра DS (как правило) плюс cмещение в операнде команды. Если DS содержит шест.04B1 (реальный адрес 04B10), то результирующий адрес данных определяется cледующим образом:

DS: 04B10 Смещение: 0012 Адрес данных: 04B22

Предположим, что по адресам 04B22 и 04B23 содержатся следующие данные:

Содержимое: 24 01 | | Адрес: 04B22 04B23

Ассемблер для IBM PC. Глава 2 39

Процессор выбирает значение 24 из ячейки по адресу 04B22 и помещает его в регистр AL, и значение 01 по адресу 04B23 - в регистр AH. Регистр AX будет содержать в результате 0124. В процессе выборки каждого байта команды процессор увеличивает значение регистра IP на единицу, так что к началу выполнения следующей команды в нашем примере IP будет содержать смещение 0026. Таким обpазом процессор теперь готов для выполнения следующей команды, которую он получает по адресу из регистра CS (04AF0) плюс текущее смещение в регистре IP (0026), т.е 04B16.

Четная адресация

Процессор 8086, 80286 и 80386 действуют более эффективно, eсли в программе обеспечиваются доступ к словам, расположен ным по четным адресам. В предыдущем примере процессор может сделать oдну выборку слова по адресу 4B22 для загрузки его непосредственно в регистр. Но если слово начинается на нечет ном адресе, процессор выполняет двойную выборку. Предполо жим, например, что команда должна выполнить выборку слова, начинающегося по адреcу 04B23 и загрузить его в регистр AX:

Содержимое памяти: |хх|24|01|хх| | Адрес: 04B23

Сначала процессор получает доступ к байтам по адресам 4B22 и 4B23 и пересылает байт из ячейки 4B23 в регистр AL. Затем он получает доступ к байтам по адресам 4B24 и 4B25 и пересылает байт из ячейки 4B23 в регистр AH. В результате регистр AX будет содержать 0124. Нет необходимости в каких-либо специальных методах программирования для получения четной или нечетной адрессации, не обязательно также знать является адрес четным или нет. Важно знать, что, во-первых, команды обращения к памяти меняют слово при загрузке его в регистр так, что получается правильная последовательность байт и, во-вторых, если программа имеет частый доступ к памяти, то для повышения эффективности можно определить данные так, чтобы они начинались по четным адресам. Например, поскольку начало сегмента должно всегда находиться по четному адресу, первое поле данных начинается также по четному адресу и пока следующие поля определены как слова, имеющие четную длину, они все будут начинаться на четных адресах. В большинстве случаев, однако, невозможно заметить ускорения работы при четной адрессации из-за очень высокой скорости работы процессоров. Ассемблер имеет директиву EVEN, которая вызывает выравнив нивание данных и команд на четные адреса памяти.




Содержание  Назад  Вперед