Содержание | Параллельные порты


Параллельные порты РС





За многолетнюю историю развития персональных компьютеров параллельный порт (parallel port), который часто называют принтерным портом (printer port) остается самым быстрым и надежным способом подключения к РС принтера и других устройств. Параллельная передача восьми битов данных и автоматическое управление потоком данных с помощью сигналов квитирования (handshaking) делают ненужными внешние схемы для декодирования данных и управляющих сигналов. Широкое применение параллельных портов объясняются их простотой и высокой производительностью. Более того, параллельный порт позволяет вводить до девяти битов и выводить до 12 битов одновременно, требуя минимальных внешних схем для реализации многих простых задач.

Стандартный параллельный порт (SPP)


Стандартный параллельный порт (Standard Parallel Port - SPP) представлен на задней стенке компьютера 25-контактным разъемом D-типа с отверстиями. Обычно кабель для этого разъема имеет на втором конце 34-контактный разъем, предназначенный для подключения к принтеру. Именно параллельный порт РС часто называется принтерным портом (printer port). На рисунке показаны разъемы и кабель для подключения принтера. Слева находится разъем со штырьками, предназначенный для параллельного порта РС, а справа - разъем для принтера.



В компьютере на разъем выведено четыре линии управления (CONTROL), пять линий состояния (STATUS) и восемь линий данных (DATA). Приведенные группы сигналов доступны через соответствующие регистры, которые часто тоже называются портами. Оставшиеся восемь контактов заземлены.

Более новые параллельные порты определены стандартом IEEE 1284, который был опубликован в 1994 г. Этом стандарт определяет пять режимов работы:

    1. Режим совместимости (Compatibility Mode).
    2. Режим тетрад (Nibble Mode).
    3. Режим байтов (Byte Mode).
    4. Режим улучшенного параллельного порта (Enhanced Parallel Port - EPP).
    5. Режим порта с расширенными возможностями (Extended Capabilities Port - ECP).

Цель стандарта заключалось в том, чтобы разработать новые драйверы и устройства, совместимые друг с другом и обратно совместимые со стандартным параллельным портом (Standard Parallel Port - SPP). Для режимов совместимости, тетрад и байтов используются стандартные схемы, имеющиеся на оригинальных картах параллельного порта, а для режимов ЕРР и ЕСР требуются дополнительные схемы, которые работают быстрее, но все же обратно совместимы со стандартным параллельным портом.

В режиме совместимости, или режиме Centronics, как его обычно называют, можно передавать данные только в прямом направлении, т.е. выводить данные, с типичной скоростью около 50 КБ/с, но возможна и большая скорость до 150 КБ/с. Для ввода данных необходимо перейти в режим тетрад или байтов. Режим тетрад позволяет вводить тетрады (4 бита) из устройства в РС. Режим байтов использует двунаправленные средства (имеющиеся только на некоторых картах) для ввода байтов (8 битов).

Порты ЕРР и ЕСР используют дополнительные схемы для управления и генерирования квитирования. Для вывода байта в принтер в режиме совместимости программа должна выполнить следующие действия:

  1. Записать байт в порт данных.
  2. Проверить, не занят ли принтер. Если принтер занят, он не воспринимает никаких данных, поэтому все записываемые в него данные теряются.
  3. Выдать сигнал строба Strobe (контакт 1) с низким уровнем. Он показывает принтеру, что на линиях данных (контакты 2-9) имеются достоверные данные.
  4. Установить высокий уровень строба, подождав примерно 5 мкс после формирования низкого уровня (на этапе 3).

Программное управление выводом ограничивает скорость стандартного параллельного порта. Более совершенные порты ЕРР и ЕСР решают эту проблему, позволяя схемно проверять занятость принтера и генерировать строб и/или подходящие сигналы квитирования. Благодаря этому необходимо выполнить только одну команду вывода, что повышает скорость работы. Новые порты могут выводить данные со скоростью 1-2 МБ/с. Кроме того, порт ЕСР использует каналы прямого доступа к памяти (Direct Memory Access - DMA) и буферы FIFO (First In - First Out), поэтому данные можно передавать без применения команд вывода.

Аппаратные средства


В следующей таблице приведена разводка 25-контактного разъема D-типа компьютера и 34-контактного разъема Centronics, который обычно имеется на принтерах. Однако стандарт IEEE 1284 определяет три разных разъема для использования с параллельным портом. Первый разъем 1284 Type A - это обычный 25-контактный разъем D-типа. Второй 36-контактный разъем 1284 Type B является разъемом Centronics. Третий разъем IEEE 1284 Type C представляет собой 36-контактный разъем, похожий на разъем Centronics, но меньше по размерам. Он имеет лучший фиксатор, лучшие электрические параметры и к нему проще подключать кабель. Два дополнительных сигнала можно использовать для проверки включенного состояния устройства. Этот разъем признан перспективным для применения в новых разработках.

# контакта
(D-25)
# контакта (Centronics)
Сигнал SPP
Направление
Регистр
Аппаратно
инвертирован
1
1
nStrobe
Вход/Выход
Управления
Да
2
2
Данные 0
Выход
Данных
 
3
3
Данные 1
Выход
Данных
 
4
4
Данные 2
Выход
Данных
 
5
5
Данные 3
Выход
Данных
 
6
6
Данные 4
Выход
Данных
 
7
7
Данные 5
Выход
Данных
 
8
8
Данные 6
Выход
Данных
 
9
9
Данные 7
Выход
Данных
 
10
10
nAck
Вход
Состояния
 
11
11
Busy
Вход
Состояния
Да
12
12
Paper-Out / Paper-End
Вход
Состояния
 
13
13
Select
Вход
Состояния
 
14
14
nAuto-Linefeed
Вход/Выход
Управления
Да
15
32
nError / nFault
Вход
Состояния
 
16
31
nInitialize
Вход/Выход
Управления
 
17
36
nSelect-Printer / nSelect-In
Вход/Выход
Управления
Да
18 - 25
19-30
Земля
Земля
 
 

Буква n перед названием сигнала означает сигнал с низким уровнем активности, например nError. Если в принтере возникла ошибка, на этой линии будет низкий уровень. Обычно на ней действует высокий уровень, показывая правильное функционирование принтера. Слова "Аппаратно инвертирован" означают, что сигнал инвертируется схемами параллельного порта. Здесь примером служит линия Busy. Если на этой линии действует напряжение +5 В (логическая 1) и производится считывание регистра состояния, то этот уровень возвращается как 0 в бите 7 регистра состояния.

Сигналы параллельного порта представлены обычными ТТЛ-уровнями. Большинство параллельных портов реализовано на основе специализированной микросхемы, которая отводит (Sink) и отдает (Source) ток около 12 мА. Однако в справочных данных могут встретиться и другие значения, например Sink/Source 6 мА, Source 12 мА/Sink 20 мА, Sink 16 мА/Source 4 мА.

Линии данных представляет собой настоящие проводники, по которым информация передается от компьютера в устройство (и от устройства в компьютер в новых портах). Для уменьшения влияния помех каждая линия данных имеет соответствующую земляную линию. Эти земляные линии обеспечивают также общий электрический эталон между компьютером и устройством. Остальные линии параллельно порта отведены для управления и квитирования (handshaking).

Чтобы обеспечить нахождение принтера в известном начальном состоянии, выдаваемый компьютером сигнал nInitialize переводит принтер в такое состояние, в котором он находится после включения питания. Таким образом, инициализация принтера сигналом nInitialize эквивалентна выключению принтера и последующему включению.

