|
Архитектура ввода вывода персональных ЭВМ
Ю.С.Лукач,
А.Е.Сибиряков
А Р Х И Т Е К Т У
Р А В В О Д А - В Ы В О Д А
П Е Р С О Н А
Л Ь Н Ы Х Э В М I B M
P C
(C)
Инженеpно-техническое бюpо
Свеpдловск
1990
------------------------------------------------------------
Содеpжание
Введение
. . . . . . . . . . . . . . . . . . . .
. . . . .
Обозначения . . . . . . .
. . . . . . . . . . . . . . . .
1. Таблица портов
ввода-вывода . . . . . . . . . . . . . .
2.
Контроллер прямого доступа к памяти . . . . . . . . . . 2.1. Принципы работы
контроллера ПДП . . . . . . . . . . . 2.2. Типы передач . . . .
. . . . . . . . . . . . . . . .
2.3. Описание
внутренних регистров ПДП . . . . . . . . . . 2.4. Программное управление
контроллером ПДП . . . . . . . 2.4.1. Оpганизация и упpавление ПДП на XT-подобных
ПЭВМ . 2.4.2. Оpганизация и упpавление
ПДП на AT-подобных ПЭВМ .
3.
Программируемый контроллер прерываний . . . . . . . . . 3.1. Описание основных
элементов ПКП . . . . . . . . . . . 3.2. Режимы работы ПКП . . . . . . . . . . . . . . . . . .
3.3. Программирование
ПКП. . . . . . . . . . . . . . . . .
4. Таймер и
генерация звука . . . . . . . . . . . .
. . . 4.1. Программируемый таймер 8253 . . . . . . . . . . . . . 4.2. Таймер на
системной плате IBM PC . . . . . . . .
. . 4.3. Генерация звука . . . . . . .
. . . . . . . . . . . .
5.
Программируемый периферийный интерфейс
. . . . . . . . 5.1. Описание ППИ 8255 . .
. . . . . . . . . . . . . . . .
5.2. Использование
ППИ в IBM PC . . . . . . . . . . . . .
6.
Клавиатура . . . . . . . . . . . . . . . . . . . . . .
6.1. Клавиатура
IBM PC/XT . . . . . . . . . . . . . . .
. 6.2. Клавиатура IBM PC AT . . . . . .
. . . . . . . . . .
7.
Дисплеи . . . . . . . . . . . . . . . .
. . . . . . . .
7.1.
Общее описание . . . . . . . . . . . . . . . . . . .
7.2.
Контроллеры ЭЛТ . . . . . . . . . . . .
. . . . . . .
7.3.
Атрибуты символов . . . . . . . . . . .
. . . . . . .
7.4. Монохромный
графический адаптер MGA . . . . . . . . . 7.5. Цветной графический адаптер CGA
. . . . . . . . . . . 7.6. Расширенный графический адаптер EGA . . . . . . . .
. 7.7. Графический видеомассив VGA . . . . . . . . . . . . .
8.
Контроллер накопителей на гибких дисках . . . . . . . . 8.1. Основные сведения
о контроллере . . . . . . . . . . . 8.2. Порты контроллера накопителей на
гибких дисках. . . . 8.3. Команды управления накопителями . . . . . . . . . . .
8.3.1. Пеpечень команд контpоллеpа НГМД
. . . . . . . . . 8.3.2. Стpуктуpа байтов состояния . . . . . . . . . . . . 8.4. Формат дорожки.
. . . . . . . . . . . . . . . . . . .
8.5. Отличия
контроллера для АТ-подобных ПЭВМ. . . . . . .
9.
Контроллер накопителей на жестких дисках
. . . . . . . 9.1. Контроллер жестких дисков для ХТ-подобных ПЭВМ. . . .
9.1.1. Поpты ввода-вывода . . . . . . .
. . . . . . . . . 9.1.2. Общий фоpмат команды и теpминология . . . . . . . .
9.1.3.
Описание команд . . . . . . . . . . . . .
. . . . .
9.1.4.
Разметка диска . . . . . . . . . . . . . . . . . .
9.2. Контроллер жестких дисков
для АТ-подобных ПЭВМ. . . . 9.2.1. Описание поpтов ввода-вывода . . . . . . . . . . . 9.2.2. Система
команд . . . . . . . . . . . . . . . . . .
10.
Печатающее устройство . . . . . . . . .
. . . . . . . 11. Последовательный интерфейс RS-232 . . . . . . . . . . 11.1. Общие сведения . . . . . . . . . . . . . . . . . . .
11.2.
Описание портов . . . . . . . . . . . . . . . . . .
11.3. Порядок инициализации 8250
. . . . . . . . . . . . .
12. Игровой адаптер . . . .
. . . . . . . . . . . . . . .
13.
CMOS . . . . . . . . . . . . . . . . . . .
. . . . . .
13.1.
Доступ к CMOS . . . . . . . . . . . . . . . . . . .
13.2. Содержимое CMOS . . . .
. . . . . . . . . . . . . .
14. Прочие порты . . . . . . . . . . . . . . . . . . . . .
Приложение 1. Скан-коды клавиш .
. . . . . . . . . . . . . Приложение 2. Типы жестких дисков . . . . . . . . . . . . Пpиложение 3.
Подготовка ПЭВМ к pаботе . . . . . . . . . . Глоссарий . . . . . . . . . . . . . . . . . . . . . . . .
Введение
Данный
документ содержит техническое
описание устройств ввода-вывода, входящих в состав ПЭВМ семейства
IBM PC, включая ПЭВМ IBM PC
XT, AT и PS/2. Он
основан на технической документации фирм
- производителей периферийной аппаратуры, охватывающей
несколько десятков руководств. В частности, описание микросхем, размещенных на системной плате, базируется на справочниках фирмы
INTEL (Intel Handbooks).
Дополнительными источниками
информации послужили
многочисленные монографии,
журнальные статьи и
диалоговые справочные системы (такие, как TECH Help!, Norton Guide и др.). Кроме того, данное описание учитывает
опыт авторов по разработке и сопровождению
программ в среде MS-DOS. Этот опыт
позволил, во-первых, исправить
отдельные неточности и
недоговоренности в использованных
материалах, и, во-вторых,
описать ряд недокументированных особенностей оборудования IBM PC.
Вся
приведенная информация подвергалась максимальной
проверке
на ЭВМ; однако,
авторы предполагают, что отдельные
нюансы описаний, заимствованных из фирменной документации, могут содержать ошибки. Такие "подозрительные" моменты мы, по мере воазможности, старались
явно оговаривать в
соответствующих местах справочника.
Для понимания
изложенного здесь материала
требуется владение основами
программирования на языке
ассемблера для IBM PC (знание архитектуры процессора и директив
ассемблера).
Авторы будут благодарны за любые указания на
неточности, замечания и дополнения, которые мы просим присылать по адресу:
620075, г. Свердловск,
ул.
Луначарского 81, Инженерно-техническое бюро. тел. 56-92-54, 56-92-41.
Обозначения
PC,
XT, AT, PCjr,
PC Convertible и
PS/2 - это имена компьютеров
семейства IBM PC. Все они более или менее совместимы между собой на уровне прикладных пакетов, но имеют определенные
аппаратные различия:
PC: центральный процессор 8088, тактовая частота 4.77 МГц, 5 позиций для
адаптерных плат.
PCjr:
ЦП 8088, нет
места для плат.
Выпущена мизерным тиражом и не
совместима с остальными IBM PC. В
нашей серии не описывается.
XT: ЦП 8088, жесткий диск, 8 позиций для
адаптерных плат. В остальном аналогична PC.
Turbo PC: ПЭВМ других фирм (не IBM),
совместимые с PC и XT, но имеюший ЦП 8086 или V30 фирмы NEC, тактовая частота
которых 6 или 8 МГц. Обычно имеет 8 позиций для плат.
XT-286:
ЦП 80286, 8 позиций для плат,
частота 6 Мгц без холостых циклов (скорость как у AT с 8 МГц). Платы
от AT к ней не подходят, от PC подходят,
но не позволяют использовать преимущества 16-разрядной системной шины.
AT: ЦП 80286, 8 позиций для плат, тактовая частота 6 или 8 МГц.
PC Convertible: Портативный вариант AT.
Отличия: плазменный (LCD) дисплей, 3.5-дюймовые дисководы, нет позиций для плат расширения.
PS/2: Новое семейство ПЭВМ фирмы IBM. Модели 25 и 30 - это улучшенные версии старых PC, совместимые с ними по
адаптерным платам. Модели 50
и 60 - ЦП 80286,
32-разрядная шина
MicroChannel, совместимости со старыми платами нет. Модель 80 имеет ЦП
80386. Все модели оснащены дисководами размером 3.5 дюйма.
AT-386: ПЭВМ третьих фирм, совместимая с AT, но имеющая ЦП 80386.
Если
рассматриваемые устройства
зависят от типа ПЭВМ, то
используются следующие пометки:
PC/XT относится
к ПЭВМ IBM PC и XT, включая
Portable PC
AT относится
к ПЭВМ IBM PC AT
PS/2 относится к семейству PS/2
Отсутствие таких
указаний означает, что данный материал применим ко всем ПЭВМ
фирмы IBM.
Десятичные числа
записываются обычным образом, шестнадцатиричные отличаются
добавлением буквы "h" в конце. Например, 256 и 100h означают десятичное число 256.
Все размеры
полей в управляющих
структурах приведены в байтах, если не оговорено противное.
В некоторых
случаях алгоритмы сопровождаются формулами. Операции в формулах
обозначаются, как принято в языке Си,
а именно:
арифметические: +, -, *, /, % (взятие
остатка)
битовые: & (и), | (или), ~ (не)
сдвиги:
<< и >>.
1. Таблица портов ввода-вывода
Приведенная ниже таблица содержит
распределение адресного пространства портов
ввода-вывода для IBM PC/XT, AT и
PS/2. При этом:
- порты 0 - FFh отведены для системной
платы;
- порты 100h - 3FFh отведены для
контроллеров устройств;
-
порты, начиная с 400h, недоступны для системной шины.
AT/PS-2 PC/XT Описание См. раздел
----------------------------------------------------------------
000-01F 000-00F Контроллер ПДП N 1,
8237А-5 2
020-03F
020-021 Контроллер прерываний N 1,
8259A 3
040-05F
040-043 Таймер (PC/XT:8253-5,
AT:8254-2) 4
060-063
Программируемый интерфейс периферии 8255 5
060-06F Контроллер клавиатуры AT 8042 6
070-07F Память CMOS и маска NMI 13
080 Диагностический регистр 14
080-08F
080-083 Регистры страниц ПДП 74LS612 2
090-097 Блок управления каналами PS/2 ---
0A0 Маска
NMI 14
0A0-0BF Контроллер прерываний N 2, 8259A 3
0C0-0DF Контроллер ПДП N 2, 8237A-5 2
0F0-0FF Сопроцессор 80287 14
----------------------------------------------------------------
101-107 Выбор программируемых опций
PS/2 ---
170-177 Жесткий диск N 2 9
1F0-1F7 Жесткий диск N 1 9
200-207
200-20F Игровой адаптер 12
210-217
Блок расширений 14
238-23F Стык RS-232 N 4 (в PS/2) 11
278-27F
278-27F Параллельный принтер N2 (N 3
при MGA) 10
2C0-2DF
2C0-2DF Расширенный графический адаптер
(EGA) N 2 7
2F8-2FF
2F8-2FF Стык RS-232 N 2 11
300-31F Плата прототипа ---
320-32F
Жесткий диск XT 9
338-33F Стык RS-232 N 3 (в RS/2) 11
370-377 Контроллер НГМД N 2 8
378-37F
378-37F Параллельный принтер N 1 (N2
при MGA) 10
380-38F
380-38F Синхронные адаптеры: SDLC или
BSC N 2 --- 3A0-3AF 3A0-3A9 Синхронный адаптер BSC N 1 --- 3B0-3BF 3B0-3BF Монохромный адаптер (MGA) + принтер N 1 7,10 3C0-3CF 3C0-3CF Расширенный графический адаптер (EGA) N 1 7
3D0-3DF
3D0-3DF Цветной графический адаптер
(CGA) и EGA 7
3F0-3F7
3F0-3F7 Контроллер НГМД N 1 8
3F8-3FF
3F8-3FF Стык RS-232 N 1 11
----------------------------------------------------------------
Примечание:
В таблицу не включены устройства, базовый адрес ввода-вывода которых
может настраиваться (сетевые
адаптеры, контроллеры стриммерных лент и т.д.).
2. Контроллер
прямого доступа к памяти
Контроллер
прямого доступа к памяти
(ПДП, DMA - Direct Memory
Access) обеспечивает высокоскоростной обмен данными между устройствами
ввода-вывода и ОЗУ без использования центрального процессора, что позволяет освободить процессор для
выполнения вычислений параллельно с обменом
и независимо от него. Наиболее часто
возможности ПДП используются при работе с
дисковыми накопителями, однако
реализовано использование ПДП адаптерами
накопителей на
магнитной ленте и
рядом других устройств. Ощутимые приемущества дает
использование ПДП в процессе обмена с устройствами, принимающими или передающими
данные достаточно большими порциями с высокой скоростью.
В
IBM PC-подобных компьютерах
функции контроллера ПДП выполняет микросхема 8237А фирмы
INTEL (советский аналог КР580ВТ57) или ее аналоги
8237А-4 и 8237А-5,
работающие с тактовой
частотой 4 и
5 Мгц соответственно
(стандартная микросхема 8237А работает на частоте 3 Мгц). Контроллер имеет 4 независимых канала, каждый из которых может
обслуживать одно периферийное устройство.
2.1. Принципы
работы контроллера ПДП
В работе ПДП
различаются 2 главных
цикла: цикл ожидания (Idle cycle)
и активный цикл
(Active cycle). Каждый
цикл подразделяется на ряд
состояний, занимающих по времени один период часов (тик). Из цикла ожидания контроллер может быть переведен в состояние
программирования (Program Condition) путем подачи на вход RESET сигнала высокого
уровня, длительностью не менее 300
нc и следующей за ним
подачи сигнала низкого уровня
(уровня 0) на вывод CS
(Chip Select). В состоянии
программирования контроллер будет находится до тех пор, пока на выводе CS сохранится сигнал низкого уровня. В
процессе программирования контроллеру задаются:
- начальный адрес памяти для обмена;
- уменьшенное на единицу число передаваемых
байтов;
-
направление обмена,
а также устанавливаются требуемые режимы работы (разрешить или запретить циклическое изменение приоритетов,
автоинициализацию, задать направление изменения адреса при обмене и т. д.).
Загрузка
16-разрядных регистров контроллера
осуществляется через 8-разрядные
порты ввода-вывода. Перед загрузкой первого (младшего) байта должен быть сброшен (очищен)
триггер-защелка (триггер
первый/последний,
First/Last flip-flop), который изменяет свое состояние после
вывода в порт первого байта и таким
образом дает возможность следующей
командой вывода в тот же порт загрузить
старший байт соответствующего регистра.
Запрограммированный канал
должен быть демаскирован (бит маски канала устанавливается
при этом в 0), после чего он может
принимать сигналы "Запрос на ПДП", генерируемые тем внешним устройством, которое
обслуживается через этот
канал. Сигнал "Запрос на ПДП" может быть также инициирован
установкой в 1 бита запроса данного
канала в регистре запросов контроллера. После появления
сигнала запроса контроллер входит
в активный цикл, в котором выполняется
обмен данными. Обмен может
осуществляется в одном из четырех режимов:
1.
Режим одиночной передачи (Signle Transfer Mode). После каждого цикла передачи контроллер освобождает шину процессору, но сразу же
начинает проверку сигналов
запроса и, как только обнаруживает
активный сигнал запроса, инициирует
следующий цикл передачи.
2. Режим блочной передачи (Block Transfer
Mode). В этом режиме наличие
сигнала запроса требуется
только до момента выдачи контроллером сигнала
"Подтверждение запроса на
ПДП" (DACK), после чего
шина не освобождается вплоть до завершения передачи всего блока.
3.
Режим передачи по
требованию (Demand Transfer Mode). Данный режим является промежуточным между двумя первыми: передача идет непрерывно до
тех пор, пока
активен сигнал запроса, состояние
которого проверяется после
каждого цикла передачи. Как только устройство не может продолжить передачу, сигнал запроса сбрасывается им и
контроллер приостанавливает работу.
Этот режим применяется для обмена с
медленными устройствами, не позволяющими по своим временным характеристикам
работать с ПДП в режиме блочной передачи.
4. Каскадный режим (Cascade Mode). Режим
позволяет включить в подсистему ПДП
более одного контроллера в тех
случаях, когда недостаточно четырех каналов ПДП. В этом режиме один из каналов ведущего контроллера используется для
каскадирования с
контроллером
второго уровня. Для работы в каскаде
сигнал HRQ ("Запрос на захват") ведомого контроллера подается на вход DREG
("Запрос на канал ПДП")
ведущего, а сигнал DACK ("Подтверждение запроса") ведущего
подается на
вход HDLA ("Потверждение захвата") ведомого.
Такая схема
подключения аналогична подключению ведущего (первого) контроллера к микропроцессору, с
которым он обменивается
сигналами HRQ и HDLA.
2.2. Типы
передач
1. Передача память-память (Memory-to-memory
DMA). Используется для передачи
блока данных из одного места
памяти в
другое. Исходный адрес
определяется в регистрах
нулевого
канала, выходной - в регистрах первого канала. Число циклов обмена (число байт
минус 1) задается в регистре числа циклов канала 1. Передача происходит с использованием рабочего регистра контроллера в качестве промежуточного звена для хранения
информации. При передачe память-память может быть задан специальный режим фиксации адреса (Address hold),
при котором значение текущего адреса
в регистре нулевого
канала не
изменяется, при этом весь выходной блок
памяти заполняется одним и тем же элементом данных, находящимся по заданному
адресу.
2. Автоинициализация
(автозагрузка, Autoinitialization).
После
завершения обычной передачи
использованный канал ПДП маскируется
и должен быть
перепрограммирован для
дальнейшей работы с ним.
При автоинициализации маскировка канала после окончания
передачи не происходит, а регистры текущего адреса и счетчик циклов
автоматически загружаются из
соответствующих регистров с начальными значениями. Таким образом для
продолжения (повторения) обмена
достаточно выставить сигнал
запроса на ПДП по данному каналу.
3. Режим фиксированных приоритетов.
В
этом режиме канал 0 всегда имеет
максимальный приоритет, а канал 3
- минимальный. Это означает, что любая передача по каналу с более высоким приоритетом будет
выполняться раньше, чем по каналу с более низким приоритетом.
4. Циклический сдвиг приоритетов.
Позволяет
избежать
"забивания" шины одним
каналом при одновременной
передачe по нескольким каналам. Каждому каналу, по которому прошла
передача, автоматически присваивается низший приоритет, после
чего право на
передачу получает канал
с наивысшим приоритетом,
для которого передача в данный
момент возможна. Таким образом,
если в начале работы распределение приоритетов было обычным (канал 0 -
наивысший), и пришли сигналы запроса
на ПДП по 1-му и
2-му каналам, то
сначала будет выполняться передача по первому каналу, затем он получит низший
приоритет (а
канал 2, соответственно, высший, т. к. сдвиг приоритетов циклический) и передача выполнится по 2-му каналу, который затем
получит низший приоритет,
а высший приоритет получит, сответственно, канал 3, который
и будет обладать преимущественным правом на
передачу.
5. Сжатие
времени передачи (Compressed transfer timing).
В
случае, если временные
характеристики быстродействия
обменивающихся устройств
совпадают, ПДП может сократить время выполнения каждого
такта передачи на
2 цикла часов за счет тактов
ожидания, входящих в каждый цикл передачи.
2.3.
Описание внутренних регистров ПДП
Контроллер имеет 344 бита внутренней
памяти, организованной в виде регистров. Описание внутренних регистров ПДП приведено в таблице.
------------------------------------T--------------T-----------¬
¦
Наименование ¦
Разрядность ¦ Число ¦
¦
регистра ¦ (бит) ¦
регистров ¦
+-----------------------------------+--------------+-----------+
¦ Регистр начального адреса ¦ 16 ¦ 4 ¦
¦
(Base Address Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Регистр начального счетчика циклов¦ 16 ¦ 4 ¦
¦
(Base Word Count Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Регистр текущего адреса ¦ 16 ¦ 4 ¦
¦
(Current Address Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Регистр текущего счетчика циклов ¦ 16 ¦ 4 ¦
¦
(Current Word Count Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Рабочий регистр адреса ¦ 16 ¦ 1 ¦
¦
(Temporary Address Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Рабочий регистр счетчика циклов ¦ 16 ¦ 1 ¦
¦
(Temporary Word Count Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Регистр состояния ¦ 8 ¦ 1 ¦
¦
(Status Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Регистр команд ¦ 8 ¦ 1 ¦
¦
(Command Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Регистр режима (Mode Register) ¦ 6 ¦ 4 ¦
¦ ¦ ¦ ¦
¦
Рабочий регистр ¦ 8 ¦ 1 ¦
¦
(Temporary Register) ¦ ¦ ¦
¦ ¦ ¦ ¦
¦
Регистр масок (Mask Register) ¦ 4 ¦ 1 ¦
¦ ¦ ¦ ¦
¦
Регистр запросов ¦ 4 ¦ 1 ¦
¦
(Request Register) ¦ ¦ ¦
L-----------------------------------+--------------+------------
Регистр
начального адреса (Base Address Register).
В этом
регистре задается стартовый
адрес ОЗУ, с которого начинается
передача. Регистр содержит 16 разрядов и определяет адрес внутри
заданной страницы памяти
размером 64К. Задание номера
страницы памяти осуществляется через специальные
страничные регистры (Page
Registers), поддерживаемые
внешней логикой. Каждый канал ПДП имеет свой регистр начального адреса и
страничный регистр. Такое
деление памяти на
страницы не
позволяет осуществить
обмен с блоком
памяти, находящимся на пересечении двух страниц. Каждая страница
начинается с
сегментного адреса,
кратного 1000h (0,
1000h, 2000h, ..., 9000h).
Регистр
начального счетчика циклов
(Base Word Count Register).
В
этом регистре задается
начальное число циклов передачи для
программируемого канала. Фактическое
число передаваемых во время работы ПДП
элементов данных на единицу превышает
заданное число циклов, т. е. если
Вы задаете 100 циклов передачи, а
размер
элемента будет равен 1 байту, то за сеанс обмена будет передан 101 байт информации.
Регистр
текущего адреса (Current Address Register).
Начальное значение заносится в этот регистр одновременно с регистром начального
адреса. В дальнейшем
в ходе передачи значение текущего адреса
автоматически увеличивается или
уменьшается (конкретное
направление изменения задается
при программировании в регистре
режима). Если разрешена автоинициализация,
то после окончания передачи в регистр
автоматически устанавливается значение из регистра начального адреса.
Регистр
текущего счетчика циклов
(Current Word Count Register).
Регистр
содержит текущее значение
счетчика циклов (число оставшихся циклов передачи). Отображаемое в нем
число циклов всегда на
единицу меньше числа
еще не переданных элементов
данных, так как изменение значения в этом регистре проиводится в конце цикла передачи, уже после
фактической передачи элемента
данных, а
конец передачи фиксируется
в момент переполнения счетчика
(изменение его значения с 0 на 0FFFFh).
Регистр режима (Mode Register).
Данный
регистр задает режимы
работы своего канала
контроллера.
7 6 5
4 3 2 1 0
--T-T--T--T--T--T--T--¬
¦X¦X¦ ¦ ¦
¦ ¦ Биты:
L-+-+--+--+T-+T-+--T---
-----
¦ ¦ ¦
L----> 0-1: Режим работы: 00=проверка,
¦ ¦ ¦ 01=запись
(в память),
¦ ¦ ¦ 10=чтение
(из памяти),
¦ ¦ ¦ 11=недопустимая
комбинация
¦ ¦ L---------> 2: Автоинициализация: 1=разрешена,
¦ ¦ 0=запрещена
¦ L------------>
3: Изменение текущего адреса при
¦ обмене: 0=увеличение,
1=уменьшение
L----------------> 4-5: Тип передачи:
00=Режим
передачи по требованию, 01=Режим одиночной передачи, 10=Режим блочной передачи,
11=Каскадный режим.
Каждый из
четырех каналов ПДП имеет свой
набор регистров, описанных выше. Кроме того, имеется следующий набор регистров, общих для всех
каналов.
Регистр команд (Command Register).
Этот
8-битный регистр управляет
работой контроллера. Он
программируется, когда контроллер находится в состоянии программирования и очищается
командами сброса "Reset" и "Master
Clear". Назначение битов регистра команд приведено на рисунке.
7 6 5
4 3 2 1 0
---T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Бит:
LT-+T-+T-+T-+T-+T-+T-+T-- ---
¦ ¦
¦ ¦ ¦ ¦ ¦
L-> 0: 0=запретить передачу память-память,
¦
¦ ¦ ¦ ¦ ¦ ¦ 1=разрешить
¦ ¦
¦ ¦ ¦ ¦ L----> 1: 0=запретить фиксацию адреса в
канале
¦
¦ ¦ ¦ ¦ ¦ 0,
1=разрешить
¦ ¦
¦ ¦ ¦ L-------> 2:
0=разблокировать, 1=заблокировать
¦
¦ ¦ ¦ ¦ контроллер
¦ ¦
¦ ¦ L----------> 3: 0=нормальная временная диаграмма,
¦ ¦
¦ ¦ 1=сжатие времени передачи; если бит
¦
¦ ¦ ¦ 0
установлен, то игнорируется
¦ ¦
¦ L-------------> 4: 0=режим
фиксированных приоритетов,
¦
¦ ¦ 1=режим циклического сдвига
¦
¦ ¦
приоритетов
¦
¦ L----------------> 5:
1=Режим расширенной записи,
¦ ¦
0=задержки при
записи; если бит 3
¦ ¦ установлен, то
игнорируется
¦ L-------------------> 6: 0=активным
считается высокий уровень
¦ сигнала
запроса (DREQ), 1=низкий
L----------------------> 7: активным
считается высокий уровень сигнала подтверждения запроса на
ПДП (DACK), 1=низкий
Регистр состояния (Status Register).
Регистр
отражает текущее состояние
запросов и передач по всем четырем
каналам. Биты 0 - 3 устанавливаются в единицу после завершения передачи по
каналам 0 - 3 (бит 0 - канал 0, бит 1 канал 1 и т.д.), если не задан
режим автоинициализации. Эти биты очищаются
после команды сброса
контроллера и после
каждой операции считывания состояния из регистра состояния. Биты 4 - 7 указывают по какому из каналов 0 - 3 активен в текущий
момент сигнал запроса на ПДП.
Регистр масок (Mask Register).
Каждый бит этого 4-битового регистра маскирует/демаскирует свой канал ПДП, при
этом значение 1 маскирует канал,
значение 0 демаскирует канал и разрешает прием сигнала запроса по этому
каналу.
Регистр запросов (Request Register).
Сигнал
запроса на ПДП
(DREQ) может быть
издан как обслуживаемым устройством, так и программно. Для
программного издания сигнала запроса по одному
из 4-х каналов ПДП необходимо установить соответствующий бит в 4-разрядном регистре запросов. Запрос на ПДП
может быть отменен записью нулевого значения в соответствующий бит
регистра. Бит запроса
очищается автоматически при окончании передачи по данному каналу. Все
биты запросов очищаются при
сбросе контроллера. Для
того, чтобы воспринимать программные запросы на ПДП, канал должен находится в режиме
блоковой передачи.
Рабочий регистр (Temporary Register).
Этот
8-разрядный регистр используется для хранения
элемента данных, передаваемого в режиме
фиксированного адреса при
передаче память-память или
для временного хранения передаваемого байта при всех
остальных режимах передачи.
2.4.
Программное управление контроллером ПДП
Программное управление
контроллером ПДП осуществляется через порты ввода-вывода.
Доступ к каждому регистру контроллера
может быть осуществлен через свои порты ввода-вывода. В разделах 2.4.1 и 2.4.2 описывается программное управление контроллерами
на
XT- и АТ-подобных ПЭВМ соответственно.
2.4.1. Организация и управление
ПДП на XT-подобных ПЭВМ
IBM
PC XT и XT-совместимые ПЭВМ имеют один
4-канальный контроллер ПДП 8237А. Назначение каналов следующее:
0 - обмен память-память;
1 - свободен (может
использоваться сетевыми адаптерами);
2 - обмен с контроллером гибких дисков;
3 -
обмен с контроллером жестких дисков.
В таблице
приведено описание портов
ввода-вывода, предназначенных для управления контроллером ПДП.
-------T--------T---------------------------------------------¬
¦ Порт ¦ Режим ¦ Назначение ¦
+------+--------+---------------------------------------------+
¦ 0h ¦ запись ¦ Запись начального
адреса в регистр начально-¦ ¦ ¦ ¦ го адреса и регистр текущего адреса канала
0¦
¦ ¦ ¦ ¦
¦
2h ¦ запись ¦ то же для канала 1 ¦
¦ ¦ ¦ ¦
¦
4h ¦ запись ¦ то же для канала 2 ¦
¦ ¦ ¦ ¦
¦
6h ¦ запись ¦ то же для канала 3 ¦
¦ ¦ ¦ ¦
¦
0h ¦ чтение ¦ Чтение начального адреса
из регистра началь-¦ ¦ ¦ ¦ ного адреса канала 0 ¦
¦ ¦ ¦ ¦
¦
2h ¦ чтение ¦ то же для канала 1 ¦
¦ ¦ ¦ ¦
¦
4h ¦ чтение ¦ то же для канала 2 ¦
¦ ¦ ¦ ¦
¦
6h ¦ чтение ¦ то же для канала 3 ¦
¦ ¦ ¦ ¦
¦
1h ¦ запись ¦ Запись в регистр
начального счетчика циклов ¦ ¦ ¦ ¦и в регистр текущего счетчика циклов
канала 0¦
¦ ¦ ¦ ¦
¦
3h ¦ запись ¦ то же для канала 1 ¦
¦ ¦ ¦ ¦
¦
5h ¦ запись ¦ то же для канала 2 ¦
¦ ¦ ¦ ¦
¦
7h ¦ запись ¦ то же для канала 3 ¦
L------+--------+----------------------------------------------
-------T--------T---------------------------------------------¬ ¦ Порт ¦
Режим ¦ Назначение ¦
+------+--------+---------------------------------------------+
¦ ¦ ¦ ¦
¦
1h ¦ чтение ¦ Чтение текущего значения
из регистра теку- ¦ ¦ ¦ ¦
щего счетчика циклов канала 0 ¦
¦ ¦ ¦ ¦
¦
3h ¦ чтение ¦ то же для канала 1 ¦
¦ ¦ ¦ ¦
¦
5h ¦ чтение ¦ то же для канала 2 ¦
¦ ¦ ¦ ¦
¦
7h ¦ чтение ¦ то же для канала 3 ¦
¦ ¦ ¦ ¦
¦
8h ¦ запись ¦ Запись регистра команд
ПДП ¦
¦ ¦ ¦ ¦
¦
8h ¦ чтение ¦ Чтение регистра
состояния ПДП ¦
¦ ¦ ¦ ¦
¦
9h ¦ запись ¦ Запись в регистр
запросов ПДП ¦
¦ ¦ ¦ ¦
¦
0Ah ¦ запись ¦ Запись бита маски для
одного из каналов ПДП ¦ ¦ ¦ ¦ ¦
¦
0Bh ¦ запись ¦ Запись регистра режимов
для одного из ¦
¦ ¦ ¦
каналов ПДП ¦
¦ ¦ ¦ ¦
¦
0Ch ¦ запись ¦ Очистка (сброс)
триггера-защелки (триггера ¦ ¦ ¦ ¦
первого/последнего) ¦
¦ ¦ ¦ ¦
¦
0Dh ¦ запись ¦ Программный сброс
контроллера ¦
¦ ¦ ¦ ¦
¦
0Eh ¦ запись ¦ Очистка битов масок всех
4-х каналов ¦
¦ ¦ ¦ ¦
¦
0Fh ¦ запись ¦ Запись регистра масок
для всех 4-х каналов ¦ ¦ ¦ ¦ ¦
¦
0Dh ¦ ¦ ¦
¦
или ¦ чтение ¦ Чтение рабочего регистра
ПДП ¦
¦
0Fh ¦ ¦ ¦
+------+--------+---------------------------------------------+
¦ 81h ¦ запись ¦ Задание номера
страницы для канала 2 ¦
¦ ¦ ¦ ¦
¦
82h ¦ запись ¦ то же для канала 3 ¦
¦ ¦ ¦ ¦
¦
83h ¦ запись ¦ то же для канала 1 ¦
¦ ¦ ¦ ¦
¦
87h ¦ запись ¦ то же для канала 0 ¦
L------+--------+----------------------------------------------
Порты 0h - 7h предназначены для записи исходных значений в регистры начального и текущего адреса,
начального и текущего
счетчика циклов для
всех 4-х каналов.
Так как порты восьмиразрядные, а
регистры, в которые
через них заносятся данные,
16-разрядные, то запись производится в два приема. Перед первой командой
вывода в требуемый
порт необходимо сбросить триггер-защелку, для чего выполняется команда вывода
произвольного значения в порт 0Ch,
после чего в требуемый порт
выводится младший байт 16-разрядного значения и затем старший байт следующей команды
вывода в тот же порт.
Вывод в порт 8h позволяет занести значение
в регистр команд ПДП. Описание битов регистра команд приведено в п.2.3.
Чтение
из порта 8h
считывает регистр состояния
ПДП. Описание битов регистра состояния приведено в п.2.3.
Запись
в порт 9h позволяет
установить или сбросить бит
запроса в регистр запросов для одного из каналов. Формат команды следующий:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦X X
X X X ¦ ¦ ¦ Биты:
L--+--+--+--+--+T-+T-+T--
-----
не
используются ¦ L--+--> 0-1: выбор
канала 00 - 0 ¦ 01 - 1
¦ 10 - 2
¦ 11 - 3
L-------->
2: 1=установить бит запроса на ПДП 0=сбросить бит запроса на ПДП
Запись
в порт 0Ah позволяет установить или сбросить бит маски в регистре масок для одного из каналов. Формат
команды:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦X X
X X X ¦ ¦ ¦ Биты:
L--+--+--+--+--+T-+T-+T--
-----
не
используются ¦ L--+--> 0-1: выбор
канала 00 - 0 ¦ 01 - 1
¦ 10 - 2
¦ 11 - 3
L-------->
2: 1=установить бит маски 0=сбросить бит маски
Запись
в порт 0Bh устанавливает значение в регистре режимов одного из 4-х каналов ПДП.
Биты 0 и 1 задают номер канала (00 0,
01 - 1, 10 - 2, 11 - 3). В биты 2
- 7 заносятся значения, передаваемые соответственно в биты 0 - 6 регистра режимов. Описание битов регистра
режимов приведено в п. 2.3.
Запись в порт 0Dh
задает программный сброс
контроллера (Master Clear). Вывод любого байта в этот порт имеет тот же эффект, что и аппаратный
сброс контроллера. При
программном сбросе очищаются регистры команд,
состояния, запросов и рабочий регистр. Так же сбрасывается триггер-защелка
и устанавливается все биты масок
в регистре масок.
После программного сброса контроллер переходит в цикл ожидания.
Вывод любого
байта в порт
0Eh очищает регистр масок сбрасывает биты
масок всех 4-х
каналов ПДП и таким образом
разрешает прием запросов на ПДП по всем каналам.
Через
порт 0Fh можно задать произвольное
значение регистра масок ПДП. Для этого необходимо в битах 0 -
3 регистра AL установить
требуемое значение масок каналов 0 - 3 соответственно и вывести это значение в
порт.
Страничные
регистры ПДП предназначены для задания параметра страницы памяти, с которой
будет производится обмен. Под номером страницы
понимаются старшие 4 бита полного 20-битового адреса ОЗУ, т.е.
начальные сегментные адреса страниц будут кратны 1000h (0, 1000h, 2000h, ..., 9000h). Напомним,
что архитектура ПДП позволяет
работать только со страницей памяти размером 64К, а логика,
обеспечивающая переключение
страниц устроена так, что
страницы имеют жесткие
границы, описанные выше.
Из-за этой особенности невозможно с помощью ПДП осуществить обмен с
блоками памяти, пересекающими границу между двумя такими страницами.
2.4.2.
Организация и управление ПДП на AT-подобных ПЭВМ
IBM PC AT
и AT-подобные ПЭВМ имеют два контроллера ПДП 8237А, работающиe в каскадном режиме.
Назначение
каналов следующие:
0 - свободен;
1 - адаптер SDLC;
2 - контроллер накопителей на гибких
дисках;
3 - контроллер накопителей на жестких
дисках;
4 - каскад с первым контроллером ПДП;
5,
6, 7 - свободны.
Управление
каналами 0 - 3 осуществляется
аналогично PC/ХТ. Каналы 4 - 7
предназначены для обмена 16-разрядными
словами. В связи с этим возникает ряд отличий в работе с этими каналами:
-
бит 0 в данных, заносимых
в регистры начального и текущего адреса, всегда
подразумевается равным 0, поэтому через
эти регистры передаются биты 1 - 16 полного 23-разрядного адреса (а не
биты 0 - 15 полного
20-разрядного адреса, как это реализовано на
ХТ-подобных ПЭВМ), по
этой же причине
в страничные регистры каналов 4 - 7 заносятся биты 17 - 23 полного
адреса, а не биты 16 - 23, как
это надо сделать при работе с
каналами 0 - 3;
- поскольку передача осуществляется 16-разрядными словами, в
регистры текущего и начального счетчика циклов заносится не число байт, а число
слов, уменьшенное на единицу;
- размеры страниц памяти, в пределах
которых возможен обмен в течение одной передачи составляют 2000h байтов.
В
таблице приведено описание
портов ввода-вывода,
предназначенных для управления вторым контроллером ПДП.
-------T--------T---------------------------------------------¬
¦ Порт ¦ Режим ¦ Назначение ¦
+------+--------+---------------------------------------------+
¦ 0C0h ¦ запись ¦ Запись начального адреса в регистр начально-¦ ¦ ¦ ¦
го адреса и регистр текущего адреса канала 4¦
¦ ¦ ¦ ¦
¦
0C4h ¦ запись ¦ то же для канала 5 ¦
¦ ¦ ¦ ¦
¦
0C8h ¦ запись ¦ то же для канала 6 ¦
¦ ¦ ¦ ¦
¦
0CCh ¦ запись ¦ то же для канала 7 ¦
¦ ¦ ¦ ¦
¦
0C0h ¦ чтение ¦ Чтение начального адреса из регистра началь-¦ ¦ ¦ ¦
ного адреса канала 4 ¦
¦ ¦ ¦ ¦
¦
0C4h ¦ чтение ¦ то же для канала 5 ¦
¦ ¦ ¦ ¦
¦
0C8h ¦ чтение ¦ то же для канала 6 ¦
¦ ¦ ¦ ¦
¦
0CCh ¦ чтение ¦ то же для канала 7 ¦
¦ ¦ ¦ ¦
¦
0C2h ¦ запись ¦ Запись в регистр начального счетчика циклов ¦ ¦ ¦ ¦и
в регистр текущего счетчика циклов канала 4¦
¦ ¦ ¦ ¦
¦
0C6h ¦ запись ¦ то же для канала 5 ¦
¦ ¦ ¦ ¦
¦
0CAh ¦ запись ¦ то же для канала 6 ¦
¦ ¦ ¦ ¦
¦
0CEh ¦ запись ¦ то же для канала 7 ¦
¦ ¦ ¦ ¦
¦
0C2h ¦ чтение ¦ Чтение текущего значения из регистра теку- ¦ ¦ ¦ ¦ щего счетчика циклов канала 4 ¦
¦ ¦ ¦ ¦
¦
0C6h ¦ чтение ¦ то же для канала 5 ¦
¦ ¦ ¦ ¦
¦
0Cah ¦ чтение ¦ то же для канала 6 ¦
¦ ¦ ¦ ¦
¦
0CCh ¦ чтение ¦ то же для канала 7 ¦
¦ ¦ ¦ ¦
¦
89h ¦ запись ¦ Задание номера страницы
для канала 6 ¦
¦ ¦ ¦ ¦
¦
8Bh ¦ запись ¦ то же для канала 5 ¦
¦ ¦ ¦ ¦
¦
8Ah ¦ запись ¦ то же для канала 7 ¦
¦ ¦ ¦ ¦
¦
8Fh ¦ запись ¦ то же для канала 4 ¦
L------+--------+----------------------------------------------
В
следующей таблице приведено
описание назначения портов второго
контроллера ПДП с указанием аналогичных портов первого контроллера.
Форматы данных, вводимых/выводимых
через эти порты совпадают с форматами
данных аналогичных портов
первого контроллера. При работе
с этими портами
следует только учитывать, что
нумерация каналов начинается
не с 0, как у первого
контроллера, а с 4 (канал
4 - это канал 0
второго
контроллера,
канал 5 - это его канал 1 и т. д.).
-------T--------T-----------------------------------T---------¬
¦ Порт ¦ ¦ ¦ Аналог. ¦
¦ ¦ Режим
¦ Назначение ¦ порт ¦
¦
ПДП-2¦ ¦ ¦
ПДП-1 ¦
+------+--------+-----------------------------------+---------+
¦ 0D0h ¦ запись ¦ Запись регистра команд ПДП ¦ 8h ¦
¦ ¦ ¦ ¦ ¦
¦
0D0h ¦ чтение ¦ Чтение регистра состояния ПДП ¦ 8h ¦
¦ ¦ ¦ ¦ ¦
¦
0D2h ¦ запись ¦ Запись в регистр запросов ПДП ¦ 9h ¦
¦ ¦ ¦ ¦ ¦
¦
0D4h ¦ запись ¦ Запись бита маски для одного из ка¦ 0Ah ¦
¦ ¦ ¦
каналов ПДП ¦ ¦
¦ ¦ ¦ ¦ ¦
¦
0D6h ¦ запись ¦ Запись регистра режимов для одного¦ 0Bh ¦
¦ ¦ ¦
из каналов ПДП ¦ ¦
¦ ¦ ¦ ¦ ¦
¦
0D8h ¦ запись ¦ Очистка (сброс) триггера-защелки ¦ 0Ch ¦
¦ ¦ ¦
(триггера первого/последнего) ¦ ¦
¦ ¦ ¦ ¦ ¦
¦
0DAh ¦ запись ¦ Программный сброс контроллера ¦ 0Dh ¦
¦ ¦ ¦ ¦ ¦
¦
0DCh ¦ запись ¦ Очистка битов масок всех
каналов ¦ 0Eh ¦
¦ ¦ ¦ ¦ ¦
¦
0DEh ¦ запись ¦ Запись регистра масок для всех 4-х¦ 0Fh ¦
¦ ¦ ¦
каналов ¦ ¦
¦ ¦ ¦ ¦ ¦
¦
0DAh ¦ чтение ¦ Чтение рабочего регистра ПДП ¦ 0Dh ¦
¦ ¦ ¦ ¦ ¦
L------+--------+-----------------------------------+----------
3. Программируемый контроллер
прерываний
Программируемый контроллер
прерываний (ПКП, Programmable
Interrupt Controller, PIC)
реализует векторную систему
прерываний. Микросхема
8259А фирмы Intel
(советский аналог
КР580ВН59), а так же ее
модификации 8259А-2 и
8259А-8, поддерживает 8 уровней прерываний от восьми различных устройств.
Основные функции контроллера:
-
фиксация запросов на
прерывания от восьми
внешних источников;
- программное маскирование поступающих
запросов;
- присвоение фиксированных или циклически
изменяемых приоритетов входам контроллера, на которые поступают
запросы;
- инициация вызова процедуры обработки
поступившего аппаратного прерывания.
Количество
обслуживаемых внешних источников
прерываний может
быть увеличено путем
каскадирования нескольких
контроллеров.
Расположение выводов микросхемы контроллера
8259A
приведено на
рисунке.
-------------¬ -------------¬
__ ¦
L--- ¦
CS
-¦ 1 28
¦- Vcc
__ ¦ ¦
WR
-¦ 2 27
¦- A0
__ ¦ ¦ ____
RD -¦ 3 26 ¦-
INTA ¦ ¦
D7
-¦ 4 25
¦- IR7
¦ ¦
D6
-¦ 5 24
¦- IR6
¦ ¦
D5
-¦ 6 23
¦- IR5
¦ ¦
D4
-¦ 7 22
¦- IR4
¦ ¦
D3
-¦ 8 21
¦- IR3
¦ ¦
D2
-¦ 9 20
¦- IR2
¦ ¦
D1
-¦ 10 19
¦- IR1
¦ ¦
D0
-¦ 11 18
¦- IR0
¦ ¦
CAS0
-¦ 12 17
¦- INT
¦ ¦ __ __
CAS1
-¦ 13 16
¦- SP/EN
¦ ¦
GND
-¦ 14 15 ¦- CAS2
¦ ¦
L-----------------------------
------------T----------T---------------------------------------¬
¦Обозначение¦Тип вывода¦
Назначение ¦
+-----------+----------+---------------------------------------+
¦ Vcc ¦
- ¦ Питание + 5 В ¦
¦ ¦ ¦ ¦
¦ GND ¦ - ¦ Общий (земля) ¦
¦ __ ¦ ¦ ¦
¦ CS ¦ вход ¦ Выбор микросхемы ¦
¦ __ ¦ ¦ ¦
¦ RD ¦ вход ¦ Чтение ¦
¦ __ ¦ ¦ ¦
¦ WR ¦ вход ¦ Запись ¦
¦ ¦ ¦ ¦
¦ D0-D7 ¦двунаправ-¦ Выводы на шину данных ¦
¦ ¦ленные ¦ ¦
¦ ¦выводы ¦ ¦
¦ ¦ ¦ ¦
¦
CAS0-CAS2 ¦ входы/ ¦ Для ведущего контроллера являются ¦
¦ ¦ выходы ¦ выходами, для всех
ведомых входами. ¦
¦ ¦ ¦ Предназначены для передачи ведущим ¦
¦ ¦ ¦ информации для выбора необходимого ¦
¦ ¦ ¦ ведомого. ¦
¦
__ __ ¦ ¦ ¦
¦
SP/EN ¦ вход ¦ Выбор ведущего
контроллера ¦
¦ ¦ ¦ ¦
¦
INT ¦ выход ¦ Запрос на прерывания ¦
¦
____ ¦ ¦ ¦
¦
INTA ¦ вход ¦ Подтверждение
прерывания ¦
¦ ¦ ¦ ¦
¦ A0 ¦
вход ¦ Выбор регистров контроллера ¦
¦ ¦ ¦ ¦
¦
IR0-IR7 ¦ входы ¦ Входы запросов на
прерывания от ¦
¦ ¦ ¦ внешних источников. ¦
L-----------+----------+----------------------------------------
В состав контроллера входят:
- схема управления чтением/записью;
- схема управления;
- схема каскадирования;
- регистр запросов на прерывания;
- схема обработки приоритетов;
- регистр состояния;
- регистр маскирования запросов на
прерывания.
ПКП может находиться в двух основных состояниях: настройки и
обслуживания запросов на
прерывания. В состоянии
настройки контроллер принимает управляющие слова
инициализации
(Initialization Command Words, ICW), в состоянии обслуживания операционные
управляющие слова (Operation
Control Words, OCW). Возможны несколько
режимов обслуживания источников прерываний:
- режим фиксированных приоритетов по по
уровням прерываний; - два различных варианта циклического сдвига приоритетов;
- режим автоматического завершения обработки
прерывания;
- режим специального маскирования;
-
режим опроса устройств.
3.1.Описание
основных элементов ПКП
Схема
управления чтением/записью (Read/Write Control
Logic). Основной функцией этого блока является
прием команд от микропроцессора и передача ему информации о состоянии
ПКП. Обмен с микропроцессором осуществляется
через специальный 8-разрядный буфер данных (Data Bus Buffer), являющийся
интерфейсом между ПКП и шиной данных. В состав
блока входят регистры управляющих слов ICW и OCW. Схема управляется входами
CS, RD, WR и A0. Вход CS
(Chip select) отвечает за выбор
микросхемы. Низкий уровень
сигнала на входе CS разрешает выполнение обмена с ПКП. Низкий уровень сигнала на
входе WR (Write) разрешает
микропроцессору выводить управляющие слова
ICW и OCW для приема их ПКП.
Низкий уровень сигнала на
входе RD (Read)
разрешает ПКП передать
микропроцессору информацию о
состоянии специальных регистров
IRR, ISR и IMR, которые описаны ниже.
Все
управляющие слова ICW и OCW принимаются
контроллером в виде 9-разрядных значений.
Разряды 0 -
7 передаются через
8-разрядный буфер данных.
Старший разряд (восьмой, считая с нуля) носит
название А0 и
устанавливается в 0 или 1 в
зависимости от того,
через какой из
двух возможных портов
ввода-вывода (четный или
нечетный) было передано
управляющее слово. Если для вывода
значения использовался порт с четным адресом, А0 будет равен 0, если использовался порт с
нечетным адресом на единицу большим, чем предыдущий, тогда А0 будет равен 1.
Регистр
запросов на прерывания (Interrupt Request Register, IRR) обслуживается через
входы IR0 - IR7 контроллера. Сигнал на
одном входов IR0 - IR7
- это запрос на прерывание соответствующего уровня
(0 - 7). В соответствии с сигналом запроса на
прерывание схемой управления
устанавливается соответствующий бит в регистре IRR.
Регистр состояния
(регистр обрабатываемых запросов, In-Service Register, ISR) описывает в битах 0 - 7 прерывания каких уровней (0 - 7) в
данный момент обрабатываются.
Регистр
маскирования запросов на прерывания (Interrupt Mask Register, IMR) описывает, прерывания каких уровней в настоящий момент замаскированы. Единичное
значение бита в IMR указывает на то, что прерывание соответствующего уровня при
появлении запроса в IRR блокируется.
Схема
обработки приоритетов (шифратор приоритетов, Priority Resolver)
определяет, прерывание какого
уровня в данный момент является
наиболее приоритетным для выполнения.
Схема
управления ПКП формирует
сигнал запроса на
прерывaние, поступающий
на вход INT
(запрос на прерывание)
микропроцессора. Если флаг IF регистра флагов процессора равен 1
(прерывания разрешены), процессор
отвечает сигналом по линии
INTA (подтверждение прерывания), после чего
сбрасывается в 0 разряд IRR и
устанавливается в 1 разряд ISR, соответствующие уровню обрабатываемого прерывания. После получения
второго сигнала подтверждения от процессора по линии INTA, ПКП передает на шину данных
8-битовый номер прерывания.
Данная
последовательность работы
схемы управления выполняется
при
подключении ПКП к
системе с микропроцессорами
8088/8086. При работе с микропроцессорами 8080/8085 последовательность работы
схемы управления несколько
отличается от описанной
выше.
Основное отличие состоит в том, что
процессору передается не только номер
прерывания, но и
код команды процессора
INT (прерывание) - байт 0CDh.
Схема каскадирования отвечает за работу
каскада из
нескольких
контроллеров. При подключении к
ведущему контроллеру выход INT каждого ведомого подключается к одному из входов
IR0 IR7 ведущего. Далее этот сигнал
передается ведущим на вход INT процессора. Когда
процессор возвращает сигнал
INTA, ведущий контроллер не только устанавливает бит в ISR и сбрасывает бит в IRR, но
и выдает на
свои выходы CAS0
- CAS2 номер уровня прерывания,
к которому подключен
ведомый, пославший запрос на
прерывание. Сигналы по
линии CAS0 -
CAS2 принимаются всеми ведомыми, однако обрабатываются только тем, который подключен к линии IR с
соответствующим номером.
3.2.Режимы
работы ПКП
1. Режим
фиксированных приоритетов (Fixed
Priority, Fully Nested Mode).
В этом режиме контроллер находится
сразу после инициализации. Запросы прерываний имеют жесткие приоритеты от 0 до 7 (0 -
высший) и обрабатываются в соответствии с
приоритетами.
Прерывание с меньшим приоритетом
никогда не будет обработано, если в
процессе обработки прерываний
с более высокими приоритетами постоянно возникают запросы
на эти прерывания.
2. Автоматический сдвиг приоритетов
(Automatic Rotation). В этом
режиме дается возможность обработать прерывания всех уровней без их дискриминации. Например,
после обработки
прерывания уровня
4 ему автоматически
присваивается низший
приоритет, при этом
приоритеты для всех
остальных уровней циклически
сдвигаются и прерывания уровня 5 будут иметь в данной ситуации высший
приоритет и, следовательно, возможность быть
обработанными.
3. Программно-управляемый сдвиг приоритетов(Specific
Rotation).
Программист может сам передать команду циклического сдвига приоритетов ПКП,
задав соответствующее управляющее слово. В команде задается номер уровня,
которому требуется присвоить
максимальный приоритет. После выполнения такой
команды
устройство работает
так же, как
и в режиме фиксированных
приоритетов, с учетом
их сдвига. Приоритеты
сдвигаются циклически,
таким образом если
максимальный приоритет был назначен уровню 3, то уровень 2 получит
минимальный и будет
обрабатываться последним.
4.
Автоматическое завершение обработки прерывания
(Automatic End Of
Interrupt, AEOI). В обычном
режиме работы процедура
обработки аппаратного прерывания
должна перед своим завершением очистить
свой бит в ISR специальной командой,
иначе новые прерывания не будут
обрабатываться ПКП. В режиме AEOI нужный бит в ISR автоматически сбрасывается в тот момент, когда
начинается
обработка прерывания нужной процедурой обработки и от нее не
требуется издавать команду
завершения обработки
прерывания (EOI). Сложность работы в данном
режиме обуславливается тем, что
все процедуры обработки аппаратных прерываний должны быть
повторно входимыми, т. к. за время их работы могут повторно возникнуть
прерывания того же уровня.
5.
Режим специальной маски
(Special Mask Mode). Данный
режим позволяет отменить
приоритетное упорядочение
обработки запросов и обрабатывать их по
мере поступления. После отмены
режима специальной маски
предшествующий порядок приоритетов уровней сохранается.
6. Режим
опроса (Polling Mode). В этом
режиме аппаратные прерывания не происходят автоматически. Появление
запросов на прерывание должно определяться считыванием IRR. Данный
режим позволяет так же получить от ПКП информацию о наличии запросов на прерывания
и, если запросы имеются, номер
уровня с
максимальным
приоритетом, по которому есть запрос.
3.3.Программирование
ПКП
Ниже описывается управление ПКП в ПЭВМ
на базе
микропроцессоров
Intel 8086/8088/80286. Возможности, позволяющие включить ПКП в ПЭВМ,
использующие другие процессоры, опущены.
Для
вывода информации в
ПКП используются 2
порта
ввода-вывода. Порт
с четным адресом (обычно это порт 20h) и порт с нечетным адресом (обычно 21h). Через эти порты
могут быть переданы 4 слова
инициализации (Initialization Control
Word, ICW1 - ICW4), задающие режим
работы ПКП, и 3 операционных управляющих слова
(слова рабочих приказов, Operation Control Words, OCW1 -
OCW3). В порт с четным адресом выводятся ICW1, OCW2 и OCW3.
OCW2 отличается от OCW3 тем, что бит 3 в ocw2 равен 0, а в OCW3 равен 1. В то
же время бит 4 в OCW2 и OCW3 равен 0, а
в ICW1 равен 1. Таким образом по значению, выводимому в порт с четным адресом,
однозначно определяется, в какой
регистр (ICW1, OCW2 или OCW3) заносятся данные.
Порт с нечетным адресом используется для
вывода ICW2, ICW3, ICW4 и OCW1. Неоднозначности интерпретации данных в этом случае так же не возникает, т. к. слова
инициализации ICW2 - ICW4 должны
непосредственно следовать за ICW1, выведенным в порт с четным адресом и
выводить в промежутке
между ними OCW1 не следует, онo
не будет опознанo контроллером.
Выводом
в порт с
четным адресом управляющего слова инициализации
ICW1 начинается инициализация ПКП. В процессе
инициализации контроллер последовательно принимает управляющие слова ICW1 - ICW4. При
наличии в системе одного контроллера ICW3 не
выводится. Наличие ICW4 определяется содержанием ICW1. При наличии каскада из
нескольких ПКП каждый из них инициализируется отдельно.
Формат ICW1 следующий:
A0 7 6
5 4 3 2 1 0
-----T----T----T----T----T----T----T----T----¬
¦ 0 ¦ -- ¦ -- ¦ -- ¦ 1 ¦LTIM¦ ADI¦SNGL¦ IC4¦
L----+----+----+----+----+-T--+-T--+-T--+-T---
¦ ¦ ¦ ¦
¦ ¦ ¦ L-> 1=будет вывод ICW4
¦ ¦ ¦ 0=не будет
¦ ¦ L------>
1=один контроллер
¦ ¦ 0=каскад
¦ L-----------> игнорируется
L----------------> 0=запуск запросов
фронтом
1=запуск
запросов уровнем
Бит 4, равный 1, определяет, что выводится ICW1, а не OCW2 или OCW3.
Бит 3 (LTIM), равный 0, задает запуск
запросов фронтом, при этом действует описанная выше схема: бит в IRR сбрасывается при установке
соответствующего бита в ISR.
Бит
2 (ADI) используется только в ПЭВМ на базе микропроцессоров Intel
8080/8085.
Бит
1 (SNGL) указывает
на наличие в
системе одного контроллера (если
равен 1) или
каскада из нескольких контроллеров (если равен 0). Если этот бит равен 1, то ICW3 не выводится в процессе
инициализации и следом за ICW2 сразу должно следовать ICW4.
Бит 0 (IC4) определяет, будет ли выводиться
ICW4. Если ICW4 не выводится (бит
0 = 0), то оно автоматически
заполняется нулями. В описываемых ПЭВМ
наличие ICW4 обязательно, т. к. тип
микропроцессора 8086/8088 задается в нем
значением 1 в одном из битов.
Управляющее слово ICW2 задает номер вектора прерывания для прерываний
уровня 0 (например 8 для IBM PC, у
которых по уровню 0 происходят прерывания от таймера). Так как вектора аппаратных прерываний располагаются подряд друг за
другом, вывод в ICW2
значения 8 не только задает восьмой
вектор для таймера, но и девятый для прерываний уровня 1, десятый (0Ah) для прерываний уровня 2 и т. д.
Управляющее слово ICW3 выводится только при
наличии каскада и имеет разный формат для
ведущего и ведомых контроллеров. ICW3 ведущего указывает, к каким
входам IR0 - IR7 подключены ведомые
контроллеры, при этом соответствующие
биты устанавливаются в 1. Остальные биты при этом равны 0. ICW3
следующего вида:
A0 7
6 5 4 3 2
1 0
-----T----T----T----T----T----T----T----T----¬
¦ 1 ¦
0 ¦ 0 ¦ 0 ¦
1 ¦ 0 ¦ 0 ¦
1 ¦ 0 ¦
L----+----+----+----+----+----+----+----+-----
задает, что
в каскаде имеется
2 ведомых контроллера, подключенных к входам IR1 и
IR4.
ICW3
ведомого (подчиненного, slave)
ПКП в трех младших битах задает
номер уровня, на
котором работает ведомый
контроллер. Для ведомого контроллера, работающего
на уровне 1 ICW3 будет выглядеть следующим образом:
A0 7
6 5 4 3 2
1 0
-----T----T----T----T----T----T----T----T----¬
¦ 1 ¦
0 ¦ 0 ¦ 0 ¦
0 ¦ 0 ¦ 0 ¦
0 ¦ 1 ¦
L----+----+----+----+----+----+----+----+-----
Если ведомый
контроллер работает на уровне 4, то его
ICW3 будет таким:
A0 7
6 5 4 3 2
1 0
-----T----T----T----T----T----T----T----T----¬
¦ 1 ¦
0 ¦ 0 ¦ 0 ¦
0 ¦ 0 ¦ 1 ¦
0 ¦ 0 ¦
L----+----+----+----+----+----+----+----+-----
Последнее
слово инициализации (ICW4)
имеет следующий формат:
A0
7 6 5 4 3 2 1 0
-----T----T----T----T----T----T----T----T----¬
¦ 1 ¦
0 ¦ 0 ¦ 0 ¦SFNM¦ BUF¦ M/S¦AEOI¦ mPM¦
L----+----+----+----+-T--+-T--+-T--+-T--+-T---
¦ ¦ ¦ ¦ ¦
¦ ¦ ¦ ¦ L--->
1=8088/8086
¦ ¦ ¦ ¦ 0=8080/8085
¦ ¦ ¦ L--------> 1=AEOI
¦ ¦ ¦ 0=EOI
¦ ¦ L------------->
1=ведущий
¦ ¦ 0=ведомый
¦ ¦ (только при BUF=1)
¦ L------------------> 1=режим
¦
буферизации
L----------------------->
1=специальный вложенный режим
Бит 0
(mPM) определяет, с каким
микропроцессором работает ПКП (0 - 8080/8085, 1 - 8086/8088).
Бит
1 (AEOI), равный
1, задает режим
автоматического завершения обработки
прерывания, описанный выше. Если
этот бит равен 0, действует
обычное соглашение: процедура
обработки аппаратного прерывания должна сама сбрасывать свой бит в ISR.
Бит 2 (M/S) игнорируется, если бит 3 (BUF)
= 0. При наличии одного контроллера и
BUF = 1 устанавливается в 1. При наличии каскада должен быть равен 1
только для ведущего контроллера.
Бит
4 (SFNM) устанавливает специальный вложенный режим, применяемый при
каскадировании для определения
приоритетов запросов от разных контроллеров (Special Fully Nested Mode).
После инициализации ПКП готов к работе в заданном режиме. Для
изменения режимов работы,
задаваемых при инициализации требуется переинициализировать
его заново.
В
процессе работы с ПКП Вы можете без переинициализации:
- маскировать
и размаскировать аппаратные прерывания;
- изменять приоритеты уровней;
- издавать
команду завершения
обработки аппаратного прерывания;
-
устанавливать/сбрасывать режим специальной маски;
- переводить контроллер в режим
опроса и считывать состояние регистров ISR и IRR; для
этого Вам потребуется вывести в порты ПКП одно из трех слов рабочих приказов
OCW1 - OCW3.
Формат
первого слова рабочих приказов OCW1:
A0
7 6 5 4 3 2 1 0
-----T----T----T----T----T----T----T----T----¬
¦ 1 ¦ M7 ¦ M6 ¦ M5 ¦ M4 ¦ M3 ¦ M2 ¦ M1 ¦ M0 ¦
L----+----+----+----+----+----+----+----+-----
Единичное значение одного из битов М0 - М7 означает, что
прерывания соответствующего уровня (IR0
- IR7) маскируются и не будут обрабатываться контроллером.
Второе
слово рабочих приказов
(OCW2) предназначено для
вывода команды завершения
обработки аппаратного прерывания (EOI), циклического сдвига и
явного изменения приоритетов уровней. Назначение битов OCW2
следующее:
A0 7 6 5 4
3 2 1 0
-----T----T----T----T----T----T----T----T----¬
¦ 0 ¦
R ¦ SL ¦ EOI¦ 0 ¦ 0 ¦ L2 ¦ L1 ¦ L0 ¦ L----+-T--+-T--+-T--+----+----+-T--+-T--+-T---
¦ ¦ ¦ ¦ ¦ L-->
Эти 3 бита опреде-
¦ ¦ ¦ ¦ L-------> ляют номер уровня
¦ ¦ ¦ L------------>
прервания, если он
¦ ¦ ¦ требуется в команде.
¦ ¦ ¦
¦ ¦ ¦
¦ ¦ L---------------------------> 1-команда
завер-
v v шения обработки
-----T----¬ аппаратного
¦ 0 ¦
0 ¦ Используется вместе с EOI=1
прерывания
+----+----+
¦ 0 ¦
1 ¦ Специфицированный EOI (сбрасывает бит, определя+----+----+ емый
полями L0 - L2 в ISR)
¦ 1 ¦
0 ¦ Циклический сдвиг приоритетов влево на одну
+----+----+ позицию
¦ 1 ¦
1 ¦ Назначение низшего приоритета уровню, определяеL----+----- мому
полями L0 - L2
Как
уже говорилось, процедура
обработки аппаратного
прерывания должна перед своим
завершением очистить свой бит в ISR
выводом команды завершения
обработки прерывания (End Of
Interrupt, EOI). Существует два варианта
команды EOI: обычный и специфицированный
EOI. Обычный EOI очищает
бит в ISR, соответствующий прерыванию
с максимальным приоритетом. Специфицированный EOI
(R=0, SL=1, EOI=1, L0 - L2 равно номеру уровня прерывания) очищает
в ISR бит, соответствующий
прерыванию с номером, указанным в
L0 - L2 независимо от его
приоритета. Команды с битом
R=1 позволяют изменить
приоритеты уровней. Циклический
сдвиг приоритетов сдвигает
приоритеты влево на единицу, при этом, если после обычного
распределения
приоритетов, издать
команду циклического сдвига,
уровень 0 получит низший приоритет, уровень 1 -
наивысший, уровень 2 следующий за
ним и т.д. Команда явного
назначения низшего приоритета
одному из уровней
изменяет приоритеты остальных уровней циклически. Таким образом,
если Вы зададите низший приоритет уровню 5, то
уровень 6 получит наивысший.
Третье слово рабочих приказов OCW3
позволяет установить и отменить режим
специальной маски, перевести
контроллер в режим опроса и
прочитать содержимое IRR и ISR.
Назначение битов OCW3 приведено на рисунке
A0 7 6 5 4
3 2 1 0
-----T----T----T----T----T----T----T----T----¬
¦ 0 ¦
0 ¦ESMM¦ SMM¦ 0 ¦ 1 ¦
P ¦ RR ¦ RIS¦ L----+----+-T--+-T--+----+----+-T--+--T-+-T---
----------- ¦ ¦ ¦ ¦
¦
------------ L-T---+---+-->
1-режим опроса
v v v v v
----T---¬ ----T---T---¬
¦
1 ¦ 0 ¦-Отменить режим ¦ 0 ¦ 1 ¦ 0 ¦
Чтение IRR
+---+---+
специальной маски +---+---+---+
¦
1 ¦ 1 ¦-Установить режим ¦ 0 ¦ 1 ¦ 1 ¦
Чтение ISR
L---+----
специальной маски L---+---+----
Единичное
значение бита Р
(бит опроса, Polling
Bit) переводит контроллер в
режим опроса. Если после этого считать данные из порта с четным адресом, в регистр AL загрузится байт следующего содержания:
7
6 5 4 3 2
1 0
-----T----T----T----T----T----T----T----¬
¦ I ¦
0 ¦ 0 ¦ 0 ¦
0 ¦ L2 ¦ L1 ¦ L0 ¦ L----+----+----+----+----+----+----+-----
Если
I = 1, значит имеются запросы на прерывания и тогда L0 - L2 - это
номер уровня с наивысшим приоритетом, по которому имеется запрос на
прерывание.
Если
P=0, Вы можете считать информацию из
ISR или IRR. Для этого необходимо издать команду чтения ISR или IRR (см. рисунок выше) и затем
считать значение из порта с нечетным адресом.
Единичное значение бита ESMM позволяет в
зависимости от значения бита
SMM установить или
отменить режим специальной маски.
4. Таймер и
генерация звука
4.1.
Программируемый таймер 8253
Для
задания временных интервалов и
формирования сигналов с различными
временными параметрами в
IBM PC/XT применяется программируемый таймер 8253 (отечественный аналог КР580ВН53), в AT -
8254. С точки зрения программиста
они идентичны. В состав таймера входят:
буфер шины данных,
схема управления
вводом-выводом и три
независимых канала, каждый
из которых содержит регистр режима,
схему управления каналом,
буфер и 16-разрядный счетчик.
Программирование канала
осуществляется путем вывода управляющих слов в регистр режима каналов и начального значения в его
счетчики. Каждый канал имеет управляющий вход GATE и выход OUT и может работать
в одном из следующих шести режимов.
Режим 0
(прерывание терминального счета). После записи управляющего слова
в регистр режима
канала на выходе
ОUT устанавливается напряжение низкого
уровня; загрузка счетчика не изменяет
это состояние. Затем
начинается декремент счетчика
(последовательное вычитание из него единицы). В момент, когда счетчик
обнулится, на выходе
OUT установливается напряжение
высокого уровня и
сохраняется до загрузки
счетчика новым значением. Счет возможен только при наличие
сигнала высокого уровня на
входе GATE. Низкий
уровень этого сигнала
или ниспадающий фронт запрещают счет.
Перезагрузка счетчика
во время приводит
к следующему: загрузка младшего
байта останавливает текущий счет, загрузка старшего байта
запускает новый цикл счета. Минимально допустимое значение счетчика равно 2.
Режим
1 (ждущий мультивибратор). На выходе
OUT формируется отрицательный
импульс длительностью t=n*T,
где n - число, загруженное в счетчик,
T - период тактовых импульсов. Низкий уровень на выходе OUT устанавливается со следующего такта после
подачи на вход GATE сигнала высокого уровня.
Загрузка
в счетчик нового числа не влияет на длительность текущего импульса,
а учитывается при
следующем запуске. Перезапуск
счетчика производится нарастающим
фронтом входа GATE (без перезагрузки счетчика). Минимальное допустимое n=1.
Режим
2 (генератор частоты).
Каждый раз после достижения счетчиком
нуля на выходе OUT появляется
отрицательный импульс с длительностью
один такт. Перезагрузка счетчика сказывается
только после перезапуска счетчика. При
исчезновении сигнала
высокого
уровня на входе GATE прекращается счет
и на выход OUT подается напряжение
высокого уровня. Перезапуск
счетчика происходит при наличии на входе GATE сигнала высокого уровня.
Режим
3 (генератор меандра).
Аналогичен режиму 2,
но положительный уровень выходного
сигнала занимает первый полупериод, а отрицательный - второй полупериод. Точнее, если n
(начальное значение счетчика) четно, то длительность положительного и отрицательного полупериодов равна n*T/2; если же n нечетно - то (n+1)*T/2 и
(n-1)*Т/2 соотвественно. Низкй уровень
сигнала на входе GATE запрещает счет, на выходе OUT устанавливается сигнал
высокого уровня. Высокий уровень GATE разрешает счет, а
нарастание его запускает счетчик
начального состояния. Отметим, что n=3 в этом режиме недопустимо.
Режим
4 (счетчик событий).
По окончании отсчета числа,
загруженного в счетчик, на выходе OUT
формируется отрицательный импульс длительностью один такт. Запись в счетчик во
время счета младшего байта не влияет на
текущий счет, а запись старшего байта перезапускает счетчик. Низкий
уровень входа GATE запрещает счет,
высокий - разрешает.
Минимальное допустимое значение счетчика равно 1.
Режим
5 (счетчик событий
с автозагрузкой). Отличие от режима 4 состоит в том, что каждое нарастание сигнала на входе GATE перезапускает счетчик. Перезагрузка счетчика не влияет на текущий цикл,
однако следующий цикл
определяется вновь занесенным
числом.
Временные диаграммы режимов таймера приведены на следующем рисунке:
¦-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬
CLK
+-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L
__
+¬n=5 -----------------¬n=4 -------------------
WR
¦L----- L-----
¦ --------------------------¬ ---------
GATE +-------- L----
+-----¬ ----------¬ ---
OUT ¦ L------------ L----------------
¦
n ¦ 5 4 3 2 1 0 4 3 2 2 1 0
L-------------------------------------------------
Режим 0
¦-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬
CLK
+-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L
__ +¬n=4 -------¬n=5 -----------------------------
WR
¦L----- L-----
¦ -----------¬ --¬
-------------- GATE +---------- L-----
L-----
+-----------¬ --------¬ --- OUT
¦ L-------- L----------------
¦
n ¦ 4 3 2 1 0 5 4 3 5 4 3 2 1 0
L-------------------------------------------------
Режим 1
¦-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬
CLK +-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L
__ +¬n=4 ---¬n=3 ---------------------------------
WR
¦L----- L-----
¦ -------------------------¬ ---------- GATE +-------
L-----
+-------------¬
-----¬ ------¬ -----------¬ ---
OUT ¦
L-- L-- L-- L--
¦
n ¦ 4 3
2 1 0 3 2 1 0 3 2 1 0 3 2 1 0
L-------------------------------------------------
Режим
2
¦-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬
CLK
+-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L
__
+¬n=4 -----------------¬n=5 -------------------
WR
¦L----- L-----
¦
---------------------------------¬
----
GATE +------ L----
+----------¬ ------¬
------¬ ---------
OUT ¦
L----- L----- L-----
¦
n ¦ 4 3
2 1 0 4 3 2 1 0 4 3 2 1 0
5 5 4
L-------------------------------------------------
Режим
3
¦-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬
CLK
+-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L
__
+¬n=4 -----------------¬n=5 ----------------------
WR
¦L----- L-----
+------------------------------¬ ---------------
GATE ¦ L----
+--------------¬
-----------------------------¬ --
OUT ¦
L-- L--
¦
n ¦ 4 3
2 1 0 5 5 4 3 2 1 0
L-------------------------------------------------
Режим
4
¦-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬-¬
CLK
+-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L-L
__
+¬n=4 -----------------------------------------
WR
¦L-----
¦ ---------¬ --¬ ------------------
GATE +---------- L---- L----
+-----------------¬
------------------¬ -------
OUT ¦ L-- L--
¦
n ¦
4 3 2 1 0 4 3 4 3 2 1 0
L-------------------------------------------------
Режим
5
В
IBM PC таймер имеет базовый
адрес 40h и следующие программируемые регистры:
Адрес
Операция Назначение
----------------------------------------------------
40h запись Загрузка счетчика канала 0
чтение Чтение счетчика канала 0
41h запись Загрузка счетчика канала 1
чтение Чтение счетчика канала 1
42h запись Загрузка счетчика канала 2
чтение Чтение счетчика канала 2
43h запись Запись управляющего слова
в регистр режима канала
-----------------------------------------------------
Управляющее слово имеет следующий формат:
7
6 5 4 3 2
1 0 --T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦ ¦
Биты
Маска
L-+--+--+--+--+T-+--+-T- ---- ------- ¦ ¦ ¦
L> 0: 0 = двоичный код,
а & 1
¦ ¦
¦ 1 =
двоично-десятичный код
¦ ¦
L-------> 1-3: режим работы канала: а & 0Eh
¦ ¦ 000 - режим 0
¦ ¦ 001 - режим 1
¦ ¦ X10 - режим 2
¦ ¦ X11 - режим 3
¦ ¦ 100 - режим 4
¦ ¦ 101 - режим 5
¦ L-------------->
4-5: вид загрузки счетчика: а &
30h
¦ 00
- "защелкивание"
¦ (биты 0-3 безразличны)
¦ 01
- только младший байт
¦ 10
- только старший байт
¦ 00
- младший байт, затем старший
L-------------------->
6-7: номер канала: a &
C0h 00 - канал 0
01 - канал 1 10 -
канал 2
11 - запрещенная
комбинация
Существует
два способа чтения текущего значения счетчика канала.
1. Чтение с остановом счетчика. Для обеспечения стабильных
показаний необходимо приостановить работу канала либо подачей сигнала
низкого уровня на
вход GATE (кроме режима 1), либо блокированием
тактовых импульсов.
2. Чтение "на лету". Для считывания счетчика без остановки
процесса счета используется посылка в порт 43h управляющего слова в режиме
"защелкивания" (см. выше).
Это управляющее слово фиксирует текущее
значение счетчика и Вы
можете считать его младший байт, а
затем старший байт.
4.2. Таймер на системной плате IBM
PC
В IBM PC
каналы таймера имеют следующее назначение.
Канал Назначение Режим
----------------------------------------------------------------
0 системные
часы (IRQ0) 3, счетчик=0
(65536)
1 запрос
для канала 0 ПДП
(регенерация памяти) 2, счетчик=18
2 генератор
звука --
----------------------------------------------------------------
Тактовая частота каждого канала равна
1,19318 МГц, т. е. каждый такт
имеет длительность 0,84 мсек. Вход GATE
каналов 0 и 1 всегда имеют высокий уровень, поэтому счет
на этих каналах
разрешен всегда.
Вход GATE канала 2 управляется битом 0 порта PB интерфейса 8255 (см. гл. 5), связанного
с портом 61h.
При
начальной загрузке BIOS
инициализирует канал 0 для
работы в режиме 3 со счетчиком 0 (т. е. 65536 декрементов на
цикл счета). Поэтому частота системных часов равна
1,19 МГц/65536 = 18.2 Гц
и
прерывание IRQ0, связанное с вектором
Int 8, происходит 18,2
раз
в секунду, т. е. каждые 55 мсек.
Вы можете перепрограммировать канал 0, но
тогда
- BIOS не сможет отслеживать
текущее время и дату;
-
нарушится работа с гибкими дисками, т.
к. включение и выключение их двигателей отсчитывается по текущему
времени.
Канал
1 работает в
режиме 2 со
счетчиком 18, поэтому регенерация
памяти происходит каждые
18 мсек. Перепрограммировать его нельзя,
т. к. это приведет к потере данных в ОЗУ.
Программирование
канала 2 описано в следующем пункте.
4.3.
Генерация звука
На вход
звукогенератора поступает логическое
"И" двух сигналов:
выхода OUT 2-го канала таймера и содержимого бита 1 порта РВ интерфейса 8255.
Поэтому простейший способ генерации
звука состоит в программировании канала
2 таймера так, чтобы он выдавал
прямоугольный импульс заданной
частоты, лежащий в звуковом
диапазоне (20 Гц
- 20 КГц). Для этого
следует использовать режим
таймера 3 с подходящим начальным значением счетчика. Если затем установить
биты 0 и 1 порта РВ, то импульс начнет
поступать на вход звукогенератора (бит
0 - это вход GATE канала 2, разрешающий
счет, а бит 1 - разрешение
выдачи выхода OUT на вход звукогенератора). Для выключения звука достаточно сбросить
биты 0 - 1 в РВ. Преимущество этого метода
состоит в том, что, запустив
генерацию звука, ЦП может
выполнять другие действия.
Значение счетчика 2-го канала вычисляется по формуле n=1193181/f=1234DDh/f
(1193181 - тактовая частота таймера в Гц,
f - требуемая частота звука).
Пример:
;
; подпрограмма генерации звука
; Вход: АX= частота звука в Гц
;
Sound
proc near
push ax ;сохранить регистры
push bx
push dx
mov bx,ax ;частота
mov ax,34DDh
mov dx,12h ;(dx,ax)=1193181
cmp dx,bx ;если bx < 18Гц, то выход
jnb Done ;чтобы избежать переполнения
div bx ;ax=(dx,ax)/bx
mov bx,ax ;счетчик таймера
in al,61h ;порт РВ
or al,3 ;установить биты 0-1
out 61h,al
mov al,00001011b ;управляющее слово таймера:
;канал
2, режим 3, двоичное слово mov dx,43h
out dx,al ;вывод в регистр режима
dec dx
mov al,bl
out dx,al ;младший байт счетчика
mov al,bh
out dx,al ;старший байт счетчика
Done:
pop dx ;восстановить регистры
pop bx
pop ax
ret
Sound
endp
;
;подпрограмма выключения звука
;
No_Sound
proc near
push ax
in al,61h ;порт РВ
and al,not
3 ;сброс битов 0-1
out 61h,al
pop ax
ret
No_Sound endp
Для
генерации музыки можно использовать следующий алгоритм. Пусть octave - номер октавы (1, 2, ...); note -
номер ноты в октаве (до=1, до#=2, ...,
си=12). Тогда:
f := 32.625;
for i := 1 to oktave do f := 2*f;
for i := 1 to note do f := 1.059463094*f
Sound
(round(f));
Второй способ
генерации звука состоит
в том, чтобы генерировать звуковые импульсы не выходом таймера, а установкой и сбросом бита 1 в регистре РВ. Для управления задержками можно
использовать программный цикл, например:
;
; Программа генерации звука
; Вход: N=количество импульсов
; FREQ=длительность импульса
;
in al,61h ;порт РВ
and al,not ;сброс бита 0
mov dx,N
Repeat:
or al,2
out 61h,al ;установить бит 1
mov cx,FREQ
Wait_On:
loop Wait_On
and al,not
2 ;сбросить бит 1
out 61h,al
mov cx,FREQ
Wait_Off:
loop Wait_Off
dec dx
jnz Repeat
Программирование этого
способа основано на
следующих формулах. Если Т - длительность звучания в сек, f - частота звука в Гц, а t - тактовая частота
процессора ПЭВМ, то
N=T*f;
FREQ=t/(34*f).
Константа
34 объясняется тем, что длительность каждого из циклов Wait_on и
Wait_off приблизительно равна (17*cx)
машинных тактов.
Неудобство
этого метода состоит в том, что
ЦП полностью занят генерацией
звука - любое прерывание испортит
временную диаграмму
звукового сигнала. Однако
он обеспечивает точную
подстройку
частоты и позволяет создавать несимметричные импульсы варьированием задержек в
циклах Wait_on и Wait_off.
5. Программируемый периферийный
интерфейс
5.1. Описание
ППИ 8255
В состав IBM PC/XT
входит программируемый
периферийный интерфейс (ППИ) 8255
(отечественный аналог КР580ИК55).
ППИ содержит три
8-разрядных порта (РА, РВ и
РС) для организации обмена между
ЦП и внешними устройствами и
регистр управления. Порты сгруппированны в две группы:
группа А состоит из РА и
старшей тетрады РС,
группа В - из РВ и
младшей тетрады РС. Группа А
может работать в трех режимах (0,
1, 2); группа В - в двух (0
и 1). Режимы определяются содержимым
регистра
управления,
имеющим следуюший формат:
7 6 5
4 3 2 1 0
---T--T--T--T--T--T-T--¬
¦1
¦
¦ ¦ ¦ ¦ Биты: Маска:
L--+--+--+--+--+T-+-+---
----- ------ ¦ ¦
¦ L---> 0-1: определение
группы В a & 3
¦
¦ ¦ (зависит
от режима)
¦
¦ L-------> 2: режим группы В (0
или 1) a & 4
¦
L-----------> 3-4: определение группы А
a & 18h
¦
(зависит от режима)
L----------------->
5-6: режим группы А: a & 60h
00=режим 0
01=режим 1
1X=режим 2
Режим
0. В этом режиме группа разделяется на два набора (порт и
тетрада РС). Каждый набор может
использоваться только для ввода.
Биты определения группы
в регистре управления определяют, какие наборы
предназначены для ввода , а какие - для вывода (бит, равный нулю, задает набор
для вывода, единица - для ввода):
-------T-----------------------¬
¦
Бит ¦ Набор ¦
+------+-----------------------+
¦
4 ¦ РА ¦
¦
3 ¦ Старшая тетрада РС ¦
¦
1 ¦ РВ ¦
¦
0 ¦ Младшая тетрада РС ¦
L------+------------------------
Режим 1. Порты РА и РВ используются для
передачи данных, РС - для управляющих сигналов. Дальнейшее описание
сделано на
примере группы А.
Бит 4 регистра управления задает использование порта РА (1 = порт ввода, 0 =
порт вывода).
При вводе биты порта РС имеют следующее
значение:
Бит(ы) Назначение
----------------------------------------------------------------
4 (STBA) 0 = "стробировать"
шину данных в порт РА
5
(IBFA) 1 = РА содержит данные, еще не
выбранные процессором
6-7 если
бит 3 регистра управления
равен 0, то это
линии управления
периферийным устройством; если он равен
1, то это линии ввода состояния устройства.
----------------------------------------------------------------
При выводе:
Бит(ы) Назначение
----------------------------------------------------------------
4-5
то же, что 6,7 при вводе
6 (OBFA) 1 = РА содержит данные, еще не переданные
периферийному устройству
7 (ASKA) 0 = данные из РА приняты устройством
----------------------------------------------------------------
С группой А
ассоциируется бит 3 порта
РС, обозначаемый INTRA.
Этот сигнал применяется
как линия запроса прерывания
системной шины. При вводе в порт РА
на этом выходе формируется 1, когда новые
данные помещаются в РА, и 0,
когда процессор считывает
данные. При выводе INTRA = 1,
когда содержимое РА принято устройством, и 0, когда
ЦП загружает новые данные.
Разрешением прерываний управляют бит 4 РС в режиме ввода и бит 6 в режиме
вывода (1 = разрешить прерывание).
Для группы
В ввод или вывод задается битом 1 регистра управления. При
вводе биты 2 и 1 порта РС именуются
STBB и IBFB (их назначение аналогично битам STBA и IBFA). При выводе биты 2 и 1 именуются OBFB и ASKB
(см. выше). Бит 0 становится
INTRB, разрешениями прерываний управляет бит 2.
Режим 2.
Этот режим допустим только для
группы А. В нем
порт А становится двунаправленным, а старшая тетрада
РС
определяется так:
Бит(ы) Назначение
----------------------------------------------------------------
4 (STBA) 0 =
"стробировать" шину данных РА
5
(IBFA) 1 = порт РА загружаются данные
с шины,
0 = процессор читает данные
6
(ACKA) 1 = устройство готово читать
данные с шины
7
(OBFA) 1 = процессор загружает в порт
РА данные,
0
= данные приняты устройством
----------------------------------------------------------------
5.2.Использование
ППИ в IBM PC
ППИ
в IBM PC/XT занимает порты 60h - 63h. BIOS заносит в регистр управления (порт 63h) 99h, т. е. программирует группы А и В в режим 0, причем РА и РС является портами
ввода, а РС портом вывода:
Адрес Операция Назначение
----------------------------------------------------------------
60h чтение Ввод из порта РА
61h запись Ввод
в порт РВ
чтение Чтение последнего вывода в порт РВ
62h чтение Вывод из
порта РС
63h чтение/ Регистр
управления ППИ
запись
----------------------------------------------------------------
Содержимое
порта РА: если бит 7 в РВ равен 0, то
чтение из этого порта означает ввод скан-кода последней нажатой клавиши (см.
гл. 6); если же бит 7
в РВ установлен, то РА содержит положение DIP-переключателей
колодки SW1 системной платы:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦
¦ ¦ ¦ Биты:
Маска:
L--+--+--+--+--+--+T-+T--
----- ------ ¦ ¦ ¦ ¦
L->0: 1=есть НГМД
а & 1
¦ ¦ ¦ L---->1: 1=есть сопроцессор 8087 а & 2
¦ ¦
L-------->2-3:размер ОЗУ системной платы: а & 0Еh
¦ ¦ 00=16K, 04h=32K, 0eh=64K и
более
¦ L-------------->4-5:тип
дисплея: а & 30h
¦ 00=
EGA/VGA
¦ 10h=CGA,
40 столбцов
¦ 20h=CGA,
80 столбцов
¦ 30h=монохромный
L-------------------->6-7:количество
НГМД-1 a & C0h 00=1,
40h=2, 80h=3, C0h=4
Содержимое порта РВ:
7 6 5
4 3 2 1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦ ¦
¦ ¦ ¦ ¦ ¦ Бит:
LT-+T-+T-+T-+T-+T-+T-+T--
----
¦ ¦
¦ ¦ ¦ ¦ ¦
L-> 0: вход GATE 2-го канала таймера:
¦ ¦ ¦
¦ ¦ ¦ ¦ а OR 3 = вкл. звук
¦ ¦ ¦
¦ ¦ ¦ ¦ а AND 0FCh = выкл. звук
¦ ¦ ¦
¦ ¦ ¦ L----> 1: данные
генератора звука
¦ ¦ ¦
¦ ¦ L-------> 2: определяет содержимое РС
¦ ¦ ¦
¦ L----------> 3: 0=включить
мотор кассетного
¦ ¦ ¦ ¦ магнитофона
¦ ¦
¦ L-------------> 4:
0=разрешить проверку паритета ОЗУ
¦ ¦
L----------------> 5: 0=разрешить сигналы об ошибках
¦ ¦ в платах расширения
¦
L-------------------> 6: 0=запретить часы клавиатуры
L----------------------> 7: задает
содержимое РА
(при вводе
1=подтверждение
от клавиатуры)
Содержимое
порта РС зависит от бита 7
порта РВ. Если он установлен,
то биты 0-3 содержат младшую
тетраду колодки
DIP-переключателей
SW2, если сброшен, то старшую:
7 6 5
4 3 2 1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦ ¦ ¦
¦ Биты:
LT-+T-+T-+T-+--+--+--+---
-----
¦ ¦ ¦ ¦
L----> 0-3: DIP-ключи SW2
(см. ниже)
¦ ¦
¦ L------------> 4: ввод данных с касетного магнитофона
¦ ¦ L---------------> 5: выход OUT 2-го канала таймера
¦
L------------------> 6:
1=ошибка в платах расширения
L---------------------> 7: 1=ошибка паритета ОЗУ
Колодка SW2 содержит следующие ключи:
7 6 5
4 3 2 1 0
---T--T--T--T--T--T--T--¬
¦
¦ ¦ Биты:
L--+--+--+--+--+--+--+---
-----
¦ L-----> 0-3: общий размер ОЗУ
L-----------------> 4-7: всегда равны
нулю
6. Клавиатура
6.1. Клавиатура IBM PC/XT
Связь с
клавиатурой осуществляется через
порты ППИ 60h и 61h (см. 5.2).
При нажатии клавиши
происходит аппаратное
прерывание IRQ1, связанное с вектором Int 9. Если Вы
хотите обрабатывать это прерывание
сами, то программа
обработки прерывания должна иметь следующий вид:
Int_09h:
push ax
push di
push es
in al,60h ;скан. код клавиши из РА
les di,buffer
;адрес буфера
stosb ;сохранить
код в буфере
pop es
pop di
in al,61h ;ввод порта РВ
mov ah,al
or al,80h ;установить бит "подтверждения
ввода"
out 61h,al
xchg ah,al ;вывести старое значение РВ
out 61h,al
mov al,20h ;послать сигнал EOI
out 20h,al ;контроллеру прерываний
pop ax
iret
Перечень
скан-кодов всех клавиш приведен в приложении 1. Вы можете запретить прерывания
от клавиатуры либо маскировкой бита 1 в
регистре IMR контроллера прерываний,
либо установкой бита 6 порта РВ ППИ:
in al,21h ;чтение IMR
or al,2 ;установка бита 1
out 21h,al ;запись IMR
или
in al,61h ;чтение РВ
or al,40h ;установка бита 6
out 61h,al ;запись
РВ
Для разрешения
работы клавиатуры необходимо
выполнить обратные действия.
6.2.
Клавиатура IBM PC AT
Взаимодействие с клавиатурой в
PC AT базируется на
микропроцессоре Intel 8042; благодаря
этому программист имеет гораздо большие
возможности по управлению клавиатурой,
нежели в PC/XT.
Управление клавиатурой
производится обращением к
порту ввода-вывода 64h. Для совместимости со старыми ПЭВМ допустимо использование порта 60h. Если
приведенные ниже примеры
не работают на Вашей ПЭВМ, то используйте порт 60h.
Порт 64h предназначен для вывода команд и данных и
для чтения состояния клавиатуры. Обшая
схема посылки команд клавиатурe такова:
cli ;запрет
прерываний
call wait_kbd ;ожидание готовности клавиатуры
mov al,cmd_code ;код команды
out 64h,al ;вывод в порт
sti ;разрешение прерываний
Для команд,
сопровождающихся байтом данных,
эта схема принимает вид:
cli
call wait_kbd
mov al,cmd_code ;код команды
out 64h,al
call wait_kbd
mov al,data_value ;байт данных
out 64h,al
sti
Проверка
ожидания готовности клавиатуры может иметь вид:
wait_kbd:
mov cx,2500h ;задержка порядка 10 мсек
test_kbd:
in al,64h ;читаем состояние клавиатуры
test al,2
;проверка бита готовности
loopnz test_kbd
ret
Авторам
известны следующие команды
контроллера клавиатуры (этот список, вероятно, не полон и может содержать
ошибки, т. к. собран из различных источников):
Код команды Описание
----------------------------------------------------------------
0FFh Сброс
клавиатуры и запуск внутреннего теста.
0FEh Повторить последнюю передачу.
0FDh Вызов прерывания IRQ1.
0F6h Привести клавиатуру в исходное
состояние и
разрешить сканирование.
0F5h Привести клавиатуру в исходное состояние
и
запретить сканирование.
0F4h Сбросить буфер клавиатуры и начать
сканирование.
0F3h Задать задержку и скорость ввода
символов.
Первоначально
клавиатура начинает повторять нажатую клавишу через 0,5 сек со скоростью
10
повторов в секунду. Вы можете изменить эти параметры, послав следующий байт
данных:
7
6 5 4 3 2 1 0
---T--T--T--T--T--T--T--¬
¦0
¦ ¦ ¦ Биты:
L--+--+--+--+--+T-+--+---
-----
¦ L--------> 0-4:количеств повторов в секунду
L------------------>
5-6:начальная задержка в мсек: 00=250, 01=500, 10=750, 11=1000
Количество повторов задается
следующей таблицей:
-------T--------T------T--------T------T--------¬
¦Конст.¦Скорость¦Конст.¦Скорость¦Конст.¦Скорость¦
+------+--------+------+--------+------+--------+ ¦ 00h ¦ 30.0 ¦ 0Bh ¦ 10.9 ¦
16h ¦ 4.3 ¦
¦ 01h ¦ 26.7 ¦ 0Ch ¦ 10.0 ¦
17h ¦ 4.0 ¦
¦ 02h ¦ 24.0 ¦ 0Dh ¦ 9.2 ¦
18h ¦ 3.7 ¦
¦ 03h ¦ 21.8 ¦ 0Eh ¦ 8.6 ¦
19h ¦ 3.3 ¦
¦ 04h ¦ 20.0 ¦ 0Fh ¦ 8.0 ¦
1Ah ¦ 3.0 ¦
¦ 05h ¦ 18.5 ¦ 10h ¦ 7.5 ¦
1Bh ¦ 2.7 ¦
¦ 06h ¦ 17.1 ¦ 11h ¦ 6.7 ¦
1Ch ¦ 2.5 ¦
¦ 07h ¦ 16.0 ¦ 12h ¦ 6.0 ¦
1Dh ¦ 2.3 ¦
¦ 08h ¦ 15.0 ¦ 13h ¦ 5.5 ¦
1Eh ¦ 2.1 ¦
¦ 09h ¦ 13.3 ¦ 14h ¦ 5.0 ¦
1Fh ¦ 2.0 ¦
¦ 0Ah ¦ 12.0 ¦ 15h ¦ 4.6 ¦ ¦ ¦
L------+--------+------+--------+------+---------
0EEh Эхо
(для диагностики). Просто возвращает 0ЕЕh.
0EDh Управление светодиодами клавиатуры.
Для включения
или
выключения светодиодов пошлите такой байт данных:
7
6 5 4 3 2 1 0
---T--T--T--T--T--T--T--¬
¦X X
X X X ¦ ¦ ¦ ¦
Биты: L--+--+--+--+--+T-+T-+T-- -----
¦ ¦
L--> 0: 1 = включить ScrollLock ¦
L-----> 1: 1 = включить NumLock L--------> 2: 1 = включить
CapsLock
0DFh Разрешить 20-битовую адресацию.
0DDh Запретить 20-битовую адресацию.
0D1h Запись в порт вывода 8042.
0D0h Чтение порта вывода 8042.
0C0h Чтение порта ввода 8042.
0AEh Разрешение клавиатуры.
0ADh Запрещение клавиатуры.
0ACh Чтение ОЗУ контроллера.
0ABh Тест синхронизации и данных.
0AAh Внутренний тест клавиатуры.
----------------------------------------------------------------
7. Дисплеи
7.1. Общее
описание
Программирование дисплея ПЭВМ IBM
PC определяется типом дисплейного
адаптера и типом видеомонитора,
подключенного к этому
адаптеру. В этой
главе описаны четыре
наиболее
распространенных видеоадаптера
IBM PC, а именно:
- монохромный графический адаптер MGA;
- цветной графический адаптер CGA;
- расширенный графический адаптер EGA;
-
графический видеомассив VGA.
Центральным устройством в управлении видеомонитором является контроллер электронно-лучевой трубки
(ЭЛТ). В IBM PC применяются
программируемые
контроллеры фирмы Motorola, позволяющие задать все основные параметры развертки изображения на
экране. Для понимания дальнейшего материала необходимо ввести ряд часто
используемых понятий. Режим
работы видеомонитора
характеризуется следующими понятиями:
-
вертикальным разрешением (количество
строк растра на экране);
- горизонтальным разрешением (количество
символов или точек в строке);
- представлением данных в видеопамяти;
- атрибутами
вывода, задающими цвет, мерцание и т. п.
Горизонтальное и вертикальное разрешение
определяются последовательностью
согласованных во времени
сигналов графического адаптера,
управляющих движением луча ЭЛТ.
Луч ЭЛТ движется с постоянной скоростью вдоль строки растра и вниз с
одной строки растра на следующую,
обновляя (разворачивая)
изображение
на экране. Для перевода луча из крайней правой точки строки в
крайнюю левую точку
следующей строки (обратный горизинтальный ход
луча) видеоадаптер генерирует
сигнал горизонтальной
синхронизации; для перемещения
луча из крайней правой позиции нижнeй строки экрана в крайнюю
левую позицию первой строки (вертикальный обратный ход луча)
- сигнал вертикальной
сихронизации.
Видеоадаптеры всегда
програмируются так, чтобы
вывод видеобуфера на экране проходил быстрее, чем развертка одного
кадра. Это дает возможность вывести на
экран бордюр (overscan), окаймляющий
изображение и позволяющий центрировать его на экране.
Длительность сигналов развертки принято
задавать в так называемых
символьных тактах (character clock).
Символьный такт - это отрезок времени,
необходимый для вывода на экран 8 точек в
графическом режиме и 8 или 9 точек в
алфавитно-цифровых режимах.
Параметры развертки
заносятся в определенные регистры контроллера
ЭЛТ; назначение этих
регистров различно в контроллерах MGA/CGA и EGA/VGA.
7.2.
Контроллеры ЭЛТ
Адаптеры
MGA и CGA содержат контроллер ЭЛТ Motorola 6845, имеющий следующие
программируемые регистры:
Регистр
Наименование Описание
----------------------------------------------------------------
R0 Общая длительность Время вывода строки растра в
строки (horizontal total) символьных тактах.
R1
Ширина кадра Количество
символов в строке.
(horizontal displayed)
R2
Позиция горизонтальной Начало
горизонтальной
синхронизации (horizontal синхронизации в символьных
sync position) тактах.
R3
Ширина синхронизации Длительность
синхронизации
(sync width) (младшая тетрада - вертикальной,
старшая -
горизонтальной).
R4
Размер кадра Общее
количество строк
(vertical total) растра в кадре.
R5 Вертикальное выравнивание
Поправка для частоты 50 или
(vertical adjust) 60 Гц.
R6
Высота кадра Количество
строк
(vertical displayed) изображения в кадре.
R7
Позиция вертикальной Начало
вертикальной
синхронизации (vertical синхронизации в символьных
sync position) тактах.
R8
Биты 4-5: режим расслоения
(interlace mode);
биты 6-7: сдвиг (skew)
R9
Макс. число строк растра Количество
строк растра на
строку символов.
R10 Начало курсора Начальная строка курсора.
R11 Конец курсора Конечная строка курсора.
R12\Начальный адрес Старший байт
R13/видеопамяти Младший байт
R14\Позиция Старший
байт
R15/курсора Младший
байт
R16\Позиция Старший
байт
R17/светового пера Младший байт
----------------------------------------------------------------
Aдаптеры EGA
и VGA имеют следующие программируемые регистры, эмулирующие
контроллер ЭЛТ:
Регистр
Наименование Описание
----------------------------------------------------------------
R0 Общая длительность Время вывода строки растра в
строки (horizontal total) символьных тактах.
R1
Ширина кадра (horizontal Количество
символов в строке
display enable end) (см. R7).
R2
Начало горизонтального Символьная
позиция, в которой
гашения
(start horizontal начинается
горизонтальное
blank) гашение
луча.
R3
Конец горизонтального Символьная
позиция, в которой
гашения (end horizontal заканчивается горизонтальное
blank) гашение
луча (в битах 0-4);
разрешение сдвига
(биты 5-6). R4 Начало обратного хода
луча Символьная позиция начала
по горизонтали (start горизонтальной синхронизации.
horizontal retrace)
R5 Конец обратного хода луча Символьная позиция окончания
по горизонтали (end горизонтальной синхронизации.
horizontal retrace)
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦ ¦ Биты:
LT-+--+--+--+--+T-+--+---
-----
¦ ¦
L------> 0-4: ширина
обратного хода луча
¦ ¦ по горизонтали
¦ L----------------> 5-6: задержка обратного хода в
¦ символьных тактах
L---------------------> 7: 1=начинать панорамирование с четного
адреса, 0=с нечетного
R6
Размер кадра Общее
количество строк
(vertical total) растра в кадре (см. R7).
R7
Регистр переполнения Содержит
старшие биты других
(overflow) регистров:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Бит:
LT-+T-+T-+T-+T-+T-+T-+T--
----
¦
¦ ¦ ¦ ¦ ¦
¦ L-> 0: 8-й бит размера
кадра (R6)
¦
¦ ¦ ¦ ¦ ¦
L----> 1: 8-й бит количества строк
¦
¦ ¦ ¦ ¦ ¦ отображения
в кадре (R18)
¦
¦ ¦ ¦ ¦ L-------> 2: 8-й бит начала вертикальной
¦
¦ ¦ ¦ ¦ синхронизации (R16)
¦
¦ ¦ ¦ L----------> 3: 8-й
бит начала вертикального
¦
¦ ¦ ¦ гашения
луча (R21)
¦
¦ ¦ L-------------> 4: 8-й бит сравнения строк (R24)
¦ ¦
L----------------> 5: EGA: 8-й бит R10, VGA: 9-й бит R6
¦
L-------------------> 6: 9-й бит R18 (только VGA)
L----------------------> 7: 9-й бит R16
(только VGA)
R8
Начало растра (preset Первая
строка растра после
row scan) вертикальной
синхронизации.
R9
Макс. число строк растра Количество
строк растра на
строку
символов (в битах 0-4); для VGA: бит 5=9-й бит R21.
R10 Начало курсора Начальная строка курсора.
R11 Конец курсора Конечная строка курсора (биты
0-4); сдвиг
курсора (биты 5-6). R12\Начальный адрес Старший
байт
R13/видеопамяти Младший байт
R14\Позиция Старший
байт
R15/курсора Младший
байт
При чтении:
R16\Позиция Старший
байт
R17/светового пера Младший байт
При записи:
R16
Начало обратного хода луча Символьная позиция начала
по вертикали (start вертикальной синхронизации.
vertical retrace)
R17
Конец обратного хода луча Символьная
позиция окончания
по вертикали (end вертикальной синхронизации.
vertical retrace)
7 6 5
4 3 2 1 0
---T--T--T--T--T--T--T--¬
¦ ¦0 ¦
¦ ¦ ¦ Биты:
LT-+--+T-+T-+--+--+--+---
-----
¦ ¦
¦ L----> 0-3: ширина обратного хода луча
¦ ¦ ¦ по вертикали
¦ ¦
L------------> 4: 0=очистить
прерывание вертикальной
¦ ¦ синхронизации
¦ L---------------> 5: 0=разрешить прерывание вертикаль-
¦ ной
синхронизации (IRQ2)
L---------------------> 7: VGA: запрет записи в R0 - R7
R18 Количество строк отобра- Количество строк растра,
жения в кадре (vertical занятых собственно изобра-
displayed end) жением
R19 Вертикальное смещение Количество слов данных в
(vertical displayed логической строке видеопамяти.
adjustment)
R20 Позиция подчеркивания Номер строки растра (биты 0-5).
R21 Начало вертикального Символьная позиция, в которой
гашения (start vertical начинается вертикальное
blank) гашение
луча.
R22 Конец вертикального Символьная позиция, в которой
гашения (end vertical заканчивается вертикальное
blank) гашение
луча.
R23 Управление режимами:
7 6 5
4 3 2 1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦ ¦
¦ ¦ ¦ ¦ ¦ Бит:
LT-+T-+T-+T-+T-+T-+T-+T--
----
¦ ¦ ¦
¦ ¦ ¦ ¦ L-> 0: 0=режим совместимости с CGA
¦ ¦ ¦
¦ ¦ ¦ ¦ для адресации графики
¦ ¦ ¦
¦ ¦ ¦ L----> 1: выбор
счетчика сканирования
¦ ¦ ¦
¦ ¦ ¦ строк
¦ ¦ ¦
¦ ¦ L-------> 2: горизонтальная синхронизация:
¦ ¦ ¦
¦ ¦ 1=двойная, 0=обычная
¦ ¦
¦ ¦ L----------> 3: длительность синхронизации при
¦ ¦
¦ ¦ регенерации слов: 1=половинная,
¦ ¦ ¦ ¦ 0=обычная
¦ ¦
¦ L-------------> 4:
1=установить высокоимпедансный
¦ ¦ ¦ выход,
0=разрешить управление
¦ ¦ ¦ выходом
¦ ¦ L----------------> 5: режим расслоения
адресов для
¦ ¦ совместимости с CGA: 0=для 64К
¦ ¦ ОЗУ, 1=для ОЗУ более 64К
¦
L-------------------> 6: режим адресации: 1=байтовая,
¦ 0=словная
L----------------------> 7: 0=аппаратный
сброс, 1=обычная работа
R24 Сравнение строк Строка растра, используемая в
(line compare) операциях расщепления экрана.
----------------------------------------------------------------
В заключение этого раздела подчеркнем, что самостоятельное
программирование контроллера ЭЛТ
чревато физическим разрушением видеомонитора, поэтому не следует прибегать к нему, если Вы не вполне понимаете
принципы расчета параметров
развертки. Все необходимые
действия по инициализации дисплея обычно
выполняются BIOS, поэтому
необходимость в непосредственном
программировании
контроллера ЭЛТ возникает крайне редко.
7.3.
Атрибуты символов
В
текстовых режимах видеопамять состоит из
пар (код
символа, атрибут);
код символа определяет
символ ASCII, выводимый в соответствующей позиции экрана, а
атрибут - цвет этого символа. Соответствие цветов атрибутам зависит от типа
видеоадаптера.
Байт атрибутов для CGA имеет следующую
структуру:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦Bl¦r g b
¦I ¦R G B ¦ Биты:
LT-+--+T-+--+T-+--+T-+---
-----
¦
¦ ¦ L----> 0-2: цвет символа
¦
¦ L----------> 3: 1=яркий
цвет символа
¦
L----------------> 4-6: цвет фона
L----------------------> 7: 1=мерцание
символа
Таким образом, цвет фона может варьироваться от 0 до 7, а цвет символа с учетом яркости - от 0 до 0Fh. Значение атрибута задается формулой:
16
* цвет фона + цвет
символа (плюс 128 для мерцания
символа)
Цвета задаются следующим образом:
----------------------T-------------------¬
¦Номер Цвет ¦Номер Цвет ¦
+---------------------+-------------------+
¦ 0 Черный ¦
8 Серый ¦
¦ 1 Синий ¦
9 Ярко-синий ¦
¦ 2 Зеленый ¦ 0Ah Ярко-зеленый¦
¦ 3 Бирюзовый ¦ 0Bh Голубой ¦
¦ 4 Красный ¦ 0Ch Алый ¦
¦ 5 Сиреневый ¦ 0Dh Розовый ¦
¦ 6 Коричневый ¦ 0Eh Желтый ¦
¦ 7 Светло-серый ¦ 0Fh Белый ¦
L---------------------+--------------------
Адаптеры
EGA и VGA имеют такую
же структуру байта атрибутов, но позволяют переопределять
цвета, перечисленные в таблице, перепрограммированием регистров палитр. Поэтому байт атрибутов символа
определяет одну из 64 (EGA)
или 256 (VGA) возможных
комбинаций цветов.
Монохромные дисплеи допускают любые
значения байта атрибутов, но реально
отрабатывают только следующие его значения:
01h Подчеркнутый
символ
07h Обычный
вывод (светлый символ на темном фоне)
09h Яркий
подчеркнутый символ
0Fh Ярко-светлый
символ на темном фоне
70h Негатив
(темный символ на светлом фоне)
81h Мерцающий
подчеркнутый символ
87h Мерцающий
светлый символ на темном фоне
89h Мерцающий
яркий подчеркнутый символ
8Fh Мерцающий
ярко-светлый символ на темном фоне
Следует
учитывать, что старший бит байта атрибутов может означать либо мерцание символа, либо повышенную
яркость фона (см. 7.4 - 7.6).
7.4. Монохромный
графический адаптер MGA
Монохромный графический адаптер (MGA
или Hercules) - это графический видеоконтроллер высокого разрешения, совмещенный с платой печатающего устройства. Для него
зарезервированы порты ввода-вывода 3B0h - 3BFh, имеющие следующее
назначение.
Порт
Операция Описание
----------------------------------------------------------------
3B4h Запись
Регистр индекса ЭЛТ. Используется для выбора
регистра ЭЛТ. Для записи регистра
ЭЛТ Rn нужно выполнить команды:
out
3B4h,n и out 3B5h,данные.
3B5h Запись/
Регистр данных ЭЛТ. Позволяет записывать все
чтение регистры
ЭЛТ и читать регистры R12 - R17.
3B8h Запись Регистр режимов дисплея:
7 6
5 4 3
2 1 0
---T-T--T-T--T-T--T-¬
¦ ¦X¦
¦X¦ ¦X¦ ¦X¦ Бит: LT-+-+T-+-+T-+-+T-+-- ----
¦
¦ ¦ L----> 1:
0=текстовый режим, 1=графический режим
¦
¦ L---------> 3: 0=очистить экран,
1=активизировать
¦ ¦ экран
¦
L--------------> 5: 1=бит 7 атрибутов - мерцание
¦ 0=бит
7 атрибутов - яркость фона
L-------------------> 7: номер текущей видеостраницы
3B9h Запись/
Вывод любого байта включает триггер светового
Чтение пера.
3BAh Чтение Регистр состояния дисплея:
7 6 5
4 3 2 1 0
---T-T-T-T--T-T-T--¬
¦ ¦X¦X¦X¦
¦X¦X¦ ¦ Бит:
LT-+-+-+-+T-+-+-+T-- ----
¦ ¦ L--->
0: 0=вывод изображения, 1=горизонтальная
¦ ¦ синхронизация
¦ L----------> 3: 0=экран включен,
1=выключен (позволяет
¦ проверить
поступление видеосигнала на
¦ на
экран)
L-------------------> 7: 0=вертикальная
синхронизация, 1=дисплей активен
3BBh Запись/
Вывод любого байта выключает триггер светового
Чтение пера.
3BCh-3BEh См. описание портов параллельного принтера
(п. 10).
3BFh Запись
Регистр конфигурации. Сюда заносится новая
конфигурация дисплея:
0 (DIAG) - работа только в
текстовом режиме;
1 (HALF) -
допустима работа только с графической страницей 0;
3
(FULL) - доступны обе графические страницы.
----------------------------------------------------------------
Видеопамять MGA располагается в адесах ОЗУ
B0000h - BFFFFh. В текстовом
режиме (25 строк
по 80 символов в строке) она
занимает 4К с B0000h по B0FFFh.
При этом адрес кода символа равен B000h : 160*L+2*C, адрес
атрибута на единицу больше. Здесь
L
- номер строки (0 - 24), C - номер столбца (0 - 79).
Графический режим имеет разрешение 720
точек по горизонтали на 348 точек
по вертикали, поэтому
один графический экран
требует 32К видеопамяти. MGA имеет
две графические страницы:
страница 0 размещается в адресах B0000h - B7FFFh, страница 1 - в адресах
B8000h - BFFFFh. Смещение от начала страницы до байта, содержащего точку
с координатами (X,Y), равно
2000h * (Y % 4) + 90 * int(Y/4) + int(X/8),
а
номер соответствующего бита в этом байте равен 7 - (X % 8). Здесь X - горизонтальная позиция точки (0 - 719), Y - ее вертикальная позиция (0 -
347).
В качестве
примера приведем программу
инициализации MGA в текстовом или графическом режиме.
; Таблицы значений регистров ЭЛТ для двух
режимов
Graph_Tbl db 35h,2Dh,2Eh,07h,5Bh,02h,57h,57h,02h,03h,00h,00h Text_Tbl db
61h,50h,52h,0Fh,19h,06h,19h,19h,02h,0Dh,0Bh,0Ch
; Установка графического режима:
Gr_Mode:
mov
al,2
lea
si,Graph_Tbl
mov
bx,0
mov
cx,4000h
call Set_Mode
. . .
; Установка текстового режима:
Txt_Mode:
mov
al,20h
lea
si,Text_Tbl
mov
bx,0720h
mov
cx,2000h
call Set_Mode
. . .
; Подпрограмма инициализации MGA.
; Вход: AL - режим
; SI - адрес таблицы регистров ЭЛТ
; CX - размер экрана в словах
; BX - значение для очистки экрана
Set_mode proc near
push ax ;
сохранить регистры
push bx
push cx
mov
dx,3B8h ; регистр режимов
out
dx,al ; изменить режим адаптера,
отключив экран
mov
ax,cs
mov
ds,ax ; DS:SI = адрес таблицы
mov
dx,3B4h ; регистр индекса
mov
cx,12 ; 12 регистров ЭЛТ
xor
ah,ah
cld
Set_CRT:
mov
al,ah
out
dx,al ; номер регистра ЭЛТ
inc
dx
lodsb
out
dx,al ; содержимое регистра ЭЛТ
dec
dx
loop Set_CRT
pop
cx
mov
ax,0B000h
mov
es,ax
pop
ax
xor
di,di ; ES:DI => видеопамять
rep
stosw ; очистка экрана
mov
dx,3B8h ; регистр режимов
pop
ax
add
al,8
out
dx,al ; активизировать экран
ret
Set_Mode endp
7.5.
Цветной графический адаптер CGA
Цветной графический адаптер (CGA - Color Graphics Adapter) - это графический
видеоконтроллер среднего разрешения.
Для него зарезервированы порты ввода-вывода 3D0h - 3DFh,
имеющие следующее назначение.
Порт
Операция Описание
----------------------------------------------------------------
3D4h Запись
Регистр индекса ЭЛТ. Используется для выбора
регистра ЭЛТ.
Для записи регистра ЭЛТ Rn нужно выполнить команды:
out
3D4h,n и out 3D5h,данные.
3D5h Запись/
Регистр данных ЭЛТ. Позволяет записывать все
чтение регистры
ЭЛТ и читать регистры R12 - R17.
3D8h Запись Регистр режимов дисплея:
7 6 5
4 3 2 1 0
--T-T--T--T--T--T--T--¬
¦X¦X¦ ¦
¦ ¦ ¦ ¦ ¦ Бит:
L-+-+T-+T-+T-+T-+T-+T--
----
¦
¦ ¦ ¦ ¦ L-->0: кол-во столбцов в текстовых режимах:
¦
¦ ¦ ¦ ¦ 0=40 столбцов, 1=80 столбцов
¦ ¦
¦ ¦ L----->1: 0=текстовый режим, 1=графический режим ¦ ¦
¦ L-------->2: 1=запрет цвета
на композитном дисплее ¦ ¦ L----------->3: 0=очистить экран,
1=активизировать
¦ ¦ экран
¦
L-------------->4: разрешение по горизонтали:
¦ 0=320
точек, 1=640 точек
L----------------->5:
1=бит 7 атрибутов - мерцание
0=бит 7 атрибутов -
яркость фона
3D9h Запись Регистр выбора цветов:
7 6 5
4 3 2 1 0
--T-T--T--T--T--T--T--¬
¦X¦X¦ ¦
¦I R G B ¦ Биты:
L-+-+T-+T-+--+--+--+---
-----
¦ ¦
L------>0-3: цвет (см. 7.3): для текста - цвет
¦ ¦ рамки, для графики - цвет фона
¦ L-------------->4: яркость: для текста -
яркость фона,
¦ для
графики - яркость пикселей
L----------------->5:
номер графической палитры (0 или 1)
Примечание: Выбор палитры задает
набор основных цветов в
графическом режиме. Палитра
0 - зеленый/красный/коричневый, палитра 1 - бирюзовый/сиреневый/светло-серый (т. е. отличается добавлением синего цвета).
3DAh Чтение Регистр состояния дисплея:
7 6 5
4 3 2 1 0 --T-T-T-T--T--T--T--¬ ¦X¦X¦X¦X¦ ¦ ¦ ¦ ¦
Бит: L-+-+-+-+T-+T-+T-+T-- ----
¦ ¦
¦ L--->0: 0=вывод
изображения, 1=горизонтальная ¦ ¦ ¦ или
вертикальная синхронизация
¦ ¦
L------>1: 1=триггер светового пера сброшен
¦ L--------->2: 1=защелка светового пера открыта
L------------>3: 0=экран включен, 1=выключен (позволяет
проверить
поступление видеосигнала на на экран - если этот бит установлен, вывод на экран
не вызывает "хлопьев")
3DBh Запись/
Вывод любого байта выключает триггер светового
Чтение пера.
3DCh Запись/
Вывод любого байта включает триггер светового
Чтение пера.
----------------------------------------------------------------
Видеопамять
CGA располагается в адесах ОЗУ B8000h - BFFFFh. CGA имеет два типа текстовых
режимов: 25 строк по 40 символов в
строке и по 80 символов
в строке. В
режимах 25 х 40 одна страница занимает 800h байтов, поэтому видеопамять состоит из 8
страниц; в режимах 25 х
80 страница занимает 1000h байтов и видеопамять состоит из 4 страниц.
Адрес кода
символа в текстовых
режимах равен B800h : n*P+m*L+2*C, адрес атрибута на единицу больше. Здесь L - номер строки (0 - 24), C - номер
столбца (0 - 79 или 0 - 39), m = 2 * количество
столбцов режима, n = 800h при m=80 и 1000h при m=160.
CGA имеет
два типа графических
режимов: цветной режим, имеющий
разрешение 320 точек по горизонтали на 200 точек по вертикали,
и черно-белый режим с разрешением 640 точек на 200 точек. В режиме 320 х 200 каждый пиксель задается двумя
битами, кодирующими его цвет; в режиме
640 х 200 цвет пикселя задается одним битом (белый/черный). В графических режимах один экран
требует 16К видеопамяти,
поэтому имеется одна
страница видеопамяти, которая размещается в адресах B8000h - BFFFFh. Эта страница расслоена на две
области: область с адреса B8000h содержит пиксели, имеющие
четные номера строк; область с адреса
BA000h содержит пиксели из нечетных
строк. Поэтому адрес байта, содержащего точку с координатами (X,Y), равен в
цветном режиме
B800h : 2000h
* (Y % 2) + 80 * int(Y/2) + int(X/4),
а номера соответствующих
битов в этом байте равны 7 - 2 * (X % 4) и 6 - 2 * (X % 4). Здесь X - горизонтальная позиция точки
(0 - 319), Y - ее вертикальная позиция (0 - 199).
Адрес байта, содержащего точку с координатами (X,Y), равен в черно-белом
режиме
B800h : 2000h
* (Y % 2) + 80 * int(Y/2) + int(X/8),
а номер соответствующего бита в этом байте равен 7 - (X % 8).
Здесь X - горизонтальная позиция
точки (0 -
639), Y - ее вертикальная позиция (0 - 199).
7.6.
Расширенный графический адаптер EGA
Расширенный графический адаптер (EGA
- Enhanced Graphics Adapter) - это графический видеоконтроллер высокого
разрешения, программно совместимый с
адаптерами CGA и
MGA, но имеющий гораздо
большие возможности. В IBM PC для EGA
зарезервированы
следующие
порты ввода-вывода:
EGA #1 -
порты 3C0h - 3DFh; EGA #2 - порты 2C0h - 2DFh.
EGA может
генерировать прерывание IRQ2 (Int
0Ah) в начале вертикальной
синхронизации. Однако, BIOS
не использует эту возможность; мы также не описываем ее, т.
к. вектор Int 0Ah используется
в PC AT как каскад второго контроллера прерываний (см. п. 3).
Все регистры EGA можно разбить на четыре
группы:
3C0h Контроллер
атрибутов (ATC)
3C2h Многоцелевой
регистр
3C4h-3C5h Блок
синхронизации (sequencer)
3CAh-3CFh Графический
контроллер (GDC)
3D4h-3DCh
или Блок управления дисплеем
3B4h-3BCh (адреса портов зависят от видеорежима)
Контроллер атрибутов (ATC) имеет 20 регистров, управляющих цветами
вывода:
Регистр
Наименование Описание
----------------------------------------------------------------
R0-R15 Регистры палитры Определяют
цвета соответствующих
(только для записи) атрибутов:
7 6 5
4 3 2 1 0
--T-T--T--T--T--T--T--¬
¦X¦X¦r
¦g ¦b ¦R ¦G ¦B ¦ Бит:
L-+-+T-+T-+T-+T-+T-+T--
----
¦
¦ ¦ ¦ ¦ L--> 0: Синий 2/3 яркости
¦
¦ ¦ ¦ L-----> 1: Зеленый
2/3 яркости
¦
¦ ¦ L--------> 2: Красный 2/3 яркости
¦
¦ L-----------> 3: Синий 1/3
яркости
¦ ¦ (подчеркивание для MGA)
¦
L--------------> 4: Зеленый 1/3 яркости
¦ (яркость для MGA)
L-----------------> 5: Красный 1/3
яркости
R16
Управление режимами Имеет
следующую структуру:
7 6 5 4 3
2 1 0
--T-T-T-T--T--T--T--¬
¦X¦X¦X¦X¦ ¦
¦ ¦ ¦ Бит:
L-+-+-+-+T-+T-+T-+T--
----
¦
¦ ¦ L--> 0: Режим: 0=текстовый, 1=графический
¦
¦ L-----> 1: 1=атрибуты MGA,
0=атрибуты CGA
¦ L--------> 2: Задает 9-ю точку для
псевдографики: ¦ 1=9-я точка совпадает с 8-й точкой
¦ 0=вывод
9-й точки цветом фона
L----------->
3: Бит 7 байта атрибутов задает: 1=мерцание символов, 0=яркость фона
R17
Цвет рамки Устроен так
же, как регистры
палитры.
R18
Управление цветовыми Имеет
следующую структуру:
плоскостями
7 6 5
4 3 2 1 0
--T-T--T--T--T--T--T--¬
¦X¦X¦ ¦ ¦ Бит:
L-+-+--+--+--+--+--+---
----
¦ L------->0-3: 1=разрешить цветовую
плоскость
¦
Ci, i = 0 - 3
L---------------->4-5:
мультиплексирование видеосигналов: 00=R&B, 01=b&G, 10=r&g,
11=не используется
R19 Горизонтальная прокрутка Задает сдвиг экрана
влево в
точках (0 - 15).
----------------------------------------------------------------
Примечания.
1. Регистры палитры
задают соответствие между
значением
атрибута
и его цветом. Например, засылка
значения 02h в регистр ATC определит
его как зеленый цвет, 10h - как бледно-зеленый, 12h - как ярко-зеленый.
2. Для того, чтобы цвета атрибутов
совпадали с цветами CGA, регистры палитры должны иметь следующие значения:
---------------------T--------------------¬
¦
Регистр Значение ¦ Регистр Значение ¦ +--------------------+--------------------+
¦
00h 00h ¦
08h 38h ¦
¦
01h 01h ¦
09h 39h ¦
¦
02h 02h ¦
0Ah 3Ah ¦
¦
03h 03h ¦
0Bh 3Bh ¦
¦
04h 04h ¦
0Ch 3Ch ¦
¦
05h 05h ¦
0Dh 3Dh ¦
¦
06h 14h ¦
0Eh 3Eh ¦
¦
07h 07h ¦
0Fh 3Fh ¦
L--------------------+---------------------
Блок
синхронизации обеспечивает синхронизацию вывода символов с работой
знакогенератора. Он имеет
следующие программируемые регистры.
Регистр
Наименование Описание
----------------------------------------------------------------
R0 Перезапуск
блока Установка и сброс бита 0
вызы-
синхронизации вает асинхронный перезапуск
блока,
установка и сброс бита 1 - синхронный перезапуск. Для нормальной работы оба
бита должны быть установлены.
R1 Режим
синхронизации Имеет следующую
структуру:
7 6 5 4 3
2 1 0
--T-T-T-T--T--T--T--¬
¦X¦X¦X¦X¦ ¦
¦ ¦ ¦ Бит:
L-+-+-+-+T-+T-+T-+T--
----
¦ ¦
¦ L--> 0: Высота символов:
1=8 точек, 0=9 точек ¦ ¦ L-----> 1: Полоса частот ЭЛТ: 1=низкая,
0=высокая ¦ L--------> 2: 0=сдвиг
всех символов, 1=только четных L-----------> 3: Частота генератора пикселей:
1=половинная,
0=обычная
R2 Маска
битовых плоскостей Установка битов 0 - 3 разрешает
запись
в соответствующие битовые плоскости.
R3 Выбор
карты символов Биты 0-1 выбирают карту
B, биты
2-3
- карту A; карта A относится к символам, у которых бит 3 атрибутов установлен,
карта B к символам, чей бит 3 сброшен. Действительно только в случае, когда
ОЗУ EGA больше 64К.
R4 Режим
видеопамяти Имеет следующую
структуру:
7 6 5 4 3
2 1 0 --T-T-T-T-T--T--T--¬ ¦X¦X¦X¦X¦X¦ ¦ ¦ ¦ Бит: L-+-+-+-+-+T-+T-+T-- ----
¦ ¦
L--> 0: 1=знакогенератор текста, 0=графика
¦ L-----> 1: Размер ОЗУ EGA: 0=64K, 1=более
64К L--------> 2: Способ хранения пикселей:
1=последовательный,
0=как в CGA (расслоение четных и нечетных строк)
----------------------------------------------------------------
Графический контроллер (GDC) управляет работой адаптера в графическом режиме и имеет
следующие регистры:
Регистр
Наименование Описание
----------------------------------------------------------------
R0 Установка/сброс Установка битов 0 - 3 выбирает
битовых плоскостей соответствующую битовую плос-
кость для
режима записи 00.
R1 Разрешение
установки Управляет доступом к R0.
и сброса
R2 Сравнение
цветов Биты 0 - 3 выбирают цвет для
режима чтения
1.
R3 Параметры
записи Имеет следующую структуру:
7 6 5
4 3 2 1 0
--T-T-T--T--T--T--T--¬
¦X¦X¦X¦ ¦ ¦ Биты:
L-+-+-+--+--+--+T-+---
-----
¦
L----> 0-2: Счетчик циклических сдвигов влево
¦ для
режима записи 00
L----------->
3-4: Способ вывода в режимах записи 00 и 02: 00=без изменений, 01=И, 10=ИЛИ,
11=исключающее ИЛИ
R4 Выбор
карты чтения Биты 0-2 задают номер
плоскости
для режима
чтения 1.
R5 Регистр
режима Имеет следующую структуру:
7 6 5
4 3 2 1 0
--T-T--T--T--T--T--T--¬
¦X¦X¦ ¦
¦ ¦ ¦ ¦ Биты:
L-+-+T-+T-+T-+T-+--+---
-----
¦ ¦
¦ ¦ L--> 0-1: Режим записи 0 - 2 (см. ниже)
¦ ¦
¦ L-------> 2:
1=высокоимпедансный выход (для диаг¦
¦ ¦ ностики), 0=обычная
работа
¦ ¦
L----------> 3: Режим чтения 0 - 1 (см. ниже)
¦ L-------------> 4: 1=использовать
расслоение видеопамяти ¦ (ср. регистр 4 блока синхронизации)
L---------------->
5: 1=использовать 2 бита на пиксель, как в CGA (сдвиг нечетных битов в нечетных
картах); 0=сдвиг четных битов в четных картах
R6 Управление
графикой Имеет следующую структуру:
7 6 5 4 3
2 1 0
--T-T-T-T--T--T--T--¬
¦X¦X¦X¦X¦ ¦
¦ Биты:
L-+-+-+-+--+--+T-+T--
-----
¦
¦ L--> 0: 1=графика,
0=знакогенератор
¦ L-----> 1: Ставить нечетные карты после
четных L---------> 2-3: Адрес и размер видеопамяти:
00=A0000h
(128K), 01=A0000h (64K) 10=B0000h (32K),
11=B8000h (32K)
R7 Маскирование
цветов Биты 0-3 исключают соответству-
ющие битовые
плоскости в режиме чтения 1.
R8 Битовая
маска Биты 0-7 задают биты,
маскируе-
мые во всех
битовых плоскостях.
----------------------------------------------------------------
Примечание.
Режимы чтения и записи имеют следующий смысл.
Режимы чтения:
0 - использовать выбранную битовую
плоскость;
1 - сравнивать цвет пикселя с цветом в
регистре R2 и возвращать 1 при их совпадении.
Режимы записи:
00 - циклически сдвинуть данные,
применить способ вывода, записать в разрешенные плоскости;
01 - вывести в каждую плоскость значение,
полученное предыдущим чтением;
10 - выводить в каждую плоскость 8 бит значения соответствующих
битов 0-3 данных (быстрая закраска)
11 - недопустим.
Порты
ввода-вывода EGA имеют следующее назначение.
Порт
Операция Описание ----------------------------------------------------------------
3C0h Запись
Регистр контроллера атрибутов. Для доступа к
регистрам
ATC подайте команды:
in al,3C2h ; перейти в адресный режим
out
3C0h,n ; номер регистра ATC (режим
данных) out 3C0h,val ; новое значение регистра
Биты 0-4 в n
- номер регистра, бит 5 задает: 1=разрешить вывод на экран, 0=установка
регистра
ATC.
3C2h Запись
Многоцелевой управляющий регистр:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦ ¦ ¦ ¦ ¦
Бит:
LT-+T-+T-+T-+--+--+T-+T--
----
¦ ¦
¦ ¦ ¦ ¦ L---> 0: Выбор портов дисплея:
¦ ¦
¦ ¦ ¦ ¦ 1=3BXh (MGA), 0=3DXh (CGA)
¦
¦ ¦ ¦ ¦ L------> 1: 0=разрешить доступ к ОЗУ
¦
¦ ¦ ¦ ¦ 1=запретить доступ к ОЗУ
¦ ¦
¦ ¦ L----------> 2-3: Частота генератора пикселей:
¦
¦ ¦ ¦ 00=14
Мгц, 01=16 Мгц,
¦ ¦
¦ ¦ 10=внешний источник, 11=резерв
¦ ¦
¦ L---------------> 4:
1=выбрать вывод признаков,
¦ ¦ ¦ 0=выбрать внутренний
источник
¦ ¦
L------------------> 5: Бит страницы при расслоенной
¦ ¦ адресации видеопамяти: 0=младшая
¦ ¦ страница, 1=старшая страница
¦ L---------------------> 6: Полярность
обратного хода луча
¦ по
горизонтали: 1=отрицательная
L------------------------> 7: Полярность
обратного хода луча по вертикали: 1=отрицательная
Чтение Регистр
состояния 0:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦X ¦X ¦X ¦ Бит:
LT-+--+--+--+--+--+--+---
----
¦
¦ L-------------> 3-4: Частота
генератора пикселей
¦ ¦ (см. выше)
¦
L-------------------> 5-6: Ввод признаков
L------------------------> 7: 0=обратный
ход луча по вертикали
3C4h Запись Регистр адреса блока синхронизации.
3C5h Запись Регистр данных блока синхронизации. Для прог-
раммирования
регистра Rn блока нужно выполнить команды:
out
3C4h,n и out 3C5h,данные
3CAh Запись Графическая позиция 2 (для EGA должна быть
1).
3CCh Запись Графическая позиция 1 (для EGA должна быть
0).
3CEh Запись Регистр адреса графического контроллера.
3CFh Запись
Регистр данных графического контроллера. Для
программирования
регистра Rn нужно выполнить команды:
out
3CEh,n и out 3CFh,данные
3D4h Запись Регистр индекса ЭЛТ. Используется для выбора
или регистра
ЭЛТ. Для записи регистра ЭЛТ Rn нужно
3B4h выполнить
команды:
out
3X4h,n и out 3X5h,данные.
3D5h/ Запись/
Регистр данных ЭЛТ. Позволяет записывать и
3B5h чтение читать все регистры ЭЛТ.
3DAh/ Запись
Биты 0 - 1 управляют выходами признаков FC0 и
3BAh FC1
(контакты 19 и 17 соответственно).
Чтение Регистр
состояния 1:
7 6 5
4 3 2 1 0
--T-T-T-T--T--T--T--¬
¦X¦X¦X¦X¦ ¦
¦ ¦ ¦ Бит:
L-+-+-+-+T-+T-+T-+T--
----
¦ ¦
¦ L--->0: 0=вывод
изображения, 1=горизонтальная ¦ ¦ ¦ или вертикальная синхронизация
¦
¦ L------>1: 1=триггер
светового пера сброшен
¦ L--------->2: 1=защелка светового пера
открыта L------------>3: 0=экран включен, 1=выключен (EGA не
требует проверки
этого бита при выводе - в любом случае "хлопьев" не будет)
3DBh/ Запись/
Вывод любого байта выключает триггер светового
3BBh Чтение пера.
3DCh/ Запись/
Вывод любого байта включает триггер светового
3BCh Чтение пера.
----------------------------------------------------------------
EGA
работает либо в режиме совместимости с CGA или MGA, либо в одном из своих собственных графических
видеорежимов:
320 х 200, 16 цветов
640 х 200, 16 цветов
640 х 350, черно-белый
640 х 350, 16 цветов
В
этих режимах видеопамять разбивается на 4
битовые плоскости, каждая из которых содержит образ экрана для одного из
основных цветов:
красного, зеленого, синего
и яркости. Контроллер EGA считывает
биты всех четырех плоскостей, соответствующие
данному пикселю, и формирует его результирующий цвет на экране (комбинация из 4
двоичных цифр дает 16 вариантов цветов).
Видеопамять EGA oтображается в адреса ОЗУ A0000h - B0000h. Размер
памяти EGA варьируется от 64К до 256К
в зависимости от комплектации адаптера. Однако, даже если память EGA
равна 256К, она размещается в 16К адресного пространства оперативной памяти.
Это обьясняется тем, что каждая битовая плоскость отображается в одни и те же
адреса ОЗУ; для выбора битовой плоскости, с которой Вы хотите
обмениваться данными, необходимо переустанавливать соответствующие
регистры графического контроллера.
В
графическом режиме 640
х 200 64К оперативной памяти разбивается на 4 страницы по 16К каждая.
Адреса этих страниц равны соответственно A0000h, A4000h, A8000h и
AC000h. Смещение от начала страницы до
байта, содержащего пиксель с координатами (X,Y), равен 80*Y + int(X/8), а номер соответствующего
бита в этом байте равен 7 - (X %
8). Здесь X - горизонтальная позиция
точки (0 - 639), Y - ее вертикальная позиция (0 - 199).
Графический режим 320 х 200 предоставляет пользователю 8 страниц
размером по 8К. Смещение от начала страницы до байта, содержащего пиксель с координатами (X,Y), равен 40*Y +
int(X/8), а номер соответствующего бита
в этом байте равен 7 - (X % 8). Здесь
X - горизонтальная
позиция точки (0
- 639), Y - ее вертикальная
позиция (0 - 199).
В
графических режимах 640 х 350 имеются
две страницы с адресами A0000h и
A8000h соответственно. В остальном этот
режим аналогичен предыдущим.
В
качестве примера приведем
три подпрограммы работы с дисплеем EGA в режиме 640 х 200. Если Вы хотите использовать их в
других режимах, достаточно
поменять значение константы PageSize на соответствующее
значение.
PageSize
equ 4000h ; размер страницы для режима 640 х 200
;г===========================================¬
;¦
Подпрограмма очистки экрана.
¦
;¦ Вход: CX = номер очищаемой страницы (0-3)
¦ ;L===========================================-
EGA_Cls proc near
push ax
push bx
push cx
push dx
push es
push di
xor
ax,ax ; вычисляем смещение до
страницы
mov
bx,PageSize
jcxz Page_0
High_Page:
add
ax,bx
loop High_Page
Page_0:
mov
di,ax ; DI = адрес страницы в
видеопамяти mov ax,0A000h
mov
es,ax ; ES:DI = полный адрес
страницы
mov
ax,0FF08h
mov
dx,3CEh ; графический
контроллер
out
dx,ax ; установить все
битовые маски
mov
ax,0FF02h
mov
dx,3C4h ; блок синхронизации
out
dx,ax ; разрешить запись во
все плоскости mov ax,3
mov
dx,3CEh ; графический
контроллер
out
dx,ax ; задать нормальный
режим работы
mov
cx,PageSize
xor
al,al
rep
stosb ; обнулить страницу
pop
di
pop
es
pop
dx
pop
cx
pop
bx
pop
ax
ret
EGA_Cls endp
;г===========================================¬
;¦
Подпрограмма вывода пикселя на экран.
¦
;¦
Вход: AX = цвет пикселя
¦
;¦ BX = номер страницы ¦
;¦ CX = номер столбца (X) ¦
;¦ DX = номер строки (Y) ¦
;L===========================================-
Put_Pixel
proc near
push ax
push bx
push cx
push dx
push
es
push ax
push cx
push dx
mov
ax,dx
mov
cx,80
mul
cx ; AX = 80 * Y
pop
dx
pop
cx
push cx
shr
cx,1
shr
cx,1
shr
cx,1 ; CX = X / 8
add
ax,cx ; AX = 80 * Y + X / 8
mov
cx,bx ; номер страницы
mov
bx,PageSize
jcxz Page_Done
Next_Page:
add
ax,bx ; учтем смещение до страницы
loop Next_Page
Page_Done:
pop
cx
mov
bx,ax ; BX = адрес байта, содержащего пиксель mov ax,0A000h
mov
es,ax ; ES:BX = полный адрес байта
and
cl,7 ; CL = X % 7
mov
ah,80h
shr
ah,cl ; AH = позиция пикселя в байте
mov
dx,3CEh
mov
al,8
out
dx,ax ; разрешить запись только в этот бит
pop
ax
mov
ch,al ; цвет пикселя
mov
dx,3C4h
mov
ax,0FF02h
out
dx,ax ; разрешить запись во все плоскости
mov
al,es:[bx] ; читаем байт
xor
al,al
mov
es:[bx],al ; обнуляем пиксель
mov
al,2
mov
ah,ch ; цвет
and
ah,0Fh ; приведем к диапазону
0-15
out
dx,ax ; разрешить запись в
соотв. плоскости
mov
al,es:[bx] ; читаем байт
mov
al,0FFh
mov
es:[bx],al ; устанавливаем пиксель
mov
ax,0FF02h
out
dx,ax ; разрешить запись во все
плоскости
mov
ax,3
mov
dx,3CEh ; графический контроллер
out
dx,ax ; задать нормальный режим
работы
mov
ax,0FF08h
out
dx,ax ; включить все биты
pop
es
pop
dx
pop
cx
pop
bx
pop
ax
ret
Put_Pixel endp
;г===========================================¬
;¦
Подпрограмма чтения цвета пикселя.
¦
;¦
Вход: CX = номер столбца (X)
¦
;¦ DX = номер строки (Y) ¦
;¦ Выход:AX = цвет пикселя ¦
;L===========================================-
Get_Pixel
proc near
push ax
push bx
push cx
push dx
push
es
push dx
mov
ax,205h
mov
dx,3CEh
out
dx,ax ; режимы: записи=01,
чтения=0
pop
dx
push cx
push dx
mov
ax,dx
mov
cx,80
mul
cx ; AX = 80 * Y
pop
dx
pop
cx
push cx
shr
cx,1
shr
cx,1
shr
cx,1 ; CX = X / 8
add
ax,cx ; AX = 80 * Y + X / 8
mov
cx,bx ; номер страницы
mov
bx,PageSize
jcxz My_Page
Higher_Page:
add
ax,bx ; учтем смещение до
страницы
loop Higher_Page
My_Page:
mov
di,ax ; DI = адрес байта,
содержащего пиксель
mov
ax,0A000h
mov
es,ax ; ES:DI = полный адрес
байта
pop
cx
and
cl,7 ; CL = X % 7
mov
ch,80h
shr
ch,cl ; CH = позиция пикселя в
байте
mov
bl,7
sub
bl,cl
mov
cl,bl ; CL = номер бита в байте
xor
bl,bl ; накопитель цвета
mov
ah,3 ; счетчик битовых
плоскостей
mov
al,4 ; R4 = регистр выбора
плоскости
mov
dx,3CEh ; графический контроллер
Read_Plane:
out
dx,ax ; выбираем плоскость AH
mov
bh,es:[di] ; читать байт
and
bh,ch ; выбрать бит
shr
bh,cl ; сдвинуть цвет в бит 0
shl
bl,1 ; сдвинуть выбранные цвета
or bl,bh ; и добавить считанный
dec
ah ; следующая плоскость
jge
Read_Plane ; повторить для всех плоскостей
mov
al,bl
xor
ah,ah ; AX = цвет пикселя
pop
es
pop
dx
pop
cx
pop
bx
pop
ax
ret
Get_Pixel endp
7.7. Графический
видеомассив VGA
Адаптер
VGA (Video Graphics Array) представляет собой дальнейшее развитие
EGA. В основном он полностью
совместим с адаптером EGA,
поэтому мы приведем только его основные отличия.
1. Если
EGA-дисплеи имеют цифровой
вход, то VGA - это дисплей с
аналоговым входом. Поэтому
при формировании цвета пикселя из
битовых плоскостей цвет
слагается из трех основных
цветов (красного, зеленого и синего), интенсивность каждого из которых может
плавно варьироваться от
нуля до максимального значения.
2.
VGA имеет большее разрешение, чем EGA, и предоставляет пользователю три
дополнительных режима:
640 x 480, 2 цвета
640 x 480, 16 цветов
320
x 200, 256 цветов
В режимах
640 х 480 имеется одна графическая страница размером 153600
байт. В режиме
320 х 200 с 256
цветами используется несколько
иной метод формирования цвета пикселя, чем в других режимах; за счет
этого видеопамять разбивается на 4 страницы
размером по 16К.
Этот режим возможен
только на аналоговых дисплеях
или дисплеях с переменной частотой.
3. Частота генератора пикселей VGA принимает
значения 25 или 28 Мгц (в отличие от 14 и 16 Мгц у EGA).
4.
VGA имеет дополнительный
порт ввода 3CCh, позволяющий
считать содержимое многоцелевого регистра (см. описание порта 3C2h в
п. 7.6). Графические позиции 3CAh и 3CCh, имеющиеся в EGA, у VGA отсутствуют.
8. Контроллер
накопителей на гибких дисках
8.1. Основные
сведения о контроллере
Управление гибкими дисками
в PC-подобных ПЭВМ
осуществляется микросхемой 8272А фирмы Intel,
выполняющей функции контроллера гибких дисков (Floppy Disk Controller,
FDC). Информация на дискете хранится на
дорожках, дорожки разбиты на сектора. В
зависимости от типа дисковода число
дорожек на одной стороне дискеты может
быть равно 40 или 80, число секторов на дорожке колеблется от 8
до 26. Кроме того существуют дисководы,
имеющие одну головку чтения/записи (при
этом вторая сторона дискеты не
используется). Контроллер управляет
дисководами для дискет диаметром
8, 5.25 и 3.5 дюйма, поддерживает
запись на дискету методами ЧМ и МЧМ,
программируемую длину секторов (128, 256,
512 или 1024 байта), мультисекторные и мультидорожечные операции
обмена с дисками,
операции поиска. Одновременно к одному контроллеру может быть подключено до четырех дисководов любого из
поддерживаемых типов. Обмен
с диском может осуществляться как
с использованием ПДП,
так и без него. В последнем случае
используются 2 метода:
опрос состояния контроллера через
регистры или использование аппаратных прерывания
контроллера. FDC генерирует
аппаратные прерывания уровня 6 (IRQ6), связанные с вектором прерываний
0Eh. Управление контроллером и накопителями осуществляется через 3
порта ввода-вывода.
8.2. Порты
контроллера накопителей на гибких дисках
Материалы данного и следующего разделов
полностью описывают возможности контроллера 8272А, система команд которого является базовой для всех более
поздних моделей. Дополнительные
возможности контроллера 82072
не описаны, т. к. этот контроллер
полностью поддерживает описываемую систему команд, а
его неописанные функции
практически не используются в стандартных средствах.
Назначение портов ввода-вывода контроллера гибких дисков приведено в таблице.
-------T--------T----------------------------------------------¬
¦ Порт ¦ Режим ¦ Назначение ¦
+------+--------+----------------------------------------------+
¦ ¦ ¦ ¦
¦
3F2h ¦ запись ¦ Передача команд по
управлению режимом работы¦ ¦ ¦ ¦
контроллера и накопителей ¦
¦ ¦ ¦ ¦
¦
3F4h ¦ чтение ¦ Чтение регистра
состояния контроллера ¦
¦ ¦ ¦ ¦
¦
3F5h ¦ запись ¦ Передача команд по
управлению накопителями ¦ ¦ ¦ ¦ ¦
¦
3F5h ¦ чтение ¦ Чтение данных с диска в
режиме работы ¦
¦ ¦ ¦ без ПДП ¦
¦ ¦ ¦ ¦
¦
3F5h ¦ запись ¦ Запись данных на диск в
режиме работы ¦
¦ ¦ ¦ без ПДП ¦
¦ ¦ ¦ ¦
¦
3F5h ¦ чтение ¦ Чтение результатов выполнения команды во ¦
¦ ¦ ¦ всех режимах ¦
L------+--------+-----------------------------------------------
Порт
3F2h.
7 6 5 4 3 2 1
0
----T---T---T---T---T---T---T---¬
¦
¦ ¦ ¦ ¦ Биты:
L-T-+-T-+-T-+-T-+-T-+-T-+-T-+-T--
-----
¦ ¦ ¦ ¦ ¦ ¦ L---+-> 0-1: выбор накопителя:
¦ ¦ ¦ ¦ ¦ ¦ 00-первый
¦ ¦ ¦ ¦ ¦ ¦ 01-второй
¦ ¦ ¦ ¦ ¦ ¦ 10-третий
¦ ¦ ¦ ¦ ¦ ¦ 11-четвертый
¦ ¦ ¦ ¦ ¦ L--------->
2: 0=сброс контроллера,
¦ ¦ ¦ ¦ ¦ 1=разблокировать
контроллер
¦ ¦ ¦ ¦ L-------------> 3: 1=разрешить работу с
ПДП и
¦ ¦ ¦ ¦ прерывания контроллера
L---+---+---+-----------------> 4-7:
включить мотор:
0001 - первый
накопитель 0010 - второй
0100 - третий
1000 -
четвертый
На
АТ-подобных ПЭВМ обычно
допускается не 4, а только 2 накопителя, вследствии чего комбинации, использующие
третий и четвертый накопители, игнорируются. Бит 2, равный 0, прекращает выполнение текущей
команды в момент вывода в порт. Если
команда не завершилась, ее выполнение
прерывается. Если не были считаны результаты выполнения команды, они
пропадают. Если не закончился ввод команды, он
пропадает и должен быть начат
заново. В любом случае продолжение работы возможно только после установки этого бита обратно в
1.
Порт 3F4h.
Через
этот порт осуществляется
чтение регистра основного состояния
FDC.
7 6 5 4 3 2 1
0
----T---T---T---T---T---T---T---¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Биты: L-T-+-T-+-T-+-T-+-T-+-T-+-T-+-T--
-----
¦ ¦ ¦ ¦ L---+---+---+-> 0-3: накопитель занят в
режиме
¦ ¦ ¦ ¦ поиска:
¦ ¦ ¦ ¦ 0001-первый, 0010-второй
¦ ¦ ¦ ¦ 0100-третий,
1000-четвертый
¦ ¦ ¦ L----------------->
4: 0=контроллер свободен,
¦ ¦ ¦ 1=контроллер
занят выполне-
¦ ¦ ¦ нием
команды чтения или
¦ ¦ ¦ записи
¦ ¦ L---------------------> 5: режим работы
контроллера:
¦ ¦ 0=с использованием
ПДП,
¦ ¦ 1=без ПДП
¦ L------------------------->
6: направление обмена:
¦ 0=процессор
--> контроллер
¦ 1=контроллер
--> процессор
L-----------------------------> 7:
готовность к обмену:
0=не готов,
1=готов
Бит 7,
равный 1, говорит о том,
что контроллер при вводе команды готов к
приему очередного байта команды, при обмене данными в
режиме без ПДП готов к приему/передаче очередного байта данных, при приеме результата выполнения команды готов к передаче очередного байта
результата.
8.3.
Команды управления накопителями
Выполнение каждой команды имеет 3 фазы:
-фаза ввода команды; -фаза выполнения; -фаза
результата.
В
фазе ввода команды
контроллер побайтно принимает
и накапливает команду. Фаза
команды заканчивается запуском мотора на соответствующем
накопителе (это не
относится к командам задания режимов
и чтения состояния).
В фазе выполнения осуществляется обмен данными между ОЗУ и накопителем (если
команда предполагает такой обмен). В
режиме с использованием ПДП перед
приемом/передачей байта данных генерируется сигнал "запрос
на ПДП". Контроллер ПДП отвечает
на него сигналом подтверждения и командой приема/передачи. В режиме работы
без ПДП при готовности к приему/передаче каждого байта генерируется прерывание. Если прерывания
запрещены, приграмма может в
цикле проверять регистр
состояния (порт 3F4h)
до получения подтверждения готовности контроллера к обмену данными.
По
окончании выполнения команды
генерируется прерывание, означающее
начало фазы результата. В фазе
результата контроллер передает
результаты выполнения команды.
Все байты результата должны
быть считаны, либо
необходимо выполнить сброс контроллера, иначе следующая команда не будет принята. Не все команды имеют фазу результата, ряд команд выполняется в 2
фазы.
8.3.1. Перечень команд контpоллеpа НГМД
Ниже
приводится подробное описание
команд FDC. Фаза
выполнения помечена знаками "* * *".
Смысл символических обозначений
элементов команд приведен после описания команд. В битовых масках биты
нумеруются справа налево. В фазе
результата все байты результата
приведены в той
последовательности, в которой они возвращаются контроллером.
------------T------------------------------------T-------------¬
¦ Команда ¦ Регистр данных ¦ Назначение ¦
+-----------+------------------------------------+-------------+
¦ 1. Чтение ¦ MT MF
SK 0 0 1 1
0 ¦ Ввод данных ¦
¦
данных ¦ X X X X X
HD US1 US0 ¦ из поля дан-¦
¦ ¦ C ¦ ных сектора ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
¦ ¦ EOT ¦ ¦
¦ ¦ GPL ¦ ¦
¦ ¦ DTL ¦ ¦
¦ ¦ * *
* ¦ ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
+-----------+------------------------------------+-------------+
¦ 2. Чтение ¦ MT MF
SK 0 1 1 0
0 ¦ Ввод данных ¦
¦
удаленных ¦ X X X X X HD
US1 US0 ¦ из поля дан-¦
¦
данных ¦ C ¦
ных, поме- ¦
¦ ¦ H ¦ ченного как ¦
¦ ¦ R ¦ удаленное ¦
¦ ¦ N ¦ ¦
¦ ¦ EOT ¦ ¦
¦ ¦ GPL ¦ ¦
¦ ¦ DTL ¦ ¦
¦ ¦ * * * ¦ ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
+-----------+------------------------------------+-------------+
¦ 3. Запись ¦ MT MF 0 0
0 1 0 1 ¦ Вывод данных¦
¦
данных ¦ X X X X X HD
US1 US0 ¦ в поле дан- ¦
¦ ¦ C ¦ ных сектора ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
¦ ¦ EOT ¦ ¦
¦ ¦ GPL ¦ ¦
¦ ¦ DTL ¦ ¦
¦ ¦ * * * ¦ ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
+-----------+------------------------------------+-------------+
¦ 4. Запись ¦ MT MF 0 0
1 0 0 1 ¦ Запись ад- ¦
¦
удаленных ¦ X X X X X HD
US1 US0 ¦ ресного мар-¦
¦
данных ¦ C ¦
кера удален-¦
¦ ¦ H ¦ ных данных и¦
¦ ¦ R ¦ занесение ¦
¦ ¦ N ¦ символа-за- ¦
¦ ¦ EOT ¦ полнителя в ¦
¦ ¦ GPL ¦ поле данных ¦
¦ ¦ DTL ¦ ¦
¦ ¦ * * * ¦ ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
+-----------+------------------------------------+-------------+
¦ 5. Чтение ¦ 0 MF
SK 0 0 0 1
0 ¦ Чтение полей¦
¦
дорожки ¦ X X X X X HD US1 US0
¦ данных сек- ¦
¦ ¦ C ¦ торов всей ¦
¦ ¦ H ¦ дорожки ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
¦ ¦ EOT ¦ ¦
¦ ¦ GPL ¦ ¦
¦ ¦ DTL ¦ ¦
¦ ¦ * * * ¦ ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
L-----------+------------------------------------+--------------
При выполнении данной команды
игнорируются параметры "начальный номер
сектора" и "
номер последнего сектора", так как чтение начинается с
первого встреченного после
индекса сектора и
передается столько
секторов, сколько было
запрошено. Если запрошенное число
секторов (длина принимаемой
информации)
больше,
чем имеется секторов на дорожке,
передача повторяется с
начала
первого сектора дорожки.
------------T------------------------------------T-------------¬
¦ 6. Чтение ¦ 0 MF 0 0 1 0 1 0 ¦
Чтение пер- ¦
¦
идентифи- ¦ X X X X X HD US1 US0 ¦ вого встре- ¦
¦
катора ¦ * * * ¦
ченного ¦
¦
сектора ¦ ST0 ¦
идентифика- ¦
¦ ¦ ST1 ¦ тора сектора¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
+-----------+------------------------------------+-------------+
¦ 7. Форма- ¦ 0 MF 0 0 1 1 0 1 ¦
Запись на ¦
¦
тирование ¦ X X X X X HD US1 US0 ¦ дорожку фор-¦
¦
дорожки ¦ N ¦
матирующей ¦
¦ ¦ SC ¦ информации ¦
¦ ¦ GPL ¦ ¦
¦ ¦ D ¦ ¦
¦ ¦ * * * ¦ ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
L-----------+------------------------------------+--------------
Перед выполнением команды форматирования необходимо
спозиционировать
головку на требуемую дорожку. Данные для записи в идентификатор адреса
сектора (цилиндр, головка,
дорожка и размер сектора)
принимаются от ПДП или через
порт данных и не проверяются. Физический размер сектора определяется параметром "N" - код длины сектора, задаваемым в команде и одинаковым для всей дорожки. Таким образом нельзя иметь
на на одной дорожке сектора разной
длины. Команда не заносит в маркер данных признак "удаленные данные", а заполняет поле данных
секторов дорожки байтом-заполнителем.
------------T------------------------------------T-------------¬
¦ 8.Сканиро-¦ MT MF SK 1 0 0 0 1 ¦
Сканирова- ¦
¦
вание до ¦ X X X X X HD US1 US0
¦ ние данных ¦
¦
"равно" ¦ C ¦ на указан-
¦
¦ ¦ H ¦
ное условие ¦
¦ ¦ R ¦ и формирова-¦
¦ ¦ N ¦ ние запроса ¦
¦ ¦ EOT ¦ на прерыва- ¦
¦ ¦ GPL ¦ ние при вы- ¦
¦ ¦ STP ¦ полнении ¦
¦ ¦ * * * ¦ условия ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
+-----------+------------------------------------+-------------+
¦ 9.Сканиро-¦ MT MF SK 1 1 0 0 1 ¦
аналогично ¦
¦
вание до ¦ X X X X X HD US1 US0
¦ предыдущей ¦
¦
"больше ¦ C ¦ команде ¦
¦
или равно"¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
¦ ¦ EOT ¦ ¦
¦ ¦ GPL ¦ ¦
¦ ¦ STP ¦ ¦
¦ ¦ * * * ¦ ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ C ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
+-----------+------------------------------------+-------------+
¦10.Сканиро-¦ MT MF
SK 1 1 1 0 1 ¦ аналогично ¦
¦
вание до ¦ X X X X X HD US1 US0
¦ предыдущей ¦
¦
"меньше ¦ C ¦
команде ¦
¦
или равно"¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
¦ ¦ EOT ¦ ¦
¦ ¦ STP ¦ ¦
¦ ¦ * * * ¦ ¦
¦ ¦ ST0 ¦ ¦
¦ ¦ ST1 ¦ ¦
¦ ¦ ST2 ¦ ¦
¦ ¦ H ¦ ¦
¦ ¦ R ¦ ¦
¦ ¦ N ¦ ¦
¦ ¦ * * * ¦ нулевую ¦
¦ ¦ ¦
дорожку ¦
+-----------+------------------------------------+-------------+
¦12. Опреде-¦ 0 0 0 0 0 0 1 1 ¦
Задание ¦
¦ ление
¦ <--- SRT ---> <--- HUT ---> ¦ режима ¦
¦ ¦ <---------
HLT ---------> ND ¦ работы ¦
¦ ¦ ¦
дисковода ¦
+-----------+------------------------------------+-------------+
¦13.Поиск ¦ 0 0 0 0 1 1 1 1 ¦ Позициониро-¦
¦ ¦ Х Х Х Х Х HD
US1 US0 ¦ вание голов-¦
¦ ¦ NCN ¦ ки на задан-¦
¦ ¦ * * * ¦ ную дорожку ¦
+-----------+------------------------------------+-------------+
¦14.Чтение ¦ 0 0 0 0 1 0 0 0 ¦ Чтение байта¦
¦
состояния ¦ * * * ¦ состояния ¦
¦
прерывания¦ ST0 ¦ ST0 после ¦
¦ ¦ PCN ¦ прерываний, ¦
¦ ¦ ¦
вызванных ¦
¦ ¦ ¦
изменением ¦
¦ ¦ ¦
готовности ¦
¦ ¦ ¦
дисковода ¦
¦ ¦ ¦
и операцией ¦
¦ ¦ ¦
поиска ¦
+-----------+------------------------------------+-------------+
¦15.Чтение ¦ 0 0 0 0 0 1 0 0 ¦ Чтение байта¦
¦
состояния ¦ Х Х Х Х Х HD US1 US0 ¦ состояния ¦
¦ НГМД ¦ * * * ¦
ST3 ¦
¦ ¦ ST3 ¦ ¦
¦ ¦ ¦ ¦
+-----------+------------------------------------+-------------+
¦16. Несуще-¦ < ошибочный код
команды FDC> ¦ При ошибоч- ¦
¦
ствующая ¦ * * * ¦
ной команде ¦
¦
команда ¦ ST0 ¦
возвращается¦
¦ ¦ ¦
ST0=80h ¦
¦ ¦ ¦ ¦
L-----------+------------------------------------+--------------
Смысловое значение элементов команд:
МТ=1 - многодорожечная (двусторонняя
операция);
MF=1 -
МЧМ-кодирование (двойная плотность)
- пропуск синхроимпульсов у единичных
битов и пропуск синхроимпульсов
у нулевых битов, стоящих после единичных;
SK=1 -
пропуск адресного маркера удаленных данных;
HD
- номер головки (0 или 1);
US1,
US0 - номер накопителя (0 - 3);
С
- номер цилиндра;
Н
- номер головки;
R
- номер сектора;
N - код длины сектора (0 - 128, 1 - 256, 2 - 512, 3 - 1024 байтов);
EOT - номер последнего сектора на цилиндре;
GPL - длина межзонного промежутка (обычно 2Ah при обмене и 50h при
форматировании);
DTL - число
считываемых/записываемых байт
(действительно при N = 0);
ST0
- ST3 - байты состояния ST0-ST3;
STP
- межсекторное смещение;
SRT - время
скорости шага в милисекундах (обычно 0Dh);
HUT -
время разгрузки головки в
единицах по 16 милисекунд (обычно = 0Fh);
HLT -
время загрузки головки в
единицах по 2 милисекунды (обычно = 1);
ND=0
- режим работы с использованием ПДП, =1 - режим работы без использования ПДП;
NCN
- номер цилиндра после поиска;
PCN
- номер текущего цилиндра;
SC
- количество секторов на цилиндре;
D
- символ-заполнитель для разметки (обычно 0F6h).
8.3.2.
Структура байтов состояния
Байт состояния ST0:
7 6 5 4 3
2 1 0
----T---T---T---T---T---T---T---¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Биты: L-T-+-T-+-T-+-T-+-T-+-T-+-T-+-T--
-----
¦ ¦ ¦ ¦ ¦
¦ L---+-> 0-1: номер
накопителя (0 - 3)
¦ ¦ ¦ ¦ ¦
L---------> 2: номер головки
¦ ¦ ¦ ¦ L-------------> 3: НГМД не готов при
обмене
¦ ¦ ¦ L----------------->
4: Сигнал "ошибка" НГМД или
¦ ¦ ¦ дорожка 0 не найдена после 77
¦ ¦ ¦ шагов
рекалибровки
¦ ¦ L---------------------> 5: команда поиска
завершена
L---+-------------------------> 6: код
прерывания:
00-нормальное
завершение команды 01-ненормальное завершение 10-недействительная команда
11-в
фазе выполнения изменилась готовность дисковода
Бит 2
(номер головки) после
выполнения команды поиска
всегда равен
0, независимо от
того, на какой
головке осуществлялся поиск.
Бит
3 будет всегда равен 1, если
на дисководе с одной
головкой
вы попробуете обратиться к стороне 1
(допустима только сторона 0).
Байт состояния ST1:
7 6 5 4 3 2 1 0
----T---T---T---T---T---T---T---¬
¦ ¦ 0 ¦
¦ ¦ 0 ¦ ¦
¦ ¦ Бит: L-T-+---+-T-+-T-+---+-T-+-T-+-T--
----
¦ ¦ ¦ ¦ ¦
L-> 0: 1=не найден маркер иденти-
¦ ¦ ¦ ¦ ¦ фикатора
сектора
¦ ¦ ¦ ¦ L-----> 1: 1=дискета защищена от
¦ ¦ ¦ ¦ записи
¦ ¦ ¦ L--------->
2: 1=искомый сектор не найден
¦ ¦ L-----------------> 4: 1=таймаут запросов
на
¦ ¦ передачу данных
¦ L--------------------->
5: 1=ошибка CRC в поле иденти-
¦ фикации
или в поле данных
L----------------------------->
7: 1=конец цилиндра (попытка обращения к сектору после обращения к последнему
сектору последнего цилиндра)
Байт состояния ST2:
7 6 5 4 3 2 1 0
----T---T---T---T---T---T---T---¬
¦
0 ¦ ¦ ¦ ¦ ¦
¦ ¦ ¦ Бит: L---+-T-+-T-+-T-+-T-+-T-+-T-+-T-- ---
¦ ¦ ¦ ¦ ¦ ¦ L-> 0: 1=не найден маркер данных
¦ ¦ ¦ ¦ ¦ ¦ или удаленных данных
¦ ¦ ¦ ¦ ¦ L----->
1: 1=сбойный цилиндр
¦ ¦ ¦ ¦ L---------> 2: 1=сканирование выполнено
¦ ¦ ¦ ¦ неудовлетворительно
¦ ¦ ¦ L------------->
3: 1=при сканировании выполне-
¦ ¦ ¦ но
условие "равно"
¦ ¦ L-----------------> 4: 1=неверный номер
цилиндра в
¦ ¦ идентификаторе сектора
¦ L--------------------->
5: 1=ошибка CRC в поле данных
L------------------------->
6: 1=в идентификаторе сектора обнаружен адресный маркер удаленных данных
Байт состояния ST3:
7 6 5 4 3 2 1 0
----T---T---T---T---T---T---T---¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Бит:
L-T-+-T-+-T-+-T-+-T-+-T-+-T-+-T-- ----
¦ ¦ ¦ ¦ ¦ ¦ L---+-> 0-1: номер накопителя
¦ ¦ ¦ ¦ ¦ L--------->
2: номер головки
¦ ¦ ¦
¦ L-------------> 3:
1=сигнал "двусторонний"
¦ ¦ ¦
¦ от НГМД
¦ ¦ ¦
L-----------------> 4: 1=сигнал "Дорожка 0" от
¦ ¦ ¦ НГМД
¦ ¦ L---------------------> 5: 1=сигнал
"Готовность" от
¦ ¦ НГМД
¦ L------------------------->
6:1=сигнал "Защита от записи"
¦ от НГМД
L----------------------------->
7: 1=сигнал "Ошибка" от НГМД
8.4. Формат
дорожки
Индикатором начала
дорожки служит индексное
отверстие. Запись на дорожку
осуществляется в несколько
приемов. При форматировании
дорожка перезаписывается полностью. При операциях записи перезаписываются отдельные сектора, что влечет за собой сбой намагниченности диска в месте
обрыва записи, причем физическая длина сектора при его
перезаписи не всегда точно
совпадает с длиной ранее имевшегося
на этом месте сектора,
разница в длине может составлять
до 4 - 5 бит
даже при перезаписи на одном
дисководе в одно время. Для синхронизации после сбоев на дорожке имеются
зазоры и синхрозоны. В общем виде формат дорожки можно изобразить следующим
образом:
-----------------------------¬
¦ ¦ Определяется индексным
¦
Индекс ¦ отверстием
¦ ¦
+----------------------------+
¦ ¦
¦
Зазор индекса ¦ 80 байт 4Eh
¦ ¦
+----------------------------+
¦ ¦ 12 байтов 00h, 3 байта 0C2h,
¦ Заголовок дорожки ¦ 1 байт 0FCh, 50 байтов
4Eh
¦ ¦
+----------------------------+
¦ ¦
¦
1-й сектор ¦ 574 байта
¦ ¦
+----------------------------+
¦ ¦
¦ Межсекторный промежуток ¦ 80
байт 4Eh
¦ ¦
+----------------------------+
. .
. 8 или 9 секторов на дорожке.
. .
+----------------------------+
¦ ¦
¦ Последний сектор ¦ 574 байта
¦ ¦
+----------------------------+
¦ ¦
¦ Межсекторный промежуток ¦ 80
байт 4Eh
¦ ¦
+----------------------------+
¦ ¦
¦
Зазор дорожки ¦ байты 4Eh до индексного
¦ ¦ отверстия
+----------------------------+
¦ ¦
¦
Индекс ¦
¦ ¦
L-----------------------------
Формат сектора:
-----------------------------¬
¦ ¦
¦ Идентификатор сектора ¦ 22
байта
¦ ¦
+----------------------------+
¦ ¦
¦ Зазор идентификатора ¦ 22 байта 4Eh
¦ ¦
+----------------------------+
¦ ¦
¦ Блок
данных ¦ 530 байт
¦ ¦
L-----------------------------
Идентификатор сектора:
-----------------------------¬
¦ ¦ 12 байтов 00, 3
байта 0A1h
¦ Маркер идентификатора ¦ 1 байт 0FEh
¦ ¦
+----------------------------+
¦ ¦ 6 байтов: цилиндр,
головка,
¦Идентификатор
адреса сектора¦ дорожка, код длины сектора
¦ ¦ и 2 байта контрольной
суммы
L-----------------------------
Блок данных:
-----------------------------¬
¦ ¦ 12 байтов 00, 3
байта 0A1h,
¦
Маркер данных ¦ 1 байт 0FXh
(Х=8 - удаленные
¦ ¦ данные, 0Bh -
действительные
+----------------------------+
данные)
¦ ¦
¦ Поле данных ¦ 512 байт
¦ ¦
+----------------------------+
¦ ¦
¦ Контрольная сумма поля ¦ 2 байта
¦
данных ¦
L-----------------------------
8.5. Отличия
контроллера для АТ-подобных ПЭВМ
Архитектура АТ-подобных
ПЭВМ отличается от
ХТ тем, что контроллер гибких дисков находится на одной плате с
контроллером жестких дисков. К
дополнительным
возможностям относится
возможность регулирования скорости
обмена данными и возможность подключения двух контроллеров к одному ПЭВМ (в этом случае вместо портов
3F2h - 3F7h используются порты 372h - 377h). Функции контроллера гибких дисков на
АТ-подобных ПЭВМ выполняются микросхемой 82072 фирмы Intel (советских
аналогов нет). Дополнительно к описанным выше портам имеется еще один
порт 3F7h, позволяющий
осуществить доступ к регистру выбора скорости обмена данными
(Data Rate Select Register, DSR).
Порт
3F7h.
7
6 5 4 3 2
1 0
----T---T---T---T---T---T---T---¬
¦ ¦ ¦ ¦
¦ ¦ ¦ ¦ ¦ Биты:
L-T-+-T-+-T-+-T-+-T-+-T-+-T-+-T--
-----
¦ ¦ ¦ ¦
¦ ¦ L---+-> 0-1: выбор скорости обмена
¦
¦ ¦ L---+---+---------> 2-4: выбор времени
¦
¦ ¦
предкомпенсации
¦ ¦ L---------------------> 5: 1=разрешить
внешний
¦ ¦ фильтр данных
¦ L------------------------->
6: 1=отключить питание
¦ дисковода
L----------------------------->
7: 1=программный сброс контроллера
Возможные скорости обмена данными в зависимости от битов 0 - 1 DSR приведены в таблице.
--------------------T--------------------------¬
¦
Биты ¦ Скорость ¦
+---------T---------+-------------T------------+
¦ 1 ¦ 0 ¦ МЧМ
¦ ЧМ ¦
+---------+---------+-------------+------------+
¦ 1 ¦ 1 ¦ 1 Мбит/сек ¦ Невозможно ¦
¦ 0 ¦ 0 ¦
500 Кбит/сек¦250 Кбит/сек¦
¦ 0 ¦ 1 ¦
300 Кбит/сек¦150 Кбит/сек¦
¦ 1 ¦ 0 ¦
250 Кбит/сек¦125 Кбит/сек¦
L---------+---------+-------------+-------------
В
зависимости от значений
битов 2, 3 и 4 DSR возможны следующие
значения времени предкомперсации:
-------------------------T---------------------¬
¦ Биты ¦ Время ¦
¦ 4 3 2 ¦ предкомпенсации ¦
+------------------------+---------------------+
¦ 1 1 1 ¦ Недопустимая ¦
¦ ¦ комбинация ¦
¦ 0 0 1 ¦ 41.67 нс ¦
¦ ¦ ¦
¦ 0 1 0 ¦ 83.34 нс ¦
¦ ¦ ¦
¦ 0 1 1 ¦ 125.00 нс ¦
¦ ¦ ¦
¦ 1 0 0 ¦ 166.00 нс ¦
¦ ¦ ¦
¦ 1 0 1 ¦ 208.33 нс ¦
¦ ¦ ¦
¦ 1 1 0 ¦ 250.00 нс ¦
¦ ¦ ¦
¦ 0 0 0 ¦ Взять значение ¦
¦ ¦ по умолчанию ¦
L------------------------+----------------------
Значения
по умолчанию для
времени предкомпенсации в
зависимости
от скорости приведены в таблице.
-------------------------T---------------------¬
¦
Скорость ¦ Время ¦
¦
обмена ¦ предкомпенсации ¦
+------------------------+---------------------+
¦ 1 Мбит/сек ¦ 41.67 нс ¦
¦ 500 Кбит/сек ¦ 125.00 нс ¦
¦ 300 Кбит/сек ¦ 125.00 нс ¦
¦ 250 Кбит/сек ¦ 125.00 нс ¦
L------------------------+----------------------
Кроме
пятнадцати описанных выше
команд контроллера 8272, 82072
поддерживает еще 4 команды:
- изменить параметры конфигурации;
- включение/выключение мотора;
- относительный поиск;
- вернуть состояние регистров контроллера.
Описание команд приведено в таблице.
----------------T------------------------------T---------------¬
¦ Команда ¦ Шина данных ¦
Назначение ¦
+---------------+------------------------------+---------------+
¦ 1. Изменить ¦ 0 0 0 1 0 0
1 1¦ Команда изме-¦
¦
параметры ¦HDSA <- MOFF-> <--- MON --->¦ няет указанные¦
¦
конфигурации ¦ 0 EIS
EF POLL <- FIFOTHR ->¦ параметры ¦
¦ ¦ <--------- PRETRK
---------->¦ ¦
¦ ¦ * * * ¦ ¦
+---------------+------------------------------+---------------+
¦ 2.Включение/ ¦ ON/OFF US1 US0 0
1 0 1 1¦ Включает/ ¦
¦
выключение ¦ ¦ выключает мо- ¦
¦
мотора ¦ ¦ тор на задан- ¦
¦ ¦ ¦
ном дисководе ¦
+---------------+------------------------------+---------------+
¦ 3. Относитель-¦ 1 DIR 0 0 1 1 1
1¦ Осуществляет-¦
¦
ный поиск ¦ 0 0 0 0 0 HD US1 US0¦ ся сдвиг голо-¦
¦ ¦ <----------- RCN
----------->¦ вок в заданном¦
¦ ¦ * * * ¦ направлении на¦
¦ ¦ ¦
заданное число¦
¦ ¦ ¦
цилиндров ¦
+---------------+------------------------------+---------------+
¦ 4. Вернуть ¦ 0 0 0 0 1 1
1 0¦ Возвращает ¦
¦
состояние ¦ * * * ¦ состояние ¦
¦
регистров ¦ <---- PCN-устр-ва 0
-------->¦ внутренних ¦
¦ ¦ <---- PCN-устр-ва 1
-------->¦ регистров ¦
¦ ¦ <---- PCN-устр-ва 2
-------->¦ контроллера ¦
¦ ¦ <---- PCN-устр-ва 3
-------->¦ ¦
¦ ¦ <--- SRT ---> <--- HUT --->¦ ¦
¦ ¦ <--------- HLT
---------> ND¦ ¦
¦ ¦ <--------- SC/EOT
---------->¦ ¦
¦ ¦HDSA <- MOFF -> <--- MON --->¦ ¦
¦ ¦ <--------- PRETRK
---------->¦ ¦
¦ ¦ 0 EIS EF POLL <- FIFOTHR ->¦ ¦
¦ ¦ ¦ ¦
L---------------+------------------------------+----------------
В таблице приняты следующие сокращения:
US1, US0 - номер устройства;
DIR
- направление изменения (0-увеличение, 1-уменьшение);
HD - номер головки чтения/записи;
RCN - относительный номер цилиндра;
PCN - текущий номер цилиндра;
SRT - время скорости шага;
HUT -время разгрузки головки;
HLT - время загрузки головки;
ND - режим без ПДП;
SC/EOT - число секторов на дорожке/номер
последнего сектора на дорожке;
ON/OFF - включение/выключение мотора (0/1);
MON - задержка перед включением мотора;
MOFF - задержка перед выключением мотора;
EIS
= 1 - разрешить автоматический поиск перед
чтением/записью данных, по умолчанию = 0;
EF = 1 - переводит контроллер в режим
имитации 8272А;
POLL = 1 - запрещает обращение к
устройствам;
HDSA
= 1 - позволяет изменять
временные задержки в зависимости от скорости вращения дисковода;
PRETRK - номер
дорожки для предкомпенсации (обычно = 0).
9. Контроллер
накопителей на жестких дисках
В данном
разделе описывается управление
контроллером накопителей на жестких
магнитных дисках типа
"винчестер". Материалы
раздела подобраны
в основном из
технической документации и программного обеспечения для жестких дисков
фирмы Seagate, однако данных
о том, что существуют значительные отличия в управлении дисками, выпускаемыми
другими фирмами, в настоящий
момент не имеется.
В связи с тем, что управление жесткими дисками
в ХТ и АТ-подобных ПЭВМ
принципиально отличается,
описание ХТ и АТ контроллеров приведены отдельно друг от друга.
Часть информации, полученная из анализа
программного обеспечения,
возможно является неполной.
Такая информация помечена звездочкой (*) в конкретной строке изложения или в заголовке раздела.
9.1. Контроллер
жестких дисков для ХТ-подобных ПЭВМ
Архитектура
ХТ-подобных ПЭВМ допускает подключение к одному контроллеру до
двух накопителей. Обмен
с жесткими дисками производится с использованием третьего канала ПДП.
Контроллер генерирует аппаратные прерывания
5-го уровня (IRQ5), вектор прерывания 0Dh. Работа с диском осуществляется с использованием
отдельного ПЗУ, содержащего
процедуры управления диском, что
является характерной особенностью ХТ-подобных ПЭВМ. Обычно
в качестве сегментного адреса ПЗУ используется 0C800h, но возможны и другие
значения (0CA00h, 0D000h или
0D800h для дисков ST-251 или ST-225
фирмы Seagate). Имеется
16 адресов портов ввода-вывода, предназначенных для управления контроллером и накопителями (320h-32Fh),
однако реально используются
только 4 из них, например 320h-323h,
324h-327h, 328h-32Bh или 32Ch-32Fh. Назначение портов (1-й, 2-й, 3-й и 4-й в каждой группе) одно и то же, поэтому далее будут описаны только
порты 320h-323h.
9.1.1. Порты
ввода-вывода
Назначение портов контроллера жестких дисков приведено
в таблице.
-------T--------T----------------------------------------------¬
¦ Порт ¦ Режим ¦ Назначение ¦
+------+--------+----------------------------------------------+
¦ 320h ¦ запись ¦ Передача команд по управлению накопителями ¦
¦
¦ ¦ ¦
¦
320h ¦ чтение ¦ Чтение параметров состояния после ошибок, ¦
¦
¦ ¦ возникших в процессе
выполнения последней ¦
¦
¦ ¦ команды ¦
¦
¦ ¦ ¦
¦
321h ¦ запись ¦ Сброс контроллера ¦
¦ ¦
¦ ¦
¦
321h ¦ чтение ¦ Чтение состояния контроллера ¦
¦ ¦
¦ ¦
¦
322h ¦ запись ¦ Разблокировка (выбор) контроллера ¦
¦ ¦
¦ ¦
¦
322h ¦ чтение ¦ Чтение типа накопителя ¦
¦ ¦
¦ ¦
¦
323h ¦ запись ¦ Установка режима работы контроллера ¦
¦ ¦
¦ ¦
L------+--------+-----------------------------------------------
Порт 320h.
Через этот порт контроллер принимает команды по управлению
накопителями. Команда содержит
до шести байтов
информации, первый из которых
определяет класс и код команды, а остальные содержат требуемые для выполнения
команды параметры. При
возникновении
ошибки в процессе выполнения команды
(бит 1 порта 321h) следует ввести в порт
320h команду "запрос
состояния", после чего прочитать
из него 4
байта состояния, первый из
которых определяет код ошибки.
Порт 321h.
Запись
нулевого байта в
этот порт вызывает
сброс контроллера. При чтении состояния контроллера возможны следующие
значения битов:
7 6 5 4 3 2 1 0
----T---T---T---T---T---T---T---¬
¦
X ¦ X ¦ ¦ X ¦ ¦
¦ ¦ ¦ Биты: L---+---+-T-+---+-T-+-T-+-T-+-T-- -----
¦ ¦ +-------+--> 0,2,3: 11=готовность к приему
¦ ¦ ¦ ¦ ¦ очередного
байта
¦ ¦ ¦ ¦ ¦ команды
¦ ¦ ¦ ¦ ¦
01=команда принята
¦ ¦ ¦ ¦ ¦ полностью
¦ L---+-------+--> 111=готовность к приему
¦ ¦ новой команды
¦ L------>
1: 1=ошибка
L----------------------> 5: номер
накопителя (0-1)
Бит 2, равный 1, вместе с битом 0,
равным 1, указывает на то, что контроллер готов к приему очередного
байта команды. Если в ходе
передачи команды бит
2 = 0, а бит
0 = 1, значит контроллер
считает, что он принял команду полностью и не ждет ввода новых байтов команды.
Бит
3, равный 1,
вместе с битами
0 и 1, равными 1, указывает
на готовность очередного
байта состояния при
выполнении
команды "запрос состояния". Если установлены в 1 биты 0, 2 и
3 - это означает, что контроллер свободен и готов к приему
первого байта новой команды.
Порт 322h.
Вывод
произвольного байта в
этот порт разблокирует контроллер. Операция
разблокирования (выбора, активизации) контроллера (enable controller) должна выполняться каждый раз перед началом вывода через порт 320h новой команды.
При чтении из порта 322h может быть
прочитан байт 0FFh, что не несет никакой информации, либо тип накопителя (применительно к данной версии ПЗУ).
7
6 5 4 3 2
1 0
----T---T---T---T---T---T---T---¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Биты:
L-T-+-T-+-T-+-T-+-T-+-T-+-T-+-T-- -----
¦
¦ ¦ ¦ ¦ ¦
¦ ¦
¦ ¦
L---+-----------+---+--> 0,1,4,5: 1111=один накопитель
¦ ¦ ¦ ¦ большой емкости, иначе - тип
¦
¦ ¦ ¦ второго накопителя
L---+-----------+---+----------> 2,3,6,7:
тип первого накопителя
Если тип второго накопителя (биты
5, 4, 1 и 0) равен 1111,
это
означает, что к
контроллеру подключен один
накопитель большой емкости
(более 32 Мбайт), который при
форматировании следует разбивать
на несколько логических дисков
(говорят, что установлен ключ
разбиения (Split switch)). Стандартное ПЗУ XT фирмы Seagate
может работать со
следующими 15-ю типами накопителей (номера 0 - 14),
приведенными в таблице. Типом 15
(неопределенный тип) отмечаются
все накопители, отличные по параметрам от описанных.
----T---------------------------------T----T---T---T---T----¬
¦Тип¦Фирма изготовитель и модель диска¦ C
¦ H ¦ R ¦ B ¦ V ¦
+---+---------------------------------+----+---+---+---+----+
¦
0 ¦ Seagate ST-225 ¦615 ¦
4 ¦ 17¦ 0 ¦21.4¦
+---+---------------------------------+----+---+---+---+----+
¦
1 ¦ Seagate ST-4038 ¦733 ¦
5 ¦ 17¦ 2 ¦31.9¦
+---+---------------------------------+----+---+---+---+----+
¦
2 ¦ Miniscribe-3425 ¦615 ¦
4 ¦ 17¦ 0 ¦21.4¦
+---+---------------------------------+----+---+---+---+----+
¦
3 ¦ Seagate ST-212 ¦306 ¦
4 ¦ 17¦ 0 ¦10.6¦
+---+---------------------------------+----+---+---+---+----+
¦
4 ¦ Priam V-150 ¦987 ¦
5 ¦ 17¦ 0 ¦42.9¦
+---+---------------------------------+----+---+---+---+----+
¦
5 ¦ Priam V-170 ¦987 ¦
7 ¦ 17¦ 0 ¦60.1¦
+---+---------------------------------+----+---+---+---+----+
¦
6 ¦ Miniscribe-8425,Kyocera 20A/20B ¦615 ¦ 4 ¦ 17¦ 0 ¦21.4¦
+---+---------------------------------+----+---+---+---+----+
¦
7 ¦ Seagate ST-138 ¦615 ¦
6 ¦ 17¦ 0 ¦32.1¦
+---+---------------------------------+----+---+---+---+----+
¦
8 ¦ Seagate ST-4051 ¦977 ¦
5 ¦ 17¦ 2 ¦42.5¦
+---+---------------------------------+----+---+---+---+----+
¦
9 ¦ Seagate ST-251/ST-251-1 ¦820 ¦
6 ¦ 17¦ 0 ¦42.8¦
+---+---------------------------------+----+---+---+---+----+
¦
10¦ HH-725 ¦612 ¦
4 ¦ 17¦ 0 ¦21.3¦
+---+---------------------------------+----+---+---+---+----+
¦
11¦ Seagate ST-4053, ¦1024¦
5 ¦ 17¦ 0 ¦44.5¦
¦ ¦ Miniscribe-3053/6053 ¦
¦ ¦ ¦ ¦ ¦
+---+---------------------------------+----+---+---+---+----+
¦ 12¦ Maxtor-1085, Newbury Data-1085
¦1024¦ 8 ¦ 17¦ 0 ¦71.3¦ ¦ ¦
Miniscribe-6085 ¦ ¦
¦ ¦ ¦ ¦
+---+---------------------------------+----+---+---+---+----+
¦ 13¦ Seagate ST-4096 ¦1024¦
9 ¦ 17¦ 0 ¦80.2¦
+---+---------------------------------+----+---+---+---+----+
¦ 14¦ Maxtor-1140,Newbury Data-1140 ¦396
¦ 15¦ 17¦ 0 ¦51.7¦
L---+---------------------------------+----+---+---+---+-----
Здесь
C-число цилиндров (десятичное);
H-число головок (десятичное);
R-число
секторов на дорожке (десятичное); B-стандартный управляющий байт
(шестнадцатеричный); V-емкость диска (Мбайт).
Порт
323h.
7
6 5 4 3 2
1 0
----T---T---T---T---T---T---T---¬
¦ не используются ¦ ¦ ¦ Бит:
L---+---+---+---+---+---+-T-+-T--
----
¦ L---> 0: 1=разрешить работу с ПДП ¦ 0=не использовать ПДП
L------->
1: 1=разрешить аппаратные прерывания от контроллера (IRQ5)
Установка
режима работы производится обычно до раз-
блокировки
контроллера перед началом вывода команды.
9.1.2. Общий формат команды и терминология
Команда
контроллера может состоять
из 1 -
6 байт. Общий формат команды приведен на рисунке.
--------T-----T-----T-----T-----T-----T-----T-----T-----¬
¦
\ биты¦ ¦ ¦ ¦ ¦
¦ ¦ ¦ ¦
¦ \ ¦ 7
¦ 6 ¦ 5 ¦
4 ¦ 3 ¦ 2 ¦ 1
¦ 0 ¦
¦байты\
¦ ¦ ¦ ¦ ¦ ¦
¦ ¦ ¦
+-------+-----+-----+-----+-----+-----+-----+-----+-----+
¦ 0 ¦ Класс команды ¦ Код операции ¦
+-------+-----T-----T-----+-----------------------------+
¦ 1 ¦ 0
¦ 0 ¦ У ¦ Номер
головки ¦
+-------+-----+-----+-----+-----------------------------+
¦ ¦ Цилиндр ¦ ¦
¦ 2 ¦
(старшие ¦ Номер сектора ¦
¦ ¦ биты) ¦ ¦
+-------+-----------+-----------------------------------+
¦ 3 ¦
Цилиндр ( младшие биты ) ¦
+-------+-----------------------------------------------+
¦ 4 ¦ Фактор чередования или число секторов ¦
¦ ¦ (зависит от команды) ¦
+-------+-----------------------------------------------+
¦ 5 ¦ Управляющий байт ¦
L-------+------------------------------------------------
Здесь и далее:
-
класс команды и
код операции определяют код команды контроллера;
- У - номер устройства (0/1);
-
номер сектора - номер начального сектора для обмена;
-
фактор чередования (Interleave
Factor) задает последовательность чередования
секторов на дорожке
(см. формат дорожки);
- управляющий байт:
7
6 5 4 3 2 1 0
----T---T---T---T---T---T---T---¬
¦ ¦ ¦
X X
X ¦ ¦ ¦ ¦ Биты:
L-T-+-T-+---+---+---+-T-+-T-+-T--
-----
¦ ¦
L---+---+-> 0-2: период импульсов сигнала
¦ ¦ "шаг"
¦ L-------------------------> 6:
1=запретить повторное счи-
¦ тывание
при ошибке контр.
¦ суммы
L----------------------------->
7: 1=запретить повторный доступ к диску при ошибке.
Бит 7,
равный 1, разрешает только одну
попытку доступа к
диску
при выполнении команды (иначе разрешены 4 попытки), при тестировании накопителя должен быть
равен 1, при нормальной работе
должен быть равен 0. Бит 6,
равный 1, запрещает повторное считывание секторов при появлении
ошибки контрольной суммы
после первой попытки считывания,
если бит 6
равен 0 -
разрешается повторное считывание
и, если повторное считывание успешно - признак ошибки не устанавливается,
обычно равен 0.
Биты
0 - 2 определяют тип накопителя и выбирают периоды импульсов сигнала "шаг":
значение
100 --> 200 микросекунд;
101 --> 70 микросекунд;
110 и 111 --> 3 милисекунды;
Остальные
варианты указывают на
неопределенный тип накопителя и
предполагают период в 3 милисекунды.
При
описании команд использованы следующие сокращения и обозначения:
0 или 1 - конкретные значения битов;
Х - бит не используется;
У - номер устройства (0/1);
П
- использовать бит
повторных попыток обращения
к накопителю (бит 7 управляющего байта);
ПС
- использовать бит
повторного считывания (бит
6 управляющего байта);
Ш
- использовать биты
задания периодичности импульсов сигнала "шаг";
ЦСБ - старшие 2 бита номера цилиндра;
ЦМБ - младшие 8 бит номера цилиндра;
НГ - номер головки (5 бит);
НС - номер начального сектора (6 бит);
ФЧ - фактор чередования (5 бит);
ЧС - число секторов (8 бит).
9.1.3.
Описание команд
-->
Проверка готовности накопителя (класс 0, опкод 0).
Команда
выбирает заданный накопитель
и проверяет его готовность.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0
0 0 0 0 0 ¦
+-------------------------------+
1 ¦ 0 0 У Х Х Х Х Х ¦
L---+---+---+---+---+---+---+----
-->
Рекалибровать (класс 0, опкод 1).
Команда
устанавливает головки
чтения/записи на выбранном
накопителе на нулевой цилиндр.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0
0 0 0 0 1 ¦
+-------------------------------+
1 ¦ 0 0 У
Х Х Х Х Х ¦
+-------------------------------+
2 ¦ Х Х Х
Х Х Х Х Х ¦
+-------------------------------+
3 ¦ Х Х Х
Х Х Х Х Х ¦
+-------------------------------+
4 ¦ Х Х Х Х Х
Х Х Х ¦
+-------------------------------+
5 ¦ П 0 0 0 0
Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Запрос состояния (класс 0, опкод 3).
Команда
подается непосредственно после
обнаружения ошибки (бит 1 порта 321h). Команда имеет длину 2 байта и вызывает передачу контроллером четырех байтов результата, определяющих параметры возникшей ошибки.
Формат команды:
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0 0
0 0 1 1 ¦
+-------------------------------+
1 ¦ 0 0 У Х
Х Х Х Х ¦
L---+---+---+---+---+---+---+----
Формат результата:
----T---T---T---T---T---T---T---¬
0 ¦ байт
состояния ¦
+-------------------------------+
1 ¦ 0 0 У <------ НГ ------>¦
+-------------------------------+
2 ¦ ЦСБ <--------
НС -------->¦
+-------------------------------+
3 ¦<------------
ЦМБ ------------>¦
L---+---+---+---+---+---+---+----
Формат байта состояния:
7 6 5 4 3 2 1
0
----T---T---T---T---T---T---T---¬
¦ ¦ 0 ¦
¦ ¦ ¦ ¦ ¦
¦ Биты: L-T-+---+-T-+-T-+-T-+-T-+-T-+-T--
¦ ¦ ¦ ¦ ¦ ¦
¦
¦ ¦ ¦ L---+---+---+--> 0-3: код ошибки
¦ ¦ ¦
¦ L---+------------------> 4-5: тип ошибки
¦
L------------------------------>
7: 1=при выполнении команды произошло обращение
к
накопителю
Бит 7 байта состояния равен 1, если при выполнении команды
произошло обращение к накопителю, в этом случае байты 1 - 3 результата содержат корректную информацию, иначе эта информация
некорректна.
Описание
возможных ошибок приведено в таблице.
-------T------T------------------------------------------------¬
¦ Тип ¦
Код ¦ ¦
¦ошибки¦ошибки¦
Значение ¦
+------+------+------------------------------------------------+
¦ 00 ¦ 0000 ¦ Нет ошибки (нормальное завершение
команды) ¦
¦ 00 ¦
0001 ¦ Нет сигнала по линии "индекс" ¦
¦ 00 ¦
0010 ¦ Нет сигнала по линии "поиск закончен" ¦
¦ 00 ¦
0011 ¦ Сигнал "ошибка записи" ¦
¦ 00 ¦
0100 ¦ Накопитель не отвечает сигналом готовности ¦
¦ ¦ ¦
после разблокировки ¦
¦ 00 ¦
0101 ¦ Не используется ¦
¦ 00 ¦
0110 ¦ Нет сигнала "дорожка 0" ¦
¦ 00 ¦
0111 ¦ Не используется ¦
¦ 00 ¦
1000 ¦ При выполнении команды "проверка готовности ¦
¦ ¦ ¦
накопителя" накопитель находится в состоянии ¦
¦ ¦ ¦
поиска ¦
+------+------+------------------------------------------------+
¦ 01 ¦ 0000 ¦ Ошибка при считывании поля
идентификации ¦
¦ 01 ¦
0001 ¦ Неисправимая ошибка чтения ¦
¦ 01 ¦
0010 ¦ Адресный маркер не обнаружен ¦
¦ 01 ¦
0011 ¦ Не используется ¦
¦ 01 ¦
0100 ¦ Сектор не найден ¦
¦ 01 ¦
0101 ¦ Ошибка поиска ¦
¦ 01 ¦
0110 ¦ Не используется ¦
¦ 01 ¦
0111 ¦ Не описан ¦
¦ 01 ¦
1000 ¦ Неисправимая ошибка ¦
¦ 01 ¦
1001 ¦ Обнаружен флаг "дефектная дорожка" ¦
+------+------+------------------------------------------------+
¦ 10 ¦ 0000 ¦ Неверная команда ¦
¦ 10 ¦
0001 ¦ Неверный логический адрес накопителя ¦
+------+------+------------------------------------------------+
¦ 11 ¦ 0000 ¦ Неуспешно окончена команда
"диагностика ¦
¦ ¦ ¦
внутреннего ОЗУ контроллера" ¦
¦ 11 ¦
0001 ¦ Неуспешно окончена диагностика ППЗУ ¦
¦ ¦ ¦
контроллера ¦
¦ 11 ¦
0010 ¦ Неуспешно окончен тест генератора кодов ¦
¦ ¦ ¦
коррекции ошибок (ECC) ¦
L------+------+-------------------------------------------------
-->
Форматирование накопителя (класс 0, опкод 4).
Команда
форматирует все цилиндры,
начиная с заданного до конца накопителя
и используя заданное значение фактора
чередования. При
форматировании
перезаписываются все поля идентификации, поля данных заполняются
байтами-заполнителями.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0
0 0 1 0 0 ¦
+-------------------------------+
1 ¦ 0 0 У
<------- НГ ------>¦
+-------------------------------+
2 ¦
ЦСБ 0 0 0 0
0 0 ¦
+-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4 ¦ 0 0 0
<------ ФЧ ------->¦
+-------------------------------+
5 ¦ П 0 0
0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Проверка секторов (класс 0, опкод 5).
Команда проверяет возможность считывания заданных секторов с диска без
передачи их содержимого в ОЗУ ПЭВМ.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0
0 0 1 0 1 ¦
+-------------------------------+
1 ¦ 0 0 У
<------- НГ ------>¦
+-------------------------------+
2
¦ ЦСБ
<--------- НС -------->¦ +-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4
¦<------------ ЧС ------------->¦ +-------------------------------+
5 ¦ П ПС 0
0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Форматирование дорожки (класс 0, опкод 6).
Команда форматирует одну заданную дорожку. В остальном ее действие аналогично команде
"форматирование накопителя".
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0 0 0 1 1 0 ¦
+-------------------------------+
1 ¦ 0 0 У
<------- НГ ------>¦
+-------------------------------+
2 ¦
ЦСБ 0 0 0 0 0 0 ¦
+-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4 ¦ 0 0 0
<------ ФЧ ------->¦
+-------------------------------+
5 ¦ П 0 0 0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Форматирование дефектной дорожки (класс 0, опкод 7).
Команда
форматирует одну заданную
дорожку, устанавливая флаги
"дефектная
дорожка" в заготовках
секторов. Никакая информация в
поля данных не записывается.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0 0 0 1 1 1 ¦
+-------------------------------+
1 ¦ 0 0 У
<------- НГ ------>¦
+-------------------------------+
2 ¦
ЦСБ 0 0 0 0 0 0 ¦
+-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4 ¦ 0 0 0
<------ ФЧ ------->¦
+-------------------------------+
5 ¦ П 0 0 0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Чтение секторов (класс 0, опкод 8).
Команда
считывает запрошенное число
секторов начиная с заданного.
Все сектора должны находиться на одной дорожке.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0 0 1 0 0 0 ¦
+-------------------------------+
1 ¦ 0 0 У
<------- НГ ------>¦
+-------------------------------+
2
¦ ЦСБ
<--------- НС -------->¦ +-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4
¦<------------ ЧС ------------->¦ +-------------------------------+
5 ¦ П ПС 0 0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Запись секторов (класс 0, опкод 0Ah).(*)
Команда
записывает заданное в
блоке параметров число секторов на диск, начиная с указанного
начального сектора. Все записываемые сектора должны находиться на одной
дорожке.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0 0 1 0 1 0 ¦
+-------------------------------+
1 ¦ 0 0 У
<------- НГ ------>¦
+-------------------------------+
2
¦ ЦСБ
<--------- НС -------->¦ +-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4
¦<------------ ЧС ------------->¦ +-------------------------------+
5 ¦ П ПС 0 0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Поиск цилиндра по номеру (класс 0, опкод 0Ch).(*)
Команда осуществляет позиционирование
головок накопителя на заданный цилиндр.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0 0 1 1 0 0 ¦
+-------------------------------+
1 ¦ 0 0 У
<------- НГ ------>¦
+-------------------------------+
2 ¦
ЦСБ Х Х Х Х Х Х ¦
+-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
5 ¦ П 0 0 0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Чтение внутреннего ОЗУ контроллера (класс 0, опкод 0Eh).(*)
Команда
считывает содержимое внутреннего
ОЗУ контроллера (512 байт).
Данное ОЗУ используется контроллером при
чтении/записи и содержит информацию, считанную/записанную при выполнении последней команды
чтения/записи секторов.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0 0 1 1 1 0 ¦
+-------------------------------+
1 ¦ 0 0 Х Х Х Х Х Х ¦
+-------------------------------+
2 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
3 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
4 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
5 ¦ Х Х Х Х Х Х Х Х ¦
L---+---+---+---+---+---+---+----
-->
Запись внутреннего ОЗУ контроллера (класс 0, опкод 0Fh).(*)
Команда
обновляет содержимое внутреннего ОЗУ контроллера.
----T---T---T---T---T---T---T---¬
0 ¦ 0 0 0 0 1 1 1 1 ¦
+-------------------------------+
1 ¦ 0 0 Х Х Х Х Х Х ¦
+-------------------------------+
2 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
3 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
4 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
5 ¦ Х Х Х Х Х Х Х Х ¦
L---+---+---+---+---+---+---+----
-->Диагностика
внутреннего ОЗУ контроллера (класс 7,опкод 0).(*)
Команда
проверяет правильность работы
внутреннего ОЗУ
контроллера. В случае ошибки генерируется ошибка с
типом 3 и кодом 0.
----T---T---T---T---T---T---T---¬
0 ¦ 1 1 1 0 0 0 0 0 ¦
+-------------------------------+
1 ¦ 0 0 Х Х Х Х Х Х ¦
+-------------------------------+
2 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
3 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
4 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
5 ¦ Х Х Х Х Х Х Х Х ¦
L---+---+---+---+---+---+---+----
-->
Тест устройства (класс 7, опкод 3).
Команда проверяет состояние и
работоспособность накопителя.
----T---T---T---T---T---T---T---¬
0 ¦ 1 1 1 0 0 0 1 1 ¦
+-------------------------------+
1 ¦ 0 0 У Х Х Х Х Х ¦
+-------------------------------+
2 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
3 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
4 ¦ Х Х Х Х Х Х Х Х ¦
+-------------------------------+
5 ¦ П Х Х У Х Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Расширенный тест контроллера (класс 0, опкод 4).
Команда
проверяет функционирование составных
частей контроллера: микропроцессора, ОЗУ, ПЗУ и схем коррекции ошибок.
----T---T---T---T---T---T---T---¬
0 ¦ 1 1 1 0 0 1 0 0 ¦
L---+---+---+---+---+---+---+----
-->
Считывание без контроля (класс 7, опкод 5).
Команда
выполняет считывание поля
данных одного сектора вместе
с его контрольной суммой. Параметр
"число секторов" игнорируется. При обнаружении ошибки
контрольной суммы флаг ошибки не
выставляется и коррекция не производится.
----T---T---T---T---T---T---T---¬
0 ¦ 1 1 1 0 0 1 0 1 ¦
+-------------------------------+
1 ¦ 0 0 У
<------- НГ ------>¦
+-------------------------------+
2
¦ ЦСБ
<--------- НС -------->¦ +-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4
¦<------------ ЧС ------------->¦ +-------------------------------+
5 ¦ П
0 0 0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
-->
Запись без контроля (класс 7, опкод 6).
Команда выполняет запись поля данных одного
сектора и его контрольной
суммы, при этом
логика коррекции ошибок
не используется. Параметр "число секторов" не используется.
----T---T---T---T---T---T---T---¬
0 ¦ 1
1 1 0 0 1 1 0 ¦
+-------------------------------+
1 ¦ 0 0
У <------- НГ ------>¦
+-------------------------------+
2 ¦ ЦСБ
<--------- НС -------->¦ +-------------------------------+
3
¦<----------- ЦМБ ------------->¦ +-------------------------------+
4
¦<------------ ЧС ------------->¦ +-------------------------------+
5 ¦ П
0 0 0 0 Ш Ш Ш ¦
L---+---+---+---+---+---+---+----
9.1.4. Разметка диска
Данные
на жесткий диск
записываются в секторах. Сектора располагаются на
дорожках. Нумерация дорожек
начинается с внешней стороны
пластины (там расположена
нулевая дорожка). Количество пластин (дисков) и головок, так же как и
максимальное число дорожек, могут колебаться в довольно широких пределах и зависят от типа конкретного
накопителя.
Дорожка обычно содержит от 8 до 26 секторов и для данного конкретного накопителя
число секторов на
дорожке постоянно. Начало
дорожки определяется сигналом "индекс", который
генерируется
накопителем при каждом обороте диска. Далее следует первый сектор дорожки. Второй сектор будет отстоять от первого на число секторов,
равное значению фактора чередования
минус 1, третий еще на столько же
и т. д. Таким образом при
факторе чередования равном 3,
сектора на 17-секторной дорожке
будут располагаться следующим образом:
---T--T--T--T--T--T--T--T--T--T--T--T--T--T--T--T--¬
¦
1¦ 7¦13¦2 ¦8 ¦14¦3 ¦9 ¦15¦4 ¦10¦16¦ 5¦11¦17¦ 6¦12¦
+--+--+--+T-+--+--+T-+--+--+--+--+--+--+--+--+--+--+
¦
¦ фактор ¦ ¦
¦
¦чер-ния ¦ ¦
¦<--индекс¦<------>¦ индекс --> ¦
Формат сектора приведен в таблице.
------------T-------------------------------------------T------¬
¦Обозначение¦ Назначение ¦Длина ¦
¦ ¦ ¦(байт)¦
+-----------+-------------------------------------------+------+
¦ АМ ¦ Адресный маркер ¦
4 ¦
¦ ИНТ1 ¦
Интервал ¦
9-12 ¦
+-----------+-------------------------------------------+------+
¦ ¦ Поле идентификации: ¦ ¦
¦ СИНХ1 ¦
Синхробайт ¦ 1 ¦
¦ ИНТ2 ¦
Интервал ¦ 2 ¦
¦ СРВ ¦
Байт для сравнения ¦ 1 ¦
¦ ЦСБ ¦
Старший байт номера цилиндра ¦ 1 ¦
¦ ЦМБ ¦
Младший байт номера цилиндра ¦ 1 ¦
¦ ГЛВ ¦
Номер головки ¦ 1 ¦
¦ СЕКТ ¦
Номер сектора ¦ 1 ¦
¦ ФЛАГ ¦
Флаговый байт ¦ 1 ¦
¦ НУЛЬ ¦
Нулевой байт ¦ 1 ¦
¦ КС1 ¦
Контрольная сумма поля идентификации ¦ 4 ¦
+-----------+-------------------------------------------+------+
¦ ИНТ3 ¦
Интервал ¦ 16 ¦
+-----------+-------------------------------------------+------+
¦ ¦ Область данных: ¦ ¦
¦ СИНХ2 ¦
Синхробайт ¦ 1 ¦
¦ ИНТ4 ¦
Интервал ¦ 2 ¦
¦ ДАННЫЕ ¦
Поле данных ¦ 512 ¦
¦ КС2 ¦
Контрольная сумма поля данных ¦ 4 ¦
+-----------+-------------------------------------------+------+
¦ ИНТ5 ¦
Интервал ¦ 43 ¦
L-----------+-------------------------------------------+-------
Начало
сектора обозначается при
помощи уникальной
комбинации, называемой адресным
маркером. Пять интервалов, обозначенных в таблице ИНТ1 - ИНТ5, заполняются нулями, причем длина ИНТ2 и ИНТ4 постоянна и равна 2 байтам, в
то время как ИНТ1, ИНТ3 и ИНТ5 могут
иметь разную длину, немного отличающуюся от
значений, приведенных в
таблице. Эти три
интервала
предназначены для подготовки накопителя к считыванию
(записи) следующей за ним области, а различие в длине объясняется тем, что
адресный маркер, поле
идентификации и данные
могут записываться в разное
время поверх ранее имевшейся
информации, что не обеспечивает точного совпадения физической
длины записанной области и ранее
имевшейся на этом месте области. Отличия в длине могут составлять несколько бит, чем объясняется
наличие после после
интервалов синхробайта, позволяющего определить истинную
начальную границу области
и правильно сгруппировать все последующие биты по байтам. Байт СРВ имеет постоянное значение
для всех секторов
и используется для проверки правильности считывания
поля идентификации. Флаговый
байт содержит служебную
информацию, в частности
отмечает дефектность сектора, если он не пригоден для записи.
Контрольные суммы служат для проверки
правильности считывания информации из поля идентификации и области данных и вычисляются специальным генератором кодов
коррекции ошибок (Error Correction
Code, ECC) с производящим полиномом 32-й степени.
9.2.
Контроллер жестких дисков для АТ-подобных ПЭВМ
IBM PC
AT отличается от всех предыдущих
моделей IBM PC и совместимых ПЭВМ в
следующем:
-
стандартный BIOS обеспечивает
возможность работы как с накопителями
на гибких, так и с накопителями на жестких дисках;
- контроллеры жестких и гибких дисков расположены на одной плате;
-
адреса портов ввода-вывода,
предназначенных для управления
жестким диском, и назначение портов полностью отличаются от ХТ-подобных
ПЭВМ.
Возможно
подключение к одному ПЭВМ двух жестких дисков. Каждый диск
имеет свой набор портов (1F0h-1F7h для первого и 170h-177h для второго). Ниже будут описаны порты только первого диска.
Назначение портов второго диска аналогично первому.
9.2.1. Описание портов ввода-вывода
Порт 1F0h
Предназначен для обмена данными
с внутренним ОЗУ
контроллера, являющимся промежуточным звеном между оперативной памятью ПЭВМ и
накопителем.
Порт 1F1h.
При
чтении через этот порт
можно получить информацию о
последней возникшей ошибке:
7 6 5 4 3 2 1 0
----T---T---T---T---T---T---T---¬
¦ ¦
¦ 0 ¦ ¦ 0 ¦ ¦
¦ ¦ Бит:
L-T-+-T-+---+-T-+---+-T-+-T-+-T-- ----
¦ ¦ ¦ ¦ ¦
L->0: 1=адресный маркер
данных не
¦ ¦ ¦ ¦ ¦ найден
¦ ¦ ¦ ¦ L----->1: 1=ошибка на нулевой дорожке
¦ ¦ ¦ L--------->2:
1=выполнение команды прекра-
¦ ¦ ¦ щено программно,
команда
¦ ¦ ¦ не
завершилась
¦ ¦ L----------------->4:
1=идентификатор сектора не
¦ ¦ найден
¦ L------------------------->6:
1=неисправимая ошибка в дан-
¦ ных, ошибка
контрольной
¦ суммы
L----------------------------->7:
1=дефектный сектор
Порт 1F2h.
Чтение/запись
числа секторов для последующей операции.
Порт 1F3h.
Чтение/запись параметра
"номер сектора" для последующей операции.
Порт 1F4h.
Чтение/запись старших битов номера цилиндра
для последующей операции (биты 0 - 1
- это биты 8 - 9
в 10-битовом номере цилиндра).
Порт 1F5h.
Чтение/запись младших восьми битов
номера цилиндра для последующей
операции.
Порт 1F6h.
Чтение/запись номера устройства и головки для последующей операции.
Порт 1F7h (запись).
Вывод команды по управлению накопителем.
Порт 1F7h (чтение).
Чтение состояния накопителя
и результатов предыдущей
команды:
7 6 5 4 3 2 1 0
----T---T---T---T---T---T---T---¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Бит:
L-T-+-T-+-T-+-T-+-T-+-T-+-T-+-T-- ----
¦ ¦ ¦ ¦ ¦
¦ ¦ L->0: 1=предыдущая команда
завер-
¦ ¦ ¦ ¦ ¦
¦ ¦ шилась с ошибкой
¦ ¦ ¦ ¦ ¦
¦ L----->1: 1=сигнал
"индекс"
¦ ¦ ¦ ¦ ¦
L--------->2: 1=данные при выполнении пос-
¦ ¦ ¦ ¦ ¦ ледней
операции были скор-
¦ ¦ ¦ ¦ ¦ ректированы при
помощи
¦ ¦ ¦ ¦ ¦ алгоритма
ECC
¦ ¦ ¦ ¦ L------------->3: 1=идет процесс обмена
данными
¦ ¦ ¦ L----------------->4:
1=поиск завершен
¦ ¦ L--------------------->5: 1=ошибка записи
¦ L------------------------->6:
1=устройство готово для чте-
¦ ния,
записи или поиска
L----------------------------->7:
1=устройство занято выполнением
команды ( остальные биты не
несут смысловой нагрузки)
9.2.2. Система команд
Код
команды заносится в
порт 1F7h после
того, как подготовлены все параметры в портах 1F2h -
1F6h. Выполнение команды
начинается сразу после
занесения в порт
1F7h кода команды. Команда состоит
из одного байта.
Старшие 4 бита содержат код требуемой операции,
младшие содержат параметры. Перечень
команд с возможными
значениями параметров приведен в
таблице.
---------T-----------------------T-----------------------------¬
¦ Код ¦ Назначение ¦ Параметры ¦
¦операции¦ ¦ ¦
+--------+-----------------------+-----------------------------+
¦ 1 ¦ Рекалибровать (сброс ¦ Период импульсов сигнала ¦
¦ ¦ головок на цилиндр 0) ¦
"шаг" ¦
+--------+-----------------------+-----------------------------+
¦ 2 ¦ Чтение секторов ¦ Биты, определяющие необходи-¦
+--------+-----------------------+
мость повторных обращений ¦
¦ 3 ¦
Запись секторов ¦ к диску и повторных
попыток ¦
+--------+-----------------------+
считывания при ошибках ¦
¦ 4 ¦
Проверка секторов ¦ контрольной суммы ¦
+--------+-----------------------+-----------------------------+
¦ 5 ¦ Форматирование дорожки¦ Параметр = 0 ¦
+--------+-----------------------+-----------------------------+
¦ 7 ¦ Поиск цилиндра ¦ Период импульсов сигнала ¦
¦ ¦ ¦
"шаг" ¦
+--------+-----------------------+-----------------------------+
¦ 9 ¦ Диагностика ¦
Параметр = 0 ¦
¦ +-----------------------+-----------------------------+
¦ ¦ Установка параметров ¦ Параметр = 1 ¦
¦ ¦ накопителя (максималь-¦ ¦
¦ ¦ ное число головок и ¦ ¦
¦ ¦ секторов) ¦ ¦
L--------+-----------------------+------------------------------
10.
Печатающее устройство
Устройство печати IBM
PC-подобных компьютеров обычно
подключается к
параллельному интерфейсу. Для
подключения используется стандартный разъем Centronix, имеющий 36
контактных выходов (отечественный аналог ИРПР-М). Допускается три варианта подключения принтеров к ПЭВМ:
-
адаптер принтера может
находится на одной
плате с
адаптером монохромного дисплея, при этом
используются порты 3BCh - 3BEh;
-
к ПЭВМ могут подключены два
отдельных адаптера для
управления принтерами,
использующие порты 378h - 37Ah (первый адаптер) и 278h - 27Ah
(второй адаптер).
При
программировании принтера важно
знать адрес базового порта ввода-вывода (первого порта из
трех); адреса базовых портов
хранятся в области данных BIOS, начиная с адреса 0:408h (LPT1) и далее по
слову на принтер до LPT4. Дальнейшее
описание предполагает, что базовый адрес принтера равен 378h.
Порт
Операция Описание
----------------------------------------------------------------
378h Запись
Регистр данных - сюда засылается байт, посылае-
мый на печать
Чтение Регистр
данных - позволяет считать последний
байт, переданный принтеру
379h Чтение Регистр состояния принтера:
7
6 5 4 3 2 1 0
---T--T--T--T--T-T-T-¬
¦ ¦
¦ ¦ ¦ ¦X¦X¦X¦ Биты:
LT-+T-+T-+T-+T-+-+-+-- -----
¦ ¦
¦ ¦ L---------> 3: 0=при печати возникла ошибка
¦ ¦
¦ L------------> 4: 0=принтер
в автономном режиме
¦ ¦
L---------------> 5: 1=сигнал "конец бумаги"
¦ L------------------> 6: 0=принтер готов к
печати
¦ следующего символа
L---------------------> 7: 0=принтер
занят, находится в автономном режиме или произошла ошибка
37Ah Чтение/ Регистр управления принтером:
Запись
7 6 5 4
3 2 1 0
--T-T-T--T--T--T--T--¬
¦X¦X¦X¦ ¦
¦ ¦ ¦ ¦ Биты:
L-+-+-+T-+T-+T-+T-+T--
-----
¦ ¦
¦ ¦ L---> 0: бит запуска печати (см. ниже)
¦
¦ ¦ L------> 1: 1=после возврата каретки выводить
¦
¦ ¦ перевод строки (в MS-DOS должен
¦
¦ ¦ быть сброшен)
¦ ¦
L---------> 2: 1=инициализировать принтер
¦ L------------> 3: 1=разрешить вывод на
печать (должен ¦ быть
всегда установлен)
L---------------> 4: 1=разрешить
прерывания от принтера ----------------------------------------------------------------
Примечания.
1.
Для запуска печати
символа нужно на короткое время установить бит 0 регистра
управления, а затем сбросить его.
2.
Прерывание происходит по
окончании вывода символа на печать:
для первого принтера
на седьмом уровне контроллера прерываний (IRQ7, вектор
прерывания 0Fh), для второго принтера на пятом уровне (IRQ5, вектор 0Dh). Следует отметить также,
что IRQ5 используется XT-контроллером
жестких дисков для генерации своих прерываний. Обычно этот бит
не используется
(сбрасывается),
а проверка готовности принтера производится на основании опроса регистра
состояния.
Типичная последовательность действий для вывода на печать
одного
символа такова:
- вывести передаваемый байт в регистр
данных;
- в цикле проверять состояние принтера до устaновки бита 7 регистра
состояния (здесь возможно использование таймаута);
- проверить биты 3-5 регистра состояния на
наличие ошибки;
-
установить и сразу
же сбросить нулевой бит регистра управления, для
этого подходит следующая
последовательность команд:
mov
dx,37Ah ;адрес регистра
управления
mov
al,00001101b ;установить биты 0,2
и 3
out
dx,al ;вывести команду
xor
al,1 ;сбросить бит 0
out dx,al ;повторно
вывести команду
- далее
можно прочитать и
запрограммировать регистр
состояния и перейти к печати следуюего символа.
Несмотря
на простоту управления,
принтер представляет из себя достаточно
сложное устройство, имеющее свой микропроцессор, ПЗУ и ОЗУ. Микропроцессор
используется для обработки управляющих последовательностей и управления печатью. ПЗУ содержит описание рисунков
символов в зависимости от их кода и выбранной таблицы и программы на
языке используемого микропроцессора. ОЗУ
используется для временного хранения
введенных данных и спроектированных пользователем символов.
Ряд принтеров, помимо интерфейса
Centronix, могут поключаться
и к последовательному интерфейсу. Принтер обрабатывает ряд спецсимволов (таких, как звонок, забой, горизонтальная и вертикальная
табуляция), а также имеет достаточно
сложную систему команд для изменения режимов работы и управления
печатью.
Обычно
команды начинаются с символа ESC
(шестнадцатиричный код 1Bh) и
имеют длину от
двух байт и
более (существуют командные последовательности,
включающие по несколько килобайт
информации, например команды
загрузки спроектированных
пользователем шрифтов).
Спецсимволы и байты команд передаются принтеру так
же, как и
обычные символы, предназначеные
для печати, описанным выше
способом. Подобный способ управления удобен для
программного изменения режимов работы устройства. Учитывая, что
выпуском принтеров для ПЭВМ занимается
достаточно большое число компаний
и возможности принтеров
постоянно совершенствуются,
нет смысла приводить
полностью какую-либо
систему команд, так
как, во-первых, она
в разных марках и моделях принтеров
различна, и, во-вторых,
достаточно полно описывается в
документации на каждый конкретный принтер.
Существует
2 основных стандарта на систему команд и таблицу используемых символов
(стандарты IBM и
EPSON), которых в основном
придерживаются фирмы-изготовители,
оставляя за собой право
вносить в них изменения и дополнения. Единого стандарта как на систему команд, так и на расположение и рисунки символов второй
половины таблицы ASCII (коды 129-255) нет. Наиболее часто используемые команды:
-
установка вида шрифта и режима печати;
- черновой
текстовый (draft) нормальной
ширины (pica), узкий (condensed) или средней ширины (elita).
- качественный шрифт (NLQ, Proportional,
Orator, Script и т. д.);
-выбор
таблицы символов из ПЗУ (обычно имеется несколько таблиц,
отличающихся расположением управляющих кодов, наличием и расположением
псевдографических символов или курсива);
-
загрузка в ОЗУ принтера спроектированных пользователем шрифтов
и работа с ОЗУ принтера (именно в этой группе команд, имеются наибольшие различия между разными
моделями);
- управление принтером в режиме точечной
графики;
- установка служебных
параметров (размеры отступов,
страницы, шаг
табуляции, расстояние между строками) и
изменение характеристик (сброс, включение/отключение датчика конца бумаги,
печать в одну или в две стороны и т. п.).
Ряд
характеристик и режимов
работы может выбираться как программно, так и аппаратно с использованием кнопок и клавиш на лицевой
панели и DIP-переключателей. Существуют
характеристики, изменить которые можно
только аппаратно (например, возможность
загрузки шрифтов или размер используемого ОЗУ).
11.Последовательный
интерфейс RS-232
11.1. Общие сведения
В сотав
IBM PC могут входить до
четырех последовательных интерфейсов,
работающих в стандарте RS-232 (отечественный аналог - стык С2) и именуемых СОМ1
- СОМ4. Им выделены следующие адреса в области портов ввода-вывода:
СОМ1: 3F8h-3FFh
COM3: 338h-33Fh
COM2: 278h-2FFh
COM4: 238h-23Fh
(интерфейсы
СОМ3 и СОМ4 поддерживаются только в моделях PS/2).
Каждый интерфейс связан с определенным уровнем контроллера
прерываний:
СОМ1 вызывает прерывание IRQ4 (Int 0Ch)
COM2 вызывает прерывание IRQ3 (Int 0Bh)
СОМ3
и СОМ4 не имеют стандартных векторов прерываний.
Каждое
из устройств RS-232
представляет собой контроллер 8250,
оснащенный 25- или 9- штырьковым разъемом на задней стенке корпуса ПЭВМ. Этот разъем может использоваться для подключения мыши, графопостроителя
или организации связи
между ПЭВМ. Контакты стыка RS-232
имеют следующие наименования
---------T---------T--------------T-------------------T--------¬
¦Название¦ Имя цепи¦Номер контакта¦ Назначение ¦Направ-
¦
¦сигнала
+---T-----+-----T--------+ ¦ление ¦
¦ ¦EIA¦CCITT¦9-шт.¦ 25-шт. ¦ ¦ ¦
+--------+---+-----+-----+--------+-------------------+--------+
¦ DCD ¦CF ¦ 109 ¦ 1 ¦ 8 ¦Связь
модемов ¦В ПЭВМ ¦
¦ ¦ ¦ ¦ ¦ ¦установлена ¦ ¦
¦
RX ¦BB ¦ 104 ¦ 2 ¦ 3 ¦Принимаемые
данные ¦В ПЭВМ ¦
¦
TX ¦BA ¦ 103 ¦ 3 ¦ 2 ¦Передаваемые
данные¦Из ПЭВМ ¦
¦
DTR ¦CD ¦108/2¦ 4
¦ 20 ¦Готовность ПЭВМ к ¦Из
ПЭВМ ¦
¦ ¦ ¦ ¦ ¦ ¦работе ¦ ¦
¦
SG ¦AB ¦ 102 ¦ 5 ¦ 7 ¦Сигнальная
земля ¦ ---- ¦
¦
DSR ¦CC ¦ 107 ¦ 6 ¦ 6 ¦Готовность
модема к¦В ПЭВМ ¦
¦ ¦ ¦ ¦ ¦ ¦работе ¦ ¦
¦
RTS ¦CA ¦ 105 ¦ 7 ¦ 4 ¦Запрос
на передачу ¦Из ПЭВМ ¦
¦
CTS ¦CB ¦ 106 ¦ 8 ¦ 5 ¦Готовность
модема к¦В ПЭВМ ¦
¦ ¦ ¦ ¦
¦ ¦ к передачи ¦ ¦
¦
RI ¦CE ¦ 125 ¦ 9
¦ 22 ¦Индикатор вызова ¦В
ПЭВМ ¦
¦
FG ¦AA ¦ 101 ¦ -- ¦ 1 ¦Защитная земля ¦ ---- ¦
L--------+---+-----+-----+--------+-------------------+---------
Контроллер стыка RS-232 является полностью программируемым
устройством; вы можете
задать следующие параметры
обмена: количество битов данных
и стоп-битов, вид четности и скорость обмена в бодах (бит/с).
11.2. Описание портов
Ниже описаны порты ввода-вывода для СОМ1, имеющего базовый адрес 3F8h.
Обратите внимание, что
порты 3F8h и 3F9h имеют разное
назначение в зависимости от бита 7
порта 3F8h (т. н. бит DLAB - Divisor Latch Access Bit).
Порт
Операция Описание
----------------------------------------------------------------
3F8h Запись
Регистр передатчика - сюда засылается байт для
передачи
Чтение Регистр
приемника - отсюда извлекается принятый
байт
Запись Если
DLAB=1, то сюда засылается младший байт
скорости
обмена (см. порт 3F9h)
3F9h Запись
Если DLAB=1, то сюда засылается старший байт
скорости
обмена. Скорость задается значением делителя, равным 115200/V, где V - скорость
в
бодах. Например, для скорости 9600 бод делитель равен 115200/9600=12=0Ch,
поэтому нужно вывести 0Ch в порт 3F8h и 0 в порт 3F9h.
Запись Регистр
управления прерываниями (1 = разрешить
прерывание):
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦0
¦0 ¦0 ¦ 0¦ ¦ ¦ ¦ ¦ Бит:
L--+--+--+--+T-+T-+T-+T--
----
¦
¦ ¦ L-> 0: прерывание по приему символа
¦
¦ L----> 1: прерывание по
завершению передачи
¦
¦ символа
¦
L-------> 2: прерывание по обрыву линии или
¦ или
ошибке в линии
L---------->
3: прерывание по изменению состояния модема (любой из линий CTS, DSR, RI и DCD)
3FAh Чтение Регистр идентификации прерывания. Когда
произошло
прерывание, здесь содержится причина, вызвавшая его:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦0
¦0 ¦0 ¦ 0¦ 0¦ ¦ ¦ Бит:
L--+--+--+--+--+--+--+T--
----
¦ ¦
¦ L--> 0: 0=есть отложенные прерывания
L------> 1-2: причина
прерывания:
11=ошибка
или обрыв линии; сбрасывается чтением регистра состояния линии (порт 3FDh)
10=принят
символ; сбрасывается чтением приемника (порт 3F8h)
01=передан
символ; сбрасывается
записью
символа в регистр передатчика (порт 3F8h)
00=изменение
состояния модема (линий CTS, DSR, RI или DCD); сбрасывается чтением регистра
состояния модема (порт 3FEh)
3FBh Чтение/ Регистр управления линией:
Запись
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦ ¦ ¦
¦ Биты:
LT-+T-+T-+--+--+T-+--+---
-----
¦
¦ ¦ ¦ ¦ ¦
¦
¦ ¦ ¦ ¦ L---> 0-1: число битов данных:
¦ ¦
¦ ¦ ¦ 00=5,
01=6, 10=6, 11=8
¦
¦ ¦ ¦ L--------> 2: число стоп-битов:
¦ ¦
¦ ¦ 0=1, 1=1.5 при 5 битах данных
¦
¦ ¦ ¦ и 2 в
противном случае
¦
¦ ¦ L------------> 3-4: тип четности:
¦
¦ ¦ X0=нет,
¦
¦ ¦ 01=нечетная,
¦
¦ ¦ 11=четная
¦
¦ L-----------------> 5:
постоянная четность
¦ ¦ 0=отмена постоянной четности
¦ ¦ 1=постоянный бит
четности,
¦ ¦ зависит от битов 3-4:
¦ ¦ биты 3-4=01 - бит четности
¦ ¦ всегда 1
¦ ¦ биты 3-4=11 - бит четности
¦ ¦ всегда 0
¦ ¦ биты 3-4=X0 - без бита четности
¦
L--------------------> 6: 1=имитировать обрыв линии
¦ (посылка
нулей)
L-----------------------> 7: бит DLAB:
1=порты
3F8h и 3F9h для загрузки скорости обмена;
0=порты
3F8h и 3F9h в обычном режиме
3FCh Запись Регистр управления модемом
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦
0¦ 0¦ 0¦ ¦ ¦ ¦ ¦ ¦
Бит:
L--+--+--+T-+T-+T-+T-+T--
---
¦ ¦
¦ ¦ L-> 0: 1=установить выход DTR
¦ ¦
¦ L----> 1: 1=установить
выход RTS
¦ ¦
L-------> 2: 1=установить OUT1 (не используется) ¦ L----------> 3: 1=установить OUT2
(разрешить преры¦ вания от RS-232)
L------------->
4: 1=диагностический режим (посылать выход на вход стыка).
3FDh Чтение
Регистр состояния линии. Биты 1-4 вызывают
прерывания по ошибке, если оно
разрешено:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦
0¦ ¦
¦ ¦ ¦ ¦ ¦ ¦
Бит:
L--+T-+T-+T-+T-+T-+T-+T--
---
¦ ¦
¦ ¦ ¦ ¦ L-> 0:1=данные приняты. Сбрасывается
¦ ¦
¦ ¦ ¦ ¦ чтением приемника
¦ ¦
¦ ¦ ¦ L----> 1:1=потеря
предыдущего символа
¦
¦ ¦ ¦ L-------> 2:1=ошибка
четности
¦
¦ ¦ L----------> 3:1=неверный стоп-бит
¦
¦ L------------->
4:1=обнаружен обрыв линии
¦ L----------------> 5:1=сдвиговый регистр
передатчика пуст. ¦ Можно передавать след. символ
L------------------->
6:1=регистр передатчика пуст. Нет обрабатываемых данных.
3FEh
Чтение Регистр состояния модема.
Биты 0-3 вызывают
прерываниe по изменению
состояния модема,
если оно разрешено:
7
6 5 4 3 2
1 0 ---T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Бит:
LT-+T-+T-+T-+T-+T-+T-+T-- ---
¦
¦ ¦ ¦ ¦ ¦
¦ ¦
¦ ¦
¦ ¦ ¦ ¦ ¦
L--> 0:1=изменилось состояние линии CTS
¦
¦ ¦ ¦ ¦ ¦
L-----> 1:1=изменилось состояние линии DSR
¦
¦ ¦ ¦ ¦ L--------> 2:1=изменилось состояние линии
RI
¦ ¦
¦ ¦ L-----------> 3:1=изменилось состояние линии DCD
¦
¦ ¦ L--------------> 4: состояние линии CTS
¦
¦ L-----------------> 5:
состояние линии DSR
¦
L--------------------> 6: состояние линии RI
L-----------------------> 7: состояние
линии DCD
Примечание: "Изменилось состояние
линии..." означает, что данная линия стыка RS-232 изменила свое
состояние по сравнению с последним чтением этого регистра.
11.3.
Порядок инициализации 8250
Для
подготовки контроллера 8250
к работе необходимо выполнить следующие шаги.
1.
Установить бит DLAB
порта 3FBh и заслать делитель, задающий скорость
обмена, в порты 3F8h и 3F9h.
2. Инициализировать регистр управления линией (порт 3FBh); при этом
сбросить бит DLAB.
3. Инициализировать регистр управления
модемом (порт 3FCh).
4.
Инициализировать регистр
управления прерываниями (порт 3F9h) и,
если прерывания разрешены, установить
адрес программы обработки прерываний от стыка RS-232.
В качестве примера приведем набор подпрограмм, обеспечивающих
обмен через порт COM1 в дуплексном режиме со скоростью 1200 бод.
title RS232
_DATA segment
para public
Buf_Size equ
1024 ; размер буфера
Source db
Buf_Size+2 dup (0) ; буфер приема символов
Src_ptr dw
Source ; указатель позиции в
буфере
Count dw
0 ; количество символов
в буфере
Ser_ip dw
0 ; старый адрес Int
0Ch
Ser_cs dw
0
Save_ds dw 0 ; служебные переменные
Int_sts db 0
Overrun db 0
_DATA ends
_TEXT segment
para public
assume cs:_TEXT, ds:_DATA
public
Ser_Ini:near, Ser_Rst:near public
Get_Chr:near, Out_Chr:near
;г============================================================¬
;¦ Подпрограмма инициализации
стыка COM1. ¦
;L============================================================-
Ser_Ini proc near
push ax ; сохранить регистры
push dx
push bx
push es
in al,21h ; IMR 1-го контролера прерываний
or al,10h ; запретить прерывание IRQ4 от COM1
out
21h,al
mov
al,0Ch
mov
ah,35h
int
21h ; взять вектор Int 0Ch в
es:bx
mov
Ser_ip,bx ; и сохранить его
mov
Ser_cs,es
mov
al,0Ch
mov
dx,offset Ser_int
push ds
mov
bx,cs
mov
ds,bx
mov
ah,25h
int
21h ; установить Int 0Ch =
ds:dx
pop
ds
pop
es
pop bx
cli ;
запретить прерывания
in al,21h ; IMR 1-го контроллера прерываний
and
al,not 10h
out
21h,al ; разрешить прерывания от
COM1
mov
dx,3FBh ; регистр управления
линией
in al,dx
or al,80h ; установить бит DLAB
out
dx,al
mov
dx,3F8h
mov
al,60h
out
dx,al ; младший байт для
скорости 1200 бод
inc
dx
mov
al,0
out
dx,al ; старший байт скорости
mov
dx,3FBh ; регистр управления
линией
mov
al,00000011b ; 8 бит, 2 стоп-бита, без четности out dx,al
mov
dx,3F9h ; регистр разрешения
прерываний
mov
al,1 ; разрешить прерывания по
приему
out
dx,al
nop ;
и чуть-чуть подождать
nop
mov
dx,3FCh ; регистр управления
модемом
mov
al,00001011b ; установить DTR, RTS и OUT2
out
dx,al
sti ;
разрешить прерывания
mov
dx,3F8h ; регистр данных
in al,dx ; сбросить буфер приема
pop
dx
pop
ax
ret
Ser_Ini endp
;г============================================================¬
;¦ Подпрограмма отключения стыка
COM1. ¦
;L============================================================- Ser_Rst proc near
push ax ; сохранить регистры
push dx
Wait_Free:
mov
dx,3FDh ; регистр состояния линии
in al,dx
jmp
short $+2 ; короткая задержка
test al,60h ; передача окончена?
jz Wait_Free
; ждем, если нет
mov
dx,3F9h ; регистр разрешения
прерываний
mov
al,0 ; запретить прерывания
out
dx,al
jmp short $+2 ; еще подождем...
jmp
short $+2
mov
dx,3FCh ; регистр управления
модемом
mov
al,00000011b ; активировать DTR и RTS
out
dx,al
jmp
short $+2
jmp
short $+2
push bx
mov
al,0Ch
mov
dx,Ser_ip
push ds
mov
bx,Ser_cs
mov
ds,bx
mov
ah,25h
int
21h ; восстановить вектор Int
0Ch
pop
ds
pop
bx
cli ;
запрет прерываний
in al,21h ; читать маску прерываний
jmp
short $+2
or al,10h ; запретить IRQ4
out
21h,al
sti ;
разрешение прерываний
pop
dx
pop
ax
ret
Ser_Rst endp
;г============================================================¬
;¦ Подпрограмма обработки
прерываний от COM1. ¦
;L============================================================-
Ser_Int proc far
push ax
push dx
push ds
mov
ax,seg _DATA
mov
ds,ax
mov
dx,3FAh ; регистр идентификации
прерываний
in al,dx
mov Int_Sts,al; сохраним его содержимое
test al,1 ; есть отложенные прерывания?
jz Is_Int ; да
pop
Save_ds ; нет, передаем управление
pop
dx ; старому обработчику Int
0Ch
pop
ax
push Ser_cs
push Ser_ip
push Save_ds
pop
ds
ret ;
длинный переход
Is_Int:
mov
al,64h ; послать EOI для IRQ4
out
20h,al ; в 1-й контроллер
прерываний
test Int_Sts,4 ; прерывание по приему?
jnz
Read_Char ; да
No_Char:
sti ;
нет, разрешить прерывания
jmp
Int_Ret ; и закончить обработку
Int 0Ch
Read_Char:
mov
dx,3FDh ; регистр состояния линии
in al,dx
and
al,2
mov
Overrun,al; ovvrrun<>0, если была потеря символа mov dx,3F8h ;
регистр данных
in al,dx ; вводим символ
or al,al ; если принят нуль,
jz No_Char ; то игнорируем его
push bx
mov
ah,Overrun
or ah,ah ; предыдущий символ потерян?
jz Save_Char
; нет
mov
ah,al ; да,
mov
al,7 ; заменяем его на звонок
(07h)
Save_Char:
mov
bx,Src_ptr; заносим символ в буфер
mov
[bx],al
inc
Src_ptr ; и обновляем счетчики
inc
bx
cmp bx,offset Src_ptr-2 ; если конец буфера
jb Ser_Int_1
mov
Src_ptr,offset Source ; то "зацикливаем" на начало Ser_Int_1:
cmp
Count,Buf_Size ; буфер полон?
jae
Ser_Int_2 ; да
inc
Count ; нет, учесть символ
Ser_Int_2:
or ah,ah ; если была потеря символа
jz Ser_Int_3
mov
al,ah ; то занести в буфер сам
символ
xor
ah,ah
jmp
short Save_Char
Ser_Int_3:
pop
bx
sti ;
разрешить прерывания
Int_Ret:
pop
ds
pop
dx
pop
ax
iret
Ser_Int endp
;г============================================================¬
;¦ Подпрограмма вывода символа AL в порт. ¦ ;¦ При ошибке возвращает CF=1, иначе
CF=0. ¦
;L============================================================- Out_Chr proc near
push ax
push cx
push dx
mov
ah,al
sub
cx,cx
Wait_Line:
mov
dx,3FDh ; регистр состояния линии
in al,dx
test al,20h ; стык готов к передаче?
jnz
Output ; да
jmp
short $+2
jmp
short $+2
loop Wait_Line ; нет, ждем
pop
dx
pop
cx
pop
ax
stc ;
нет готовности порта
ret
Output:
mov
al,ah
mov
dx,3F8h ; регистр данных
jmp
short $+2
out
dx,al ; вывести символ
pop
dx
pop
cx
pop
ax
clc ;
нормальный возврат
ret
Out_Chr endp
;г============================================================¬
;¦ Подпрограмма ввода символа из порта в AL. ¦ ;¦ Если буфер пуст, возвращает CF=1, иначе
CF=0. ¦
;L============================================================- Get_Chr proc near
cmp
Count,0 ; буфер пуст?
jne loc_1729
; нет
stc ;
да, возврат по ошибке
ret
loc_1729:
push si
cli ;
запретим прерывания
mov
si,Src_ptr
sub
si,Count
cmp
si,offset Source
jae
loc_1730
add
si,Buf_Size
loc_1730:
mov
al,[si] ; выберем символ
dec Count ;
и уменьшим счечик
sti ;
разрешение прерываний
pop
si
clc ;
и нормальный возврат
ret
Get_Chr endp
_TEXT ends
end
12.
Игровой адаптер
Игровой
адаптер - это
аналого-цифровой преобразователь, который может использоваться для подключения к ПЭВМ аналоговых устройств (например, джойстика или измерительных приборов). Он принимает до четырех цифровых входов типа "включено/выключено"
(например, для нажатия кнопок) и до четырех аналоговых входов (таких, как координаты джойстика
или показания электронного
термометра). Игровой адаптер подключен
в IBM PC к порту ввода 201h. Байт, введенный из этого порта, имеет следующий
формат:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦B2
B1 A2 A1¦By Bx Ay Ax¦ Биты:
L--+--+--+--+--+--+--+---
-----
¦ L------> 0-3: координаты (аналоговые
входы)
L------------------>
4-7: триггеры (цифровые входы)
Для чтения триггеров используются команды:
mov
dx,201h
out
dx,al ;инициировать обмен, AL
-любой байт
in al,dx ;читать
порт, биты 4-7 - 0=кнопка нажата
; 1=отпущена
Аналоговые
входы считываются путем
отслеживания времени,в
течениe
которого соответствующий бит установлен в единицу, после команды OUT 201h,XXX.
Пример чтения координаты X устройства А:
mov dx,201h
out dx,al ;инициировать обмен, AL-любой байт
mov cx,-1 ;счетчик для цикла
Again:
in al,dx
inc cx ;увеличить счетчик
test
al,1 ;бит AX сброшен?
jne Again ;нет, ждем
Результат в СX указывает координаты Х. Этот способ зависит от
тактовой частоты ЦП, поэтому аккуратней
было бы использовать не счетчик цикла, а системный таймер.
13.
CMOS
13.1.
Доступ к CMOS
В состав IBM PC AT входят часы реального
времени (RTC) и 64 байта неразрушающейся
оперативной памяти (CMOS), питающиеся
от автономного источника питания.
При включении ПЭВМ содержимое
CMOS анализируется BIOS, который
извлекает из нее конфигурацию системы и
текущие дату и время.
Для
доступа к данным CMOS используются порты 70h и 71h. Чтение байта CMOS производится следующим образом:
mov al,XXh
out 70h,al ;выбрать адрес CMOS XX
jmp $+2 ;небольшая задержка
in al,71h ;ввод байта из CMOS
Запись байта в CMOS производится аналогино:
mov al,XXh
out 70h,al
jmp $+2
in al,71h
Адреса
CMOS с 10h по 20h
защищены контрольной суммой, хранящейся
по адресу 2Eh. Поэтому изменения содержимого этих адресов необходимо сопровождать пересчетом и изменением
контрольной суммы.
Порт 70h применяется не только для задания адреса CMOS, но и для разрешения
или запрещения NMI (немаскируемого прерывания). Если бит 7 равен 0, то NMI разрешается, если 1 -
запрещается, например:
mov
al,2Dh ;2Dh -резервный адрес
CMOS
out
70h,al ;разрешить NMI
mov
al,0ADh
out
70h,al ;запретить NMI
13.2. Содержимое CMOS
Краткая схема содержимого CMOS такова:
Адрес Содержимое
----------------------------------------------------------------
00h-0Dh Данные часов реального
времени (RTC)
0Eh Байт результатов начального тестирования
0Fh Состояние перезагрузки
10h Тип НГМД
11h Резерв
12h Тип жесткого диска
13h Резерв
14h Байт оборудования
15h-16h Размер базовой памяти
17h-18h Размер дополнительной памяти
19h-1Ah Типы
жестких дисков
1Bh-2Dh Резерв
2Eh-2Fh Контрольная сумма CMOS
30h-31h Размер дополнительной памяти
32h Текущее столетие
33h Разная информация
34h-3Fh Резерв
---------------------------------------------------------------
Приведем полное описание всех полей CMOS.
Адрес
Описание Примечание
----------------------------------------------------------------
0 Текущее время RTC, секунды Все данные RTC
1 Время
побудки, секунды хранятся в
двоично-
2 Текущее
время, минуты десятичном
формате
3 Время
побудки, минуты (BCD)
4 Текущее
время, часы
5 Время
побудки, часы
6 Текущий
день недели
7 Текущий
день месяца
8 Текущий
месяц
9 Текущий
год
----------------------------------------------------------------
0Ah Регистр
A состояния RTC:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦ Биты:
LT-+--+-T+--+--+--+--+---
-----
¦ ¦ L-------> 0-3:скорость отсчета (равна 0110)
¦ L----------------->
4-6: делитель (равен 010)
L------------------------>
7: флаг обновления (0=можно читать)
0Bh Регистр
B состояния RTC:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦
¦ ¦ ¦ ¦ ¦
¦ ¦ Биты:
LT-+T-+T-+T-+T-+T-+T-+T-- -----
¦ ¦
¦ ¦ ¦ ¦ ¦
L---> 0: тип времени (равен 0)
¦ ¦
¦ ¦ ¦ ¦ L------> 1: 12- или 24-часовое время
¦
¦ ¦ ¦ ¦ ¦ (равен 1=24 часа)
¦ ¦
¦ ¦ ¦ L---------> 2:
формат данных: 0=BCD,
¦ ¦
¦ ¦ ¦
1=двоичный (равен 0)
¦ ¦
¦ ¦ L------------> 3: 1=разрешить прямоугольный
¦
¦ ¦ ¦
импульс (равен 0)
¦ ¦
¦ L---------------> 4:
1=разрешить прерывание по
¦ ¦
¦ концу
обновления (равен 0)
¦
¦ L------------------> 5:
1=разрешить прерывание
¦ ¦ побудки (равен 0)
¦
L---------------------> 6: 1=разрешить периодические
¦ прерывания (равен 0)
L------------------------>
7: флаг обновления (0=можно читать)
0Ch Регистр С состояния RTC: биты состояния
прерываний,
только для чтения.
0Dh Регистр D состояния RTC. Бит 7=1, если
CMOS получает
питание; 0=нет питания от автономного
источника. ----------------------------------------------------------------
0Eh Байт
результатов начального тестирования:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦ ¦ ¦
¦ ¦0 ¦0 ¦ Биты:
LT-+T-+T-+T-+T-+T-+--+--- -----
¦ ¦
¦ ¦ ¦ L---------> 2:
1=формат текущего времени
¦
¦ ¦ ¦ ¦ и даты верен
¦
¦ ¦ ¦ L------------> 3:
1=жесткий диск не является
¦
¦ ¦ ¦ загружаемым
¦
¦ ¦ L---------------> 4: 1=размер ОЗУ неверен
¦ ¦
L------------------> 5: 1=оборудование не соответствует
¦ ¦ конфигурации CMOS
¦
L---------------------> 6: 1=неверна контрольная сумма CMOS
L------------------------> 7: 1=неисправен
автономный источник питания CMOS
----------------------------------------------------------------
0Fh Байт
состояния перезагрузки. Этот байт считываетса после
сброса
ЦП, чтобы определить не был ли сброс вызван для вывода 80286 из защенного
режима. Он принимает значения:
0
= теплый рестарт (по Ctrl-Alt-Del) или неожиданный останов
1 = останов после определения размера
ОЗУ
2 = останов после тестирования памяти
3 = останов по ошибке паритета памяти
4
= рестарт по запросу начального загрузчика
5
= рестарт по сбросу контроллера прерываний и
JMP FAR PTR [0:467h]
6,
7, 8 = останов после теста защищенного режима
9 = рестарт по JMP FAR PTR [0:467h]
----------------------------------------------------------------
10h Тип
НГМД А и В:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦ Биты:
L--+--+--+--+--+--+--+---
-----
¦ L-------> 0-3: тип дисковода А
L------------------->
4-7: тип дисковода В:
0
= нет дисковода или его тип неизвестен
1 = 360 К, 5 1/4
дюйма
2 = 1.2 M, 5 1/4
дюйма
3 = 720 К, 3 1/2
дюйма ----------------------------------------------------------------
12h Тип
жестких дисков C и D:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦ Биты:
L--+--+--+--+--+--+--+---
-----
¦ L-------> 0-3: тип дисковода C
L------------------->
4-7: тип дисковода D: 0000 = диска нет
1111
= см. адреса 19h и 1Ah прочие=тип диска
(см.
приложение 2) -----------------------------------------------------------------
14h Байт
оборудования:
7
6 5 4 3 2
1 0
---T--T--T--T--T--T--T--¬
¦ ¦ ¦X
¦X ¦ ¦
¦ Биты:
L--+--+--+--+--+--+T-+T--
----
¦
¦ ¦ L--> 0: 1=есть НГМД
¦ ¦
L-----> 1: 1=есть сопроцессор 80287
¦
L---------------> 4-5: тип дисплея:
¦ 00 - EGA или VGA
¦ 01 - CGA, 40 столбцов
¦ 10 - CGA, 80 столбцов
¦ 11 - монохромный
L---------------------> 6-7: количество
НГМД - 1
----------------------------------------------------------------
15h-16h Размер базовой памяти (0100h=256 K,
0200h=512 K,
0280h=640 K)
17h-18h Размер
дополнительной памяти, Кб (от 0 до 3C00h)
----------------------------------------------------------------
19h Тип
диска С, если его тип в 12h равен 0Fh
1Ah Тип
диска D, если его тип в 12h равен 0Fh
----------------------------------------------------------------
2Eh-2Fh Контрольная сумма адресов CMOS
с 10h по 20h (обычная
16-битовая сумма этих байтов; 2Eh
содержит старший байт КС)
----------------------------------------------------------------
30h-31h Размер дополнительной памяти, Кб
(0-3C00h), опреде-
ленный при начальном тестировании
---------------------------------------------------------------- 32h Двоично-десятичный номер столетия
----------------------------------------------------------------
33h Разная
информация. Бит 7: 1=установлена опция 128К ОЗУ
Бит
6 используется программой SETUP ----------------------------------------------------------------
14. Прочие
порты
В
этом разделе приведено описание портов,
не относящихся к конретным устройствам.
Адрес Операция Назначение
----------------------------------------------------------------
80h запись Используется в AT на этапе начального
тестирования для накопления
информации об ошибках.
----------------------------------------------------------------
90h запись Управляющий порт центрального арбитра PS/2
----------------------------------------------------------------
91h чтение Обратная связь с выбранной платой PS/2
----------------------------------------------------------------
92h запись Управляющий порт A PS/2
----------------------------------------------------------------
94h запись Установка параметров системной платы PS/2
----------------------------------------------------------------
96h, 97h запись Выбор коннектора канаклов в PS/2
----------------------------------------------------------------
0A0h запись Разрешение или запрещение NMI в PC/XT:
out 0A0h,80h - разрешает
NMI;
out 0A0h,0 - запрещает NMI.
---------------------------------------------------------------- 0F0h запись Вывод
любого байта сбрасывает защелку
сопроцессора
80287, которая включается по незамаскированной ошибке сопроцессора.
0F1h запись Вывод
любого байта сбрасывает сопроцессор
80287
из защищенного режима в реальный.
0F8h-0FCh --- Эти
порты используются процессором 80286
для обмена данными с
сопроцессором. ----------------------------------------------------------------
210h запись Управляющий
порт блока расширения XT.
213h запись Разрешение
блока расширения XT.
215h запись Регистр
шины данных блока расширения XT.
215h запись Регистр
адреса блока расширения XT
(старший
байт).
216h запись Регистр
адреса блока расширения XT
(младший
байт).
----------------------------------------------------------------
Приложение
1. Скан-коды клавиш
Всякий
раз, когда клавиатура
вызывает прерывание по
нажатию
или отпусканию клавиши, она
передает обработчику этого прерывания
"скан-код" данной клавиши, т. е. ее порядковый номер на клавиатуре. При этом скан-код клавиши является семибитовым, а старший бит байта,
содержащего скан-код, сообщает
причину прерывания: 0 - клавиша нажата, 1 - клавиша отпущена.
---------T-------------T--------T-------------¬
¦Скан-код¦ Клавиша ¦Скан-код¦ Клавиша ¦
+----T---+-------------+----T---+-------------+
¦01h ¦ 1 ¦ Esc ¦2Bh ¦ 43¦ \
| ¦
¦02h ¦ 2 ¦ 1
! ¦2Ch ¦ 44¦ Z ¦
¦03h
¦ 3 ¦ 2 @ ¦2Dh ¦ 45¦ X ¦
¦04h ¦ 4 ¦ 3
# ¦2Eh ¦ 46¦ C ¦
¦05h ¦ 5 ¦ 4
$ ¦2Fh ¦ 47¦ V ¦
¦06h ¦ 6 ¦ 5
% ¦30h ¦ 48¦ B ¦
¦07h ¦ 7 ¦ 6
^ ¦31h ¦ 49¦ N ¦
¦08h ¦ 8 ¦ 7
& ¦32h ¦ 50¦ M ¦
¦09h ¦ 9 ¦ 8
* ¦33h ¦ 51¦ , < ¦
¦0Ah ¦ 10¦ 9
( ¦34h ¦ 52¦ . > ¦
¦0Bh ¦ 11¦ 0
) ¦35h ¦ 53¦ / ? ¦
¦0Ch ¦ 12¦ -
_ ¦36h ¦ 54¦правый Shift ¦
¦0Dh ¦ 13¦ =
+ ¦37h ¦ 55¦ PrtSc * ¦
¦0Eh ¦ 14¦ BackSpace ¦38h ¦ 56¦ Alt ¦
¦0Fh ¦ 15¦ Tab ¦39h ¦ 57¦ пробел ¦
¦10h ¦ 16¦ Q ¦3Ah ¦ 58¦ CapsLock ¦
¦11h ¦ 17¦ W ¦3Bh ¦ 59¦ F1 ¦
¦12h ¦ 18¦ E ¦3Ch ¦ 60¦ F2 ¦
¦13h ¦ 19¦ R ¦3Dh ¦ 61¦ F3 ¦
¦14h ¦ 20¦ T ¦3Eh ¦ 62¦ F4 ¦
¦15h ¦ 21¦ Y ¦3Fh ¦ 63¦ F5 ¦
¦16h ¦ 22¦ U ¦40h ¦ 64¦ F6 ¦
¦17h ¦ 23¦ I ¦41h ¦ 65¦ F7 ¦
¦18h ¦ 24¦ O ¦42h ¦ 66¦ F8 ¦
¦19h ¦ 25¦ P ¦43h ¦ 67¦ F9 ¦
¦1Ah ¦ 26¦ [
{ ¦44h ¦ 68¦ F10 ¦
¦1Bh ¦ 27¦ ]
} ¦45h ¦ 69¦ NumLock ¦
¦1Ch ¦ 28¦ Enter ¦46h ¦ 70¦
ScrollLock ¦
¦1Dh ¦ 29¦ Ctrl ¦47h ¦ 71¦ Home [7]
¦
¦1Eh ¦ 30¦ A ¦48h ¦ 72¦стр. вверх[8]¦
¦1Fh ¦ 31¦ S ¦49h ¦ 73¦ PgUp [9] ¦
¦20h ¦ 32¦ D ¦4Ah ¦ 74¦ - ¦
¦21h ¦ 33¦ F ¦4Bh ¦ 75¦ <- [4] ¦
¦22h ¦ 34¦ G ¦4Ch ¦ 76¦ [5] ¦
¦23h ¦ 35¦ H ¦4Dh ¦ 77¦ -> [6] ¦
¦24h ¦ 36¦ J ¦4Eh ¦ 78¦ + ¦
¦25h ¦ 37¦ K ¦4Fh ¦ 79¦ End [1] ¦
¦26h ¦ 38¦ L ¦50h ¦ 80¦стр. вниз [2]¦
¦27h ¦ 39¦ ;
: ¦51h ¦ 81¦ PgDn [3] ¦
¦28h ¦ 40¦ '
" ¦52h ¦ 82¦ Ins [0]
¦
¦29h ¦ 41¦ `
~ ¦53h ¦ 83¦ Del [.] ¦
¦2Ah ¦ 42¦ левый Shift ¦54h ¦ 84¦ SysReq ¦
L----+---+-------------+----+---+--------------
Приложение 2. Типы жестких дисков
В
этом приложении приведена
информация о жестких дисках,
поддерживаемых BIOS IBM PC AT
в порядке их номеров, присваиваемых в CMOS.
Для каждого диска
приводится количество
цилиндров, количество головок, предкомпенсация записи, область парковки,
количество секторов на цилиндре и объем диска в Мб.
--------------------------------------------------------------
Номер Кол-во Кол-во Предкомп. Область Кол-во Объем
типа цилиндров головок записи парковки секторов диска, Мб
---------------------------------------------------------------
1 306 4 128 305 17 10,1
2 615 4 300 615 17 20,4
3 615 6 300 615 17 30,6
4 940 8 512 940 17 62,4
5 940 6 512 940 17 46,8
6 615 4 нет 615 17 20,4
7 462 8 256 511 17 30,6
8 733 5 нет 733 17 30,4
9 900 15 нет 901 17 112,0
10 820 3 нет 820 17 20,4
11 855 5 нет 855 17 35,4
12 855 7 нет 855 17 49,6
13 306 8 128 319 17 20,3
14 733 7 нет 733 17 42,5
15 Заpезеpвиpован
- см. 13.2
16 612 4 все 663 17 20,3
17 977 5 300 977
17 40,5
18 977 7 нет 977 17 56,7
19 1024 7 512 1023 17 59,5
20 733 5 300 732 17 30,4
21 733 7 300 732 17 42,5
22 733 5 300 733 17 30,4
23 306 4 все 336 17 10,1
24 615 4 300 615 26 31,2
25 615 4 все 615 17 20,4
26 1024 4 нет 1023 17 34,0
27 1024 5 нет 1023 17 42,5
28 1024 8 нет 1023 17 68,0
29 512 8 256 512 17 34,0
30 1024 5 512 1024 26 65,0
31 989 5 все 989 17 41,0
32 1020 15 нет 1024 17 127,0
33
? ?
? ? ? ?
34
? ?
? ? ? ?
35 1024 9
1024 1024 17 76,5
36 1024 5 512 1024 17 42,5
37 830
10 нет 830 17 68,8
38 823 10 256 824 17 68,3
39 615 4 128 664 17 20,4
40 615 8 128 664 17 40,8
41 917 15 нет 918 17 114,1
42 1023 15 нет 1024 17 127,3
43 823
10 512 823 17 68,3
44 820 6 нет 820 17 40,8
45 1024 8 нет 1024 17 68,0
46 925 9 нет 925 17 69,1
47 699 7 256 700 17 40,6
---------------------------------------------------------------
Примечания.
1.
Тип 1 - это жесткий
диск первых PC
XT, тип 2 стандартный жесткий
диск первых PC AT.
2. Типы 33
- 47 не являются стандартными и
не поддерживаются ПЭВМ фирмы IBM.
Приложение 3. Подготовка ПЭВМ к работе
В этом
приложении описана установка
DIP-переключателей на системной плате ПЭВМ
и адаптере EGA-дисплеев. Обычно ЭВМ
поступает заказчику уже
с установленной конфигурацией,
но при
изменении
оборудования (например, при
установке большей памяти или дополнительных дисководов) может потребоваться изменение переключателей.
Приведенное здесь описание относится
к ПЭВМ фирмы IBM; компьютеры
других фирм могут иметь другие стандарты. Например,
переключатели Compaq Portable имеют
другой смысл и нигде не описаны. Переключатели Deskpro
подписаны внутри корпуса ЭВМ.
Переключатели IBM PC
--------------------
Первоначальная модель IBM PC, имевшая 64К ОЗУ на системной плате (далее назывемая
PC-1), настраивается двумя колодками
переключателей, помеченными SW1 и SW2.
SW1
ON г1T2T3T4T5T6T7T8¬
¦ ¦ ¦
¦ ¦
¦
LT+T+-+-+-+-+-+--
¦ ¦ LT- LT-
L=¦= 7-8: количество НГМД ¦ ¦ ¦
L====== 5-6: активный дисплей
¦
¦ L========== 3-4: pазмеp ОЗУ на системной плате
¦
L============= 2: наличие сопpоцессоpа 8087
L=============== 1: наличие НГМД
SW2 (PC-1)
ON
г1T2T3T4T5T6T7T8¬
¦ ¦-¦-¦-¦-¦
L-+-+-+-+-+-+-+--
L==T==- L=====¦= 5-8: всегда OFF
L============ 1-4: полный pазмеp ОЗУ
Более
поздняя веpсия IBM
PC (называемая здесь
PC-2) интеpпpетиpует пеpеключатели несколько иначе. Точнее говоpя, SW1
имеет то же назначение, а SW2 показано ниже:
SW 2
(PC-2)
ON г1T2T3T4T5T6T7T8¬
¦ ¦-¦-¦-¦
L-+-+-+-+-+-+-+--
L===T===- L===¦= 6-8: всегда OFF
L=========== 1-5: полный pазмеp ОЗУ
Опишем подpобно назначение пеpеключателей.
Количество
накопителей на гибких дисках (НГМД):
-----------------------------------------------
SW1
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦
¦ ¦ ¦ ¦ ¦-¦-¦ 1 НГМД ¦-¦ ¦ ¦ ¦ ¦
¦-¦-¦ 3 НГМД
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦
¦ ¦ ¦ ¦ ¦-¦-¦ 2 НГМД ¦-¦ ¦ ¦ ¦ ¦
¦-¦-¦ 4 НГМД
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
Примечание.
Ключ 1 в позиции ON означает отсутствие НГМД.
Активный дисплей:
-----------------
SW1
ON г1T2T3T4T5T6T7T8¬
¦ ¦ ¦ ¦ ¦-¦-¦ ¦ ¦ Нет или EGA
L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬
¦ ¦ ¦ ¦ ¦-¦-¦ ¦ ¦ 40x25 CGA
L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬
¦ ¦ ¦ ¦ ¦-¦-¦ ¦ ¦ 80x25 CGA
L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬
¦
¦ ¦ ¦ ¦-¦-¦ ¦ ¦ Монохромный адаптер (MDA) либо и MDA, и CGA L-+-+-+-+-+-+-+--
Наличие сопроцессора 8087:
-------------------------
SW1
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦ ¦-¦ ¦ ¦ ¦ ¦ ¦ ¦
есть 8087 ¦ ¦-¦ ¦ ¦ ¦ ¦ ¦ ¦ нет 8087
L-+-+-+-+-+-+-+--
L-+-+-+-+-+-+-+--
Размер
ОЗУ на системной плате: ------------------------------
SW1
ON г1T2T3T4T5T6T7T8¬
¦ ¦ ¦-¦-¦ ¦ ¦ ¦ ¦ 64K или больше
L-+-+-+-+-+-+-+--
Полный
размер ОЗУ (SW2 для PC-1): ---------------------------------
Для
PC-1 ключи 5 - 8 всегда в положении OFF. Максимальный размер ОЗУ -
544К.
SW2
(PC-1)
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 64K ¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 384K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 128K ¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 448K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 192K ¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 512K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 256K ¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 544K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦ ¦ ¦ ¦ ¦ 320K
L-+-+-+-+-+-+-+--
Полный
размер ОЗУ (SW2 для PC-2): ---------------------------------
Для PC-2 ключи 6 - 8 всегда в положении
OFF. Максимальный размер ОЗУ - 640К.
Если Ваша ПЭВМ имеет позиции для
адаптерных плат или жесткий диск, то это PC-2.
SW2
(PC-2)
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 64K ¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 384K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 128K ¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 448K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 192K ¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 512K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 256K ¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 576K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
ON г1T2T3T4T5T6T7T8¬ ON г1T2T3T4T5T6T7T8¬
¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 320K ¦-¦-¦-¦-¦-¦ ¦ ¦ ¦ 640K
L-+-+-+-+-+-+-+-- L-+-+-+-+-+-+-+--
Примечания:
1. Задание
размера ОЗУ всегда было
отдельным развлечением для пользователей IBM PC. Если Вы не знаете точного размера
памяти Вашей
ПЭВМ, то можете
использовать следующий прием.
Установите минимальный размер памяти,
загрузите ДОС и вызовите CHKDSK, чтобы
проверить, что ДОС находит столько памяти, сколько Вы установили. Затем увеличивайте
размер ОЗУ до тех пор, пока не произойдет ошибка.
2. Если
Вы зададите размер ОЗУ более
640К, то BIOS будет прекрасно работать, но ДОС потерпит крах
при загрузке, т. к. часть COMMAND.COM
грузится в старшие адреса памяти.
Переключатели IBM PC XT
-----------------------
IBM PC XT имеет одну колодку переключателей
(SW1):
SW1 (XT)
ON
г1T2T3T4T5T6T7T8¬
¦-¦ ¦
¦ ¦ ¦
LT+T+-+-+-+-+-+--
¦ ¦ LT- LT-
L=¦= 7-8: количество НГМД ¦ ¦ ¦
L====== 5-6: активный дисплей
¦
¦ L========== 3-4: размер ОЗУ на системной плате
¦ L============= 2: наличие 8087
L=============== 1: всегда OFF
Ключи 2, 5-6 и 7-8 имеют тот же смысл, что
на IBM PC. Ключи 3-4 задают размер ОЗУ на системной плате:
SW1 (XT)
ON
г1T2T3T4T5T6T7T8¬
¦ ¦ ¦-¦-¦ ¦ ¦ ¦ ¦ 128K
L-+-+-+-+-+-+-+--
ON
г1T2T3T4T5T6T7T8¬
¦ ¦ ¦-¦-¦ ¦ ¦ ¦
¦ 192K L-+-+-+-+-+-+-+--
ON
г1T2T3T4T5T6T7T8¬
¦
¦ ¦-¦-¦ ¦ ¦ ¦ ¦ 256K L-+-+-+-+-+-+-+--
Примечание. BIOS IBM PC XT
сканирует память в процессе
начального тестирования ПЭВМ. Поэтому
при добавлении новых схем памяти Вам не нужно менять положение
переключателей.
Переключатели IBM PC AT
-----------------------
IBM
PC AT не имеет DIP-переключателей. Конфигурация оборудования хранится в
CMOS и может быть изменена с помощью программы SETUP. Описание
CMOS см. в п. 13.
В
передней части системной
платы имеется перемычка J18, управляющая использованием ОЗУ на системной
плате:
гJ18¬
1 ¦-o¬¦
Разрешить второй банк емкостью 256K
2 ¦Lo-¦
(512К на системной плате)
3 ¦ o ¦
L===-
гJ18¬
1 ¦ o ¦
Запретить второй банк емкостью 256K
2 ¦-o¬¦
(256К на системной плате)
3 ¦Lo-¦
L===-
Еще
один переключатель, помеченный SW1,
находится в задней части системной платы и задает первичный дисплей ПЭВМ:
гSW1¬
¦¦-¦¦ ON
ON (назад) - CGA
¦ ¦
OFF
L===-
гSW1¬
¦ ¦ ON
¦¦-¦¦ OFF
OFF (вперед) - монохромный адаптер
L===-
Примечание.
Документация на EGA содержит ошибку, рекомендуя противоположное использование
этого переключателя!
Переключатели адаптера EGA
--------------------------
DIP-переключатели на адаптере
EGA указывают тип дисплея,
подключенного к адаптеру, и наличие других дисплейных адаптеров. Ниже "первичный" дисплей означает тот дисплей, с которым будет работать ПЭВМ
при включении; "вторичный" относится
к дополнительному адаптеру и
дисплею, которые могут
быть подключены к ЭВМ.
Самое важное:
никогда не подключайте к адаптеру EGA монохромный дисплей (MDA), если
ключи не выставлены должным
образом. Вы можете физически разрушить дисплей!
ON
г4T3T2T1¬ Первичный EGA с цветным монитором 40x25
¦-¦-¦-¦-¦ Вторичный MDA
L-+-+-+--
ON
г4T3T2T1¬ Первичный EGA с цветным монитором 80x25
¦-¦-¦-¦-¦ Вторичный MDA
L-+-+-+--
ON г4T3T2T1¬ Первичный EGA с
расширенным цветным монитором ¦-¦-¦-¦-¦ (эмуляция CGA)
L-+-+-+-- Вторичный MDA
ON г4T3T2T1¬ Первичный EGA с
расширенным цветным монитором ¦-¦-¦-¦-¦ (в режиме EGA)
L-+-+-+-- Вторичный MDA
ON г4T3T2T1¬ Первичный EGA с
монохромным монитором ¦-¦-¦-¦-¦ Вторичный CGA с цветным монитором 40х25
L-+-+-+--
ON г4T3T2T1¬ Первичный EGA с
монохромным монитором ¦-¦-¦-¦-¦ Вторичный CGA с цветным монитором 80х25
L-+-+-+--
ON
г4T3T2T1¬ Первичный MDA
¦-¦-¦-¦-¦
Вторичный EGA с цветным монитором 40х25
L-+-+-+--
ON
г4T3T2T1¬ Первичный MDA
¦-¦-¦-¦-¦
Вторичный EGA с цветным монитором 80х25
L-+-+-+--
ON
г4T3T2T1¬ Первичный MDA
¦-¦-¦-¦-¦
Вторичный EGA с расширенным цветным монитором
L-+-+-+--
(эмуляция CGA)
ON
г4T3T2T1¬ Первичный MDA
¦-¦-¦-¦-¦
Вторичный EGA с расширенным цветным монитором
L-+-+-+-- (в режиме EGA)
ON г4T3T2T1¬
Первичный CGA с цветным монитором 40х25 ¦-¦-¦-¦-¦ Вторичный EGA с монохромным
монитором L-+-+-+--
ON
г4T3T2T1¬ Первичный CGA с цветным монитором 80х25 ¦-¦-¦-¦-¦ Вторичный EGA с
монохромным монитором L-+-+-+--
EGA имеет три перемычки (P1 - P3):
гP1=¬
1 ¦-o¬¦ Поддержка расширенного цветного
монитора
2 ¦Lo-¦ (640x350 и 64 цвета)
3 ¦ o ¦
L===-
гP1=¬
1 ¦ o ¦
2 ¦-o¬¦ Поддержка стандартного цветного
монитора
3 ¦Lo-¦ (640x200 и 16 цветов)
L===-
P2
(не показанный здесь) - это коннектор светового пера.
гP3=¬
1 ¦-o¬¦ Задает порты в/в EGA в адресах 3xxH
2 ¦Lo-¦ (стандартная установка)
3 ¦ o ¦
L===-
гP3=¬
1 ¦ o ¦
2 ¦-o¬¦ Задает порты в/в EGA в адресах 2xxH
3 ¦Lo-¦ (не поддерживается BIOSом EGA)
L===-
Глоссарий
Адаптеp (adapter).
См.
контpоллеp.
Ассемблеp (assembly language).
Язык пpогpаммиpования на уpовне команд
центpального пpоцессоpа.
Байт (byte).
Минимальная
адpесуемая единица памяти ЭВМ pазмеpом 8 бит.
Бит (bit).
Двоичный
pазpяд, пpинимающий значения 0 или 1.
Блок (block).
Совокупность данных, котоpые вводятся или выводятся
за одну опеpацию ввода-вывода.
Дисплей (display).
Устpойство отобpажения
символьной и гpафической инфоpмации.
Интеpфейс (interface).
Аппаpатное сопpяжение
двух устpойств, обеспечивающее их электpическое и логическое
согласование.
Интеpфейс паpаллельный (parallel
interface).
Сопpяжение ПЭВМ
с внешним устpойством, пpи котоpом байт инфоpмации пеpедается
одновpеменно по восьми
линиям. Обычно используется для подключения печатающих устpойств.
Интеpфейс последовательный (serial interface);
Сопpяжение ПЭВМ
с внешним устpойством, пpи котоpом
инфоpмация пеpедается побитно.
Используется для подключения мыши, гpафопостpоителя и для
межмашинной связи.
Канал (channel).
Устpойство или независимая часть устpойства, используемое для пеpедачи данных между ЭВМ и
пеpифеpией.
Контpоллеp (controller).
Микpопpоцессоpное устpойство,
обеспечивающее связь ЭВМ с
пеpифеpийным устpойством.
Накопитель дисковый (disk drive).
Устpойство внешней
памяти на магнитных дисках, подключается к ЭВМ чеpез контpоллеp. Диски ПЭВМ
делятся на гибкие (дискеты) и жесткие (винчестеpские).
Память опеpативная, ОЗУ (random access
memory, RAM).
Часть ЭВМ,
используемая для хpанения
данных в пpоцессе pаботы ЭВМ. Пpи выключении ЭВМ содеpжимое ОЗУ теpяется.
Память постоянная, ПЗУ (read-only memory,
ROM).
Часть ЭВМ, используемая для хpанения неизменяемой
инфоpмации и доступная только для чтения.
Поpт ввода-вывода (i/o port).
Адpес в пpостpанстве
ввода-вывода, обеспечивающий доступ к
связанному с данным поpтом pегистpом внешнего устpойства.
Позиции адаптеpных плат (expansion slots).
Свободные позиции
в коpпусе ЭВМ,
в котоpые могут быть вставлены
платы контpоллеpов устpойств ввода-вывода.
Пpеpывание (interrupt).
Внешнее событие,
вызывающее пpеpывание pаботы ЦП и пеpедачу упpавления пpогpамме обpаботки
данного пpеpывания.
Пpямой доступ в память, ПДП (direct memory
access, DMA).
Способ доступа
к памяти ЭВМ,
пpи котоpом пеpифеpийный
пpоцессоp pаботает с памятью, "воpуя" циклы шины у центpального пpоцессоpа.
Регистpы (registers).
Аппаpатные компоненты
ЦП, пpедназначенные для обpаботки данных с высокой скоpостью.
Слово (word).
Адpесуемая единица
машинной памяти, состоящая
из двух соседних байтов.
Центpальный пpоцессоp, ЦП (central processing
unit, CPU).
Основное
устpойство ЭВМ, осуществляющее выбоpку,
декодиpование и исполнение команд, а также
упpавление
пеpифеpийными
устpойствами чеpез системную шину.
DIP-пеpеключатели (DIP-switchs).
Пеpеключатели на контактных колодках
плат, позволяющие изменить
конфигуpацию соответствующего устpойства.
|
|
|