af062818b47340eef15700d2f0211576ba3506eevboxsync/*
af062818b47340eef15700d2f0211576ba3506eevboxsync * DDK definitions for serial port
af062818b47340eef15700d2f0211576ba3506eevboxsync *
af062818b47340eef15700d2f0211576ba3506eevboxsync * Copyright (C) 2006 Eric Pouech
af062818b47340eef15700d2f0211576ba3506eevboxsync * From w32api package
af062818b47340eef15700d2f0211576ba3506eevboxsync *
af062818b47340eef15700d2f0211576ba3506eevboxsync * This library is free software; you can redistribute it and/or
af062818b47340eef15700d2f0211576ba3506eevboxsync * modify it under the terms of the GNU Lesser General Public
af062818b47340eef15700d2f0211576ba3506eevboxsync * License as published by the Free Software Foundation; either
af062818b47340eef15700d2f0211576ba3506eevboxsync * version 2.1 of the License, or (at your option) any later version.
af062818b47340eef15700d2f0211576ba3506eevboxsync *
af062818b47340eef15700d2f0211576ba3506eevboxsync * This library is distributed in the hope that it will be useful,
af062818b47340eef15700d2f0211576ba3506eevboxsync * but WITHOUT ANY WARRANTY; without even the implied warranty of
af062818b47340eef15700d2f0211576ba3506eevboxsync * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
af062818b47340eef15700d2f0211576ba3506eevboxsync * Lesser General Public License for more details.
af062818b47340eef15700d2f0211576ba3506eevboxsync *
af062818b47340eef15700d2f0211576ba3506eevboxsync * You should have received a copy of the GNU Lesser General Public
af062818b47340eef15700d2f0211576ba3506eevboxsync * License along with this library; if not, write to the Free Software
af062818b47340eef15700d2f0211576ba3506eevboxsync * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
af062818b47340eef15700d2f0211576ba3506eevboxsync */
af062818b47340eef15700d2f0211576ba3506eevboxsync
b955672b950093ff7416d1269dd4d3b69983bd8fvboxsync/*
4b9d6701570cb98fd36e209314239d104ec584d3vboxsync * Oracle LGPL Disclaimer: For the avoidance of doubt, except that if any license choice
4b9d6701570cb98fd36e209314239d104ec584d3vboxsync * other than GPL or LGPL is available it will apply instead, Oracle elects to use only
b955672b950093ff7416d1269dd4d3b69983bd8fvboxsync * the Lesser General Public License version 2.1 (LGPLv2) at this time for any software where
b955672b950093ff7416d1269dd4d3b69983bd8fvboxsync * a choice of LGPL license versions is made available with the language indicating
b955672b950093ff7416d1269dd4d3b69983bd8fvboxsync * that LGPLv2 or any later version may be used, or where a choice of which version
b955672b950093ff7416d1269dd4d3b69983bd8fvboxsync * of the LGPL is applied is otherwise unspecified.
b955672b950093ff7416d1269dd4d3b69983bd8fvboxsync */
b955672b950093ff7416d1269dd4d3b69983bd8fvboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#ifndef _NTDDSER_H_
af062818b47340eef15700d2f0211576ba3506eevboxsync#define _NTDDSER_H_
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#ifdef __cplusplus
af062818b47340eef15700d2f0211576ba3506eevboxsyncextern "C" {
af062818b47340eef15700d2f0211576ba3506eevboxsync#endif
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_CLEAR_STATS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 36, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_CLR_DTR \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 10, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_CLR_RTS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 13, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_CONFIG_SIZE \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 32, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_BAUD_RATE \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 20, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_CHARS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 22, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_COMMSTATUS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 27, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_DTRRTS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 30, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_HANDFLOW \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 24, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_LINE_CONTROL \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 21, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_MODEM_CONTROL \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 37, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_MODEMSTATUS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 26, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_PROPERTIES \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 29, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_STATS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 35, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_TIMEOUTS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 8, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_GET_WAIT_MASK \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 16, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_IMMEDIATE_CHAR \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 6, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#ifndef IOCTL_SERIAL_LSRMST_INSERT
af062818b47340eef15700d2f0211576ba3506eevboxsync/* it's already defined in winioctl.h */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_LSRMST_INSERT \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 31, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#endif
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_PURGE \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 19, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_RESET_DEVICE \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 11, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_BAUD_RATE \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 1, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_BREAK_ON \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 4, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_BREAK_OFF \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 5, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_CHARS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 23, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_DTR \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 9, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_FIFO_CONTROL \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 39, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_HANDFLOW \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 25, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_LINE_CONTROL \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 3, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_MODEM_CONTROL \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 38, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_QUEUE_SIZE \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 2, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_RTS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 12, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_TIMEOUTS \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 7, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_WAIT_MASK \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 17, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_XOFF \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 14, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_SET_XON \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 15, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_WAIT_ON_MASK \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 18, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync#define IOCTL_SERIAL_XOFF_COUNTER \
af062818b47340eef15700d2f0211576ba3506eevboxsync CTL_CODE (FILE_DEVICE_SERIAL_PORT, 28, METHOD_BUFFERED, FILE_ANY_ACCESS)
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_BAUD_RATE
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG BaudRate;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_BAUD_RATE, *PSERIAL_BAUD_RATE;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* SERIAL_BAUD_RATE.BaudRate constants */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_075 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_110 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_134_5 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_150 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_300 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_600 0x00000020
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_1200 0x00000040
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_1800 0x00000080
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_2400 0x00000100
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_4800 0x00000200
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_7200 0x00000400
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_9600 0x00000800
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_14400 0x00001000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_19200 0x00002000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_38400 0x00004000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_56K 0x00008000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_128K 0x00010000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_115200 0x00020000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_57600 0x00040000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BAUD_USER 0x10000000
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_CHARS
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR EofChar;
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR ErrorChar;
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR BreakChar;
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR EventChar;
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR XonChar;
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR XoffChar;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_CHARS, *PSERIAL_CHARS;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_STATUS
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG Errors;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG HoldReasons;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG AmountInInQueue;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG AmountInOutQueue;
af062818b47340eef15700d2f0211576ba3506eevboxsync BOOLEAN EofReceived;
af062818b47340eef15700d2f0211576ba3506eevboxsync BOOLEAN WaitForImmediate;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_STATUS, *PSERIAL_STATUS;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_HANDFLOW
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ControlHandShake;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG FlowReplace;
af062818b47340eef15700d2f0211576ba3506eevboxsync LONG XonLimit;
af062818b47340eef15700d2f0211576ba3506eevboxsync LONG XoffLimit;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_HANDFLOW, *PSERIAL_HANDFLOW;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DTR_MASK 0x00000003
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DTR_CONTROL 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DTR_HANDSHAKE 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_CTS_HANDSHAKE 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DSR_HANDSHAKE 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DCD_HANDSHAKE 0x00000020
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_OUT_HANDSHAKEMASK 0x00000038
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DSR_SENSITIVITY 0x00000040
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_ERROR_ABORT 0x80000000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_CONTROL_INVALID 0x7fffff84
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_AUTO_TRANSMIT 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_AUTO_RECEIVE 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_ERROR_CHAR 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_NULL_STRIPPING 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_BREAK_CHAR 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_RTS_MASK 0x000000c0
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_RTS_CONTROL 0x00000040
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_RTS_HANDSHAKE 0x00000080
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_TRANSMIT_TOGGLE 0x000000c0
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_XOFF_CONTINUE 0x80000000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_FLOW_INVALID 0x7fffff20
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_LINE_CONTROL
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR StopBits;
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR Parity;
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR WordLength;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_LINE_CONTROL, *PSERIAL_LINE_CONTROL;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* SERIAL_LINE_CONTROL.StopBits constants */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define STOP_BIT_1 0x00
af062818b47340eef15700d2f0211576ba3506eevboxsync#define STOP_BITS_1_5 0x01
af062818b47340eef15700d2f0211576ba3506eevboxsync#define STOP_BITS_2 0x02
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* SERIAL_LINE_CONTROL.Parity constants */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define NO_PARITY 0x00
af062818b47340eef15700d2f0211576ba3506eevboxsync#define ODD_PARITY 0x01
af062818b47340eef15700d2f0211576ba3506eevboxsync#define EVEN_PARITY 0x02
af062818b47340eef15700d2f0211576ba3506eevboxsync#define MARK_PARITY 0x03
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SPACE_PARITY 0x04
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* IOCTL_SERIAL_(GET_MODEM_CONTROL, SET_MODEM_CONTROL) flags */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_MCR_DTR 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_MCR_RTS 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_MCR_OUT1 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_MCR_OUT2 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_MCR_LOOP 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_COMMPROP
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync USHORT PacketLength;
af062818b47340eef15700d2f0211576ba3506eevboxsync USHORT PacketVersion;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ServiceMask;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG Reserved1;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG MaxTxQueue;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG MaxRxQueue;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG MaxBaud;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ProvSubType;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ProvCapabilities;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG SettableParams;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG SettableBaud;
af062818b47340eef15700d2f0211576ba3506eevboxsync USHORT SettableData;
af062818b47340eef15700d2f0211576ba3506eevboxsync USHORT SettableStopParity;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG CurrentTxQueue;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG CurrentRxQueue;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ProvSpec1;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ProvSpec2;
af062818b47340eef15700d2f0211576ba3506eevboxsync WCHAR ProvChar[1];
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_COMMPROP, *PSERIAL_COMMPROP;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* SERIAL_COMMPROP.SettableParams flags */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_PARITY 0x0001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_BAUD 0x0002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_DATABITS 0x0004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_STOPBITS 0x0008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_HANDSHAKING 0x0010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_PARITY_CHECK 0x0020
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_CARRIER_DETECT 0x0040
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* SERIAL_COMMPROP.ProvCapabilities flags */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_DTRDSR 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_RTSCTS 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_CD 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_PARITY_CHECK 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_XONXOFF 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_SETXCHAR 0x00000020
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_TOTALTIMEOUTS 0x00000040
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_INTTIMEOUTS 0x00000080
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_SPECIALCHARS 0x00000100
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PCF_16BITMODE 0x00000200
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* SERIAL_COMMPROP.SettableData flags */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DATABITS_5 0x0001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DATABITS_6 0x0002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DATABITS_7 0x0004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DATABITS_8 0x0008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DATABITS_16 0x0010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DATABITS_16X 0x0020
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* SERIAL_COMMPROP.SettableStopParity flags */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_STOPBITS_10 0x0001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_STOPBITS_15 0x0002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_STOPBITS_20 0x0004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PARITY_NONE 0x0100
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PARITY_ODD 0x0200
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PARITY_EVEN 0x0400
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PARITY_MARK 0x0800
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PARITY_SPACE 0x1000
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIALPERF_STATS
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ReceivedCount;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG TransmittedCount;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG FrameErrorCount;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG SerialOverrunErrorCount;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG BufferOverrunErrorCount;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ParityErrorCount;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIALPERF_STATS, *PSERIALPERF_STATS;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_TIMEOUTS
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ReadIntervalTimeout;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ReadTotalTimeoutMultiplier;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ReadTotalTimeoutConstant;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG WriteTotalTimeoutMultiplier;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG WriteTotalTimeoutConstant;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_TIMEOUTS, *PSERIAL_TIMEOUTS;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* IOCTL_SERIAL_(GET_WAIT_MASK, SET_WAIT_MASK, WAIT_ON_MASK) flags */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_RXCHAR 0x0001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_RXFLAG 0x0002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_TXEMPTY 0x0004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_CTS 0x0008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_DSR 0x0010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_RLSD 0x0020
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_BREAK 0x0040
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_ERR 0x0080
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_RING 0x0100
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_PERR 0x0200
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_RX80FULL 0x0400
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_EVENT1 0x0800
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_EV_EVENT2 0x1000
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* IOCTL_SERIAL_LSRMST_INSERT constants */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_LSRMST_LSR_DATA 0x01
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_LSRMST_LSR_NODATA 0x02
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_LSRMST_MST 0x03
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_LSRMST_ESCAPE 0x00
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* IOCTL_SERIAL_PURGE constants */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PURGE_TXABORT 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PURGE_RXABORT 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PURGE_TXCLEAR 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_PURGE_RXCLEAR 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync/* IOCTL_SERIAL_SET_FIFO_CONTROL constants */
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_FCR_FIFO_ENABLE 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_FCR_RCVR_RESET 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_FCR_XMIT_RESET 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_FCR_DMA_MODE 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_FCR_RES1 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_FCR_RES2 0x00000020
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_FCR_RCVR_TRIGGER_LSB 0x00000040
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_IOC_FCR_RCVR_TRIGGER_MSB 0x00000080
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_QUEUE_SIZE
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG InSize;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG OutSize;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_QUEUE_SIZE, *PSERIAL_QUEUE_SIZE;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_XOFF_COUNTER
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG Timeout;
af062818b47340eef15700d2f0211576ba3506eevboxsync LONG Counter;
af062818b47340eef15700d2f0211576ba3506eevboxsync UCHAR XoffChar;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_XOFF_COUNTER, *PSERIAL_XOFF_COUNTER;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIAL_BASIC_SETTINGS
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync SERIAL_TIMEOUTS Timeouts;
af062818b47340eef15700d2f0211576ba3506eevboxsync SERIAL_HANDFLOW HandFlow;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG RxFifo;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG TxFifo;
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIAL_BASIC_SETTINGS, *PSERIAL_BASIC_SETTINGS;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_ERROR_BREAK 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_ERROR_FRAMING 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_ERROR_OVERRUN 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_ERROR_QUEUEOVERRUN 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_ERROR_PARITY 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_UNSPECIFIED 0x00000000
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_RS232 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_PARALLEL 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_RS422 0x00000003
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_RS423 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_RS449 0x00000005
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_MODEM 0X00000006
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_FAX 0x00000021
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_SCANNER 0x00000022
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_BRIDGE 0x00000100
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_LAT 0x00000101
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_TELNET 0x00000102
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_X25 0x00000103
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_SP_SERIALCOMM 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_TX_WAITING_FOR_CTS 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_TX_WAITING_FOR_DSR 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_TX_WAITING_FOR_DCD 0x00000004
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_TX_WAITING_FOR_XON 0x00000008
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_TX_WAITING_XOFF_SENT 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_TX_WAITING_ON_BREAK 0x00000020
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_RX_WAITING_FOR_DSR 0x00000040
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DTR_STATE 0x00000001
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_RTS_STATE 0x00000002
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_CTS_STATE 0x00000010
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DSR_STATE 0x00000020
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_RI_STATE 0x00000040
af062818b47340eef15700d2f0211576ba3506eevboxsync#define SERIAL_DCD_STATE 0x00000080
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsynctypedef struct _SERIALCONFIG
af062818b47340eef15700d2f0211576ba3506eevboxsync{
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG Size;
af062818b47340eef15700d2f0211576ba3506eevboxsync USHORT Version;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG SubType;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ProvOffset;
af062818b47340eef15700d2f0211576ba3506eevboxsync ULONG ProviderSize;
af062818b47340eef15700d2f0211576ba3506eevboxsync WCHAR ProviderData[1];
af062818b47340eef15700d2f0211576ba3506eevboxsync} SERIALCONFIG,*PSERIALCONFIG;
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#ifdef __cplusplus
af062818b47340eef15700d2f0211576ba3506eevboxsync}
af062818b47340eef15700d2f0211576ba3506eevboxsync#endif
af062818b47340eef15700d2f0211576ba3506eevboxsync
af062818b47340eef15700d2f0211576ba3506eevboxsync#endif /* _NTDDSER_H_ */