Аппаратные интерфейсы ПК | страница 24



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

1.3.6. Согласование режимов IEEE 1284

ПУ в стандарте IEEE 1284 обычно не требуют от контроллера реализации всех предусмотренных этим стандартом режимов. Для определения режимов и методов управления конкретным устройством стандарт предусматривает последовательность согласования (negotiation sequence). Последовательность построена так, что старые устройства, не поддерживающие IEEE 1284, на нее не ответят, и контроллер останется в стандартном режиме. Периферия IEEE 1284 может сообщить о своих возможностях, и контроллер установит режим, удовлетворяющий и хост, и ПУ.

Во время фазы согласования контроллер выставляет на линии данных байт расширяемости (extensibility byte), запрашивая подтверждение на перевод интерфейса в требуемый режим или прием идентификатора ПУ (табл. 1.9). Идентификатор передается контроллеру в запрошенном режиме (любой режим обратного канала, кроме EPP). ПУ использует сигнал >Xflag (>Select в терминах SPP) для подтверждения запрошенного режима обратного канала, кроме полубайтного, который поддерживается всеми устройствами IEEE 1284. Бит >Extensibility Link request послужит для определения дополнительных режимов в будущих расширениях стандарта.


Таблица 1.9. Биты в байте расширяемости

БитОписаниеДопустимые комбинации бит [7:0]
7Request Extensibility Link — зарезервирован1000 0000
6Запрос режима ЕРР0100 0000
5Запрос режима ЕСР с RLE0011 0000
4Запрос режима ЕСР без RLE0001 0000
3Зарезервировано0000 1000
2Запрос идентификатора устройства с ответом в режиме: 
полубайтный0000 0100
байтный0000 0101
ЕСР без RLE0001 0100
ЕСР с RLE0011 0100
1Зарезервировано0000 0010
0Запрос полубайтного режима0000 0001
noneЗапрос байтного режима0000 0000

Последовательность согласования (рис. 1.6) состоит из следующих шагов.

1. Хост выводит байт расширяемости на линии данных.

2. Хост устанавливает высокий уровень сигнала >SelectIn# и низкий — >AutoFeed#, что означает начало последовательности согласования.

3. ПУ отвечает установкой низкого уровня сигнала >Ack# и высокого — >Error#, >PaperEnd и >Select. Устройство, «не понимающее» стандарта 1284, ответа не даст, и дальнейшие шаги не выполнятся.

4. Хост устанавливает низкий уровень сигнала