Параллельные порты рс. Устранение ошибок в портах

Для того чтобы передать информацию какому-либо устройству или получить ее от этого устройства, компьютеру необходимо специально организовать процесс обмена данными.

Организация операций, связанных с вводом и выводом информации, подразумевает следующее:

    соблюдение одинакового кода передаваемых данных (то есть «разговор на одном языке»);

    согласование скоростей передачи и приема информации (или «диалог в одинаковом темпе»);

    единство формата обмена данными (то есть способ дробления их на фрагменты, передаваемые за один цикл);

    стандартный протокол специальных управляющих сигналов (команды, «понятные» принимающему и передающему устройству) .

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

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

Помимо оперативной памяти, процессор может адресовать и другую область, известную как адресное пространство ввода-вывода. Каждый порт ввода-вывода имеет уникальное множество адресов ввода-вывода. Микропроцессор включает две команды: IN и OUT, используемые для чтения и записи данных в адресном пространстве ввода-вывода, а также другие инструкции, управляющие портами ввода-вывода (эти команды будут рассмотрены при изучении языка ассемблера).

Порты ввода/вывода, соответственно способам передачи, подразделяют на параллельные и последовательные.

В параллельном порту (Parallel Port) в одном направлении одновременно передаются сразу 8 бит (1 байт) информации. Поэтому разъем параллельного порта содержит восемь линий для передачи данных, а на компьютере с двунаправленным параллельным портом разъем дополнительно восемь линий используются для приема данных.

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

Интерфейс Centronics в компьютере использует для обмена данными 25-контактный «материнский» разъем (контактные гнезда под штыри кабеля).

Существуют следующие типы параллельного порта:

    стандартный;

    улучшенный параллельный порт EPP (Enhanced Parallel Port);

    порт с расширенными функциями ECP (Extended Capability Port).

Стандартный параллельный порт предназначен только для односторонней передачи данных от компьютера к принтеру. Он обеспечивает максимальную скорость передачи данных от 120 до 200 Кбайт/с.

Порт EPP является двунаправленным, то есть обеспечивает передачу 8 бит данных в обоих направлениях. Это избавляет центральный процессор от необходимости выполнения медленных команд типа IN и OUT, позволяя программе непосредственно заниматься пересылкой данных. Порт EPP передает и принимает данные почти в 6 раз быстрее стандартного параллельного порта, в основном, за счет наличия буферной памяти. Специальный режим (с использованием прямого доступа в память – DMA) позволяет порту EPP передавать блоки данных непосредственно из оперативной памяти в последовательный порт, минуя процессор. При использовании соответствующего программного обеспечения порт EPP может принимать и передавать данные со скоростью до 2 Мбайт/с. Подобно интерфейсу SCSI порт EPP позволяет подключать в цепочку до 64 периферийных устройств.

Дальнейшим развитием порта EPP явился порт ECP . Он обладает теми же возможностями, что и порт EPP, но количество устройств увеличено до 128. Кроме того, в порту ECP реализована такая важная функция, как сжатие данных.

Для сжатия данных используется метод RLE (Run Length Encoding), в котором длинная последовательность одинаковых символов передается двумя байтами: один байт определяет повторяющийся символ, другой – число повторений. Стандарт ECP допускает сжатие и распаковку данных как программно (с помощью драйвера), так и аппаратно (схемой порта).

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

Хотя в операционной системе предусмотрено три логических имени для параллельных портов – LPT1 (синоним PRN), LPT2 и LPT3 обычно в комплектацию компьютера входит один параллельный порт (в современных компьютерах контроллер параллельного порта располагается на материнской плате)

Параллельный порт чаще всего используется для подключения принтера. Однако к нему можно подключать и другие устройства, например, сканеры, внешние дисководы, стримеры и дисководы CD. Параллельный порт можно использовать также для обмена данными между двумя компьютерами.

Параллельный порт обеспечивает довольно высокую скорость передачи, поскольку эта передача осуществляется побайтно. Однако при большой длине кабеля или при не очень интенсивном обмене данными удобнее оказывается последовательный порт.

