emulator/emulatorbsp/wpdpack/include/ntddndis.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 01:39:10 +0200
changeset 0 cec860690d41
permissions -rw-r--r--
Revision: 201005 Kit: 201005

/*++ BUILD Version: 0001                // Increment this if a change has global effects
   Copyright (c) 1990-1993  Microsoft Corporation
   Module Name:
   ntddndis.h
   Abstract:
   This is the include file that defines all constants and types for
   accessing the Network driver interface device.
   Author:
   Steve Wood (stevewo) 27-May-1990
   Revision History:
   Adam Barr (adamba)           04-Nov-1992             added the correct values for NDIS 3.0.
   Jameel Hyder (jameelh)       01-Aug-95               added Pnp IoCTLs and structures
   Kyle Brandon (kyleb) 09/24/96                added general co ndis oids.
   -- */
#ifndef _NTDDNDIS_
#define _NTDDNDIS_
//
// Device Name - this string is the name of the device.  It is the name
// that should be passed to NtOpenFile when accessing the device.
//
// Note:  For devices that support multiple units, it should be suffixed
//                with the Ascii representation of the unit number.
//
#define DD_NDIS_DEVICE_NAME "\\Device\\UNKNOWN"
//
// NtDeviceIoControlFile IoControlCode values for this device.
//
// Warning:  Remember that the low two bits of the code specify how the
//                       buffers are passed to the driver!
//
#define _NDIS_CONTROL_CODE(request,method) \
			CTL_CODE(FILE_DEVICE_PHYSICAL_NETCARD, request, method, FILE_ANY_ACCESS)
#define IOCTL_NDIS_QUERY_GLOBAL_STATS	_NDIS_CONTROL_CODE( 0, METHOD_OUT_DIRECT )
#define IOCTL_NDIS_QUERY_ALL_STATS		_NDIS_CONTROL_CODE( 1, METHOD_OUT_DIRECT )
#define IOCTL_NDIS_ADD_DEVICE			_NDIS_CONTROL_CODE( 2, METHOD_BUFFERED )
#define IOCTL_NDIS_DELETE_DEVICE		_NDIS_CONTROL_CODE( 3, METHOD_BUFFERED )
#define IOCTL_NDIS_TRANSLATE_NAME		_NDIS_CONTROL_CODE( 4, METHOD_BUFFERED )
#define IOCTL_NDIS_ADD_TDI_DEVICE		_NDIS_CONTROL_CODE( 5, METHOD_BUFFERED )
#define IOCTL_NDIS_NOTIFY_PROTOCOL		_NDIS_CONTROL_CODE( 6, METHOD_BUFFERED )
#define	IOCTL_NDIS_GET_LOG_DATA			_NDIS_CONTROL_CODE( 7, METHOD_OUT_DIRECT )
//
// NtDeviceIoControlFile InputBuffer/OutputBuffer record structures for
// this device.
//
//
// This is the type of an NDIS OID value.
//
typedef ULONG NDIS_OID, *PNDIS_OID;
//
// IOCTL_NDIS_QUERY_ALL_STATS returns a sequence of these, packed
// together (no padding is required since statistics all have
// four or eight bytes of data).
//
typedef struct _NDIS_STATISTICS_VALUE {
    NDIS_OID Oid;
    ULONG DataLength;
    UCHAR Data[1];		// variable length

} NDIS_STATISTICS_VALUE, *PNDIS_STATISTICS_VALUE;

//
// Structure used by TRANSLATE_NAME IOCTL
//
typedef struct _NET_PNP_ID {
    ULONG ClassId;
    ULONG Token;
} NET_PNP_ID, *PNET_PNP_ID;

typedef struct _NET_PNP_TRANSLATE_LIST {
    ULONG BytesNeeded;
    NET_PNP_ID IdArray[ANYSIZE_ARRAY];
} NET_PNP_TRANSLATE_LIST, *PNET_PNP_TRANSLATE_LIST;

//
// Structure used to define a self-contained variable data structure
//
typedef struct _NDIS_VAR_DATA_DESC {
    USHORT Length;		// # of octects of data

    USHORT MaximumLength;	// # of octects available

    LONG Offset;		// Offset of data relative to the descriptor

} NDIS_VAR_DATA_DESC, *PNDIS_VAR_DATA_DESC;

