Работа с COM и LPT в Win32. | страница 16



>BOOL GetCommProperties(HANDLE hFile, LPCOMMPROP lpCommProp);

Запросить информацию можно только об уже открытом устройстве. При этом для структуры, адресуемой вторым параметром, должна быть выделена память. Приведу пример получения информации о коммуникационном устройстве:

>#include

>. . .

>HANDLE port;

>COMMPROP *pr;

>. . .

>port = CreateFile("COM2", GENERIC_READ|GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, NULL);

>pr = (COMMPROP*)HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(COMMPROP));

>GetCommProperties(port, pr);

>if (pr->wPacketLength != sizeof(COMMPROP)) {

> pr=(COMMPROP*)HeapRealloc(GetProcessHeap(), HEAP_ZERO_MEMORY, pr, pr->wPacketLength);

> pr->wProvSpec1=COMMPROP_INITIALIZED;

> GetCommProperties(port, pr);

>}

>. . .

>HeapFree(GetProcessHeap(),0,pr);

>CloseHandle(port);

>. . .

Не всегда настройку порта можно жестко зашить в код программы. Внешние устройства могут позволять изменять параметры линии связи, чаще всего скорость обмена, которая зависит от длины соединительного кабеля. В таких случаях разумно предоставить пользователю самому задавать режимы обмена. Можно самому разработать соответвующий настроечный диалог, а можно воспользоваться стандартным, предоставляемым операционной системой, а точнее, производителем порта. Стандартый диалог выводится функцией CommConfigDialog, которая работает со структурой COMMCONFIG. Как и в случае со структурой DCB, заполнять структуру COMMCONFIG можно вручную или вызовом соответсвующих функций. Начнем с самой структуры COMMCONFIG:

>typedef struct _COMM_CONFIG {

> DWORD dwSize;

> WORD wVersion;

> WORD wReserved;

> DCB dcb;

> DWORD dwProviderSubType;

> DWORD dwProviderOffset;

> DWORD dwProviderSize;

> WCHAR wcProviderData[1];

>} COMMCONFIG, *LPCOMMCONFIG;

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

dwSize

Задает размер структуры COMMCONFIG в байтах

wVersion

Задает номер версии структуры COMMCONFIG. Должен быть равным 1.

wReserved

Зарезервировано и не используется

dcb

Блок управления устройством (DCB) для порта RS-232.

dwProviderSubType

Задает тип устройства и формат устройство-зависимого блока информации. Фактически это тип порта. Конкретные значения данного поля приведены в описании структуры COMMPROP выше.

dwProviderOffset