Последовательный порт (Serial Port) передает в одном направлении одновременно всего лишь 1 бит информации. Данные могут передаваться через этот порт как от ПК к внешнему устройству, так и наоборот.

Последовательные порты компьютера обычно соответствуют международному стандарту RS-232C (Reference Standard 232 версии С), поэтому к этому порту можно подсоединить любое устройство, которое также ориентировано на этот стандарт (например, мышь, модем, последовательный принтер или последовательный порт другого компьютера). Этот интерфейс использует 9 каналов связи: один из них служит для передачи информации от компьютера, другой – для приема данных от периферийного устройства. Оставшиеся 7 каналов используются для управления самим процессом обмена данными.

Последовательный порт состоит из UART-микросхемы (Universal Asynchronous Receiver/Transmitter – универсальный асинхронный приемник/передатчик) и некоторых поддерживающих компонентов. Эта микросхема принимает байты данных от шины компьютера, преобразует их в строку битов, добавляет необходимые биты кадровой синхронизации и затем выполняет передачу данных, а также выполняет обратные действия по приему строки данных.

Современные микросхемы UART оснащены буферной памятью и обеспечивают скорость передачи данных до 115 Кбит/с.

Данные при последовательной передаче разделяются служебными посылками, такими, как стартовый бит и стоп-бит. Эти биты указывают на начало и конец передачи последовательных бит данных. Данный метод передачи позволяет осуществить синхронизацию между приемной и передающей стороной, а также выровнять скорость обмена данными.

Для идентификации и распознавания ошибок при последовательной передаче в состав посылки дополнительно может включаться бит контроля четности. Значение бита контроля четности определяется двоичной суммой всех передаваемых битов данных. В режиме, когда бит контроля четности четный (Even Parity), значение бит контроля четности равно 0, если сумма битов четная, и 1 – в противном случае. Биты контроля четности имеют инверсные (обратные) значения (соответственно 1 или 0), если бит контроля четности нечетный (Odd Parity).

Стандартная комплектация компьютера содержит два последовательных порта. В современных компьютерах контроллеры последовательных портов, также, как и контроллер параллельного порта, располагается на материнской плате. Отличие разъема последовательного порта от параллельного состоим в том, что этот разъем имеет контактные штыри, а не гнезда («отцовский» разъем). В старых компьютерах использовался один 25-контактный и один 9-контактный разъем, в современных компьютерах – два 9-контактных разъема. Длина кабеля последовательного порта ограничена 18 м. Основным устройством, подключаемым к последовательному порту, является модем.

Некоторые компьютеры, особенно ориентированные на коммуникационные приложения, могут иметь последовательные порты, выполненные по другим стандартам (например, RS-449A или RS-613), имеющие более высокую скорость передачи данных на более дальние расстояния.

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

Параллельная связь означает, что все 8 бит (или 1 байт) пересылаются и передаются не один за другим, а одновременно (параллельно) или, точнее, каждый по своему проводу. Принцип параллельной передачи данных становится очевидным, если рас­смотреть кабель, подсоединенный к разъему параллельного ин­терфейса, например кабель принтера. Он значительно толще, чем последовательный кабель мыши, поскольку кабель для параллель­ной передачи данных должен как минимум содержать восемь про­водов, каждый из которых предназначен для передачи одного бита.

Параллельные интерфейсы разрабатывает фирма Centronics, поэтому параллельный интерфейс часто называют интерфейсом Centronics.

Параллельный интерфейс для принтера обычно обозначают LPT (Line Printer). Первый подключенный принтер обозначается как от LPT1, а второй - как от LPT2.

Существуют несколько типов параллельных портов: стандарт­ный, ЕРР и ЕСР.

Стандартный параллельный порт предназначен только для од­носторонней передачи информации от ПК к принтеру, что зало­жено в электрической схеме порта. Он обеспечивает максималь­ную скорость передачи данных от 120 до 200 Кбайт/с.