//
// Object Identifiers used by NdisRequest Query/Set Information
//
//
// General Objects
//
#define OID_GEN_SUPPORTED_LIST			  		0x00010101
#define OID_GEN_HARDWARE_STATUS			 		0x00010102
#define OID_GEN_MEDIA_SUPPORTED			 		0x00010103
#define OID_GEN_MEDIA_IN_USE					0x00010104
#define OID_GEN_MAXIMUM_LOOKAHEAD		   		0x00010105
#define OID_GEN_MAXIMUM_FRAME_SIZE		  		0x00010106
#define OID_GEN_LINK_SPEED				  		0x00010107
#define OID_GEN_TRANSMIT_BUFFER_SPACE	   		0x00010108
#define OID_GEN_RECEIVE_BUFFER_SPACE			0x00010109
#define OID_GEN_TRANSMIT_BLOCK_SIZE		 		0x0001010A
#define OID_GEN_RECEIVE_BLOCK_SIZE		  		0x0001010B
#define OID_GEN_VENDOR_ID				   		0x0001010C
#define OID_GEN_VENDOR_DESCRIPTION		  		0x0001010D
#define OID_GEN_CURRENT_PACKET_FILTER	   		0x0001010E
#define OID_GEN_CURRENT_LOOKAHEAD		   		0x0001010F
#define OID_GEN_DRIVER_VERSION			  		0x00010110
#define OID_GEN_MAXIMUM_TOTAL_SIZE		  		0x00010111
#define OID_GEN_PROTOCOL_OPTIONS				0x00010112
#define OID_GEN_MAC_OPTIONS				 		0x00010113
#define OID_GEN_MEDIA_CONNECT_STATUS			0x00010114
#define OID_GEN_MAXIMUM_SEND_PACKETS			0x00010115
#define OID_GEN_VENDOR_DRIVER_VERSION			0x00010116
#define OID_GEN_XMIT_OK					 		0x00020101
#define OID_GEN_RCV_OK					  		0x00020102
#define OID_GEN_XMIT_ERROR				  		0x00020103
#define OID_GEN_RCV_ERROR				   		0x00020104
#define OID_GEN_RCV_NO_BUFFER			   		0x00020105
#define OID_GEN_DIRECTED_BYTES_XMIT		 		0x00020201
#define OID_GEN_DIRECTED_FRAMES_XMIT			0x00020202
#define OID_GEN_MULTICAST_BYTES_XMIT			0x00020203
#define OID_GEN_MULTICAST_FRAMES_XMIT	   		0x00020204
#define OID_GEN_BROADCAST_BYTES_XMIT			0x00020205
#define OID_GEN_BROADCAST_FRAMES_XMIT	   		0x00020206
#define OID_GEN_DIRECTED_BYTES_RCV		  		0x00020207
#define OID_GEN_DIRECTED_FRAMES_RCV		 		0x00020208
#define OID_GEN_MULTICAST_BYTES_RCV		 		0x00020209
#define OID_GEN_MULTICAST_FRAMES_RCV			0x0002020A
#define OID_GEN_BROADCAST_BYTES_RCV		 		0x0002020B
#define OID_GEN_BROADCAST_FRAMES_RCV			0x0002020C
#define OID_GEN_RCV_CRC_ERROR			   		0x0002020D
#define OID_GEN_TRANSMIT_QUEUE_LENGTH	   		0x0002020E
#define OID_GEN_GET_TIME_CAPS					0x0002020F
#define OID_GEN_GET_NETCARD_TIME				0x00020210
//
//      These are connection-oriented general OIDs.
//      These replace the above OIDs for connection-oriented media.
//
#define OID_GEN_CO_SUPPORTED_LIST			  	0x00010101
#define OID_GEN_CO_HARDWARE_STATUS			 	0x00010102
#define OID_GEN_CO_MEDIA_SUPPORTED			 	0x00010103
#define OID_GEN_CO_MEDIA_IN_USE					0x00010104
#define OID_GEN_CO_LINK_SPEED				  	0x00010105
#define OID_GEN_CO_VENDOR_ID				   	0x00010106
#define OID_GEN_CO_VENDOR_DESCRIPTION		  	0x00010107
#define OID_GEN_CO_DRIVER_VERSION			  	0x00010108
#define OID_GEN_CO_PROTOCOL_OPTIONS				0x00010109
#define OID_GEN_CO_MAC_OPTIONS				 	0x0001010A
#define OID_GEN_CO_MEDIA_CONNECT_STATUS			0x0001010B
#define OID_GEN_CO_VENDOR_DRIVER_VERSION		0x0001010C
#define OID_GEN_CO_MINIMUM_LINK_SPEED			0x0001010D
#define OID_GEN_CO_GET_TIME_CAPS				0x00010201
#define OID_GEN_CO_GET_NETCARD_TIME				0x00010202
//
//      These are connection-oriented statistics OIDs.
//
#define	OID_GEN_CO_XMIT_PDUS_OK					0x00020101
#define	OID_GEN_CO_RCV_PDUS_OK					0x00020102
#define	OID_GEN_CO_XMIT_PDUS_ERROR				0x00020103
#define	OID_GEN_CO_RCV_PDUS_ERROR				0x00020104
#define	OID_GEN_CO_RCV_PDUS_NO_BUFFER			0x00020105
#define	OID_GEN_CO_RCV_CRC_ERROR				0x00020201
#define OID_GEN_CO_TRANSMIT_QUEUE_LENGTH		0x00020202
#define	OID_GEN_CO_BYTES_XMIT					0x00020203
#define OID_GEN_CO_BYTES_RCV					0x00020204
#define	OID_GEN_CO_BYTES_XMIT_OUTSTANDING		0x00020205
#define	OID_GEN_CO_NETCARD_LOAD					0x00020206
//
// These are objects for Connection-oriented media call-managers and are not
// valid for ndis drivers. Under construction.
//
#define OID_CO_ADD_PVC							0xFF000001
#define OID_CO_DELETE_PVC						0xFF000002
#define OID_CO_GET_CALL_INFORMATION				0xFF000003
#define OID_CO_ADD_ADDRESS						0xFF000004
#define OID_CO_DELETE_ADDRESS					0xFF000005
#define OID_CO_GET_ADDRESSES					0xFF000006
#define OID_CO_ADDRESS_CHANGE					0xFF000007
#define OID_CO_SIGNALING_ENABLED				0xFF000008
#define OID_CO_SIGNALING_DISABLED				0xFF000009
//
// 802.3 Objects (Ethernet)
//
#define OID_802_3_PERMANENT_ADDRESS		 		0x01010101
#define OID_802_3_CURRENT_ADDRESS		   		0x01010102
#define OID_802_3_MULTICAST_LIST				0x01010103
#define OID_802_3_MAXIMUM_LIST_SIZE		 		0x01010104
#define OID_802_3_MAC_OPTIONS				 	0x01010105
//
//
#define	NDIS_802_3_MAC_OPTION_PRIORITY			0x00000001
#define OID_802_3_RCV_ERROR_ALIGNMENT	   		0x01020101
#define OID_802_3_XMIT_ONE_COLLISION			0x01020102
#define OID_802_3_XMIT_MORE_COLLISIONS	  		0x01020103
#define OID_802_3_XMIT_DEFERRED			 		0x01020201
#define OID_802_3_XMIT_MAX_COLLISIONS	   		0x01020202
#define OID_802_3_RCV_OVERRUN			   		0x01020203
#define OID_802_3_XMIT_UNDERRUN			 		0x01020204
#define OID_802_3_XMIT_HEARTBEAT_FAILURE		0x01020205
#define OID_802_3_XMIT_TIMES_CRS_LOST	   		0x01020206
#define OID_802_3_XMIT_LATE_COLLISIONS	  		0x01020207
//
// 802.5 Objects (Token-Ring)
//
#define OID_802_5_PERMANENT_ADDRESS		 		0x02010101
#define OID_802_5_CURRENT_ADDRESS		   		0x02010102
#define OID_802_5_CURRENT_FUNCTIONAL			0x02010103
#define OID_802_5_CURRENT_GROUP			 		0x02010104
#define OID_802_5_LAST_OPEN_STATUS		  		0x02010105
#define OID_802_5_CURRENT_RING_STATUS	   		0x02010106
#define OID_802_5_CURRENT_RING_STATE			0x02010107
#define OID_802_5_LINE_ERRORS			   		0x02020101
#define OID_802_5_LOST_FRAMES			   		0x02020102
#define OID_802_5_BURST_ERRORS			  		0x02020201
#define OID_802_5_AC_ERRORS				 		0x02020202
#define OID_802_5_ABORT_DELIMETERS		  		0x02020203
#define OID_802_5_FRAME_COPIED_ERRORS	   		0x02020204
#define OID_802_5_FREQUENCY_ERRORS		  		0x02020205
#define OID_802_5_TOKEN_ERRORS			  		0x02020206
#define OID_802_5_INTERNAL_ERRORS		   		0x02020207
//
// FDDI Objects
//
#define OID_FDDI_LONG_PERMANENT_ADDR			0x03010101
#define OID_FDDI_LONG_CURRENT_ADDR		  		0x03010102
#define OID_FDDI_LONG_MULTICAST_LIST			0x03010103
#define OID_FDDI_LONG_MAX_LIST_SIZE		 		0x03010104
#define OID_FDDI_SHORT_PERMANENT_ADDR	   		0x03010105
#define OID_FDDI_SHORT_CURRENT_ADDR		 		0x03010106
#define OID_FDDI_SHORT_MULTICAST_LIST	   		0x03010107
#define OID_FDDI_SHORT_MAX_LIST_SIZE			0x03010108
#define OID_FDDI_ATTACHMENT_TYPE				0x03020101
#define OID_FDDI_UPSTREAM_NODE_LONG		 		0x03020102
#define OID_FDDI_DOWNSTREAM_NODE_LONG	   		0x03020103
#define OID_FDDI_FRAME_ERRORS			   		0x03020104
#define OID_FDDI_FRAMES_LOST					0x03020105
#define OID_FDDI_RING_MGT_STATE			 		0x03020106
#define OID_FDDI_LCT_FAILURES			   		0x03020107
#define OID_FDDI_LEM_REJECTS					0x03020108
#define OID_FDDI_LCONNECTION_STATE		  		0x03020109
#define OID_FDDI_SMT_STATION_ID			 		0x03030201
#define OID_FDDI_SMT_OP_VERSION_ID		  		0x03030202
#define OID_FDDI_SMT_HI_VERSION_ID		  		0x03030203
#define OID_FDDI_SMT_LO_VERSION_ID		  		0x03030204
#define OID_FDDI_SMT_MANUFACTURER_DATA	  		0x03030205
#define OID_FDDI_SMT_USER_DATA			  		0x03030206
#define OID_FDDI_SMT_MIB_VERSION_ID		 		0x03030207
#define OID_FDDI_SMT_MAC_CT				 		0x03030208
#define OID_FDDI_SMT_NON_MASTER_CT		  		0x03030209
#define OID_FDDI_SMT_MASTER_CT			  		0x0303020A
#define OID_FDDI_SMT_AVAILABLE_PATHS			0x0303020B
#define OID_FDDI_SMT_CONFIG_CAPABILITIES		0x0303020C
#define OID_FDDI_SMT_CONFIG_POLICY		  		0x0303020D
#define OID_FDDI_SMT_CONNECTION_POLICY	  		0x0303020E
#define OID_FDDI_SMT_T_NOTIFY			   		0x0303020F
#define OID_FDDI_SMT_STAT_RPT_POLICY			0x03030210
#define OID_FDDI_SMT_TRACE_MAX_EXPIRATION   	0x03030211
#define OID_FDDI_SMT_PORT_INDEXES		   		0x03030212
#define OID_FDDI_SMT_MAC_INDEXES				0x03030213
#define OID_FDDI_SMT_BYPASS_PRESENT		 		0x03030214
#define OID_FDDI_SMT_ECM_STATE			  		0x03030215
#define OID_FDDI_SMT_CF_STATE			   		0x03030216
#define OID_FDDI_SMT_HOLD_STATE			 		0x03030217
#define OID_FDDI_SMT_REMOTE_DISCONNECT_FLAG 	0x03030218
#define OID_FDDI_SMT_STATION_STATUS		 		0x03030219
#define OID_FDDI_SMT_PEER_WRAP_FLAG		 		0x0303021A
#define OID_FDDI_SMT_MSG_TIME_STAMP		 		0x0303021B
#define OID_FDDI_SMT_TRANSITION_TIME_STAMP  	0x0303021C
#define OID_FDDI_SMT_SET_COUNT			  		0x0303021D
#define OID_FDDI_SMT_LAST_SET_STATION_ID		0x0303021E
#define OID_FDDI_MAC_FRAME_STATUS_FUNCTIONS 	0x0303021F
#define OID_FDDI_MAC_BRIDGE_FUNCTIONS	   		0x03030220
#define OID_FDDI_MAC_T_MAX_CAPABILITY	   		0x03030221
#define OID_FDDI_MAC_TVX_CAPABILITY		 		0x03030222
#define OID_FDDI_MAC_AVAILABLE_PATHS			0x03030223
#define OID_FDDI_MAC_CURRENT_PATH		   		0x03030224
#define OID_FDDI_MAC_UPSTREAM_NBR		   		0x03030225
#define OID_FDDI_MAC_DOWNSTREAM_NBR		 		0x03030226
#define OID_FDDI_MAC_OLD_UPSTREAM_NBR	   		0x03030227
#define OID_FDDI_MAC_OLD_DOWNSTREAM_NBR	 		0x03030228
#define OID_FDDI_MAC_DUP_ADDRESS_TEST	   		0x03030229
#define OID_FDDI_MAC_REQUESTED_PATHS			0x0303022A
#define OID_FDDI_MAC_DOWNSTREAM_PORT_TYPE   	0x0303022B
#define OID_FDDI_MAC_INDEX				  		0x0303022C
#define OID_FDDI_MAC_SMT_ADDRESS				0x0303022D
#define OID_FDDI_MAC_LONG_GRP_ADDRESS	   		0x0303022E
#define OID_FDDI_MAC_SHORT_GRP_ADDRESS	  		0x0303022F
#define OID_FDDI_MAC_T_REQ				  		0x03030230
#define OID_FDDI_MAC_T_NEG				  		0x03030231
#define OID_FDDI_MAC_T_MAX				  		0x03030232
#define OID_FDDI_MAC_TVX_VALUE			  		0x03030233
#define OID_FDDI_MAC_T_PRI0				 		0x03030234
#define OID_FDDI_MAC_T_PRI1				 		0x03030235
#define OID_FDDI_MAC_T_PRI2				 		0x03030236
#define OID_FDDI_MAC_T_PRI3				 		0x03030237
#define OID_FDDI_MAC_T_PRI4				 		0x03030238
#define OID_FDDI_MAC_T_PRI5				 		0x03030239
#define OID_FDDI_MAC_T_PRI6				 		0x0303023A
#define OID_FDDI_MAC_FRAME_CT			   		0x0303023B
#define OID_FDDI_MAC_COPIED_CT			  		0x0303023C
#define OID_FDDI_MAC_TRANSMIT_CT				0x0303023D
#define OID_FDDI_MAC_TOKEN_CT			   		0x0303023E
#define OID_FDDI_MAC_ERROR_CT			   		0x0303023F
#define OID_FDDI_MAC_LOST_CT					0x03030240
#define OID_FDDI_MAC_TVX_EXPIRED_CT		 		0x03030241
#define OID_FDDI_MAC_NOT_COPIED_CT		  		0x03030242
#define OID_FDDI_MAC_LATE_CT					0x03030243
#define OID_FDDI_MAC_RING_OP_CT			 		0x03030244
#define OID_FDDI_MAC_FRAME_ERROR_THRESHOLD  	0x03030245
#define OID_FDDI_MAC_FRAME_ERROR_RATIO	  		0x03030246
#define OID_FDDI_MAC_NOT_COPIED_THRESHOLD   	0x03030247
#define OID_FDDI_MAC_NOT_COPIED_RATIO	   		0x03030248
#define OID_FDDI_MAC_RMT_STATE			  		0x03030249
#define OID_FDDI_MAC_DA_FLAG					0x0303024A
#define OID_FDDI_MAC_UNDA_FLAG			  		0x0303024B
#define OID_FDDI_MAC_FRAME_ERROR_FLAG	   		0x0303024C
#define OID_FDDI_MAC_NOT_COPIED_FLAG			0x0303024D
#define OID_FDDI_MAC_MA_UNITDATA_AVAILABLE  	0x0303024E
#define OID_FDDI_MAC_HARDWARE_PRESENT	   		0x0303024F
#define OID_FDDI_MAC_MA_UNITDATA_ENABLE	 		0x03030250
#define OID_FDDI_PATH_INDEX				 		0x03030251
#define OID_FDDI_PATH_RING_LATENCY		  		0x03030252
#define OID_FDDI_PATH_TRACE_STATUS		  		0x03030253
#define OID_FDDI_PATH_SBA_PAYLOAD		   		0x03030254
#define OID_FDDI_PATH_SBA_OVERHEAD		  		0x03030255
#define OID_FDDI_PATH_CONFIGURATION		 		0x03030256
#define OID_FDDI_PATH_T_R_MODE			  		0x03030257
#define OID_FDDI_PATH_SBA_AVAILABLE		 		0x03030258
#define OID_FDDI_PATH_TVX_LOWER_BOUND	   		0x03030259
#define OID_FDDI_PATH_T_MAX_LOWER_BOUND	 		0x0303025A
#define OID_FDDI_PATH_MAX_T_REQ			 		0x0303025B
#define OID_FDDI_PORT_MY_TYPE			   		0x0303025C
#define OID_FDDI_PORT_NEIGHBOR_TYPE		 		0x0303025D
#define OID_FDDI_PORT_CONNECTION_POLICIES   	0x0303025E
#define OID_FDDI_PORT_MAC_INDICATED		 		0x0303025F
#define OID_FDDI_PORT_CURRENT_PATH		  		0x03030260
#define OID_FDDI_PORT_REQUESTED_PATHS	   		0x03030261
#define OID_FDDI_PORT_MAC_PLACEMENT		 		0x03030262
#define OID_FDDI_PORT_AVAILABLE_PATHS	   		0x03030263
#define OID_FDDI_PORT_MAC_LOOP_TIME		 		0x03030264
#define OID_FDDI_PORT_PMD_CLASS			 		0x03030265
#define OID_FDDI_PORT_CONNECTION_CAPABILITIES	0x03030266
#define OID_FDDI_PORT_INDEX				 		0x03030267
#define OID_FDDI_PORT_MAINT_LS			  		0x03030268
#define OID_FDDI_PORT_BS_FLAG			   		0x03030269
#define OID_FDDI_PORT_PC_LS				 		0x0303026A
#define OID_FDDI_PORT_EB_ERROR_CT		   		0x0303026B
#define OID_FDDI_PORT_LCT_FAIL_CT		   		0x0303026C
#define OID_FDDI_PORT_LER_ESTIMATE		  		0x0303026D
#define OID_FDDI_PORT_LEM_REJECT_CT		 		0x0303026E
#define OID_FDDI_PORT_LEM_CT					0x0303026F
#define OID_FDDI_PORT_LER_CUTOFF				0x03030270
#define OID_FDDI_PORT_LER_ALARM			 		0x03030271
#define OID_FDDI_PORT_CONNNECT_STATE			0x03030272
#define OID_FDDI_PORT_PCM_STATE			 		0x03030273
#define OID_FDDI_PORT_PC_WITHHOLD		   		0x03030274
#define OID_FDDI_PORT_LER_FLAG			  		0x03030275
#define OID_FDDI_PORT_HARDWARE_PRESENT	  		0x03030276
#define OID_FDDI_SMT_STATION_ACTION		 		0x03030277
#define OID_FDDI_PORT_ACTION					0x03030278
#define OID_FDDI_IF_DESCR				   		0x03030279
#define OID_FDDI_IF_TYPE						0x0303027A
#define OID_FDDI_IF_MTU					 		0x0303027B
#define OID_FDDI_IF_SPEED				   		0x0303027C
#define OID_FDDI_IF_PHYS_ADDRESS				0x0303027D
#define OID_FDDI_IF_ADMIN_STATUS				0x0303027E
#define OID_FDDI_IF_OPER_STATUS			 		0x0303027F
#define OID_FDDI_IF_LAST_CHANGE			 		0x03030280
#define OID_FDDI_IF_IN_OCTETS			   		0x03030281
#define OID_FDDI_IF_IN_UCAST_PKTS		   		0x03030282
#define OID_FDDI_IF_IN_NUCAST_PKTS		  		0x03030283
#define OID_FDDI_IF_IN_DISCARDS			 		0x03030284
#define OID_FDDI_IF_IN_ERRORS			   		0x03030285
#define OID_FDDI_IF_IN_UNKNOWN_PROTOS	   		0x03030286
#define OID_FDDI_IF_OUT_OCTETS			  		0x03030287
#define OID_FDDI_IF_OUT_UCAST_PKTS		  		0x03030288
#define OID_FDDI_IF_OUT_NUCAST_PKTS		 		0x03030289
#define OID_FDDI_IF_OUT_DISCARDS				0x0303028A
#define OID_FDDI_IF_OUT_ERRORS			  		0x0303028B
#define OID_FDDI_IF_OUT_QLEN					0x0303028C
#define OID_FDDI_IF_SPECIFIC					0x0303028D
//
// WAN objects
//
#define OID_WAN_PERMANENT_ADDRESS		   		0x04010101
#define OID_WAN_CURRENT_ADDRESS			 		0x04010102
#define OID_WAN_QUALITY_OF_SERVICE		  		0x04010103
#define OID_WAN_PROTOCOL_TYPE			   		0x04010104
#define OID_WAN_MEDIUM_SUBTYPE			  		0x04010105
#define OID_WAN_HEADER_FORMAT			   		0x04010106
#define OID_WAN_GET_INFO						0x04010107
#define OID_WAN_SET_LINK_INFO			   		0x04010108
#define OID_WAN_GET_LINK_INFO			   		0x04010109
#define OID_WAN_LINE_COUNT				  		0x0401010A
#define OID_WAN_GET_BRIDGE_INFO			 		0x0401020A
#define OID_WAN_SET_BRIDGE_INFO			 		0x0401020B
#define OID_WAN_GET_COMP_INFO			   		0x0401020C
#define OID_WAN_SET_COMP_INFO			   		0x0401020D
#define OID_WAN_GET_STATS_INFO			  		0x0401020E
//
// LocalTalk objects
//
#define OID_LTALK_CURRENT_NODE_ID		   		0x05010102
#define OID_LTALK_IN_BROADCASTS			 		0x05020101
#define OID_LTALK_IN_LENGTH_ERRORS		  		0x05020102
#define OID_LTALK_OUT_NO_HANDLERS		   		0x05020201
#define OID_LTALK_COLLISIONS					0x05020202
#define OID_LTALK_DEFERS						0x05020203
#define OID_LTALK_NO_DATA_ERRORS				0x05020204
#define OID_LTALK_RANDOM_CTS_ERRORS		 		0x05020205
#define OID_LTALK_FCS_ERRORS					0x05020206
//
// Arcnet objects
//
#define OID_ARCNET_PERMANENT_ADDRESS			0x06010101
#define OID_ARCNET_CURRENT_ADDRESS		  		0x06010102
#define OID_ARCNET_RECONFIGURATIONS		 		0x06020201
//
// TAPI objects
//
#define OID_TAPI_ACCEPT					 		0x07030101
#define OID_TAPI_ANSWER					 		0x07030102
#define OID_TAPI_CLOSE					  		0x07030103
#define OID_TAPI_CLOSE_CALL				 		0x07030104
#define OID_TAPI_CONDITIONAL_MEDIA_DETECTION	0x07030105
#define OID_TAPI_CONFIG_DIALOG			  		0x07030106
#define OID_TAPI_DEV_SPECIFIC			   		0x07030107
#define OID_TAPI_DIAL					   		0x07030108
#define OID_TAPI_DROP					   		0x07030109
#define OID_TAPI_GET_ADDRESS_CAPS		   		0x0703010A
#define OID_TAPI_GET_ADDRESS_ID			 		0x0703010B
#define OID_TAPI_GET_ADDRESS_STATUS		 		0x0703010C
#define OID_TAPI_GET_CALL_ADDRESS_ID			0x0703010D
#define OID_TAPI_GET_CALL_INFO			  		0x0703010E
#define OID_TAPI_GET_CALL_STATUS				0x0703010F
#define OID_TAPI_GET_DEV_CAPS			   		0x07030110
#define OID_TAPI_GET_DEV_CONFIG			 		0x07030111
#define OID_TAPI_GET_EXTENSION_ID		   		0x07030112
#define OID_TAPI_GET_ID					 		0x07030113
#define OID_TAPI_GET_LINE_DEV_STATUS			0x07030114
#define OID_TAPI_MAKE_CALL				  		0x07030115
#define OID_TAPI_NEGOTIATE_EXT_VERSION	  		0x07030116
#define OID_TAPI_OPEN					   		0x07030117
#define OID_TAPI_PROVIDER_INITIALIZE			0x07030118
#define OID_TAPI_PROVIDER_SHUTDOWN		  		0x07030119
#define OID_TAPI_SECURE_CALL					0x0703011A
#define OID_TAPI_SELECT_EXT_VERSION		 		0x0703011B
#define OID_TAPI_SEND_USER_USER_INFO			0x0703011C
#define OID_TAPI_SET_APP_SPECIFIC		   		0x0703011D
#define OID_TAPI_SET_CALL_PARAMS				0x0703011E
#define OID_TAPI_SET_DEFAULT_MEDIA_DETECTION	0x0703011F
#define OID_TAPI_SET_DEV_CONFIG			 		0x07030120
#define OID_TAPI_SET_MEDIA_MODE			 		0x07030121
#define OID_TAPI_SET_STATUS_MESSAGES			0x07030122
//
// ATM Connection Oriented Ndis
//
#define OID_ATM_SUPPORTED_VC_RATES				0x08010101
#define OID_ATM_SUPPORTED_SERVICE_CATEGORY		0x08010102
#define OID_ATM_SUPPORTED_AAL_TYPES				0x08010103
#define OID_ATM_HW_CURRENT_ADDRESS				0x08010104
#define OID_ATM_MAX_ACTIVE_VCS					0x08010105
#define OID_ATM_MAX_ACTIVE_VCI_BITS				0x08010106
#define OID_ATM_MAX_ACTIVE_VPI_BITS				0x08010107
#define OID_ATM_MAX_AAL0_PACKET_SIZE			0x08010108
#define OID_ATM_MAX_AAL1_PACKET_SIZE			0x08010109
#define OID_ATM_MAX_AAL34_PACKET_SIZE			0x0801010A
#define OID_ATM_MAX_AAL5_PACKET_SIZE			0x0801010B
#define OID_ATM_SIGNALING_VPIVCI				0x08010201
#define OID_ATM_ASSIGNED_VPI					0x08010202
#define OID_ATM_ACQUIRE_ACCESS_NET_RESOURCES	0x08010203
#define OID_ATM_RELEASE_ACCESS_NET_RESOURCES	0x08010204
#define OID_ATM_ILMI_VPIVCI						0x08010205
#define OID_ATM_DIGITAL_BROADCAST_VPIVCI		0x08010206
#define	OID_ATM_GET_NEAREST_FLOW				0x08010207
#define OID_ATM_ALIGNMENT_REQUIRED				0x08010208
//
//      ATM specific statistics OIDs.
//
#define	OID_ATM_RCV_CELLS_OK					0x08020101
#define	OID_ATM_XMIT_CELLS_OK					0x08020102
#define	OID_ATM_RCV_CELLS_DROPPED				0x08020103
#define	OID_ATM_RCV_INVALID_VPI_VCI				0x08020201
#define	OID_ATM_CELLS_HEC_ERROR					0x08020202
#define	OID_ATM_RCV_REASSEMBLY_ERROR			0x08020203
//
// PCCA (Wireless) object
//
//
// All WirelessWAN devices must support the following OIDs
//
#define OID_WW_GEN_NETWORK_TYPES_SUPPORTED		0x09010101
#define OID_WW_GEN_NETWORK_TYPE_IN_USE			0x09010102
#define OID_WW_GEN_HEADER_FORMATS_SUPPORTED		0x09010103
#define OID_WW_GEN_HEADER_FORMAT_IN_USE			0x09010104
#define OID_WW_GEN_INDICATION_REQUEST			0x09010105
#define OID_WW_GEN_DEVICE_INFO					0x09010106
#define OID_WW_GEN_OPERATION_MODE				0x09010107
#define OID_WW_GEN_LOCK_STATUS					0x09010108
#define OID_WW_GEN_DISABLE_TRANSMITTER			0x09010109
#define OID_WW_GEN_NETWORK_ID					0x0901010A
#define OID_WW_GEN_PERMANENT_ADDRESS			0x0901010B
#define OID_WW_GEN_CURRENT_ADDRESS				0x0901010C
#define OID_WW_GEN_SUSPEND_DRIVER				0x0901010D
#define OID_WW_GEN_BASESTATION_ID				0x0901010E
#define OID_WW_GEN_CHANNEL_ID					0x0901010F
#define OID_WW_GEN_ENCRYPTION_SUPPORTED			0x09010110
#define OID_WW_GEN_ENCRYPTION_IN_USE			0x09010111
#define OID_WW_GEN_ENCRYPTION_STATE				0x09010112
#define OID_WW_GEN_CHANNEL_QUALITY				0x09010113
#define OID_WW_GEN_REGISTRATION_STATUS			0x09010114
#define OID_WW_GEN_RADIO_LINK_SPEED				0x09010115
#define OID_WW_GEN_LATENCY						0x09010116
#define OID_WW_GEN_BATTERY_LEVEL				0x09010117
#define OID_WW_GEN_EXTERNAL_POWER				0x09010118
//
// Network Dependent OIDs - Mobitex:
//
#define OID_WW_MBX_SUBADDR						0x09050101
// OID 0x09050102 is reserved and may not be used
#define OID_WW_MBX_FLEXLIST						0x09050103
#define OID_WW_MBX_GROUPLIST					0x09050104
#define OID_WW_MBX_TRAFFIC_AREA					0x09050105
#define OID_WW_MBX_LIVE_DIE						0x09050106
#define OID_WW_MBX_TEMP_DEFAULTLIST				0x09050107
//
// Network Dependent OIDs - Pinpoint:
//
#define OID_WW_PIN_LOC_AUTHORIZE				0x09090101
#define OID_WW_PIN_LAST_LOCATION				0x09090102
#define OID_WW_PIN_LOC_FIX						0x09090103
//
// Network Dependent - CDPD:
//
#define OID_WW_CDPD_SPNI						0x090D0101
#define OID_WW_CDPD_WASI						0x090D0102
#define OID_WW_CDPD_AREA_COLOR					0x090D0103
#define OID_WW_CDPD_TX_POWER_LEVEL				0x090D0104
#define OID_WW_CDPD_EID							0x090D0105
#define OID_WW_CDPD_HEADER_COMPRESSION			0x090D0106
#define OID_WW_CDPD_DATA_COMPRESSION			0x090D0107
#define OID_WW_CDPD_CHANNEL_SELECT				0x090D0108
#define OID_WW_CDPD_CHANNEL_STATE				0x090D0109
#define OID_WW_CDPD_NEI							0x090D010A
#define OID_WW_CDPD_NEI_STATE					0x090D010B
#define OID_WW_CDPD_SERVICE_PROVIDER_IDENTIFIER	0x090D010C
#define OID_WW_CDPD_SLEEP_MODE					0x090D010D
#define OID_WW_CDPD_CIRCUIT_SWITCHED			0x090D010E
#define	OID_WW_CDPD_TEI							0x090D010F
#define	OID_WW_CDPD_RSSI						0x090D0110
//
// Network Dependent - Ardis:
//
#define OID_WW_ARD_SNDCP						0x09110101
#define OID_WW_ARD_TMLY_MSG						0x09110102
#define OID_WW_ARD_DATAGRAM						0x09110103
//
// Network Dependent - DataTac:
//
#define OID_WW_TAC_COMPRESSION					0x09150101
#define OID_WW_TAC_SET_CONFIG					0x09150102
#define OID_WW_TAC_GET_STATUS					0x09150103
#define OID_WW_TAC_USER_HEADER					0x09150104
//
// Network Dependent - Metricom:
//
#define OID_WW_MET_FUNCTION						0x09190101
//
// IRDA objects
//
#define OID_IRDA_RECEIVING						0x0A010100
#define OID_IRDA_TURNAROUND_TIME				0x0A010101
#define OID_IRDA_SUPPORTED_SPEEDS				0x0A010102
#define OID_IRDA_LINK_SPEED						0x0A010103
#define OID_IRDA_MEDIA_BUSY						0x0A010104
#define OID_IRDA_EXTRA_RCV_BOFS					0x0A010200
#define OID_IRDA_RATE_SNIFF						0x0A010201
#define OID_IRDA_UNICAST_LIST					0x0A010202
#define OID_IRDA_MAX_UNICAST_LIST_SIZE			0x0A010203
#define OID_IRDA_MAX_RECEIVE_WINDOW_SIZE		0x0A010204
#define OID_IRDA_MAX_SEND_WINDOW_SIZE			0x0A010205
//
// Medium the Ndis Driver is running on (OID_GEN_MEDIA_SUPPORTED/
// OID_GEN_MEDIA_IN_USE).
//
typedef enum _NDIS_MEDIUM {
    NdisMedium802_3,
    NdisMedium802_5,
    NdisMediumFddi,
    NdisMediumWan,
    NdisMediumLocalTalk,
    NdisMediumDix,		// defined for convenience, not a real medium
     NdisMediumArcnetRaw,
    NdisMediumArcnet878_2,
    NdisMediumAtm,
    NdisMediumWirelessWan,
    NdisMediumIrda,
    NdisMediumMax		// Not a real medium, defined as an upper-bound
} NDIS_MEDIUM, *PNDIS_MEDIUM;

