У процесі початкового тестування POST BIOS перевіряє наявність паралельних портів LPT1-LPT4 по адресах 3BCh, 378h, 278h і поміщає базові адреси виявлених портів в пам’ять за адресами: 0:0408h, 040Ah, 040Ch, 040Eh. Після виявлення порти ініціалізуються – на порт подається сигнал Init і в порт записуються нульові значення.
Програмне переривання BIOS int 17h забезпечує наступні функції підтримки LPT-порту:
00h - вивід символу з регістру AL, строб формується після готовності принтера
01h - ініціалізація принтера
02h - опитування стану принтера
При виклику INT 17h номер функції задається в регістрі AH, а номер порту – у регістрі DX (0 – LPT1, 1 – LPT2..). Дані з порта повертаються у регістр AH.
Використання переривань: LPT1 – IRQ7, LPT2 – IRQ5.
4. Проектування апаратури для спряження з Centronics
Для Centronics характерні такі особливості:
1) обмін даними є програмно-керованим (обробка переривань і прямий доступ до пам’яті неможливі).
2) Невисока швидкість обміну
3) Обмеження на довжину лінії зв’язку (2м)
4) Немає шини живлення.
Розглянемо підключення до комп’ютера найпростішого пристрою – набору світло діодів і кнопок.
Для керування використано сигнали Strobe – стробування запису даних та Init – очистка регістру.
Після світло діода сигнал з напругою (0, +5В ) і струмом 10мА можна подати на підсилювач напруги та струму і далі на виконавчий пристрій. Для безпосереднього керування виконавчими пристроями використовують тиристори, оптопари, реле.
Рис.9.2. Під’єднання до комп’ютера зовнішнього пристрою через Centronics
Для збільшення розрядності вхідних даних використовують мультиплекс ори (вхід – 16 біт, вихід – 4 ), а для збільшення розрядності вихідних даних – демультиплексори (вхід – 4 біт, вихід – 16 біт). Для побудови мультиплексорів використовують буфери з трьома станами (0В, 5В, відключено), наприклад К155ЛП8.
Для формування команд – дешифратори (напр.. К155ИД3 : на вхід біти D0-D3, на виході команди K0-K15).
Рис. 2. Разъем интерфейсного адаптера Cetronics DB-25S
5. Програмування паралельного порта під Windows NT/2000/XP
Windows працює з портами як з файлами і вимагає точного дотримання протоколу обміну даними. Наприклад при передачі навіть одного біту на паралельний порт система вимагає також відпрацювання сигналів Strobe і Ask (відповідь – підтвердження).
Спочатку порт потрібно відкрити як файл функцією CreateFile, що надається Win32 API i прототип якої:
HANDLE CreateFile(
LPCTSTR lpFileName,
DWORD dwDesiredAccess,
DWORD dwSharedMode,
LPSECURITY_ATTRIBUTES lpSecurityAttributes,
DWORD dwCreationDistribution,
DWORD dwFlagAndAttributes,
HANDLE hTemplateFile ); де:
lpFileName - назва порта: COM1, COM2, ..., LPT1, LPT2, ..
вказівник на рядок з нульовим символом у кінці (PCHAR) , яка визначає назву об’єкту, що створюється (файл, канал, почтовый слот, ресурс связи (в данном случае порты), дисковое устройство, приставка, или каталог)
dwDesiredAccess - тип доступу до файлу: GENETIC_READ - файл для зчитування, GENETIC_WRITE - файл для запису, GENETIC_READ | GENETIC_WRITE - файл для зчитування / запису.
dwSharedMode - параметр спільного доступу до файлу (=0 – монопольний режим)
lpSecurityAttributes - атрибут захисту файлу (=Null)
dwCreationDistribution
Определяет поведение функции если объект уже существует и как он будет открыт в этом случае Принимает одно из следующих значений :
CREATE_NEW
Создает новый объект (файл) Выдает ошибку если указанный объект (файл) уже существует.
CREATE_ALWAYS
Создает новый объект (файл) Функция перезаписывает существующий объект (файл)
OPEN_EXISTING
Открывает объект (файл) Выдает ошибку если указанный объект (файл) не существует.(Для более детального смотрите SDK)
OPEN_ALWAYS
Открывает объект (файл), если он существует. Если объект (файл) не существует, функция создает его, как будто dwCreationDistribution были CREATE_NEW.
TRUNCATE_EXISTING
Открывает объект (файл). После этого объект (файл) будет усечен до нулевого размера.Выдает ошибку если указанный объект (файл) не существует
DwFlagsAndAttributes
Атрибуты объекта (файла), атрибуты могут комбинироваться
· FILE_ATTRIBUTE_ARCHIVE
· FILE_ATTRIBUTE_COMPRESSED
· FILE_ATTRIBUTE_HIDDEN
· FILE_ATTRIBUTE_NORMAL
· FILE_ATTRIBUTE_OFFLINE
· FILE_ATTRIBUTE_READONLY
· FILE_ATTRIBUTE_SYSTEM
· FILE_ATTRIBUTE_TEMPORARY
HTemplateFile
Определяет дескриптор с GENERIC_READ доступом к временному объекту(файлу). Временный объект(файл)поставляет атрибуты файла и расширенные атрибуты для создаваемого объекта (файла) ИСПОЛЬЗУЕТСЯ ТОЛЬКО В WINDOWS NT Windows 95: Это значение должно быть установлено в Nil.
LPTPort := 'LPT1'; hCommFile := CreateFile(Pchar(LPTPort), GENERIC_WRITE, 0, nil, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);При використанні DOSі Windows 95/98 доступ до портів вводу/виводу (I/Oports) комп’ютера був відносно простим. Проте у WindowsNT/2000/XP (захищена операційна система) доступ до портів вв/вив значно ускладнився за рахунок віртуалізації апаратного забезпечення (virtualizehardware). Віртуалізація означає, що програма вже не може звертатися безпосередньо до фізичного пристрою, а звертається тільки до драйвера, який емулює (emulates) роботу фізичного пристрою (відеоадаптеру, клавіатури, звукової карти чи принтера). Програмна емуляція фізичних пристроїв (хороший стиль для станд. задач) з одного боку підвищує надійність і захищеність роботи операційної системи (помилкові команди перехоплюються), а з іншого обмежую можливості керування нестандартними зовнішніми пристроями через порти вв/вив.
Тому команди вводу/вив в порт (INandOUT) у WindowsNT/2000/XP не працюють, а операційна система працює із зовнішніми пристроями як з файлами (команди запису/зчитування з файлу). Крім ускладнення програмування використання драйвера як посередника значно змекншує швидкодію операцій вв/вив.
Тому для роботи з портами розроблена динамічно під’єднувана бібліотека IO.DLL, що дозволяє зручно виконувати команди вв/вив даних у порти для 95/98 andNT/2000/XP.
io.zip 46k (Contains all the files) io.dll 46k
The following two files are for C++ users. There is more info on these in the prototypes section.
io.cpp 1k io.h 1k
Please refer to the prototype for the particular language you are using.
PortOut
Вивід байта у спеціальний порт / Outputs a byte to the specified port.
PortWordOut
Вивід слова (16 біт) у порт / Outputs a word (16-bits) to the specified port.
PortDWordOut
Вивід подвійного слова у порт / Outputs a double word (32-bits) to the specified port.
PortIn
Зчитування байту з порта / Reads a byte from the specified port.
PortWordIn
Зчитування слова / Reads a word (16-bits) from the specified port.
PortDWordIn
Зчитування подвійного слова / Reads a double word (32-bits) from the specified port.
SetPortBit
Встановлення бітів порта / Sets the bit of the specified port.
ClrPortBit
Очищення бітів порта / Clears the bit of the specified port.
NotPortBit
Інвертування бітів порта / Nots (inverts) the bit of the specified port.
GetPortBit
Повернути стан порта / Returns the state of the specified bit.
RightPortShift
Shifts the specified port to the right. The LSB is returned, and the value passed becomes the MSB.
LeftPortShift
Shifts the specified port to the left. The MSB is returned, and the value passed becomes the LSB.
IsDriverInstalled
Повертає не 0, якщо io.dll інстальовано. Returns non-zero if io.dll is installed and functioning.
Приклад процедур у Delphi
function IsDriverInstalled : Boolean; stdcall; external 'io.dll'; // протопити
procedure PortOut(Port: Word; Data: Byte);stdcall; external 'io.dll';
function PortIn(Port: Word): Byte;stdcall; external 'io.dll';
procedure TForm1.FormCreate(Sender: TObject);
begin
if IsDriverInstalled then
begin
Label1.Caption:='Driver ready...';
end;
end;
procedure TForm1.Button1Click(Sender: TObject);
var
i:byte;
begin
for i:=0 to 255 do
begin
PortOut($378,i);
Sleep(200);
Application.ProcessMessages;
end;
end;
procedure TForm1.Button2Click(Sender: TObject);
var
b:byte;
begin
b:=PortIn($379);.Text:=IntToStr(b);
end;