Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Расширение основной памяти IBM PC




Рабочая концепция фирмы IBM при создании IBM PC содержала гипотезу, что объем основной памяти ЭВМ, предназначенной для пер­сонального использования в любой предметной области, не должен превышать 640 Кбайт. Поэтому в базовую модель IBM PC заложили 20-разрядную шину адреса системной магистрали. Наличие 20 линий в шине адреса позволяло адресовать память большего объема, чем было предусмотрено концепцией (220 = 1 Мбайт). «Излишек» адрес-, ного пространства в 384 Кбайта был поделен между видеопамятью (128 Кбайт) и ПЗУ (256 Кбайт).

Физически увеличить объем памяти несложно, для этого необходи­мо только подключить к системной магистрали дополнительные мо­дули. Такая возможность в IBM PC была предусмотрена. Но каждый байт дополнительной памяти должен иметь уникальный адрес, а ад­ресного пространства для дополнительной памяти нет.

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

В IBM PC XT фирма IBM применила другой способ: 256 Кбайт было сначала оставлено для ПЗУ, в котором размещалась базовая система ввода-вывода (BIOS). Анализ программ BIOS показал, что в оставленном для ПЗУ адресном пространстве (UMB — Upper Memory Block) имеются «окна» — неиспользуемые участки. Четыре таких участка (paqe frames), no 16 Кбайт каждый, были выделены, и их адре­са стали использоваться для адресации дополнительной памяти, под­ключенной к системной магистрали. Таким образом, общий объем ОП удалось увеличить на 64 Кбайта. Специальная программа (драйвер дополнительной памяти) «перехватывала» обращение к «окнам» ПЗУ и вместо них «подставляла» дополнительный модуль памяти (Expended Memory).

Дополнительная память не обязательно должна была иметь объем 64 Кбайта. Ее объем мог быть и большим (фирма IBM выпускала модули допблнительной памяти объемом 8 и 32 Мбайта). При этом драйвер дополнительной памяти делил ее на блоки по 16 Кбайт и «отображал» каждое окно UMB на один из блоков Expended Memory. Из-за этого память такого вида получила название отображаемой.

Но развитие персональных ЭВМ привело к необходимости более, серьезной корректировки рабочей концепции. Поэтому в IBM AT с микропроцессором i80286 разрядность шины адреса увеличили до 24, что позволило увеличить ее объем до 16 Мбайт. В МП i80386 разряд­ность шины адреса и адресных регистров микропроцессора увели­чена до 32, в результате чего допустимый объем ОП увеличился до 4 Гбайт.

Наряду с этим изменился принцип формирования абсолютного ад­реса ОП, в результате чего утрачена совместимость с программным обеспечением, разработанным для IBM PC XT.

Для того чтобы обеспечить совместимость AT с XT, было решено реализовать два режима работы микропроцессоров, имеющих номер, больший 80286: реальный и защищенный.

В реальном режиме дополнительные разряды шины адреса забло­кированы, что обеспечивает совместимость с микропроцессором i8086 и позволяет использовать операционную систему MS DOS и программ­ное обеспечение, разработанное для XT. Но при этом остается неис­пользованной вся дополнительная память, находящаяся за пределами 1 Мбайта.

В защищенном режиме применяется другой принцип формирова­ния абсолютного адреса ОП, благодаря чему возможно использова­ние всей имеющейся в наличии дополнительной (расширенной) памя­ти, но возникают трудности с использованием программного обеспе­чения, разработанным для MS DOS.

В IBM PC XT 20-битовый адрес формировался из двух машинных слов: базового адреса сегмента (16 бит) и смещения (16 бит). Это было связано с тем, что вся ОП делилась на сегменты емкостью 64 Кбайта. Адресация байтов внутри сегмента начиналась с 0 и заканчивалась адресом FFFF.

Внутрисегментный адрес байта называется смещением (т.е. сме­щением относительно начала сегмента). Начало же сегмента (т.е. его базовый 20-битовый адрес) однозначно определялось 16-битовым ад­ресом, который преобразовывался в 20-битовый адрес дописыванием справа четырех нулей. В машинных командах абсолютный (физичес­кий) адрес задавался либо прямым указанием базового адреса сег­мента и смещения (которые разделялись двоеточием, например OA12:F4B2, где ОА12 — 20-битовый адрес начала сегмента; F4B2 — 16-битовое смещение внутри сегмента), лдбо по умолчанию (базовые адреса сегментов программы, данных, стека запоминаются в специ­альных регистрах микропроцессора), либо указанием регистра, в ко­тором содержится необходимый базовый адрес (например, если регистр называется CS, то абсолютный адрес в машинной команде может быть задан в виде CS:F4B2).

Начиная с МП i80386, благодаря увеличению длины всех регист­ров для смещений до 32 бит, реализована возможность работы «с плос­кой памятью», не разделяемой на сегменты. Это допускает адреса­цию 232 байт или 4 Гбайта ОП. Кроме того, в защищенном режиме (начиная с МП i80286) можно использовать и сегментированную память, но сегментные регистры не суммируются со смещением, а предназначены в качестве указателя на управляющие таблицы, содержащие необходимую информацию о сегментах.

Желание использовать в реальном режиме всю фактически имеющуюся в наличии дополнительную память привело к созданию двух виртуальных режимов, один из которых — стандарт EMS (Expended Memory Specifications), реализующий принцип банкирования допол­нительной памяти.

Вся дополнительная память делится на страницы (банки) емкос­тью по 16 Кбайт; выбираются четыре страницы и объявляются актив­ными. Выбранные активные страницы отображаются на четыре окна UMB, теперь при обращении к одному из окон UMB вместо него под­ставляется отображенная на него страница дополнительной памяти.

Поскольку любое окно UMB можно отобразить на любую страни­цу дополнительной памяти (объявив ее активной), то, изменяя отобра­жение в процессе работы, можно использовать всю дополнительную память любого объема.

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

В соответствии с этим стандартом работают драйверы XMA2EMS.SYS, EMM386.SYS и др.

Стандарт EMS несколько снижает производительность системы, но не накладывает никаких ограничений на размещение в дополни­тельной памяти программ и данных.

Другой виртуальный режим основан на том, что за счет разблоки­рования на время дополнительных (по сравнению с XT) линий шины адреса системной магистрали удается увеличить доступное MS DOS адресное пространство еще почти на 64 Кбайта, начиная с адреса FFFFF (т.е. за пределами адресного пространства 1 Мбайт). Эта об­ласть адресного пространства (64 Кбайта, начиная с 1 Мбайта) полу­чила название НМЛ (High Memory Area) — старшая область памяти. Ее также можно использовать, работая в MS DOS, для хранения и про­грамм, и данных.

Блоки памяти, расположенные выше границы НМЛ, называются ЕМВ (Extended Memory Blocks) — расширенные блоки памяти, хотя часто расширенной памятью (ЕМ — Extended Memory) называют всю дополнительную память, расположенную в адресном пространстве выше 1 Мбайта, иногда выделяя в ней область НМЛ.

Кратковременное разблокирование дополнительных линий шины адреса системной магистрали позволяет реализовать стандарт XMS(extended Memory Specification), при котором разделенная на страни­цы ЕМ отображается на НМЛ, но в этом стандарте программные модули могут располагаться только в НМА, а остальная память мо­жет использоваться лишь для хранения данных. Стандарт XMS реа­лизуется драйвером HIMEM.SYS, который способен работать с ши­ной адреса, имеющей до 32 линий.




Поделиться с друзьями:


Дата добавления: 2015-06-26; Просмотров: 531; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.015 сек.