//
// Hardware status codes (OID_GEN_HARDWARE_STATUS).
//
typedef enum _NDIS_HARDWARE_STATUS {
    NdisHardwareStatusReady,
    NdisHardwareStatusInitializing,
    NdisHardwareStatusReset,
    NdisHardwareStatusClosing,
    NdisHardwareStatusNotReady
} NDIS_HARDWARE_STATUS, *PNDIS_HARDWARE_STATUS;

//
// this is the type passed in the OID_GEN_GET_TIME_CAPS request
//
typedef struct _GEN_GET_TIME_CAPS {
    ULONG Flags;		// Bits defined below

    ULONG ClockPrecision;
} GEN_GET_TIME_CAPS, *PGEN_GET_TIME_CAPS;

#define	READABLE_LOCAL_CLOCK					0x000000001
#define	CLOCK_NETWORK_DERIVED					0x000000002
#define	CLOCK_PRECISION							0x000000004
#define	RECEIVE_TIME_INDICATION_CAPABLE			0x000000008
#define	TIMED_SEND_CAPABLE						0x000000010
#define	TIME_STAMP_CAPABLE						0x000000020
//
//
// this is the type passed in the OID_GEN_GET_NETCARD_TIME request
//
typedef struct _GEN_GET_NETCARD_TIME {
    ULONG ReadTime;
} GEN_GET_NETCARD_TIME, *PGEN_GET_NETCARD_TIME;

