Программирование видеоадаптеров CGA,EGA и VGA

         

Краткий обзор


Видеоадаптеры EGA и VGA содержат большое количество регистров. EGA имеет около шестидесяти регистров, а VGA и Super VGA еще больше. Большая часть регистров EGA доступна только для записи, что создает определенные проблемы, особенно для мультизадачных систем. Из-за этого некоторые фирмы-изготовители видеоадаптеров выпускают совместимые с EGA платы видеоадаптеров, для регистров которых разрешена также и операция чтения.

В новых адаптерах VGA и Super VGA практически все регистры доступны как для записи так и для чтения.

Условимся, что в тех случаях, когда VGA имеет отличия от EGA, мы будем на это специально указывать.

Доступ к большинству регистров видеоадаптеров осуществляется в два этапа: через один порт ввода/вывода выбирается номер интересующего вас регистра, а затем через другой порт ввода/вывода осуществляется обмен данными. Это позволяет сэкономить большое число портов процессора.

Заметим, что в различных режимах работы видеоадаптера, его регистры могут иметь различные адреса. В таблицах 8.1 и 8.2 приведен список адресов регистров в монохромных и цветных режимах.



АдресРегистр
3C2регистр определения различных режимов работы (Miscellaneous Output Register - MOR);
регистр состояния 0 (Input Status Register 0 - ISR0)
3BAрегистр управления дополнительным устройством (Feature Control Register)
регистр состояния 1 (Input Status Register 1 - ISR1)
3BBрегистр очистки защелки светового пера (Clear Light Pen Latch Register- CLPLR)
3BCустановка защелки светового пера (Set Light Pen Latch Register - SLPLR)
3C4,регистры синхронизатора
3C5(Sequencer Register's - SR)
3B4,регистры контроллера ЭЛТ
3B5(CRT Controller Register's - CRT_CR)
3CA,регистры графического контроллера
3CC,(Graphics Controller Register's - GCR)
3CE,
3CF
3C0регистр контроллера атрибутов (Attribute Controller Register - ACR)
3C3регистр разрешения работы системы VGA (VGA Enable Register - VGA_ER)
3C6,регистры цифро-аналогового преобразователя (ЦАП) VGA
3C7,(VGA Video DAC Register - VGA_DAC_R)
3C8,
3C9

Таблица 8.1 Карта портов ввода/вывода (монохромный режим).

АдресРегистр
3C2регистр определения различных режимов работы (Miscellaneous Output Register - MOR);
регистр состояния 0 (Input Status Register 0 - ISR0).
3DAрегистр управления дополнительным устройством Feature Control Register)
регистр состояния 1 (Input Status Register 1 - ISR1)
3DBрегистр очистки защелки светового пера (Clear Light Pen Latch Register- CLPLR)
3DCустановка защелки светового пера (Set Light Pen Latch Register - SLPLR)
3C4,регистры синхронизатора
3C5(Sequencer Register's - SR)
3D4,регистры контроллера ЭЛТ
3D5(CRT Controller Register's - CRT_CR)
3CA,регистры графического контроллера
3CC,(Graphics Controller Register's - GCR)
3CE,
3CF
3C0регистр контроллера атрибутов (Attribute Controller Register - ACR)
3C3регистр разрешения работы системы VGA (VGA Enable Register - VGA_ER)
3C6,регистры ЦАП VGA
3C7,(VGA Video DAC Register - VGA_DAC_R)
3C8,
3C9

Таблица 8.2 Карта портов ввода/вывода (цветной режим).

Адресное пространство видеопамяти также различается в разных режимах работы видеоадаптера. В таблице 8.3 приведены адреса памяти в зависимости от режима работы.

Номер режима работыАдрес памяти
0,1,2,3,4,5,6B000:8000-B000:FFFF
7B000:0000-B000:7FFF
0Dh,0Eh,0Fh,10h,11h,12h,13hA000:0000-A000:FFFF

Таблица 8.3 Распределение видеопамяти в различных режимах.

Функция Get_Seg_Vmem, приведенная ниже, при помощи функции 0Fh прерывания INT 10h определяет текущий режим работы видеоадаптера и возвращает сегмент начала видеопамяти. Если видеоадаптер работает в нестандартном режиме, функция возвращает ноль. #include "sysp.h" unsigned Get_Seg_Vmem(void) { unsigned char mode; unsigned seg_address; // определяем текущий режим видеоадаптера _asm { mov ah,0Fh int 10h mov mode,al } // если видеоадаптер находится в режимах 0, 1, 2, 3, // 4, 5, 6 то видеопамять начинается с сегмента B800h if((mode >= 0) && (mode <= 6)) seg_address = 0xB800; // если видеоадаптер находится в режиме 7, // то видеопамять начинается с сегмента B000h else if(mode == 7) seg_address = 0xB000; // если видеоадаптер находится в режимах 0Dh - 13h, // то видеопамять начинается с сегмента A000h else if((mode >= 0x0D) && (mode <= 0x13)) seg_address = 0xA000; // если видеоадаптер не находится в стандартном режиме // возвращаем ноль else seg_address = 0x0; return(seg_address); }

Ниже подробно рассмотрены регистры видеоадаптеров EGA и VGA. Регистры сгруппированы по признаку выполняемых ими функций. Мы выделили следующие группы регистров:

  • Внешние регистры.
  • Регистры контроллера ЭЛТ.
  • Регистры графического контроллера.
  • Регистры контроллера атрибутов.
  • Регистры синхронизатора
  • Регистры цифро-аналогового преобразователя VGA.



Содержание раздела