Сигнал на линии Select сообщает компьютеру о том, что периферийное устройство находится в онлайновом режиме (online) и готово принимать данные. Компьютер не посылает данные, если на линии Select имеется сигнал с низким уровнем. Обычно состояние этого сигнала соответствует индикатору "on-line" на принтере.

Когда компьютер сформировал на линиях данных сигналы достоверных данных, устройству необходимо сообщить о готовности данных. Именно для этого предназначен импульсный сигнал строба nStrobe, который должен заставить устройство воспринять байт данных и сохранить его в буфере для последующей обработки.

Для достижения высокой скорости передачи данных принтеру необходим конкретный метод координации передач. Компьютер должен ожидать между байтами до тех пор, пока принтер не будет готов к возобновлению приема новых байтов. Принтеры используют сигнал занятости Busy для задержки компьютера до тех пор, пока принтер не будет в состоянии готовности к приему следующего байта. Принтер формирует высокий уровень сигнала Busy в ответ на получение сигнала nStrobe и этот уровень сохраняется до тех пор, пока не подготовится к приему следующего байта. Отметим, что сигнал Busy может задержать компьютер на любой временной интервал, если возникла серьезная ошибка, например замятие бумаги. Когда же принтер обработал байт, он должен запросить у ожидающего компьютера следующий байт. Принтер снимает сигнал Busy и выдает короткий импульс подтверждения nAck. Таким образом с помощью сигналов nStrobe, Busy и nAck осуществляется управление (квитирование) передачей данных в параллельном порту.

В некоторых принтерах управляющий символ возврата каретки (Carriage Return - CR) автоматически транспортирует бумагу на следующую строку, а в других просто возвращает каретку в начало текущей строки без транспорта бумаги. Во многих принтерах любой из этих вариантов можно установить переключателем, но можно управлять этим и с помощью сигнала nAuto-LineFeed. Низкий уровень этого сигнала заставляет принтер автоматически производить транспорт бумаги на одну строку при получении управляющего символа CR.

Линия nSelect-Printer позволяет компьютеру дистанционно переводить периферийное устройство в онлайновый или офлайновый режим. Большинство параллельных портов поддерживают на этой линии низкий уровень, чтобы устройство автоматически воспринимало данные. Сигнал высокого уровня на этой линии запрещает работу устройства. Сигнал nError от периферийного устройства сообщает компьютеру о возникшей проблеме, препятствующей печати, но не конкретизирует ее. Ошибку может вызвать множество причин, детали которых зависят от периферийного устройства. Обычно в сигнал nError "собираются" такие ситуации, как отсутствие бумаги (эту причину конкретизирует сигнал Paper Out), нахождение принтера в офлайновом режиме (offline mode) или внутренние сбои схем принтера.

Интерфейс Centronics


Centronics - это старый стандарт (его часто называют интерфейсом и протоколом) на передачу данных из компьютера (хоста - host) в принтер. Квитирование этого стандарта используется в большинстве принтеров и обычно реализуется программно. На рисунке показана упрощенная диаграмма протокола Centronics.


Сначала на контакты 2-9 параллельного порта выдаются данные. Затем хост проверяет занятость принтера, т.е. на линии Busy должен действовать низкий уровень. После этого программа выдает строб, ожидает минимум 1 мкс и снимает строб. Данные обычно считываются устройством по нарастающему фронту строба. Принтер показывает свою занятость обработкой данных по линии Busy. Когда принтер воспринял данные, он подтверждает байт отрицательным импульсом длительностью около 5 мкс на линии nAck.

Часто для экономии времени хост игнорирует сигнал на линии nAck. При рассмотрении порта с расширенными возможностями ЕСР будет показана реализация быстрого режима Centronics (Fast Centronics Mode), в котором квитирование осуществляется схемно. Программист должен только записать байт данных в порт ввода-вывода. Схемы проверяют занятость принтера и формируют строб. Отметим, что в этом режиме линию nAck не контролируется.

Адреса портов


Адрес
Примечания
3BCh - 3BFh
Используется для параллельных портов на видеокартах -
не поддерживает адресов ECP
378h - 37Fh
Обычный адрес для LPT1
278h - 27Fh
Обычный адрес для LPT2
   

Параллельный порт имеет три общепринятых базовых адреса, которые приведены в следующей таблице. Базовый адрес 3BCh был вначале введен для параллельных портов на первых видеокартах. После того, как параллельные порты были вынесены с видеокарт, этот адрес исчез. Впоследствии он появился как вариант для параллельных портов, интегрированных в материнские платы, где конфигурацию можно изменять с помощью BIOS. Имени LPT1 обычно присваивается базовый адрес 378h, а LPT2 - адрес 278h. Однако далее показано, что это не всегда соблюдается. Адреса 378h и 278h почти всегда используются для параллельных портов, но могут изменяться в разных РС.

При включении компьютера BIOS определяет число имеющихся портов и присваивает им имена LPT1, LPT2 и LPT3. Вначале BIOS обращается по адресу 3BCh. Если там обнаруживается параллельный порт, ему присваивается имя LPT1, а затем проверяется адрес 378h. Если там обнаруживается параллельный порт, ему присваивается следующее свободное имя. Им будет LPT1, если по адресу 3BCh не найдена карта, или LPT2, если карта была найдена. Аналогично проверяется порт по адресу 278h. В результате можно иметь LPT2 по адресу 378h, а не ожидаемому адресу 278h.

Ситуацию усложняет то, что некоторые производители карт параллельного порта устанавливают перемычки, которые позволяют настроить порт на LPT1, LPT2, LPT3. Какой же теперь адрес у LPT1? В большинстве карт LPT1 находится по адресу 378h, а LPT2 - по адресу 278h, но некоторые используют 3BCh как LPT1, 378h как LPT1 и 278h как LPT2.

Начальный адрес
Функция
0000:0408
Базовый адрес LPT1
0000:040A
Базовый адрес LPT2
0000:040C
Базовый адрес LPT3
0000:040E
Базовый адрес LPT4 (*)
   

Для интерфейса с портом вместо имени часто используется базовый адрес, а не имена LPT1 и др. Таблица адресов портов находится в области данных BIOS. Когда BIOS назначает адреса принтерным устройствам, он сохраняет адреса в конкретных ячейках памяти и их там можно найти. Примечание * : В новых BIOS адрес 0000:040E из области данных BIOS может использоваться как расширенная область данных BIOS (Extended BIOS Data Area).

Программные регистры (порты) стандартного параллельного порта



Порт данных


Смещение
Название
Read/Write
Биты
Назначение
База + 0
Порт данных
Write (*)
Бит 7 - 0
Данные 7 - 0

Примечание *: Если порт является двунаправленным, то допускается выполнение операций Read (ввод) и Write (вывод).

Базовый адрес, обычно называемый портом данных или регистром данных, просто используется для вывода данных на линии данных (контакты 2-9) параллельного порта. Обычно этот регистр допускает только запись (Write). При считывании из порта вводится последний переданный байт. В случае двунаправленного порта (см. далее) по этому адресу находятся принятые данные.

Порт состояния


Смещение
Название
Read/Write
Бит
Назначение
База + 1
Порт состояния
Только Read
Бит 7
Busy
Бит 6
Ack
Бит 5
Paper Out
Бит 4
Select In
Бит 3
Error
Бит 2
IRQ (инвертирован)
Бит 1
Зарезервирован
Бит 0
Зарезервирован