//
// Defines the attachment types for FDDI (OID_FDDI_ATTACHMENT_TYPE).
//
typedef enum _NDIS_FDDI_ATTACHMENT_TYPE {
    NdisFddiTypeIsolated = 1,
    NdisFddiTypeLocalA,
    NdisFddiTypeLocalB,
    NdisFddiTypeLocalAB,
    NdisFddiTypeLocalS,
    NdisFddiTypeWrapA,
    NdisFddiTypeWrapB,
    NdisFddiTypeWrapAB,
    NdisFddiTypeWrapS,
    NdisFddiTypeCWrapA,
    NdisFddiTypeCWrapB,
    NdisFddiTypeCWrapS,
    NdisFddiTypeThrough
} NDIS_FDDI_ATTACHMENT_TYPE, *PNDIS_FDDI_ATTACHMENT_TYPE;

//
// Defines the ring management states for FDDI (OID_FDDI_RING_MGT_STATE).
//
typedef enum _NDIS_FDDI_RING_MGT_STATE {
    NdisFddiRingIsolated = 1,
    NdisFddiRingNonOperational,
    NdisFddiRingOperational,
    NdisFddiRingDetect,
    NdisFddiRingNonOperationalDup,
    NdisFddiRingOperationalDup,
    NdisFddiRingDirected,
    NdisFddiRingTrace
} NDIS_FDDI_RING_MGT_STATE, *PNDIS_FDDI_RING_MGT_STATE;