Порт.ЕРРявляется двунаправленным, т.е. обеспечивает парал­лельную передачу 8 бит данных в обоих направлениях и полнос­тью совместим со стандартным портом. Порт ЕРР передает и при­нимает данные почти в шесть раз быстрее стандартного парал­лельного порта, чему способствует то, что порт ЕРР имеет бу­фер, сохраняющий передаваемые и принимаемые символы до момента, когда принтер будет готов их принять. Специальный режим позволяет порту ЕРР передавать блоки данных непосред­ственно из RAM PC в принтер и обратно, минуя процессор. При использовании надлежащего программного обеспечения порт ЕРР может передавать и принимать данные со скоростью до 2 Мбит/с.

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


Использование преимуществ функциональных возможностей портов ЕСР и ЕРР возможно при наличии компьютера, оборудо­ванного одним из этих стандартов.

Последовательная связь осуществляется побитно: от­дельные биты пересылаются (или принимаются) последователь­но один за другим по одному проводу, при этом возможен обмен данными в двух направлениях, прием и передача данных осуще­ствляются с одинаковой тактовой частотой. Для последователь­ных интерфейсов выбор подключаемых устройств значительно шире, поэтому большинство ПК обычно оборудовано двумя ин­терфейсными разъемами для последовательной передачи данных. В качестве стандартного обозначения для последовательного интерфейса чаще всего используют RS-232, RS-422, RS-465. Разъемы последовательного интерфейса на ПК представляют собой 9-контактный (вилка) Sub-D или 25-контактный (вилка) Sub-D.

Для установления связи между двумя последовательными ин­терфейсами предварительно необходимо сконфигурировать их со­ответствующим образом, т.е. указать, как будет осуществляться обмен данными: скорость обмена, формат данных, контроль чет­ности и т. п. Аппаратное конфигурирование интерфейса путем со­ответствующей установки джамперов или переключателей неудоб­но, поскольку приходится вскрывать корпус ПК. Обычно конфи­гурирование последовательного интерфейса осуществляется про­граммным способом, тем более что среда Windows предоставляет такую возможность.



За многолетнюю историю развития персональных компьютеров параллельный порт (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 был вначале введен для параллельных портов на первых видеокартах. После того, как параллельные порты были вынесены с видеокарт, этот адрес исчез. Впоследствии он появился как вариант для параллельных портов, интегрированных в материнские платы, где конфигурацию можно изменять с помощью 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.

Для интерфейса с портом вместо имени часто используется базовый адрес, а не имена 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). При считывании из порта вводится последний переданный байт. В случае двунаправленного порта (см. далее) по этому адресу находятся принятые данные.

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

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

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