Порт состояния допускает только считывание, поэтому все записываемые в него данные игнорируются. Порт имеет пять входных линий (контакты 10, 11, 12, 13 и 15), бит запроса прерывания IRQ и два зарезервированных бита. Бит 7 (Busy) является входным сигналом с низким уровнем активности, т.е. если бит 7 содержит 0, то на контакте 11 имеется напряжение +5 В. Так же действует бит 2 (nIRQ) - если бит содержит 1, то прерывания не возникло.

Порт управления


Смещение
Название
Read/Write
Бит
Назначение
База + 2
Порт управления
Read/Write
Бит 7
Не используется
Бит 6
Не используется
Бит 5
Разрешение двунаправленного порта
Бит 4
Разрешение IRQ через линию Ack
Бит 3
Select Printer
Бит 2
Инициализация принтера (Reset)
Бит 1
Auto Linefeed
Бит 0
Strobe

Порт управления (базовый адрес + 2) был предназначен только для записи. При подключении к параллельному порту принтера используются четыре сигнала управления: строб Strobe (бит 0), автоматический перевод строки Auto Linefeed (бит 1), инициализации Reset (бит 2) и выбора принтера Select Printer (бит 3). Все эти сигналы кроме Reset инвертированы.

Принтер не выдает сигнал для инициализации компьютера и не сообщает компьютеру использовать автоматический перевод строки. Однако приведенные ранее четыре выхода можно использовать для ввода. Если компьютер вывел на контакт высокий уровень (+5 В), а устройство хочет сделать его низким, порт закорачивается, вызывая конфликт. Поэтому эти выходы выполнены по схеме "открытый коллектор". Они имеют два состояния: низкий уровень (0 В) и высокоимпедансное состояние (разомкнутая цепь).

Обычно карта принтера имеет внутренние "вытягивающие" (pull-up) резисторы, но они есть не на всех картах. Некоторые карты имеют просто выходы типа открытый коллектор, а другие - обычные пушпульные (totem) выходы. Чтобы устройство правильно работало с максимально большим числом принтерных портов, можно использовать внешний резистор. Если уже есть внутренний резистор, то внешний резистор действует параллельно ему, а в случае пушпульного выхода - как нагрузка.

Величина внешнего резистора обычно составляет 4.7 кОм. Не рекомендуется применять меньший резистор с учетом того, что на карте может быть внутренний резистор. В высокоимпедансном состоянии контакт параллельного порта имеет высокий уровень +5 В. В этом состоянии внешнее устройство может установить низкий уровень и заставить порт управления считать другое значение. Благодаря этому четыре контакта порта управления можно использовать для двунаправленной передачи данных. Однако для считывания данных через порт управления необходимо установить его на xxxx0100, чтобы все контакты имели +5 В и устройство могло установить низкий уровень (землю - логический 0).

Биты 4 и 5 предназначены для внутреннего управления. Бит 4 разрешает запрос прерывания IRQ (см. далее), а бит 5 разрешает двунаправленный порт, т.е. можно вводить 8 битов по линиям DATA 0-7. Этот режим возможет, если только его поддерживает карта. Биты 6 и 7 зарезервированы, любая запись в эти биты игнорируется.

Двунаправленные порты


Следующая схема показывает упрощенное представление регистра данных параллельного порта. Оригинальные платы параллельного порта реализованы на логике семейства 74LS. Сейчас применяются специализированные микросхемы, но принципы работы остались теми же.


Недвунаправленные порты выпускаются с сигналом разрешения выхода nOE микросхемы 74LS374, постоянно подключенным к земле, поэтому порт данных выполняет только вывод. При считывании из регистра данных данные берутся из схемы 74LS374, которая также подключена к контактам данных. Если запретить схему 74LS374, можно получить двунаправленный порт.

В двунаправленных портах бит 5 регистра управления соединяется с входом разрешением выхода nOE схемы 74LS374, так что выходные драйверы можно запретить (выключить). В этом случае можно без конфликтов считывать данные с контактов данных параллельного порта.

Бит 5 регистра управления разрешает или запрещает двунаправленную работу параллельного порта. Он действует только для истинно двунаправленных портов. Когда этот бит становлен в 1, контакты 2-9 переводятся в высокоимпедансное состояние. В этом состоянии можно вводить данные на эти линии и считывать их порта данных (базовый адрес). Записываемые в порт данные сохраняются, но не доступны на контактах данных. Для выключения двунаправленного режима бит 5 порта управления нужно сбросить в 0.

Однако не все порты действуют одинаково. Некоторые порты могут потребовать установки бита 6 порта управления для разрешения двунаправленного режима, а бита 5 - для запрещения его. Различные производители реализуют свои двунаправленные порты по-разному. Если необходимо использовать двунаправленный порт для ввода данных, следует вначале с помощью логического пробника или мультиметра убедиться в том, что порт является двунаправленным.

Использование параллельного порта для ввода восьми бит


Если параллельный порт не поддерживает двунаправленного режима, все же можно осуществить ввод до девяти бит. Для этого можно использовать пять входных линий порта состояния и четыре входные линии (открытый коллектор) порта управления в соответствии со следующей схемой.


Входы параллельного порта выбраны так, чтобы упростить подключения. Сигнал Busy является старшим битом 7 порта состояния, а затем идут сигналы Ack, Paper Out и Select порта состояния, образуя старшую тетраду. Черточки показывают, какие входы аппаратно инвертируются, т.е. +5 В считывается как логический 0, а 0 В - как логическая 1. Порт состояния имеет только один инвертированный вход.

Младшая тетрада считывается из порта управления (Select Printer, Init, Auto Linefeed, Strobe). Здесь использованы инверторы с открытым коллектором. При этом могут потребоваться "вытягивающие" (pull-up) резисторы 4.7 кОм.

Режим тетрад




Режим тетрад (nibble mode) является предпочтительным способом ввода восьми битов данных без перевода порта в инверсный режим и использования линий данных. Этот режим реализуется наиболее просто. Для поочередного считывания тетрад применяется мультиплексор (счетверенный 2:1). Объединение тетрад в байт осуществляется программно. Конечно, этот способ несколько медленнее предыдущих. Здесь для считывания одного байта требуется несколько команд ввода-вывода и необходима внешняя микросхема.

Мультиплексор 74LS157 работает очень просто, как четыре переключателя. Когда вход A/B = 0 (низкий), выбираются входы А, т.е. вход 1А передается на выход 1Y, вход 2A на выход 2Y и т.д. Когда вход A/B = 1 (высокий), выбираются входы В. Выходы Y подключаются к порту состояния параллельного порта так, чтобы они оказались старшей тетрадой регистра состояния. Хотя такое подключение и необязательно, но при этом несколько упрощается программа.

Использование прерывания IRQ параллельного порта


Запрос прерывания параллельного порта не используется для печати под DOS. Прерывания хороши для устройств, момент активизации которых неизвестен, например датчика высокой температуры. В этом случае эффективнее работать по прерыванию, чем периодически программно опрашивать датчик. Кроме того, прерывания особенно важны для мультизадачной операционной системы.