//
// Defines the Lconnection state for FDDI (OID_FDDI_LCONNECTION_STATE).
//
typedef enum _NDIS_FDDI_LCONNECTION_STATE {
    NdisFddiStateOff = 1,
    NdisFddiStateBreak,
    NdisFddiStateTrace,
    NdisFddiStateConnect,
    NdisFddiStateNext,
    NdisFddiStateSignal,
    NdisFddiStateJoin,
    NdisFddiStateVerify,
    NdisFddiStateActive,
    NdisFddiStateMaintenance
} NDIS_FDDI_LCONNECTION_STATE, *PNDIS_FDDI_LCONNECTION_STATE;

//
// Defines the medium subtypes for WAN medium (OID_WAN_MEDIUM_SUBTYPE).
//
typedef enum _NDIS_WAN_MEDIUM_SUBTYPE {
    NdisWanMediumHub,
    NdisWanMediumX_25,
    NdisWanMediumIsdn,
    NdisWanMediumSerial,
    NdisWanMediumFrameRelay,
    NdisWanMediumAtm,
    NdisWanMediumSonet,
    NdisWanMediumSW56K
} NDIS_WAN_MEDIUM_SUBTYPE, *PNDIS_WAN_MEDIUM_SUBTYPE;

//
// Defines the header format for WAN medium (OID_WAN_HEADER_FORMAT).
//
typedef enum _NDIS_WAN_HEADER_FORMAT {
    NdisWanHeaderNative,	// src/dest based on subtype, followed by NLPID
     NdisWanHeaderEthernet	// emulation of ethernet header
} NDIS_WAN_HEADER_FORMAT, *PNDIS_WAN_HEADER_FORMAT;

//
// Defines the line quality on a WAN line (OID_WAN_QUALITY_OF_SERVICE).
//
typedef enum _NDIS_WAN_QUALITY {
    NdisWanRaw,
    NdisWanErrorControl,
    NdisWanReliable
} NDIS_WAN_QUALITY, *PNDIS_WAN_QUALITY;

