Банки памяти
Банки памяти используются, когда адресное пространство процессора мало, а приложение требует. При этом стоимостные и электротехнические ограничения позволяют нам установить в систему гораздо больше памяти, чем процессор может адресовать. Например, у многих" микроконтроллеров адрес имеет длину всего 8 бит, однако 256 байт данных, и тем более 256 команд кода для большинства приложений недостаточно. Многие из ранних персональных компьютеров, основанных на 8-разрядных микропроцессорах i8085 и Z80 с 16-разрядным адресом, имели гораздо больше 64 Кбайт памяти. Например, популярные в годы детства авторов компьютеры Yamaha имели до 2 Мбайт оперативной памяти.Адресация дополнительной памяти в этой ситуации обеспечивается дополнительным адресным регистром, который может быть как конструктивным элементом процессора, так и внешним устройством. Этот регистр дает нам дополнительные биты адреса, которые и обеспечивают адресацию дополнительной памяти. Регистр этот называется
расширителем адреса или селектором банка, а область памяти, которую можно адресовать, не изменяя селектор банка, - банком памяти. Значение регистра-селектора называют номером банка.
Банковая адресация в 16-разрядных
микропроцессорах
Внимательный читатель, знакомый с системой команд Intel 8086, не может
не отметить, что "сегментные" регистры этого процессора имеют
мало общего с собственно сегментацией, описываемой в главе
5. Эти регистры более похожи на причудливый гибрид селектора банков
и базового регистра. Как и описываемый далее PIC, I8086 имеет команды
"ближних" (внутрибанковых) и "дальних" (межбанковых)
переходов, вызовов и возвратов.
Относящийся к тому же поколению процессоров Zylog 800 имеет полноценные
селекторы банков. Из всех изготовителей 16-разрядных микропроцессоров
только инженеры фирмы Motorola осмелились расширить адрес до 24 бит (это
потребовало увеличения разрядности регистров и предоставления команд 32-разрядного
сложения), все остальные так или иначе экспериментировали с селекторами
банков и вариациями на эту тему.
В том случае, когда селектор банка программной памяти интегрирован в процессор, предоставляются специальные команды, позволяющие перезагрузить одновременно "младшую" (собственно регистр PC) и "старшую" (селектор банка) части счетчика команд.
Банки команд в Р/С
У микроконтроллеров PIC арифметические операции производятся только над
младшими 8 битами счетчика команд, поэтому относительные и вычислимые
переходы допустимы только в пределах 256-командного банка. Однако полное
— с учетом селектора банка — адресное пространство для команд достигает
64 Кбайт, а у старших моделей и 16 Мбайт за счет использования двух регистров-расширителей.
Переключение банка осуществляется специальными командами "длинного"
— межбанкового — перехода.
Рассмотрим ситуацию детальнее (рис. 2.15): из кода, находящегося в банке 1 по адресу OxlOaf, мы хотим вызвать процедуру, находящуюся в банке 2 по адресу 0x2000. Если мы сначала выполним переключение банка, мы окажемся в банке 2 по адресу ОхЮЬО, не имея никакого представления о том, какой же код или данные размещены по этому адресу. С той же проблемой мы столкнемся, если сначала попытаемся сделать переход по адресу Oxlfff.
В качестве решения можно предложить размещение по адресу Oxlfff в банке 1 команды переключения на банк 2. Возможно, для этого придется переместить какой-то код или данные, но мы попадем по желаемому адресу. Впро-Чем, если мы постоянно осуществляем межбанковые переходы, этот подход Потребует вставки команд переключения банка для каждой возможной точки входа во всех остальных банках. Ручное (да и автоматизированное)размещение этих команд — операция чрезвычайно трудоемкая, и возникает естественная идея: сконцентрировать все эти вставленные команды и соответствующие им точки входа в каком-то одном месте. Впрочем, даже эта идея не дает нам ответа на вопрос, как же при такой архитектуре возвращать управление из процедур? Вставлять команду переключения еще и для каждой команды вызова?
Рис. 2.15. Межбанковый переход
Развитие этой идеи приводит нас к чему-то, похожему на менеджер оверлеев (см.
разд. Оверлеи (перекрытия). программный
модуль, который присутствует во всех банках по одному и тому же адресу
(рис. 2.16). Если нам нужно вызвать известную процедуру в определенном
банке, мы передаем ее адрес и номер банка этому модулю, и он осуществляет
сохранение текущего банка, переключение и переход. Если процедура делает
возврат, она возвращает управление тому же модулю, который, в свою очередь,
восстанавливает исходный банк и возвращает управление в точку вызова.
Дальнейшее развитие этой идеи приводит к мысли, что самый простой способ
разместить этот код во всех банках — это усложнить схему работы селектора
банков, например, всегда отображать первый килобайт адресного пространства
на одни и те же физические адреса. Аппаратно это несложно: мы анализируем
старшие шесть битов адресной шины процессора. Если они не равны нулю,
мы подаем на старшие биты адресной шины памяти содержимое селектора банка,
если же равны — нулевые биты. Примерно этим способом и расширяют память
большинство микрокомпьютеров на основе 8-разрядных процессоров.
Поскольку мы вступили на путь анализа логического адреса, можно пойти
и дальше: разбить адресное пространство процессора на несколько банков,
каждый со своим селектором.
Рис. 2.16. Переключатель банков
Адресное пространство PDP-11
Машины серии PDP-11 имеют 16-разрядный адрес, который позволял адресовать
64 Кбайт. У старших моделей серии это пространство разбито на 8 сегментов
по 8 Кбайт каждый. Каждому из этих сегментов соответствует свой селектор
банка (в данном случае следует уже говорить о дескрипторе сегмента) (рис.
2.17). Физическое адресное пространство, которое может быть охвачено дескрипторами
сегментов, составляет 2 Мбайт, что намного больше адресов, доступных отдельному
процессу. На первый взгляд, эта конструкция представляет собой усложненную
реализацию банковой адресации, цель которой — только расширить физическое
адресное пространство за пределы логического, но тот факт, что, кроме
физического адреса, каждый сегмент имеет и другие атрибуты, в том числе
права доступа, заставляет нас признать, что это уже совсем другая история,
заслуживающая отдельной главы (см. главу
5).
Рис. 2.17. Виртуальная память PDP-11/20