Обычно запросом прерывания параллельного порта служит линия IRQ 5 или IRQ 7, но может быть и другая. Возможно, что прерывания на карте полностью запрещены, если она применяется только для печати. Прерывания параллельного порта можно разрешать и запрещать с помощью бита 4 регистра управления - разрешение IRQ через линию Ack (Enable IRQ Via Ack Line). Разрешенное прерывание возникает при переходе от низкого уровня к высокому (нарастающий фронт) сигнала nAck. Однако некоторые карты запускают прерывание по переходу от высокого уровня к низкому.

Режимы параллельного порта в BIOS


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

    Режим принтера (Printer Mode), иногда называемый режимом Default или Normal
    Стандартный и двунаправленный режим (SPP)
    Режим EPP1.7 и SPP
    Режим EPP1.9 и SPP
    Режим ECP
    Режим ECP и EPP1.7
    Режим ECP и EPP1.9

Режим принтера является наиболее простым режимом - он соответствует только выводу стандартного параллельного порта. В нем отсутствуют средства двунаправленной работы, поэтому бит 5 порта управления не действует. Стандартный и двунаправленный режим (SPP) является двунаправленным режимом. В этом режиме бит 5 порта управления изменяет направление порта, поэтому можно считать вводимое значение по линиям данных.

Режим EPP1.7 и SPP представляет собой комбинацию режимов EPP 1.7 (Enhanced Parallel Port) и SPP. В этом режиме работы обеспечивается доступ к регистрам SPP (регистры данных, состояния и управления), а также доступ к регистрам EPP. В этом же режиме можно изменять направление порта с помощью бита 5 регистра управления. Первая версия EPP 1.7 может не иметь бита таймаута (Timeout).

Режим EPP1.9 и SPP аналогичен предыдущему, но теперь используется EPP Версия 1.9. Здесь по-прежнему предоставляется доступ к регистрам SPP, включая бит 5 порта управления. Но этом режим отличается от режима EPP1.7 и SPP тем, что можно обращаться к биту таймаута (Timeout) порта EPP.