//
// Defines the state of a token-ring adapter (OID_802_5_CURRENT_RING_STATE).
//
typedef enum _NDIS_802_5_RING_STATE {
    NdisRingStateOpened = 1,
    NdisRingStateClosed,
    NdisRingStateOpening,
    NdisRingStateClosing,
    NdisRingStateOpenFailure,
    NdisRingStateRingFailure
} NDIS_802_5_RING_STATE, *PNDIS_802_5_RING_STATE;

//
// Defines the state of the LAN media
//
typedef enum _NDIS_MEDIA_STATE {
    NdisMediaStateConnected,
    NdisMediaStateDisconnected
} NDIS_MEDIA_STATE, *PNDIS_MEDIA_STATE;

//
// The following is set on a per-packet basis as OOB data with NdisClass802_3Priority
//
typedef ULONG Priority_802_3;	// 0-7 priority levels
//
//      The following structure is used to query OID_GEN_CO_LINK_SPEED and
//      OID_GEN_CO_MINIMUM_LINK_SPEED.  The first OID will return the current
//      link speed of the adapter.  The second will return the minimum link speed
//      the adapter is capable of.
//

typedef struct _NDIS_CO_LINK_SPEED {
    ULONG Outbound;
    ULONG Inbound;
} NDIS_CO_LINK_SPEED,

*PNDIS_CO_LINK_SPEED;
//
// Ndis Packet Filter Bits (OID_GEN_CURRENT_PACKET_FILTER).
//
#define NDIS_PACKET_TYPE_DIRECTED				0x0001
#define NDIS_PACKET_TYPE_MULTICAST				0x0002
#define NDIS_PACKET_TYPE_ALL_MULTICAST			0x0004
#define NDIS_PACKET_TYPE_BROADCAST				0x0008
#define NDIS_PACKET_TYPE_SOURCE_ROUTING			0x0010
#define NDIS_PACKET_TYPE_PROMISCUOUS			0x0020
#define NDIS_PACKET_TYPE_SMT					0x0040
#define NDIS_PACKET_TYPE_ALL_LOCAL				0x0080
#define NDIS_PACKET_TYPE_MAC_FRAME				0x8000
#define NDIS_PACKET_TYPE_FUNCTIONAL				0x4000
#define NDIS_PACKET_TYPE_ALL_FUNCTIONAL			0x2000
#define NDIS_PACKET_TYPE_GROUP					0x1000
//
// Ndis Token-Ring Ring Status Codes (OID_802_5_CURRENT_RING_STATUS).
//
#define NDIS_RING_SIGNAL_LOSS					0x00008000
#define NDIS_RING_HARD_ERROR					0x00004000
#define NDIS_RING_SOFT_ERROR					0x00002000
#define NDIS_RING_TRANSMIT_BEACON				0x00001000
#define NDIS_RING_LOBE_WIRE_FAULT				0x00000800
#define NDIS_RING_AUTO_REMOVAL_ERROR			0x00000400
#define NDIS_RING_REMOVE_RECEIVED				0x00000200
#define NDIS_RING_COUNTER_OVERFLOW				0x00000100
#define NDIS_RING_SINGLE_STATION				0x00000080
#define NDIS_RING_RING_RECOVERY					0x00000040
//
// Ndis protocol option bits (OID_GEN_PROTOCOL_OPTIONS).
//
#define NDIS_PROT_OPTION_ESTIMATED_LENGTH   	0x00000001
#define NDIS_PROT_OPTION_NO_LOOPBACK			0x00000002
#define NDIS_PROT_OPTION_NO_RSVD_ON_RCVPKT		0x00000004
//
// Ndis MAC option bits (OID_GEN_MAC_OPTIONS).
//
#define NDIS_MAC_OPTION_COPY_LOOKAHEAD_DATA 	0x00000001
#define NDIS_MAC_OPTION_RECEIVE_SERIALIZED  	0x00000002
#define NDIS_MAC_OPTION_TRANSFERS_NOT_PEND  	0x00000004
#define NDIS_MAC_OPTION_NO_LOOPBACK				0x00000008
#define NDIS_MAC_OPTION_FULL_DUPLEX				0x00000010
#define	NDIS_MAC_OPTION_EOTX_INDICATION			0x00000020
#define NDIS_MAC_OPTION_RESERVED				0x80000000
//
//      NDIS MAC option bits for OID_GEN_CO_MAC_OPTIONS.
//
#define	NDIS_CO_MAC_OPTION_DYNAMIC_LINK_SPEED	0x00000001
#ifdef	IRDA
//
// The following is set on a per-packet basis as OOB data with NdisClassIrdaPacketInfo
// This is the per-packet info specified on a per-packet basis
//
typedef struct _NDIS_IRDA_PACKET_INFO {
    UINT ExtraBOFs;
    UINT MinTurnAroundTime;
} NDIS_IRDA_PACKET_INFO, *PNDIS_IRDA_PACKET_INFO;

#endif
#ifdef  WIRELESS_WAN
//
// Wireless WAN structure definitions
//
//
// currently defined Wireless network subtypes
//
typedef enum _NDIS_WW_NETWORK_TYPE {
    NdisWWGeneric,
    NdisWWMobitex,
    NdisWWPinpoint,
    NdisWWCDPD,
    NdisWWArdis,
    NdisWWDataTAC,
    NdisWWMetricom,
    NdisWWGSM,
    NdisWWCDMA,
    NdisWWTDMA,
    NdisWWAMPS,
    NdisWWInmarsat,
    NdisWWpACT
} NDIS_WW_NETWORK_TYPE;

//
// currently defined header formats
//
typedef enum _NDIS_WW_HEADER_FORMAT {
    NdisWWDIXEthernetFrames,
    NdisWWMPAKFrames,
    NdisWWRDLAPFrames,
    NdisWWMDC4800Frames
} NDIS_WW_HEADER_FORMAT;

//
// currently defined encryption types
//
typedef enum _NDIS_WW_ENCRYPTION_TYPE {
    NdisWWUnknownEncryption = -1,
    NdisWWNoEncryption,
    NdisWWDefaultEncryption
} NDIS_WW_ENCRYPTION_TYPE, *PNDIS_WW_ENCRYPTION_TYPE;

//
// OID_WW_GEN_INDICATION_REQUEST
//
typedef struct _NDIS_WW_INDICATION_REQUEST {
    NDIS_OID Oid;		// IN

    UINT uIndicationFlag;	// IN

    UINT uApplicationToken;	// IN OUT

    HANDLE hIndicationHandle;	// IN OUT

    INT iPollingInterval;	// IN OUT

    NDIS_VAR_DATA_DESC InitialValue;	// IN OUT

    NDIS_VAR_DATA_DESC OIDIndicationValue;	// OUT - only valid after indication

    NDIS_VAR_DATA_DESC TriggerValue;	// IN

} NDIS_WW_INDICATION_REQUEST, *PNDIS_WW_INDICATION_REQUEST;

#define OID_INDICATION_REQUEST_ENABLE			0x0000
#define OID_INDICATION_REQUEST_CANCEL			0x0001
//
// OID_WW_GEN_DEVICE_INFO
//
typedef struct _WW_DEVICE_INFO {
    NDIS_VAR_DATA_DESC Manufacturer;
    NDIS_VAR_DATA_DESC ModelNum;
    NDIS_VAR_DATA_DESC SWVersionNum;
    NDIS_VAR_DATA_DESC SerialNum;
} WW_DEVICE_INFO, *PWW_DEVICE_INFO;

//
// OID_WW_GEN_OPERATION_MODE
//
typedef INT WW_OPERATION_MODE;	//  0 = Normal mode
												//  1 = Power saving mode
												// -1 = mode unknown
//
// OID_WW_GEN_LOCK_STATUS
//

typedef INT WW_LOCK_STATUS;	//  0 = unlocked
												//  1 = locked
												// -1 = unknown lock status
//
// OID_WW_GEN_DISABLE_TRANSMITTER
//

typedef INT WW_DISABLE_TRANSMITTER;	//  0 = transmitter enabled
												//  1 = transmitter disabled
												// -1 = unknown value
//
// OID_WW_GEN_NETWORK_ID
//

typedef NDIS_VAR_DATA_DESC WW_NETWORK_ID;
//
// OID_WW_GEN_PERMANENT_ADDRESS 
//
typedef NDIS_VAR_DATA_DESC WW_PERMANENT_ADDRESS;
//
// OID_WW_GEN_CURRENT_ADDRESS   
//
typedef struct _WW_CURRENT_ADDRESS {
    NDIS_WW_HEADER_FORMAT Format;
    NDIS_VAR_DATA_DESC Address;
} WW_CURRENT_ADDRESS, *PWW_CURRENT_ADDRESS;

