"Ассемблер и программирование для IBM PC. (IBM PC assembler language and programming)" - читать интересную книгу автора (Абель Питер, Переводчик: Ю.В.Сальников)


+————————————————+
| D O S |
+———————+ +— — — — — — — — + +
SS | Адрес +—>| Сегмент стека | |
+ — — — + +— — — — — — — — + | Перемещаемые
DS | Адрес +—>| Сегмент данных | |
+ — — — + +— — — — — — — — + | в памяти
CS | Адрес +—>| Сегмент кода | |
+———————+ +— — — — — — — — + +
Сегментные | |
регистры | |
+————————————————+
Память
__________________________________________________________________________

Рис.1.2. Сегменты и регистры.


Внутри программы все адреса памяти относительны к началу cегмента.
Такие адреса называются смещением от начала сегмента. Двухбайтовое
смещение (16-бит) может быть в пределах от шест.0000 до шест.FFFF или от 0
до 65535. Для обращения к любому адресу в программе, компьютер складывает
адрес в регистре сегмента и смещение. Например, первый байт в сегменте
кодов имеет смещение 0, второй байт - 01 и так далее до смещения 65535.
В качестве примера адресации, допустим, что регистр сегмента данных
содержит шест.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 может
адресовать до четырех миллиардов байт.