Режим ECP предоставляет порт с расширенными возможностями (Extended Capabilities Port. Режим этого порта можно затем установить с помощью расширенного регистра управления (Extended Control Register - ECR) порта ECP. Однако в этом режиме из BIOS режим EPP (100) будет недоступен.

Режим ECP и EPP1.7 и режим ECP и EPP1.9 предоставляет порт с расширенными возможностями ECP, как и в предыдущем режиме. Однако режим EPP в регистре ECR порта ECP теперь доступен. В режиме ECP и EPP1.7 в вашем распоряжении порт EPP1.7, а в режиме ECP и EPP1.9 - порт EPP1.9.

Рассмотренные режимы конфигурируются через BIOS. Пользователь может реконфигурировать своей программой, но этого делать не рекомендуется. Программные регистры по адресам 2FAh, 3F0h, 3F1h предназначены для обращения только из BIOS. Для этих регистров конфигурирования нет установленного стандарта, поэтому использующая их прикладная программа становится плохо переносимой (portable).

Гораздо лучше выбрать из BIOS режим ECP и EPP1.7 или режим ECP и EPP1.9, а затем с помощью расширенного регистра управления порта ECP установить режим параллельного порта. В режиме EPP1.7 было несколько проблем, связанных с формированием стробов данных и адреса для запуска цикла независимо от состояний ожидания, поэтому сейчас этот режим не применяется. Лучше всего установить параллельный порт на режим ECP и EPP1.9.

Режимы параллельного порта и расширенный регистр управления порта ECP


Ранее показано, что рекомендуется установить параллельный порт на режим ECP и EPP1.9, а затем использовать расширенный регистр управления порта ECP для выбора различных режимов работы. Регистры порта ECP стандартизованы Extended Capabilities Port Protocol and ISA Interface Standard компании Microsoft.

Биты
Функция
7:5
Выбирают текущий режим работы
000
Стандартный режим
001
Режим байтов
010
Режим FIFO параллельного порта
011
Режим ECP FIFO
100
Режим EPP
101
Зарезервирована
110
Режим теста FIFO
111
Режим конфигурирования
4
Бит прерывания ECP
3
Бит разрешения DMA
2
Служебный бит ECP
1
FIFO заполнен (Full)
0
FIFO пуст (Empty)
   

При установке режима ECP доступен новый набор регистров по адресу База + 400h. Подробное рассмотрение из приведено в материале по порту ECP, а здесь необходим нам только расширенный регистр управления по адресу База + 402h. Формат этого регистра приведен в таблице слева. Отметим, что регистры ECP недоступны для порта с базовым адресом 3BCh.

Нас пока интересуют только три старших бита расширенного регистра управления, которые определяющие режим работы. Имеются семь возможных режимов работы, но не все порты поддерживают все режимы. Например, некоторые порты не поддерживает режим EPP. В следующей таблице приведены более подробные сведения о режимах работы.

Режимы работы

Стандартный режим Установка этого режима заставляет порт ECP действовать как стандартный параллельный порт без возможности двунаправленной работы.
Режим байтов Действует как SPP в двунаправленном режиме. Бит 5 переводит порт в инверсный режим.
Режим FIFO параллельного порта В этом режиме все данные, записываемые в FIFO данных, будут передаваться в периферийное устройство с использованием квитирования SPP. Необходимое квитирование реализуется схемно. Этот режим удобен для не-ECP устройств, например принтеров. Предоставляются некоторые возможности ECP, например буферы FIFO и схемное генерирование квитирования, но с квитированием SPP, а не с квитированием ECP.
Режим ECP FIFOСтандартный режим для порта ECP. В этом режиме используется квитирование ECP. - Когда режим ECP установлен через BIOS и регистр ECR устанавливается на режим ECP FIFO Mode (011), регистры SPP могут исчезнуть.
Режим EPP/ЗарезервированРазрешается режим EPP, если он доступен. Под BIOS, если установлен режим ECP, то более чем вероятно, этот режим не является опцией. Но если BIOS установлен на режим ECP и EPP1.x, то будет разрешен EPP 1.x. - Согласно Extended Capabilities Port Protocol and ISA Interface Standard этот режим определяется поставщиком.
ЗарезервированПока зарезервирован. - Согласно Extended Capabilities Port Protocol and ISA Interface Standard этот режим определяется поставщиком.
Режим теста FIFOВ этом режиме все данные, записываемые в регистр Test FIFO, будут помещаться в FIFO, а любые данные, считываемые из регистра Test FIFO, будут считываться из буфера FIFO. Биты состояния FIFO Full/Empty будут отражать их истинное значение, поэтому в этом режиме можно определить некоторые характеристики FIFO, например его глубину.
Режим конфигурированияВ этом режиме становятся доступными два регистра конфигурирования cnfgA и cnfgB по их адресам.

Если режим ECP установлен в BIOS или карта перемычкой конфигурирована на ECP, то рекомендуется до использования инициализировать порт ECP на предопределенное состояние. При использовании SPP прежде всего нужно установить порт на стандартный режим. Нельзя полагать, что порт будет уже находиться в стандартном (SPP) режиме.

В некоторых режимах регистры SPP могут исчезать или не работать правильно. При использовании SPP необходимо установить регистр ECR на стандартный режим.

Улучшенный параллельный порт (EPP)


Улучшенный параллельный порт (Enhanced Parallel Port - ЕРР) разработан компаниями Intel, Xircom и Zenith Data Systems. Порты ЕРР были вначале определены в стандарте EPP 1.7, а затем включены в стандарт IEEE 1284 (1994 г.). Порт EPP имеет два стандарта EPP 1.7 и EPP 1.9. Между ними есть отличия, которые могут повлиять на работу устройств (см. далее). Скорость передачи данных составляет от от 500 КБ/с до 2 МБ/с. Она достигается тем, что квитирование, стробирование и другие операции формируются схемами порта, а не программно, как в интерфейсе Centronics.

Любители обычно используют порт ЕРР чаще, чем порт с расширенными возможностями (Extended Capabilities Port - ЕСР). Порт ЕРР отличается от порта ЕСР тем, что порт ЕРР генерирует и управляет всеми передачами в/из периферийного устройства. С другой стороны, порт ЕСР требует, чтобы периферийное устройство подтверждало обратный канал и управляло квитированием. Этого трудно достичь обычными простыми схемами и требуется специализированный контроллер или ECP Peripheral Chip.

Аппаратные средства


В режиме EPP каждой линии назначаются другие функции и обозначения, которые приведены в следующей таблице.

Контакт
Сигнал SPP
Сигнал EPP
Вход/Выход
Функция
1
Строб
Write
Выход
Низкий уровень на этой линии показывает Write, а высокий уровень - Read
2-9
Данные 0-7
Данные 0-7
Вход/Выход
Двунаправленная шина данных.
10
Ack
Interrupt
Вход
Линия прерывания. Прерывание возникает по положительному (нарастающему) фронту.
11
Busy
Wait
Вход
Используется для квитирования. Цикл EPP можно начинать при низком уровне, а заканчивается он при высоком уровне.
12
Paper Out / End
Резервный
Вход
Резервный - не используется в квитировании EPP.
13
Select
Резервный
Вход
Резервный - не используется в квитировании EPP.
14
Auto Linefeed
Data Strobe
Выход
При низком уровне показывает передачу данных.
15
Error / Fault
Резервный
Вход
Резервный - не используется в квитировании EPP.
16
Initialize
Reset
Выход
Сброс с низким уровнем активности.
17
Select Printer
Address Strobe
Выход
При низком уровне показывает передачу адреса.
18-25
Земля
Земля
GND
Земля

Сигналы Paper Out, Select и Error не определены в квитировании EPP и соответствующие линии пользователь может использовать по своему усмотрению. Состояния этих линий можно определить в любой момент времени, считывая регистр состояния. К сожалению, резервные выходы отсутствуют, что может вызвать определенные трудности.

Квитирование порта EPP


Чтобы выполнить правильный обмен данными с использованием порта ЕРР, необходимо соблюдать квитирование ЕРР. Поскольку все операции выполняются схемно, квитирование должна использовать только аппаратура, а не программа, как в случае порта SPP. Для инициирования цикла ЕРР программа должна выполнить только одну операцию ввода-вывода в соответствующий регистр ЕРР (подробнее см. далее).

Цикл EPP записи данных




1. Программа записывает в регистр данных EPP (База + 4).
2. Формируется низкий уровень nWrite, показывая операцию записи.
3. Данные помещаются на линии данных 0-7.
4. Выдается строб nData Strobe, если Wait имеет низкий уровень (можно начать цикл).
5. Компьютер ожидает подтверждения - высокого уровня на nWait (можно закончить цикл).
6. Снимается строб nData Strobe.
7. Цикл записи данных EPP заканчивается.

Цикл EPP записи адреса




1. Программа записывает адрес в регистр адреса EPP (База + 3).
2. Формируется низкий уровень сигнала Write, показывающий операцию записи.
3. Адрес помещается на линии данных 0-7.
4. Выдается строб Address Strobe, если Wait имеет низкий уровень (можно начать цикл).
5. Компьютер ожидает подтверждения - высокого уровня на nWait (можно закончить цикл).
6. Снимается строб nAddress Strobe.
7. Цикл записи адреса EPP заканчивается.

Цикл EPP считывания данных




1. Программа считывает регистр данных EPP (База + 4).
2. Выдается строб nData Strobe, если Wait имеет низкий уровень (можно начать цикл).
3. Компьютер ожидает подтверждения - высокого уровня на nWait.
4. Данные считываются с контактов параллельного порта.
5. Снимается строб nData Strobe.
6. Цикл считывания данных EPP заканчивается.

Цикл EPP считывания адреса




1. Программа считывает регистр адреса EPP (База + 3).
2. Выдается строб nAddr Strobe, если Wait имеет низкий уровень (можно начать цикл).
3. Компьютер ожидает подтверждения - высокого уровня на nWait.
4. Данные считываются с контактов параллельного порта.
5. Снимается строб nAddr Strobe.
6. Цикл считывания адреса EPP заканчивается.

Примечание При реализации квитирования EPP 1.7 (до IEEE 1284) стробы данных и адреса можно выдавать для запуска цикла независимо от от состояния Wait. В стандарте EPP 1.9 цикл запускается только при низком уровне Wait. Оба стандарта EPP 1.7 и EPP 1.9 требуют высокого уровня Wait для прекращения цикла.

Программные регистры порта EPP


Порт EPP имеет также новый набор регистров, причем три из них унаследованы т стандартного параллельного порта SPP. В следующей таблице приведены новые и существовавшие регистры.

Адрес
Название порта
Read/Write
База + 0
Порт данных (SPP)
Write
База + 1
Порт состояния Port (SPP)
Read
База + 2
Порт управления (SPP)
Write
База + 3
Порт адреса (EPP)
Read/Write
База + 4
Порт данных (EPP)
Read/Write
База + 5
Не определен (16/32-битовые передачи)
-
База + 6
Не определен (32-битовые передачи)
-
База + 7
Не определен (32-битовые передачи)
-

Как видно, первые три адреса точно такие же, как у регистров порта SPP и функционируют они аналогично. Следовательно, при использовании порта ЕРР можно выводить данные по адресу Базе + 0 точно так же, как в SPP. При подключении принтера и использовании режима совместимости необходимо проверять, занят ли порт, а затем выдавать и снимать строб, используя порты управления и состояния, а затем ожидать подтверждения Ack.

При необходимости взаимодействовать с ЕРР-совместимым устройством нужно просто загрузить передаваемые данные в регистр данных ЕРР по адресу База + 4 и карта сформирует все требуемые сигналы квитирования. Аналогично, при необходимости выдать в устройство адрес следует применять регистр адреса ЕРР по адресу База + 3.

Регистры адреса и данных ЕРР допускают считывание и запись, поэтому для считывания данных из устройства можно использовать эти же регистры. Однако принтерная карта EPP должна инициировать цикл считывания, так как оба строба nData Strobe и nAddress Strobe являются выходами. Устройство может сигнализировать запрос считывания с помощью прерывания и заставить процедуру обслуживания прерывания (Interrupt Service Routine - ISR) выполнить операцию считывания.

Порт состояния имеет одну небольшую модификацию. Бит 0, который зарезервирован в наборе регистров порта SPP, теперь стал битом таймаута (Timeout) порта EPP. Этот бит устанавливается, когда возникает таймаут порта ЕРР. Это происходит, когда сигнал на линии nWait не снимается через примерно 10 мкс (в зависимости от порта) после выдачи сигналов IOW или IOR. Линии сигналов IOW и IOR записи и считывания ввода-вывода имеются в шине ISA.

Режим ЕРР очень сильно зависит от временной диаграммы (timing) шины ISA. Когда выполняется цикл считывания, порт должен предпринять соответствующее квитирование Read/Write и вернуть данные в этом цикле шины ISA. Конечно, этого не происходит в одном цикле ISA, поэтому порт использует сигнал готовности IOCHRDY (I/O Channel Ready) на шине ISA для введения состояний ожидания до завершения цикла. Теперь что произойдет, если запускается Read или Write порта ЕРР, а периферийное устройство не подключено?. Порт никогда не получит подтверждения (nWait) и будет сохранять запросы состояний ожидания, а компьютер блокируется. Поэтому в порту ЕРР поддерживается таймер (watchdog), который настроен примерно на 10 мкс.

Три регистра с адресами База + 5, База + 6 и База + 7 можно использовать для 16- и 32-битовых операций считывания и записи, если порт поддерживает их. Это может сократить число операций ввода-вывода. Параллельный порт может одновременно передавать только восемь битов, поэтому записываемое в параллельный 32- или 16-битовое слово разбивается на байты и передается по восьми линиям данных порта.

Особенности программирования порта EPP


Порт ЕРР имеет только два основных регистра и флажок таймаута. Что же приходится настраивать? До того, как запустить любые циклы порта ЕРР считыванием и записью в порты данных и адреса ЕРР, порт должен быть правильно конфигурирован. В холостом состоянии ЕРР должен иметь свои линии nAddress Strobe, nData Strobe, nWrite и nReset пассивными (высокий уровень). Некоторые порты требуют такой установки перед запуском любого цикла ЕРР. Поэтому первая задача - вручную инициализировать эти линии с помощью регистров порта SPP. Для этого нужно записать в порт управления код XXXX0100.

На некоторых картах, если параллельный порт переведен в инверсный режим, невозможно выполнить цикл записи ЕРР. Поэтому до использования порта ЕРР рекомендуется перевести его в прямой режим. Сброс бита 5 в регистре управления должен привести к правильной работе.

Бит таймаута (Timeout) порта EPP мы уже обсуждали. Когда этот бит установлен, порт может функционировать неправильно. Поэтому рекомендуется всегда считать FFh в цикле адреса или данных. Этот бит должен сбрасываться для надежной работы и должен постоянно контролироваться.

Порт с расширенными возможностями (ECP)


Режим расширенных возможностей разработан фирмами Hewlett-Packard и Microsoft для реализации в качестве Extended Capabilities Port Protocol and ISA Interface Standard. Этот протокол использует дополнительные схемы для генерирования сигналов квитирования так же, как в режиме ЕРР, и работает с большей скоростью, чем порт ЕРР. Однако этот режим лучше работает под Windows, так как может использовать для передачи данных каналы прямого доступа к памяти (Direct Memory Access - DMA). В нем также применяется буфер FIFO для принимаемых и передаваемых данных.

Еще одна возможность ЕСР - сжатие данных в реальном времени. Алгоритм кодирования длинами отрезков (Run Length Encoding - RLE) обеспечивает коэффициент сжатия до 64:1. Это удобно для сканеров и принтеров, в которых значительная часть данных представлена повторяющимися цепочками.

Порт ЕСР поддерживает метод адресации канала (channel addressing). Он не предназначен для использования в устройствах шлейфной цепочки (daisy chain), но позволяет адресовать несколько устройств внутри одного устройства. Примером служат многие современные факс-машины, которые содержат параллельный порт для интерфейса с компьютером. Факс-машину можно разбить на отдельные устройства, например сканер, модем/факс и принтер, причем каждый компонент можно адресовать отдельно, даже если другие устройства не могут воспринимать данные по причине заполненных буферов.

Аппаратные средства


Несмотря на то, что принтерные порты ЕСР используют такой же разъем D25, как и стандартный параллельный порт (SPP), порт ЕСР назначает другие функции контактам (как и порт ЕРР). Поэтому в интерфейсе порта ЕСР применяется и другой метод квитирования.

Порт ЕСР обратно совместим с портами SPP и EPP. При работе в режиме SPP отдельные линии функционируют так же, как в порту SPP, и называются Strobe, Auto Linefeed, Init, Busy и т.д. При работе в режиме ЕРР линии выполняют функции в соответствии с методом, описанном в протоколе порта ЕРР, и используется другой метод квитирования. Когда порт работает в режиме ЕСР, линии определяются следующим образом.

Контакт
Сигнал SPP
Сигнал ECP
Вход/Выход
Функция
1
Strobe
HostCLK
Выход
Низкий уровень на этой линии показывает, что в хосте имеются достоверные данные. При снятии этого сигнала положительный фронт синхронизации должен использоваться для фиксации данных в устройстве.
2-9
Данные 0-7
Данные 0-7
Вход/Выход
Двунаправленная шина данных.
10
Ack
PeriphCLK
Вход
Низкий уровень на этой линии показывает, что устройство имеет достоверные данные. Когда этот сигнал снимается, положительный фронт синхронизации должен использоваться для фиксации данных в хосте.
11
Busy
PeriphAck
Вход
В инверсном направлении высокий уровень показывает цикл данных, а низкий уровень - цикл команды. В прямом направлении действует как PeriphAck.
12
Paper Out / End
nAckReverse
Вход
Низким уровнем устройство подтверждает запрос инверсии (Reverse Request).
13
Select
X-Flag
Вход
Флажок расширяемости (Extensibility Flag).
14
Auto Linefeed
Host Ack
Выход
В прямом направлении высокий уровень показывает цикл данных, а низкий уровень - цикл команды. В инверсном направлении действует как HostAck.
15
Error / Fault
PeriphRequest
Вход
Установленный устройством низкий уровень показывает доступность инверсных данных.
16
Initialize
nReverseRequest
Выход
Низкий уровень показывает передачу данных в инверсном направлении.
17
Select Printer
1284 Active
Выход
Высокий уровень показывает работу хоста в режиме 1284 Transfer Mode. Низкий уровень прекращает этот режим.
18-25
Земля
Земля
GND
Земля

Сигналы на линиях HostAck и PeriphAck показывают, находятся ли на шине данных 0-7 данные или команда. При наличии на этих линиях высокого уровня на шине данных (контакты 2-9) находятся данные. Если реализуется цикл команды, то на соответствующей линии будет низкий уровень; если, например, хост выдает команду, то на линии HostAck будет низкий уровень, а если устройство выдает команду, то на линии PeriphAck будет низкий уровень.

Цикл команды может быть одним из двух - счетчиком RLE или адресом, что определяется битом 7 линий данных (контакт 9). Если бит 7 содержит 0, то остальные данные (биты 0-6) являются счетчиком длины RLE, который применяется в алгоритме сжатия. Но если бит 7 содержит 1, то данные в битах 0-6 являются адресом канала. При отсутствии одного бита номер может быть только значением от 0 до 127.

Квитирование порта ECP


Квитирование порта ЕСР отличается от квитирования порта SPP. Наиболее очевидное отличие состоит в том, что порт ЕСР в любой момент времени может передавать данные в любом направлении, а для этого требуется дополнительная сигнализация. Далее рассмотрено квитирование порта ЕСР для прямого (forward) и инверсного (reverse) направлений.

Прямой цикл данных ECP




1. Хост помещает данные на линии данных.
2. Затем хост показывает цикл данных, выдавая низкий уровень сигнала HostAck.
3. Хост показывает достоверность данных, формируя низкий уровень сигнала HostClk.
4. Периферийное устройство выдает свое подтверждение достоверных данных, выдавая сигнал PeriphAck.
5. Хост выдает высокий уровень сигнала HostClk. Положительный фронт используется для фиксации данных в периферийном устройстве.
6. Периферийное устройство выдает подтверждение байта, снимая сигнал PeriphAck.

Прямой цикл команды ECP




1. Хост помещает данные на линии данных.
2. Затем хост показывает цикл команды, снимая HostAck.
3. Хост показывает достоверность данных, формируя низкий уровень сигнала HostClk.
4. Периферийное устройство выдает подтверждение достоверных данных, формируя сигнал PeriphAck.
5. Хост снимает сигнал HostClk высоким уровнем. Положительный фронт используется для фиксации данных в периферийном устройстве.
6. Устройство выдает подтверждение байта, снимая сигнал PeriphAck.

Инверсный цикл данных ECP




1. Хост устанавливает низкий уровень сигнала nReverseRequest для запроса инверсного канала.
2. Периферийное устройство подтверждает запрос инверсного канала, выдавая низкий уровень сигнала nAckReverse.
3. Устройство помещает данные на линии данных.
4. Затем устройство выбирает цикл данных, формируя высокий уровень сигнала PeriphAck.
5. Устройство показывает достоверные данные низким уровнем сигнала PeriphClk.
6. Хост выдает свое подтверждение достоверных данных высоким уровнем сигнала HostAck.
7. Устройство устанавливает высокий уровень сигнала PeriphClk. Положительный фронт используется для фиксации данных в хосте.
8. Хост выдает свое подтверждение байта, формируя низкий уровень сигнала HostAck.

Инверсный цикл команды ECP




1. Хост устанавливает низкий уровень сигнала nReverseRequest для запроса инверсного канала.
2. Периферийное устройство подтверждает запрос инверсного канала, выдавая низкий уровень сигнала nAckReverse.
3. Устройство помещает данные на линии данных.
4. Затем устройство выбирает цикл команды, формируя низкий уровень сигнала PeriphAck.
5. Устройство показывает достоверные данные низким уровнем сигнала PeriphClk.
6. Хост выдает свое подтверждение достоверных данных высоким уровнем сигнала HostAck.
7. Устройство устанавливает высокий уровень сигнала PeriphClk. Положительный фронт используется для фиксации данных в хосте.
8. Хост выдает свое подтверждение байта, формируя низкий уровень сигнала HostAck.

Сравнение квитирования портов EСP и SPP


Квитирование порта SPP состоит всего из пяти этапов:

  1. Записать байт в порт данных.
  2. Проверить занятость принтера. Если принтер занят, он не будет воспринимать никаких данных, поэтому все записываемые данные теряются.
  3. Сформировать низкий уровень сигнала Strob (контакт 1). Он сообщает принтеру о наличии правильных данных на линиях данных (контакты 2-9).
  4. Примерно через 5 мкс сформировать высокий уровень сигнала Strobe.
  5. Проверить подтверждение Ack от устройства.

С другой стороны, квитирование порта ЕСР требует больше этапов. Поэтому кажется, что порт ЕСР будет работать медленнее порта SPP. Однако это не так, поскольку управление всеми этапами квитирования реализовано схемно. Если бы квитирование реализовалось программно, оно было бы значительно медленнее квитирования порта SPP.

Кодирование RLE


Ранее вкратце говорилось, что протокол порта ЕСР включает в себя простой алгоритм сжатия кодирования длинами отрезков (Run Length Encoding - RLE). Он обеспечивает максимальный коэффициент сжатия до 64:1 и работает, посылая повторяющиеся байты как счетчики отрезков и одну копию байта. Счетчик отрезка определяет, сколько раз должен быть повторен последующий байт.

Если, например, передается цепочка из 25 букв 'А', то первым должен быть передан байт счетчика отрезка, равный 24, а затем байт 'A'. Принимающее устройство при приеме счетчика длины отрезка (Run Length Count), должно расширить (повторить) следующий байт число раз, определяемое счетчиком.

Байт счетчика длины отрезка должен отличаться от других байтов в тракте данных. Он посылается как команда в порт адреса FIFO (Address FIFO Port). Байты, посылаемые в этот регистр, могут быть счетчиком длины отрезка или адресом. Они различаются старшим битом 7. Если бит 7 содержит 1, то остальные семь битов (0-6) являются адресом канала. Если бит 7 сброшен в 0, то младшие семь битов являются счетчиком длины отрезка. В этом случае адреса каналов и счетчики длин отрезков ограничены семью битами (значения от 0 до 127).

Программные регистры порта ECP


В следующей таблице приведены регистры порта ЕСР. Первые три регистра совпадают с регистрами порта SPP. Отметим, однако, появление бита разрешения двунаправленного порта (бит 5 порта управления). Этот бит показывает текущее направление порта ЕСР и влияет на биты FIFOpFull FIFOpEmpty в регистре ECR (см. далее).

Адрес
Название порта
Read/Write
База + 0
Порт данных (SPP)
Write
Адрес ECP FIFO (режим ECP)
Read/Write
База + 1
Порт состояния (все режимы)
Read/Write
База + 2
Порт управления (все режимы)
Read/Write
База + 400h
Данные FIFO (параллельный порт режима FIFO)
Read/Write
Данные FIFO (режим ECP)
Read/Write
Проверка FIFO (режим Test)
Read/Write
Регистр конфигурирования A (режим конфигурирования)
Read/Write
База + 401h
Регистр конфигурирования В (режим конфигурирования)
Read/Write
База + 402h
Расширенный регистр управления (используется всеми режимами)
Read/Write

Расширенный регистр управления (ECR)


Бит
Функция
7:5
Выбирают текущий режим работы
000
Стандартный режим
001
Режим байтов
010
Режим FIFO параллельного порта
011
Режим ECP FIFO
100
Режим EPP
101
Зарезервированы
110
Режим проверки FIFO
111
Режим конфигурирования
4
Бит прерывания ECP
3
Бит разрешения DMA
2
Служебный бит ECP
1
FIFO Full
0
FIFO Empty
   

Наиболее важным регистром порта ЕСР является расширенный регистр управления (Extended Control Register - ECR), поэтому рассмотрим вначале его работу. Этот регистр определяет, в каком режиме будет работать порт ЕСР, а также задает состояние буфера FIFO. Функции этого регистра приведены в следующей таблице.

Три старших бита расширенного регистра управления определяют режим работы. Имеются семь возможных режимов работы, но не все порты поддерживают все режимы. Например, некоторые порты не поддерживает режим EPP. В следующей таблице приведены более подробные сведения о режимах работы.

Стандартный режим Установка этого режима заставляет порт ECP действовать как стандартный параллельный порт без возможности двунаправленной работы.
Режим байтов Действует как SPP в двунаправленном режиме. Бит 5 переводит порт в инверсный режим.
Режим FIFO параллельного порта В этом режиме все данные, записываемые в FIFO данных, будут передаваться в периферийное устройство с использованием квитирования SPP. Необходимое квитирование реализуется схемно. Этот режим удобен для не-ECP устройств, например принтеров. Предоставляются некоторые возможности ECP, например буферы FIFO и схемное генерирование квитирования, но с квитированием SPP, а не с квитированием ECP.
Режим ECP FIFOСтандартный режим для порта ECP. В этом режиме используется квитирование ECP. - Когда режим ECP установлен через BIOS и регистр ECR устанавливается на режим ECP FIFO Mode (011), регистры SPP могут исчезнуть.
Режим EPP/ЗарезервированРазрешается режим EPP, если он доступен. Под BIOS, если установлен режим ECP, то более чем вероятно, этот режим не является опцией. Но если BIOS установлен на режим ECP и EPP1.x, то будет разрешен EPP 1.x. - Согласно Extended Capabilities Port Protocol and ISA Interface Standard этот режим определяется поставщиком.
ЗарезервированПока зарезервирован. - Согласно Extended Capabilities Port Protocol and ISA Interface Standard этот режим определяется поставщиком.
Режим теста FIFOВ этом режиме все данные, записываемые в регистр Test FIFO, будут помещаться в FIFO, а любые данные, считываемые из регистра Test FIFO, будут считываться из буфера FIFO. Биты состояния FIFO Full/Empty будут отражать их истинное значение, поэтому в этом режиме можно определить некоторые характеристики FIFO, например его глубину.
Режим конфигурированияВ этом режиме становятся доступными два регистра конфигурирования cnfgA и cnfgB по их адресам.

Как показано ранее, когда порт установлен на работу в стандартном режиме, он действует как порт SPP без двунаправленных передач данных. Если требуется двунаправленная передача, нужно установить режим байтов. Режимы FIFO параллельного порта и ECP FIFO используют схемы для генерирования необходимых сигналов квитирования. Единственное различие между ними состоит в том, что режим FIFO параллельного порта использует квитирование порта SPP и может быть использован для работы с SPP-принтером. Режим ECP FIFO использует квитирование порта ЕСР.

Режим проверки FIFO можно использовать для тестирования емкости буферов FIFO, а также проверки правильности их функционирования. В этом режиме любой байт, который записывается в регистр TEST FIFO (База + 400h), помещается в буфер FIFO, а любой байт, считываемый из этого регистра, берется из буфера FIFO. Это можно использовать вместе с битами FIFO Full и FIFO Empty расширенного регистра управления ECR для определения емкости буфера FIFO. Глубина FIFO обычно составляет около 16 байтов.

Другие биты регистра ECR также играют важную роль в работе порта ЕСР. Бит прерывания (бит 4) разрешает использование прерываний, а бит разрешения DMA (бит 3) разрешает применять прямой доступ к памяти. Служебный бит ЕСР (бит 2) показывает, инициирован ли запрос прерывания. Если он есть, этот бит будет установлен. Сброс этого бита осуществляется по-разному в разных микросхемах. Некоторые требуют сбросить бит, т.е. записать в него 0, а другие сбрасывают при считывании из регистра.

Бит FIFO Full (бит 1) и FIFO Empty (бит 0) показывают состояние буфера FIFO. Эти биты зависят от направления, поэтому нужно учитывать бит 5 регистра управления. Если бит 0 (FIFO Empty) установлен, то буфер FIFO пустой, а если установлен бит 1, то буфер FIFO полный. Если же ни один из этих битов не установлен, то в FIFO имеются данные, но буфер пока не заполнен. Эти биты можно использовать в режиме проверки FIFO для определения емкости буфера FIFO.

Регистр конфигурирования А (cnfgA)


Регистр конфигурирования А (cnfgA) представляет собой один из двух регистров конфигурирования порта ЕСР. Регистры конфигурирования доступны только в режиме конфигурирования. Адрес регистра cnfgA равен База + 400h. Формат регистра cnfgA приведен в следующей таблице.

Бит
Функция
7
1
Прерывания запускаются уровнем
0
Прерывания запускаются фронтом
6:4
00h
Воспринимает слова шириной макс. 16 битов
01h
Воспринимает слова шириной макс. 8 битов
02h
Воспринимает слова шириной макс. 32 бита
03h:07h
Зарезервированы для расширения
3
Зарезервирован
2
Восстановление хоста : Байт конвейера/передатчика включен в FIFO?
0
В прямом направлении один байт в конвейере передатчика не влияет на FIFO Full.
1
В прямом направлении один байт в конвейере передатчика учитывается как часть FIFO Full.
1:0
Восстановление хоста : Непереданные байты оставлены в FIFO
00
Полное слово
01
1 достоверный байт
10
2 два достоверных байта
11
3 достоверных байта
   

Регистр конфигурирования А можно считать для получения дополнительной информации о ЕСР. Бит 7 показывает, генерирует ли карта прерывания уровнем или фронтом. Это зависит от типа используемой картой шины. Биты 6:4 показывают ширину шин внутри карты. Некоторые карты используют только 8-битовый тракт данных, а другие - 16- или 32-битовые. Для получения максимальной эффективности от карты программа должна считать состояние этих битов, чтобы определить максимальный размер слова, выводимого в порт.

Три младших бита применяются для восстановления хоста (Host Recovery). Чтобы произвести восстановление при появлении ошибки, программа должна знать, сколько байтов передано, определяя, остались ли байты в FIFO. Некоторые реализации могут учитывать ожидающий передачи байт в регистре передатчика как часть состояния FIFO Full, а другие не учитывают. Бит 2 определяет ту или иную ситуацию.

Еще одна проблема связана с тем, что выход параллельных портов имеет ширину только восемь битов, а программа может использовать команды 16- или 32-битового ввода-вывода. В этом случае может быть послана часть слова порта. Поэтому биты 0 и 1 показывают число достоверных байтов, оставшихся в FIFO, и их можно передать повторно.

Регистр конфигурирования В (cnfgВ)


Регистр конфигурирования В, как и регистр конфигурирования А, доступен только в режиме конфигурирования. Его адрес в этом режиме равен База + 401h. Формат регистра cnfgB приведен в следующей таблице.

Бит
Функция
7
1
Сжимать выводимые данные по алгоритму RLE
0
Не сжимать данные
6
Состояние прерывания - показывает текущее состояние контакта IRQ
5:3
Выбирает или отображает состояние линии запроса прерывания IRQ
000
Прерывание выбрано с помощью перемычки
001
IRQ 7
010
IRQ 9
011
IRQ 10
100
IRQ 11
101
IRQ 14
110
IRQ 15
111
IRQ 5
2:0
Выбирает или отображает состояние канала DMA, используемого картой принтера
000
Использует 8-битовый канал DMA, выбранный перемычкой
001
Канал 1 DMA
010
Канал 2 DMA
011
Канал 3 DMA
100
Использует 16-битовый канал DMA, выбранный перемычкой
101
Канал 5 DMA
110
Канал 6 DMA
111
Канал 7 DMA
   

Регистр конфигурирования В (cnfgB) может быть комбинацией доступа считывания-записи. Некоторые порты конфигурируются программно с установкой ресурсов IRQ и DMA из регистра. Другие конфигурируются через BIOS или с помощью перемычек на карте, поэтому из регистра можно только считывать.

Бит 7 определяет, производить или нет сжатие выводимых данных по алгоритму RLE: 1 - хост сжимает данные перед передачей, 0 - данные передаются в устройство сырыми (несжатыми). Бит 6 возвращает состояние контакта IRQ. Его можно использовать для диагностики конфликтов, так как он будет показывать не только состояние IRQ параллельного порта, но и другого устройства, использующего данную линию IRQ.

Биты 5:3 показывают состояние присваивания порту линии IRQ, а биты 2:0 - состояние присваивания порту канала DMA. Как говорилось ранее, эти поля можно считывать и записывать. Для исчезающих плат с перемычками эти биты просто показывают ресурсы как "Jumpered" или правильные номера линий. Конечно, в этом случае их можно только считывать.






Наверх