//
// OID_WW_GEN_SUSPEND_DRIVER
//
typedef BOOLEAN WW_SUSPEND_DRIVER;	// 0 = driver operational
												// 1 = driver suspended
//
// OID_WW_GEN_BASESTATION_ID
//

typedef NDIS_VAR_DATA_DESC WW_BASESTATION_ID;
//
// OID_WW_GEN_CHANNEL_ID
//
typedef NDIS_VAR_DATA_DESC WW_CHANNEL_ID;
//
// OID_WW_GEN_ENCRYPTION_STATE
//
typedef BOOLEAN WW_ENCRYPTION_STATE;	// 0 = if encryption is disabled
												// 1 = if encryption is enabled
//
// OID_WW_GEN_CHANNEL_QUALITY
//

typedef INT WW_CHANNEL_QUALITY;	//  0 = Not in network contact,
												// 1-100 = Quality of Channel (100 is highest quality).
												// -1 = channel quality is unknown
//
// OID_WW_GEN_REGISTRATION_STATUS
//

typedef INT WW_REGISTRATION_STATUS;	//  0 = Registration denied
												//  1 = Registration pending
												//  2 = Registered
												// -1 = unknown registration status
//
// OID_WW_GEN_RADIO_LINK_SPEED
//

typedef UINT WW_RADIO_LINK_SPEED;	// Bits per second.
//
// OID_WW_GEN_LATENCY
//

typedef UINT WW_LATENCY;	//  milliseconds
//
// OID_WW_GEN_BATTERY_LEVEL
//

typedef INT WW_BATTERY_LEVEL;	//  0-100 = battery level in percentage
												//      (100=fully charged)
												// -1 = unknown battery level.
//
// OID_WW_GEN_EXTERNAL_POWER
//

typedef INT WW_EXTERNAL_POWER;	//   0 = no external power connected
												//   1 = external power connected
												//  -1 = unknown
//
// OID_WW_MET_FUNCTION
//

typedef NDIS_VAR_DATA_DESC WW_MET_FUNCTION;
//
// OID_WW_TAC_COMPRESSION
//
typedef BOOLEAN WW_TAC_COMPRESSION;	// Determines whether or not network level compression
												// is being used.
//
// OID_WW_TAC_SET_CONFIG
//

typedef struct _WW_TAC_SETCONFIG {
    NDIS_VAR_DATA_DESC RCV_MODE;
    NDIS_VAR_DATA_DESC TX_CONTROL;
    NDIS_VAR_DATA_DESC RX_CONTROL;
    NDIS_VAR_DATA_DESC FLOW_CONTROL;
    NDIS_VAR_DATA_DESC RESET_CNF;
    NDIS_VAR_DATA_DESC READ_CNF;
} WW_TAC_SETCONFIG, *PWW_TAC_SETCONFIG;

//
// OID_WW_TAC_GET_STATUS
//
typedef struct _WW_TAC_GETSTATUS {
    BOOLEAN Action;		// Set = Execute command.

    NDIS_VAR_DATA_DESC Command;
    NDIS_VAR_DATA_DESC Option;
    NDIS_VAR_DATA_DESC Response;	// The response to the requested command
    // - max. length of string is 256 octets.

} WW_TAC_GETSTATUS, *PWW_TAC_GETSTATUS;

//
// OID_WW_TAC_USER_HEADER
//
typedef NDIS_VAR_DATA_DESC WW_TAC_USERHEADER;	// This will hold the user header - Max. 64 octets.
//
// OID_WW_ARD_SNDCP
//

typedef struct _WW_ARD_SNDCP {
    NDIS_VAR_DATA_DESC Version;	// The version of SNDCP protocol supported.

    INT BlockSize;		// The block size used for SNDCP

    INT Window;			// The window size used in SNDCP

} WW_ARD_SNDCP, *PWW_ARD_SNDCP;

//
// OID_WW_ARD_TMLY_MSG
//
typedef BOOLEAN WW_ARD_CHANNEL_STATUS;	// The current status of the inbound RF Channel.
//
// OID_WW_ARD_DATAGRAM
//

typedef struct _WW_ARD_DATAGRAM {
    BOOLEAN LoadLevel;		// Byte that contains the load level info.

    INT SessionTime;		// Datagram session time remaining.

    NDIS_VAR_DATA_DESC HostAddr;	// Host address.

    NDIS_VAR_DATA_DESC THostAddr;	// Test host address.

} WW_ARD_DATAGRAM, *PWW_ARD_DATAGRAM;

//
// OID_WW_CDPD_SPNI
//
typedef struct _WW_CDPD_SPNI {
    UINT SPNI[10];		//10 16-bit service provider network IDs

    INT OperatingMode;		// 0 = ignore SPNI,
    // 1 = require SPNI from list,
    // 2 = prefer SPNI from list.
    // 3 = exclude SPNI from list.

} WW_CDPD_SPNI, *PWW_CDPD_SPNI;

//
// OID_WW_CDPD_WASI
//
typedef struct _WW_CDPD_WIDE_AREA_SERVICE_ID {
    UINT WASI[10];		//10 16-bit wide area service IDs

    INT OperatingMode;		// 0 = ignore WASI,
    // 1 = Require WASI from list,
    // 2 = prefer WASI from list
    // 3 = exclude WASI from list.

} WW_CDPD_WIDE_AREA_SERVICE_ID, *PWW_CDPD_WIDE_AREA_SERVICE_ID;

//
// OID_WW_CDPD_AREA_COLOR
//
typedef INT WW_CDPD_AREA_COLOR;
//
// OID_WW_CDPD_TX_POWER_LEVEL
//
typedef UINT WW_CDPD_TX_POWER_LEVEL;
//
// OID_WW_CDPD_EID
//
typedef NDIS_VAR_DATA_DESC WW_CDPD_EID;
//
// OID_WW_CDPD_HEADER_COMPRESSION
//
typedef INT WW_CDPD_HEADER_COMPRESSION;		//  0 = no header compression,
												//  1 = always compress headers,
												//  2 = compress headers if MD-IS does
												// -1 = unknown
//
// OID_WW_CDPD_DATA_COMPRESSION
//

typedef INT WW_CDPD_DATA_COMPRESSION;	// 0  = no data compression,
												// 1  = data compression enabled
												// -1 =  unknown
//
// OID_WW_CDPD_CHANNEL_SELECT
//

typedef struct _WW_CDPD_CHANNEL_SELECT {
    UINT ChannelID;		// channel number

    UINT fixedDuration;		// duration in seconds

} WW_CDPD_CHANNEL_SELECT, *PWW_CDPD_CHANNEL_SELECT;

//
// OID_WW_CDPD_CHANNEL_STATE
//
typedef enum _WW_CDPD_CHANNEL_STATE {
    CDPDChannelNotAvail,
    CDPDChannelScanning,
    CDPDChannelInitAcquired,
    CDPDChannelAcquired,
    CDPDChannelSleeping,
    CDPDChannelWaking,
    CDPDChannelCSDialing,
    CDPDChannelCSRedial,
    CDPDChannelCSAnswering,
    CDPDChannelCSConnected,
    CDPDChannelCSSuspended
} WW_CDPD_CHANNEL_STATE, *PWW_CDPD_CHANNEL_STATE;

//
// OID_WW_CDPD_NEI
//
typedef enum _WW_CDPD_NEI_FORMAT {
    CDPDNeiIPv4,
    CDPDNeiCLNP,
    CDPDNeiIPv6
} WW_CDPD_NEI_FORMAT, *PWW_CDPD_NEI_FORMAT;
typedef enum _WW_CDPD_NEI_TYPE {
    CDPDNeiIndividual,
    CDPDNeiMulticast,
    CDPDNeiBroadcast
} WW_CDPD_NEI_TYPE;
typedef struct _WW_CDPD_NEI {
    UINT uNeiIndex;
    WW_CDPD_NEI_FORMAT NeiFormat;
    WW_CDPD_NEI_TYPE NeiType;
    WORD NeiGmid;		// group member identifier, only
    // meaningful if NeiType ==
    // CDPDNeiMulticast

    NDIS_VAR_DATA_DESC NeiAddress;
} WW_CDPD_NEI;

