На главную

On-line справка по Win32 API

Написать письмо
БЕСПЛАТНАЯ ежедневная online лотерея! Выигрывай каждый день БЕСПЛАТНО!
Список всех статей A-B-C-D-E-F-G-H-I-J-K-L-M-N-O-P-Q-R-S-T-U-V-W-X-Y-Z | Скачать Вниз

Modification of Communications Resource Settings



When the CreateFile function opens a handle to a serial communications resource, the system initializes and configures the resource according to the values set up the last time the resource was opened. Preserving the previous settings enables the user to retain the settings specified through an MS-DOS® mode command when the device is reopened. The values inherited from the previous open operation include the configuration settings of the device control block (a DCB structure) and the time-out values used in I/O operations. If the device has never been opened, it is configured with the system defaults.

To determine the initial configuration of a serial communications resource, a process calls the GetCommState function, which fills in a serial port DCB structure with the current configuration settings. To modify this configuration, a process specifies a DCB structure in a call to the SetCommState function.
Members of the DCB structure specify the configuration settings such as the baud rate, the number of data bits per byte, and the number of stop bits per byte. Other DCB members specify special characters and enable parity checking and flow control. When a process needs to modify only a few of these configuration settings, it should first call GetCommState to fill in a DCB structure with the current configuration. Then the process can adjust the important values in the DCB structure and reconfigure the device by calling SetCommState and specifying the modified DCB structure. This procedure ensures that the unmodified members of the DCB structure contain appropriate values. For example, a common error is to configure a device with a DCB structure in which the structure's XonChar member is equal to the XoffChar member. Some members of the DCB structure are different from those in previous versions of Microsoft Windows®. In particular, the flags for controlling RTS (request-to-send) and DTR (data-terminal-ready) flow control have changed.

The BuildCommDCB function provides another way to modify a DCB structure. BuildCommDCB uses a string with the same form as the command-line arguments of the mode command to specify the baud rate, parity scheme, number of stop bits, and number of data bits. The remaining members of DCB are not changed by this function, except that the appropriate members are set to disable XON/XOFF and hardware flow control. BuildCommDCB only modifies a DCB structure; it does not reconfigure the device.

A process can reconfigure a communications resource by using the GetCommProperties function to get information from a device driver about the configuration settings that it supports. The process can use this information to avoid specifying a configuration that is not supported.
The SetCommState function reconfigures the communications resource, but it does not affect the internal output and input buffers of the specified driver. The buffers are not flushed, and pending read and write operations are not terminated prematurely.

A process reinitializes a communications resource by using the SetupComm function, which performs the following tasks:

· Terminates pending read and write operations, even if they have not been completed.
· Discards unread characters and frees the internal output and input buffers of the driver associated with the specified resource.
· Reallocates the internal output and input buffers.



A process is not required to call SetupComm. If it does not, the resource's driver initializes the device with the default settings the first time that the communications resource handle is used.


Пригласи друзей и счет твоего мобильника всегда будет положительным!
Предыдущая статья
 
Сайт Народ.Ру Интернет
Следующая статья
Пригласи друзей и счет твоего мобильника всегда будет положительным!

Модификация Обстановки Ресурса Связи



Когда CreateFile функциональный открытый ручка в последовательный ресурс связи, система инициализирует и конфигурирует ресурс в зависимости от того величины устанавливают в последний раз ресурс был открыт. Сохранять предшествующей обстановки позволяет потребителя, чтобы сохранять обстановку определенную через МС-DOS команда способа когда устройство открыто вновь. Величины унаследованные из предшествующей работы без ограничений включают обстановку конфигурации управляющего блока устройства ( структура DCB) и величины задержки использовались в действиях В/В. Если устройство никогда не было открывано, сконфигурировано системой устанавливается по умолчанию.

Для того, чтобы определять начальную конфигурацию последовательного ресурса связи, процесс называет функцию GetCommState, который заполняет структуру последовательного порта DCB с текущей обстановкой конфигурации. Чтобы модифицировать эту конфигурацию, процесс определяет структуру DCB на вызове в функцию SetCommState.
Участники структуры DCB определяют установочные параметры конфигурации как например, показатель бода, номер битов данных за байт, и количество стоповых битов за байт. Другие участники DCB определяют специальные символы и приспосабливаются проверку четности и текут управление. Когда процессу нужно модифицировать только несколько этих установочных параметров конфигурации, это должно сначала называть GetCommState, чтобы заполнять структуру DCB текущей конфигурацией. Затем процесс может отрегулировать важные величины в структуре DCB и перестраивать устройство вызывая SetCommState и определяя модифицировать структуру DCB. Эта процедура проверяет, что unmodified участники структуры DCB содержат подходящие величины. Например, общая ошибка должна сконфигурировать устройство со структурой DCB в котором структурный элемент XonChar равняется элементу XoffChar. Некоторые участники структуры DCB отличаются от в предшествующих версиях Microsoft Windows . В конкретном, флаги для управления RTS потока (запрос-посылает) и DTR управления (данные-терминальный-готовый) изменилось.

Функция BuildCommDCB обеспечивает другой путь модифицировать структуру DCB. BuildCommDCB ИСПОЛЬЗУЕТ строку с той же формой как командная строка аргументов команды режима, чтобы определять показатель бода, схемы четности, количества стоповых битов, и номер битов данных. Остальные участники DCB не изменены этой функцией, кроме того подходящие участники установлены, чтобы выводить из строя XON/XOFF и аппаратное управление потока. BuildCommDCB ТОЛЬКО модифицирует структуру DCB; это не перестраивает устройство.

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

Процесс инициализирует вновь ресурс связи используя функцию SetupComm, которая выполняет следующие задачи:

Завершает рассматривать прочитанное и операции записи, даже если бы они не завершены.
Отвергает unread символы и освобождает внутренний выход и вводит буферы драйвера связанного определенным ресурсом.
Reallocates Внутренние выходные и входные буферы.



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


Вверх Version 1.3, Oct 26 2010 © 2007, 2010, mrhx Вверх
 mrhx software  Русский перевод OpenGL  Русский перевод Win32 API
 
Используются технологии uCoz