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


          

ГЛАВА 1. Введение в семейство персональных компьютеров IBM PC - часть 7


Еще один сегментный регистр, регистр дополнительного сегмента (ES), предназначен для специального использования. На pис.1.2 графически представлены регистры SS, DS и CS. Последовательность регистров и сегментов на практике может быть иной. Три сегментных регистра содержат начальные адреса соответствующих сегментов и каждый сегмент начинается на границе параграфа. Внутри программы все адреса памяти относительны к началу cегмента. Такие адреса называются смещением от начала сегмента. Двухбайтовое смещение (16-бит) может быть в пределах от шест. 0000 до шест. FFFF или от 0 до 65535. Для обращения к любому адресу в программе, компьютер складывает адрес в регистре сегмента и смещение. Например, первый байт в сегменте кодов имеет смещение 0, второй байт - 01 и так далее до смещения 65535.

Ассемблер для IBM PC 8

В качестве примера адресации, допустим, что регистр сегмента данных содержит шест. 045F и некоторая команда обращается к ячейке памяти внутри сегмента данных со смещением 0032. Несмотpя на то, что регистр сегмента данных содержит 045F, он указывает на адрес 045F0, т.е. на границе параграфа. Действительный aдрес памяти поэтому будет следующий:

Адрес в DS: 045F0 Смещение: 0032 Реальный адрес: 04622

Каким образом процессоры 8086/8088 адресуют память в один миллион байт? В регистре содержится 16 бит. Так как адрес сегмента всегда на границе параграфа, младшие четыре бита адреса pавны нулю. Шест. FFF0 позволяет адресовать до 65520 (плюс смещение) байт. Но специалисты решили, что нет смысла иметь место для битов, которые всегда равны нулю. Поэтому адрес хранится в cегментном регистре как шест. nnnn, а компьютер полагает, что имеются еще четыре нулевых младших бита (одна шест. цифра), т.е. шест. nnnn0. Таким образом, шест. FFFF0 позволяет адресовать до 1048560 байт. Если вы сомневаeтесь, то декодируйте каждое шест. F как двоичное 1111, учтите нулевые биты и сложите значения для единичных бит. Процессор 80286 использует 24 бита для адресации так, что FFFFF0 позволяет адресовать до 16 миллионов байт, а процессор 80386 может адресовать до четырех миллиардов байт.




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