Порт управления (базовый адрес + 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 стандартизованы компании Microsoft.

Биты Функция
7:5
000 Стандартный режим
001 Режим байтов
010
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 . В следующей таблице приведены более подробные сведения о режимах работы.

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

Стандартный режим
Режим байтов
Режим FIFO параллельного порта
Режим ECP FIFO
Режим EPP/Зарезервирован Согласно Extended Capabilities Port Protocol and ISA Interface Standard
Зарезервирован Пока зарезервирован. - Согласно
Режим теста FIFO
Режим конфигурирования

Если режим 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 Резервный Вход
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 имеет низкий уровень (можно начать цикл).

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 имеет низкий уровень (можно начать цикл).


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. В следующей таблице приведены новые и существовавшие регистры.

Как видно, первые три адреса точно такие же, как у регистров порта 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


2. Затем хост показывает цикл данных, выдавая низкий уровень сигнала HostAck.

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

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

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

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




4. Затем устройство выбирает цикл данных, формируя высокий уровень сигнала PeriphAck.




Инверсный цикл команды 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" или правильные номера линий. Конечно, в этом случае их можно только считывать.

Параллельный порт (сокращенное название – LPT) появился на самом первом IBM PC. Иногда его называют Centronics – по имени фирмы-разработчика. Параллельный порт использовался раньше преимущественно для подключения принтеров.

Современные принтеры обычно подключаются к компьютеру через USB (см. главу 10), но многие модели имеют разъем для подключения LPT-кабеля (кабеля параллельного порта).

Научимся находить разъемы параллельного порта. На рис. 9.1 изображен LPT-разъем на принтере Lexmark E321 – довольно современная модель (принтер куплен в прошлом году). Под ним – USB-разъем с подключенным USB-кабелем. Это говорит о том, что в данный момент принтер подключен к компьютеру через USB.


Рис. 9.1. LPT-разъем на принтере

Если бы принтер подключался к параллельному порту компьютера, то нам бы понадобился кабель, изображенный на рис. 9.2.


Рис. 9.2. Кабель

На рис. 9.3 показана материнская плата. Самый большой разъем, изображенный на этом рисунке, – параллельный порт. Обычно он окрашен для подключения устройств к параллельному порту компьютера в розовый цвет. Как различить последовательный и параллельный порты, одинаковые по размерам? Разъем параллельного порта имеет тип «мама», а последовательного порта – «папа». Другими словами, даже если вы перепутаете цвета (последовательный порт обычно окрашивается в синий цвет), вы не сможете подключиться к последовательному порту с помощью LPT-кабеля.


Рис. 9.3. Параллельный и последовательный порты

К параллельному порту, кроме принтера, можно подключить:

Некоторые носители данных, например внешние приводы CD-ROM, магнитные накопители «повышенной» емкости (раньше повышенной емкостью считалось 120 Мб);

Стримеры – устройства хранения данных на магнитной ленте. Сейчас они практически не используются, а раньше часто использовались для создания резервных копий на серверах предприятий – ведь магнитная лента стоила копейки по сравнению с другими носителями информации и позволяла записывать большие на то время объемы информации (несколько гигабайтов);

Сканеры старых образцов (современные подключаются через USB).

Откровенно говоря, я сомневаюсь, что сегодня вам придется воспользоваться параллельным портом, но такая вероятность есть – может быть, у вас есть старенький принтер, который еще хорошо работает, но подключается только к LPT-порту. Тогда вы должны знать о режимах работы параллельного порта (режим работы порта обычно выбирается в BIOS):

SPP (Standard Parallel Port) – стандартный режим параллельного порта. В данном режиме разрешается только односторонняя передача данных от компьютера к периферийному устройству, подключенному к порту. Скорость передачи данных – 200 Кбит/с;

EPP (Enhanced Parallel Port) – расширенный режим. Разрешен двусторонний обмен данными. Скорость работы – до 2 Мбит/с. Разрешается подключение до 64 периферийных устройств (в цепочку);

ЛЕКЦИЯ 7. ПАРАЛЛЕЛЬНЫЕ И ПОСЛЕДОВАТЕЛЬНЫЕ ПОРТЫ

МПС работает с внешними устройствами (ВУ), от ВУ она получает информацию и обработанную информацию передает на ВУ. В качестве ВУ может служить любой объект управления или источник информации (различные кнопки, датчики, микросхемы приемников, синтезаторов частот, дополнительной памяти, исполнительные механизмы, двигатели, реле и т.д.). Все ВУ подключаются к МП с помощью параллельных или последовательных портов.

Параллельные порты позволяют осуществить параллельный обмен информацией между МП и ВУ. С точки зрения ВУ порт представляет собой обычный источник или приемник информации со стандартными цифровыми логическими уровнями (обычно ТТЛ), а с точки зрения МП - это ячейка памяти, в которую можно записывать данные (из МП) или в которой появляется информация (от ВУ). Параллельные порты позволяют согласовывать низкую скорость работы ВУ и высокую скорость работы системной шины МП.

Порты ввода. В зависимости от направления передачи данных параллельные порты называются портами ввода, вывода или портами ввода – вывода (если они двунаправленные). На рисунке 7.1 приведена функциональная схема порта ввода.

В качестве порта ввода обычно используются схемы с третьим состоянием - шинным формирователем (ШФ). Из порта ввода возможно только чтение информации. Выход ШФ подключается к системной шине. Значение сигнала с внешнего вывода порта считывается по сигналу "RD".Чтобы попасть именно на заданное ВУ в составе порта ввода-вывода всегда присутствует дешифратор адреса.

Рис. 7.1. Функциональная схема порта ввода

Порт вывода. Функциональная схема порта вывода приведена на рисунке 7.2.

Рис. 7.2. Функциональная схема порта вывода

В качестве порта вывода может быть использован параллельный регистр. В порт вывода возможна только запись. Данные с внутренней шины микроконтроллера записываются в регистр по сигналу "WR". Выходы "Q" регистра могут быть использованы как источники логических уровней для управления ВУ.

Во многих МП и МК для портов выделяется отдельное адресное пространство и, соответственно, отдельные команды. Например, ……

Порты ввода-вывода. Параллельные порты могут быть двунаправленными. В МК, например, параллельные порты являются встроенными и двунаправленными. Типичная схема двунаправленного порта ввода/вывода (одной линии) МК приведена на рис. 7.3.



Рис. 7.3. Типовая схема одного вывода двунаправленного порта

ввода - вывода МК.

Дешифратор адреса разрешает работу именно этого порта – разрешение на ввод или вывод. Схема содержит триггер данных и триггер управления. Триггер управления разрешает вывод данных на внешний вывод, если подан управляющий сигнал WR. В современных МК, как правило, обеспечивается индивидуальный доступ к триггерам данных и управления, что позволяет использовать каждую линию независимо в режиме ввода или вывода.



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

Для МК в качестве параметра приводят число линий ввода -вывода. Линии ввода – вывода объединены в многоразрядные (чаще

8-разрядные) параллельные порты ввода/вывода. В памяти МК каждому порту ввода/вывода соответствует свой адрес регистра данных.

Обращение к регистру данных порта ввода/вывода в некоторых МК производится теми же командами, что и обращение к памяти данных. Во многих МК отдельные разряды портов могут быть опрошены или установлены командами битового процессора.

Каждый порт обычно имеет 3 регистра. Например, если имеем дело с портом В, имеется регистр данных порта (PORTB ), регистр направления порта (DDRB) и регистр PINB , с которого считываются сигналы на внешних контактах порта.

При выводе информация на канале фиксируется и сохраняется до ее смены в выходном регистре порта (до следующей команды OUT, адресованной к этому каналу). При вводе же информация не фиксируется.

Параллельный обмен является быстродействующим, однако характеризуется небольшим расстоянием передачи (1 – 2 метра).

Уровни сигналов и нагрузочная способность. Согласование между собой уровней сигналов портов и внешних микросхем не представляет трудностей, так как практически все современные МС по входу и выходу согласованы с TTЛ уровнями. Если же это не так, то для согласования нестандартных уровней с TTЛ уровнями выпускаются специальные МС.

Дело не только в уровнях сигналов согласуемых МС, но и нагрузочной способности. Необходимо знать нагрузочную способность портов и в случае необходимости «умощнять» выход. В качестве примера на рисунке 7.4. показано подключение светодиодного индикатора.

Рис. 7.4. Подключение одиночного светодиодного индикатора.

Транзистор в схеме служит для увеличения тока параллельного порта, при помощи которого МП зажигает и гасит светодиодный индикатор.

8.2. ПОСЛЕДОВАТЕЛЬНЫЕ ИНТЕРФЕЙСЫ (ПОРТЫ).

Последовательная связь. В настоящее время наиболее распространенным способом обмена данными в МПС является последовательная. Последовательно связываются между собой микропроцессоры (микроконтроллеры); МП и ПЭВМ; МП и интеллектуальные датчики; МП и другие МС на плате.


Рис. 7.5. Последовательная связь между передатчиком и приемником

В случае последовательной связи байт данных передается по единственному проводу бит за битом (рис. 7.5). Очевидное преимущество последовательной передачи данных состоит в том, что она требует небольшого количества линий связи.

Последовательная связь может быть однонаправленная (симплексная), двунаправленная с разделением во времени (полудуплексная) и двунаправленная (дуплексная).

Существует 2 типа последовательной связи: асинхронная и синхронная. Если передача данных нерегулярная, то осуществляется асинхронный обмен. Если обмен осуществляется большими массивами, то используется синхронная передача. Кадр асинхронного обмена представлен на рис. 7.6.


Рис 7.6. Кадр асинхронной передачи

В этом режиме на линии поддерживается уровень «1» пока не передается информация. При начале передачи на линию поступает стартовый бит, равный «0», затем от 5 до 8 информационных бит, за ними может следовать (или не следовать) бит паритета. Передача символа завершается одним или двумя стоповыми битами, равными «1». После этого снова может передаваться стартовый бит и следующий символ, или же, при отсутствии информации, на линии устанавливается уровень «1». Каждый раз при передаче байта происходит ресинхронизация.

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

При синхронной передаче должен быть отдельный канал синхронизации. Выборка данных на входе приемника и изменение данных на выходе передатчика синхронизируется от одного и того же тактового сигнала (рисунок 7.7). Каждый информационный кадр стробируется синхросигналом. Скорость передачи в синхронном режиме выше из-за отсутствия служебных бит.

Скорость передачи по последовательному каналу измеряется в битах в секунду (в бодах) и может доходить до десятков Мбит/с.

Рис. 7.7. Синхронная передача данных

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

Кроме преобразования кодов контроллеры позволяют:

– изменять число информационных бит в кадре,

– изменять скорость передачи информации,

– контролировать ошибки и т.д.

В качестве примера можно привести контроллеры последовательной связи USART – универсальный синхронно-асинхронный приемо-передатчик. Он встраивается в МК (в МПС может быть выполнен в виде отдельной МС) и выполняет все необходимые процедуры преобразования кодов. Может работать в синхронном и асинхронном режимах. Обеспечивает дуплексный режим связи, детектирование стартовых посылок, ошибок четности и формата. Единица обмена - символ, буква, цифра, любой другой знак. Он кодируется последовательностью из 5-8 бит. Максимальная скорость обмена информацией в асинхронном режиме - 9,6 кбит/с, в синхронном - 56 кбит/с.

Последовательная связь с ПЭВМ. Частоинформация должна передаваться из МК в ПЭВМ, например, в системах сбора информации. Первым и наиболее удачным среди последовательных интерфейсов оказался RS-232 , до настоящего времени являющийся неотъемлемой частью любого РС - совместимого компьютера в виде СОМ - порта.

Интерфейс RS-232C разработан в 1969 году и до сих пор активно используется для синхронной и асинхронной последовательной связи при двухточечном соединении, в полудуплексном и дуплексном режимах обмена. При передаче используются уровни сигналов ±12 В. Скорость передачи данных составляет от 50 до 115 кбод на расстояние до 15 м.

Различными фирмами выпускается широкая номенклатура микросхем, предназначенных для преобразования ТТЛ/КМОП - уровней в уровни RS-232 и обратно. Большинство из них имеют встроенный преобразователь напряжения и работают от одного источника питания +5 В. Различные типы микросхем могут отличаться нагрузочной способностью, величиной емкостной нагрузки, типом корпуса.

RS-232 имеют низкую защищенность от синфазной помехи. Существенными преимуществами в этом плане обладают двухточечный интерфейс RS-422 и его магистральный аналог RS-485, в которых сигнал передается в дифференциальном виде. Но эти интерфейсы отсутствуют в стандартной комплектации компьютеров и микроконтроллеров. Поэтому применение RS-422 и RS-485 приводит к необходимости использования дополнительных устройств и программного драйвера.

В настоящее время последовательная связь с ПЭВМ может осуществляться через интерфейс USB с использованием соответствующих драйверов. В современных программаторах последовательный порт USB используется как для программирования, так и для питания.

Похожие публикации