//
// OID_WW_CDPD_NEI_STATE
//
typedef enum _WW_CDPD_NEI_STATE {
    CDPDUnknown,
    CDPDRegistered,
    CDPDDeregistered
} WW_CDPD_NEI_STATE, *PWW_CDPD_NEI_STATE;
typedef enum _WW_CDPD_NEI_SUB_STATE {
    CDPDPending,		// Registration pending
     CDPDNoReason,		// Registration denied - no reason given
     CDPDMDISNotCapable,	// Registration denied - MD-IS not capable of
    //  handling M-ES at this time
     CDPDNEINotAuthorized,	// Registration denied - NEI is not authorized to
    //  use this subnetwork
     CDPDInsufficientAuth,	// Registration denied - M-ES gave insufficient
    //  authentication credentials
     CDPDUnsupportedAuth,	// Registration denied - M-ES gave unsupported
    //  authentication credentials
     CDPDUsageExceeded,		// Registration denied - NEI has exceeded usage
    //  limitations
     CDPDDeniedThisNetwork	// Registration denied on this network, service
    //  may be obtained on alternate Service Provider
    //  network
} WW_CDPD_NEI_SUB_STATE;
typedef struct _WW_CDPD_NEI_REG_STATE {
    UINT uNeiIndex;
    WW_CDPD_NEI_STATE NeiState;
    WW_CDPD_NEI_SUB_STATE NeiSubState;
} WW_CDPD_NEI_REG_STATE, *PWW_CDPD_NEI_REG_STATE;

//
// OID_WW_CDPD_SERVICE_PROVIDER_IDENTIFIER
//
typedef struct _WW_CDPD_SERVICE_PROVIDER_ID {
    UINT SPI[10];		//10 16-bit service provider IDs

    INT OperatingMode;		// 0 = ignore SPI,
    // 1 = require SPI from list,
    // 2 = prefer SPI from list.
    // 3 = exclude SPI from list.

} WW_CDPD_SERVICE_PROVIDER_ID, *PWW_CDPD_SERVICE_PROVIDER_ID;

//
// OID_WW_CDPD_SLEEP_MODE
//
typedef INT WW_CDPD_SLEEP_MODE;
//
// OID_WW_CDPD_TEI
//
typedef ULONG WW_CDPD_TEI;
//
// OID_WW_CDPD_CIRCUIT_SWITCHED
//
typedef struct _WW_CDPD_CIRCUIT_SWITCHED {
    INT service_preference;	// -1 = unknown,
    //  0 = always use packet switched CDPD,
    //  1 = always use CS CDPD via AMPS,
    //  2 = always use CS CDPD via PSTN,
    //  3 = use circuit switched via AMPS only
    //      when packet switched is not available.
    //  4 = use packet switched only when circuit
    //   switched via AMPS is not available.
    //  5 = device manuf. defined service
    //   preference.
    //  6 = device manuf. defined service
    //   preference.

    INT service_status;		// -1 = unknown,
    //  0 = packet switched CDPD,
    //  1 = circuit switched CDPD via AMPS,
    //  2 = circuit switched CDPD via PSTN.

    INT connect_rate;		//  CS connection bit rate (bits per second).
    //  0 = no active connection,
    // -1 = unknown
    //  Dial code last used to dial.

    NDIS_VAR_DATA_DESC dial_code[20];

    UINT sid;			//  Current AMPS system ID

    INT a_b_side_selection;	// -1 = unknown,
    //  0 = no AMPS service
    //  1 = AMPS "A" side channels selected
    //  2 = AMPS "B" side channels selected

    INT AMPS_channel;		// -1= unknown
    //  0 = no AMPS service.
    //  1-1023 = AMPS channel number in use

    UINT action;		//  0 = no action
    //  1 = suspend (hangup)
    //  2 = dial

    //  Default dial code for CS CDPD service
    //  encoded as specified in the CS CDPD
    //  implementor guidelines.
    NDIS_VAR_DATA_DESC default_dial[20];

    //  Number for the CS CDPD network to call
    //   back the mobile, encoded as specified in
    //   the CS CDPD implementor guidelines.
    NDIS_VAR_DATA_DESC call_back[20];

    UINT sid_list[10];		//  List of 10 16-bit preferred AMPS
    //   system IDs for CS CDPD.

    UINT inactivity_timer;	//  Wait time after last data before dropping
    //   call.
    //  0-65535 = inactivity time limit (seconds).

    UINT receive_timer;		//  secs. per CS-CDPD Implementor Guidelines.

    UINT conn_resp_timer;	//  secs. per CS-CDPD Implementor Guidelines.

    UINT reconn_resp_timer;	//  secs. per CS-CDPD Implementor Guidelines.

    UINT disconn_timer;		//  secs. per CS-CDPD Implementor Guidelines.

    UINT NEI_reg_timer;		//  secs. per CS-CDPD Implementor Guidelines.

    UINT reconn_retry_timer;	//  secs. per CS-CDPD Implementor Guidelines.

    UINT link_reset_timer;	//  secs. per CS-CDPD Implementor Guidelines.

    UINT link_reset_ack_timer;	//  secs. per CS-CDPD Implementor Guidelines.

    UINT n401_retry_limit;	//  per CS-CDPD Implementor Guidelines.

    UINT n402_retry_limit;	//  per CS-CDPD Implementor Guidelines.

    UINT n404_retry_limit;	//  per CS-CDPD Implementor Guidelines.

    UINT n405_retry_limit;	//  per CS-CDPD Implementor Guidelines.

} WW_CDPD_CIRCUIT_SWITCHED, *WW_PCDPD_CIRCUIT_SWITCHED;
typedef UINT WW_CDPD_RSSI;
//
// OID_WW_PIN_LOC_AUTHORIZE
//
typedef INT WW_PIN_AUTHORIZED;	// 0  = unauthorized
												// 1  = authorized
												// -1 = unknown
//
// OID_WW_PIN_LAST_LOCATION
// OID_WW_PIN_LOC_FIX
//

typedef struct _WW_PIN_LOCATION {
    INT Latitude;		// Latitude in hundredths of a second

    INT Longitude;		// Longitude in hundredths of a second

    INT Altitude;		// Altitude in feet

    INT FixTime;		// Time of the location fix, since midnight,  local time (of the
    // current day), in tenths of a second

    INT NetTime;		// Current local network time of the current day, since midnight,
    // in tenths of a second

    INT LocQuality;		// 0-100 = location quality

    INT LatReg;			// Latitude registration offset, in hundredths of a second

    INT LongReg;		// Longitude registration offset, in hundredths of a second

    INT GMTOffset;		// Offset in minutes of the local time zone from GMT

} WW_PIN_LOCATION, *PWW_PIN_LOCATION;

//
// The following is set on a per-packet basis as OOB data with NdisClassWirelessWanMbxMailbox
//
typedef ULONG WW_MBX_MAILBOX_FLAG;	// 1 = set mailbox flag, 0 = do not set mailbox flag
//
// OID_WW_MBX_SUBADDR
//

typedef struct _WW_MBX_PMAN {
    BOOLEAN ACTION;		// 0 = Login PMAN,  1 = Logout PMAN

    UINT MAN;
    UCHAR PASSWORD[8];		// Password should be null for Logout and indications.
    // Maximum length of password is 8 chars.

} WW_MBX_PMAN, *PWW_MBX_PMAN;

//
// OID_WW_MBX_FLEXLIST
//
typedef struct _WW_MBX_FLEXLIST {
    INT count;			//  Number of MAN entries used.
    // -1=unknown.

    UINT MAN[7];		//  List of MANs.

} WW_MBX_FLEXLIST;

//
// OID_WW_MBX_GROUPLIST
//
typedef struct _WW_MBX_GROUPLIST {
    INT count;			//  Number of MAN entries used.
    // -1=unknown.

    UINT MAN[15];		//  List of MANs.

} WW_MBX_GROUPLIST;

//
// OID_WW_MBX_TRAFFIC_AREA
//
typedef enum _WW_MBX_TRAFFIC_AREA {
    unknown_traffic_area,	// The driver has no information about the current traffic area.
     in_traffic_area,		// Mobile unit has entered a subscribed traffic area.
     in_auth_traffic_area,	// Mobile unit is outside traffic area but is authorized.
     unauth_traffic_area	// Mobile unit is outside traffic area but is un-authorized.
} WW_MBX_TRAFFIC_AREA;

//
// OID_WW_MBX_LIVE_DIE
//
typedef INT WW_MBX_LIVE_DIE;	//  0 = DIE last received       
												//  1 = LIVE last received
												// -1 = unknown
//
// OID_WW_MBX_TEMP_DEFAULTLIST
//

typedef struct _WW_MBX_CHANNEL_PAIR {
    UINT Mobile_Tx;
    UINT Mobile_Rx;
} WW_MBX_CHANNEL_PAIR, *PWW_MBX_CHANNEL_PAIR;
typedef struct _WW_MBX_TEMPDEFAULTLIST {
    UINT Length;
    WW_MBX_CHANNEL_PAIR ChannelPair[1];
} WW_MBX_TEMPDEFAULTLIST, *WW_PMBX_TEMPDEFAULTLIST;

#endif				// WIRELESS_WAN
#endif				// _NTDDNDIS_