4 * Network Device Interface Specification definitions
6 * This file is part of the w32api package.
9 * Created by Casper S. Hornstrup <chorns@users.sourceforge.net>
11 * THIS SOFTWARE IS NOT COPYRIGHTED
13 * This source code is offered for use in the public domain. You may
14 * use, modify or distribute it freely.
16 * This code is distributed in the hope that it will be useful but
17 * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
18 * DISCLAIMED. This includes but is not limited to warranties of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
21 * DEFINES: i386 - Target platform is i386
22 * NDIS_WRAPPER - Define only for NDIS library
23 * NDIS_MINIPORT_DRIVER - Define only for NDIS miniport drivers
24 * NDIS40 - Use NDIS 4.0 structures by default
25 * NDIS50 - Use NDIS 5.0 structures by default
26 * NDIS51 - Use NDIS 5.1 structures by default
27 * NDIS40_MINIPORT - Building NDIS 4.0 miniport driver
28 * NDIS50_MINIPORT - Building NDIS 5.0 miniport driver
29 * NDIS51_MINIPORT - Building NDIS 5.1 miniport driver
36 #pragma GCC system_header
49 #if defined(NDIS_WRAPPER)
50 #define NDISAPI DECLSPEC_EXPORT
52 #define NDISAPI DECLSPEC_IMPORT
55 #if defined(NDIS50_MINIPORT) && !defined(NDIS_MINIPORT_MAJOR_VERSION) && !defined(NDIS_MINIPORT_MINOR_VERSION)
56 #define NDIS_MINIPORT_MAJOR_VERSION 5
57 #define NDIS_MINIPORT_MINOR_VERSION 0
60 #if defined(NDIS51_MINIPORT) && !defined(NDIS_MINIPORT_MAJOR_VERSION) && !defined(NDIS_MINIPORT_MINOR_VERSION)
61 #define NDIS_MINIPORT_MAJOR_VERSION 5
62 #define NDIS_MINIPORT_MINOR_VERSION 1
65 #if defined(NDIS50) && !defined(NDIS_PROTOCOL_MAJOR_VERSION) && !defined(NDIS_PROTOCOL_MINOR_VERSION)
66 #define NDIS_PROTOCOL_MAJOR_VERSION 5
67 #define NDIS_PROTOCOL_MINOR_VERSION 0
70 #if defined(NDIS51) && !defined(NDIS_PROTOCOL_MAJOR_VERSION) && !defined(NDIS_PROTOCOL_MINOR_VERSION)
71 #define NDIS_PROTOCOL_MAJOR_VERSION 5
72 #define NDIS_PROTOCOL_MINOR_VERSION 1
75 #if defined(NDIS_MINIPORT_DRIVER) && !defined(BINARY_COMPATIBLE)
76 #define BINARY_COMPATIBLE 1
79 #if !defined(_M_IX86) && BINARY_COMPATIBLE
80 #undef BINARY_COMPATIBLE
81 #define BINARY_COMPATIBLE 0
86 typedef PVOID QUEUED_CLOSE
;
89 typedef ULONG NDIS_OID
, *PNDIS_OID
;
91 typedef struct _X_FILTER FDDI_FILTER
, *PFDDI_FILTER
;
92 typedef struct _X_FILTER TR_FILTER
, *PTR_FILTER
;
93 typedef struct _X_FILTER NULL_FILTER
, *PNULL_FILTER
;
95 typedef struct _REFERENCE
{
97 USHORT ReferenceCount
;
99 } REFERENCE
, * PREFERENCE
;
102 /* NDIS base types */
104 typedef struct _NDIS_SPIN_LOCK
{
107 } NDIS_SPIN_LOCK
, * PNDIS_SPIN_LOCK
;
109 typedef struct _NDIS_EVENT
{
111 } NDIS_EVENT
, *PNDIS_EVENT
;
113 typedef PVOID NDIS_HANDLE
, *PNDIS_HANDLE
;
114 typedef int NDIS_STATUS
, *PNDIS_STATUS
;
116 typedef ANSI_STRING NDIS_ANSI_STRING
, *PNDIS_ANSI_STRING
;
117 typedef UNICODE_STRING NDIS_STRING
, *PNDIS_STRING
;
119 typedef MDL NDIS_BUFFER
, *PNDIS_BUFFER
;
120 typedef ULONG NDIS_ERROR_CODE
, *PNDIS_ERROR_CODE
;
123 /* NDIS_STATUS constants */
124 #define NDIS_STATUS_SUCCESS ((NDIS_STATUS)STATUS_SUCCESS)
125 #define NDIS_STATUS_PENDING ((NDIS_STATUS)STATUS_PENDING)
126 #define NDIS_STATUS_NOT_RECOGNIZED ((NDIS_STATUS)0x00010001L)
127 #define NDIS_STATUS_NOT_COPIED ((NDIS_STATUS)0x00010002L)
128 #define NDIS_STATUS_NOT_ACCEPTED ((NDIS_STATUS)0x00010003L)
129 #define NDIS_STATUS_CALL_ACTIVE ((NDIS_STATUS)0x00010007L)
130 #define NDIS_STATUS_ONLINE ((NDIS_STATUS)0x40010003L)
131 #define NDIS_STATUS_RESET_START ((NDIS_STATUS)0x40010004L)
132 #define NDIS_STATUS_RESET_END ((NDIS_STATUS)0x40010005L)
133 #define NDIS_STATUS_RING_STATUS ((NDIS_STATUS)0x40010006L)
134 #define NDIS_STATUS_CLOSED ((NDIS_STATUS)0x40010007L)
135 #define NDIS_STATUS_WAN_LINE_UP ((NDIS_STATUS)0x40010008L)
136 #define NDIS_STATUS_WAN_LINE_DOWN ((NDIS_STATUS)0x40010009L)
137 #define NDIS_STATUS_WAN_FRAGMENT ((NDIS_STATUS)0x4001000AL)
138 #define NDIS_STATUS_MEDIA_CONNECT ((NDIS_STATUS)0x4001000BL)
139 #define NDIS_STATUS_MEDIA_DISCONNECT ((NDIS_STATUS)0x4001000CL)
140 #define NDIS_STATUS_HARDWARE_LINE_UP ((NDIS_STATUS)0x4001000DL)
141 #define NDIS_STATUS_HARDWARE_LINE_DOWN ((NDIS_STATUS)0x4001000EL)
142 #define NDIS_STATUS_INTERFACE_UP ((NDIS_STATUS)0x4001000FL)
143 #define NDIS_STATUS_INTERFACE_DOWN ((NDIS_STATUS)0x40010010L)
144 #define NDIS_STATUS_MEDIA_BUSY ((NDIS_STATUS)0x40010011L)
145 #define NDIS_STATUS_MEDIA_SPECIFIC_INDICATION ((NDIS_STATUS)0x40010012L)
146 #define NDIS_STATUS_WW_INDICATION NDIS_STATUS_MEDIA_SPECIFIC_INDICATION
147 #define NDIS_STATUS_LINK_SPEED_CHANGE ((NDIS_STATUS)0x40010013L)
148 #define NDIS_STATUS_WAN_GET_STATS ((NDIS_STATUS)0x40010014L)
149 #define NDIS_STATUS_WAN_CO_FRAGMENT ((NDIS_STATUS)0x40010015L)
150 #define NDIS_STATUS_WAN_CO_LINKPARAMS ((NDIS_STATUS)0x40010016L)
152 #define NDIS_STATUS_NOT_RESETTABLE ((NDIS_STATUS)0x80010001L)
153 #define NDIS_STATUS_SOFT_ERRORS ((NDIS_STATUS)0x80010003L)
154 #define NDIS_STATUS_HARD_ERRORS ((NDIS_STATUS)0x80010004L)
155 #define NDIS_STATUS_BUFFER_OVERFLOW ((NDIS_STATUS)STATUS_BUFFER_OVERFLOW)
157 #define NDIS_STATUS_FAILURE ((NDIS_STATUS)STATUS_UNSUCCESSFUL)
158 #define NDIS_STATUS_RESOURCES ((NDIS_STATUS)STATUS_INSUFFICIENT_RESOURCES)
159 #define NDIS_STATUS_CLOSING ((NDIS_STATUS)0xC0010002L)
160 #define NDIS_STATUS_BAD_VERSION ((NDIS_STATUS)0xC0010004L)
161 #define NDIS_STATUS_BAD_CHARACTERISTICS ((NDIS_STATUS)0xC0010005L)
162 #define NDIS_STATUS_ADAPTER_NOT_FOUND ((NDIS_STATUS)0xC0010006L)
163 #define NDIS_STATUS_OPEN_FAILED ((NDIS_STATUS)0xC0010007L)
164 #define NDIS_STATUS_DEVICE_FAILED ((NDIS_STATUS)0xC0010008L)
165 #define NDIS_STATUS_MULTICAST_FULL ((NDIS_STATUS)0xC0010009L)
166 #define NDIS_STATUS_MULTICAST_EXISTS ((NDIS_STATUS)0xC001000AL)
167 #define NDIS_STATUS_MULTICAST_NOT_FOUND ((NDIS_STATUS)0xC001000BL)
168 #define NDIS_STATUS_REQUEST_ABORTED ((NDIS_STATUS)0xC001000CL)
169 #define NDIS_STATUS_RESET_IN_PROGRESS ((NDIS_STATUS)0xC001000DL)
170 #define NDIS_STATUS_CLOSING_INDICATING ((NDIS_STATUS)0xC001000EL)
171 #define NDIS_STATUS_NOT_SUPPORTED ((NDIS_STATUS)STATUS_NOT_SUPPORTED)
172 #define NDIS_STATUS_INVALID_PACKET ((NDIS_STATUS)0xC001000FL)
173 #define NDIS_STATUS_OPEN_LIST_FULL ((NDIS_STATUS)0xC0010010L)
174 #define NDIS_STATUS_ADAPTER_NOT_READY ((NDIS_STATUS)0xC0010011L)
175 #define NDIS_STATUS_ADAPTER_NOT_OPEN ((NDIS_STATUS)0xC0010012L)
176 #define NDIS_STATUS_NOT_INDICATING ((NDIS_STATUS)0xC0010013L)
177 #define NDIS_STATUS_INVALID_LENGTH ((NDIS_STATUS)0xC0010014L)
178 #define NDIS_STATUS_INVALID_DATA ((NDIS_STATUS)0xC0010015L)
179 #define NDIS_STATUS_BUFFER_TOO_SHORT ((NDIS_STATUS)0xC0010016L)
180 #define NDIS_STATUS_INVALID_OID ((NDIS_STATUS)0xC0010017L)
181 #define NDIS_STATUS_ADAPTER_REMOVED ((NDIS_STATUS)0xC0010018L)
182 #define NDIS_STATUS_UNSUPPORTED_MEDIA ((NDIS_STATUS)0xC0010019L)
183 #define NDIS_STATUS_GROUP_ADDRESS_IN_USE ((NDIS_STATUS)0xC001001AL)
184 #define NDIS_STATUS_FILE_NOT_FOUND ((NDIS_STATUS)0xC001001BL)
185 #define NDIS_STATUS_ERROR_READING_FILE ((NDIS_STATUS)0xC001001CL)
186 #define NDIS_STATUS_ALREADY_MAPPED ((NDIS_STATUS)0xC001001DL)
187 #define NDIS_STATUS_RESOURCE_CONFLICT ((NDIS_STATUS)0xC001001EL)
188 #define NDIS_STATUS_NO_CABLE ((NDIS_STATUS)0xC001001FL)
190 #define NDIS_STATUS_INVALID_SAP ((NDIS_STATUS)0xC0010020L)
191 #define NDIS_STATUS_SAP_IN_USE ((NDIS_STATUS)0xC0010021L)
192 #define NDIS_STATUS_INVALID_ADDRESS ((NDIS_STATUS)0xC0010022L)
193 #define NDIS_STATUS_VC_NOT_ACTIVATED ((NDIS_STATUS)0xC0010023L)
194 #define NDIS_STATUS_DEST_OUT_OF_ORDER ((NDIS_STATUS)0xC0010024L)
195 #define NDIS_STATUS_VC_NOT_AVAILABLE ((NDIS_STATUS)0xC0010025L)
196 #define NDIS_STATUS_CELLRATE_NOT_AVAILABLE ((NDIS_STATUS)0xC0010026L)
197 #define NDIS_STATUS_INCOMPATABLE_QOS ((NDIS_STATUS)0xC0010027L)
198 #define NDIS_STATUS_AAL_PARAMS_UNSUPPORTED ((NDIS_STATUS)0xC0010028L)
199 #define NDIS_STATUS_NO_ROUTE_TO_DESTINATION ((NDIS_STATUS)0xC0010029L)
201 #define NDIS_STATUS_TOKEN_RING_OPEN_ERROR ((NDIS_STATUS)0xC0011000L)
202 #define NDIS_STATUS_INVALID_DEVICE_REQUEST ((NDIS_STATUS)STATUS_INVALID_DEVICE_REQUEST)
203 #define NDIS_STATUS_NETWORK_UNREACHABLE ((NDIS_STATUS)STATUS_NETWORK_UNREACHABLE)
206 /* NDIS error codes for error logging */
208 #define NDIS_ERROR_CODE_RESOURCE_CONFLICT EVENT_NDIS_RESOURCE_CONFLICT
209 #define NDIS_ERROR_CODE_OUT_OF_RESOURCES EVENT_NDIS_OUT_OF_RESOURCE
210 #define NDIS_ERROR_CODE_HARDWARE_FAILURE EVENT_NDIS_HARDWARE_FAILURE
211 #define NDIS_ERROR_CODE_ADAPTER_NOT_FOUND EVENT_NDIS_ADAPTER_NOT_FOUND
212 #define NDIS_ERROR_CODE_INTERRUPT_CONNECT EVENT_NDIS_INTERRUPT_CONNECT
213 #define NDIS_ERROR_CODE_DRIVER_FAILURE EVENT_NDIS_DRIVER_FAILURE
214 #define NDIS_ERROR_CODE_BAD_VERSION EVENT_NDIS_BAD_VERSION
215 #define NDIS_ERROR_CODE_TIMEOUT EVENT_NDIS_TIMEOUT
216 #define NDIS_ERROR_CODE_NETWORK_ADDRESS EVENT_NDIS_NETWORK_ADDRESS
217 #define NDIS_ERROR_CODE_UNSUPPORTED_CONFIGURATION EVENT_NDIS_UNSUPPORTED_CONFIGURATION
218 #define NDIS_ERROR_CODE_INVALID_VALUE_FROM_ADAPTER EVENT_NDIS_INVALID_VALUE_FROM_ADAPTER
219 #define NDIS_ERROR_CODE_MISSING_CONFIGURATION_PARAMETER EVENT_NDIS_MISSING_CONFIGURATION_PARAMETER
220 #define NDIS_ERROR_CODE_BAD_IO_BASE_ADDRESS EVENT_NDIS_BAD_IO_BASE_ADDRESS
221 #define NDIS_ERROR_CODE_RECEIVE_SPACE_SMALL EVENT_NDIS_RECEIVE_SPACE_SMALL
222 #define NDIS_ERROR_CODE_ADAPTER_DISABLED EVENT_NDIS_ADAPTER_DISABLED
225 /* Memory allocation flags. Used by Ndis[Allocate|Free]Memory */
226 #define NDIS_MEMORY_CONTIGUOUS 0x00000001
227 #define NDIS_MEMORY_NONCACHED 0x00000002
229 /* NIC attribute flags. Used by NdisMSetAttributes(Ex) */
230 #define NDIS_ATTRIBUTE_IGNORE_PACKET_TIMEOUT 0x00000001
231 #define NDIS_ATTRIBUTE_IGNORE_REQUEST_TIMEOUT 0x00000002
232 #define NDIS_ATTRIBUTE_IGNORE_TOKEN_RING_ERRORS 0x00000004
233 #define NDIS_ATTRIBUTE_BUS_MASTER 0x00000008
234 #define NDIS_ATTRIBUTE_INTERMEDIATE_DRIVER 0x00000010
235 #define NDIS_ATTRIBUTE_DESERIALIZE 0x00000020
236 #define NDIS_ATTRIBUTE_NO_HALT_ON_SUSPEND 0x00000040
237 #define NDIS_ATTRIBUTE_SURPRISE_REMOVE_OK 0x00000080
238 #define NDIS_ATTRIBUTE_NOT_CO_NDIS 0x00000100
239 #define NDIS_ATTRIBUTE_USES_SAFE_BUFFER_APIS 0x00000200
244 typedef union _NDIS_RW_LOCK_REFCOUNT
{
247 } NDIS_RW_LOCK_REFCOUNT
;
249 typedef struct _NDIS_RW_LOCK
{
258 NDIS_RW_LOCK_REFCOUNT RefCount
[MAXIMUM_PROCESSORS
];
259 } NDIS_RW_LOCK
, *PNDIS_RW_LOCK
;
261 typedef struct _LOCK_STATE
{
264 } LOCK_STATE
, *PLOCK_STATE
;
271 (*PNDIS_TIMER_FUNCTION
)(
272 IN PVOID SystemSpecific1
,
273 IN PVOID FunctionContext
,
274 IN PVOID SystemSpecific2
,
275 IN PVOID SystemSpecific3
);
277 typedef struct _NDIS_TIMER
{
280 } NDIS_TIMER
, *PNDIS_TIMER
;
286 typedef CM_MCA_POS_DATA NDIS_MCA_POS_DATA
, *PNDIS_MCA_POS_DATA
;
287 typedef CM_EISA_SLOT_INFORMATION NDIS_EISA_SLOT_INFORMATION
, *PNDIS_EISA_SLOT_INFORMATION
;
288 typedef CM_EISA_FUNCTION_INFORMATION NDIS_EISA_FUNCTION_INFORMATION
, *PNDIS_EISA_FUNCTION_INFORMATION
;
289 typedef CM_PARTIAL_RESOURCE_LIST NDIS_RESOURCE_LIST
, *PNDIS_RESOURCE_LIST
;
291 /* Hardware status codes (OID_GEN_HARDWARE_STATUS) */
292 typedef enum _NDIS_HARDWARE_STATUS
{
293 NdisHardwareStatusReady
,
294 NdisHardwareStatusInitializing
,
295 NdisHardwareStatusReset
,
296 NdisHardwareStatusClosing
,
297 NdisHardwareStatusNotReady
298 } NDIS_HARDWARE_STATUS
, *PNDIS_HARDWARE_STATUS
;
300 /* OID_GEN_GET_TIME_CAPS */
301 typedef struct _GEN_GET_TIME_CAPS
{
303 ULONG ClockPrecision
;
304 } GEN_GET_TIME_CAPS
, *PGEN_GET_TIME_CAPS
;
307 #define READABLE_LOCAL_CLOCK 0x00000001
308 #define CLOCK_NETWORK_DERIVED 0x00000002
309 #define CLOCK_PRECISION 0x00000004
310 #define RECEIVE_TIME_INDICATION_CAPABLE 0x00000008
311 #define TIMED_SEND_CAPABLE 0x00000010
312 #define TIME_STAMP_CAPABLE 0x00000020
314 /* OID_GEN_GET_NETCARD_TIME */
315 typedef struct _GEN_GET_NETCARD_TIME
{
317 } GEN_GET_NETCARD_TIME
, *PGEN_GET_NETCARD_TIME
;
319 /* NDIS driver medium (OID_GEN_MEDIA_SUPPORTED / OID_GEN_MEDIA_IN_USE) */
320 typedef enum _NDIS_MEDIUM
{
328 NdisMediumArcnet878_2
,
330 NdisMediumWirelessWan
,
336 } NDIS_MEDIUM
, *PNDIS_MEDIUM
;
338 /* NDIS packet filter bits (OID_GEN_CURRENT_PACKET_FILTER) */
339 #define NDIS_PACKET_TYPE_DIRECTED 0x00000001
340 #define NDIS_PACKET_TYPE_MULTICAST 0x00000002
341 #define NDIS_PACKET_TYPE_ALL_MULTICAST 0x00000004
342 #define NDIS_PACKET_TYPE_BROADCAST 0x00000008
343 #define NDIS_PACKET_TYPE_SOURCE_ROUTING 0x00000010
344 #define NDIS_PACKET_TYPE_PROMISCUOUS 0x00000020
345 #define NDIS_PACKET_TYPE_SMT 0x00000040
346 #define NDIS_PACKET_TYPE_ALL_LOCAL 0x00000080
347 #define NDIS_PACKET_TYPE_GROUP 0x00001000
348 #define NDIS_PACKET_TYPE_ALL_FUNCTIONAL 0x00002000
349 #define NDIS_PACKET_TYPE_FUNCTIONAL 0x00004000
350 #define NDIS_PACKET_TYPE_MAC_FRAME 0x00008000
352 /* NDIS protocol option bits (OID_GEN_PROTOCOL_OPTIONS) */
353 #define NDIS_PROT_OPTION_ESTIMATED_LENGTH 0x00000001
354 #define NDIS_PROT_OPTION_NO_LOOPBACK 0x00000002
355 #define NDIS_PROT_OPTION_NO_RSVD_ON_RCVPKT 0x00000004
357 /* NDIS MAC option bits (OID_GEN_MAC_OPTIONS) */
358 #define NDIS_MAC_OPTION_COPY_LOOKAHEAD_DATA 0x00000001
359 #define NDIS_MAC_OPTION_RECEIVE_SERIALIZED 0x00000002
360 #define NDIS_MAC_OPTION_TRANSFERS_NOT_PEND 0x00000004
361 #define NDIS_MAC_OPTION_NO_LOOPBACK 0x00000008
362 #define NDIS_MAC_OPTION_FULL_DUPLEX 0x00000010
363 #define NDIS_MAC_OPTION_EOTX_INDICATION 0x00000020
364 #define NDIS_MAC_OPTION_8021P_PRIORITY 0x00000040
365 #define NDIS_MAC_OPTION_RESERVED 0x80000000
367 /* State of the LAN media (OID_GEN_MEDIA_CONNECT_STATUS) */
368 typedef enum _NDIS_MEDIA_STATE
{
369 NdisMediaStateConnected
,
370 NdisMediaStateDisconnected
371 } NDIS_MEDIA_STATE
, *PNDIS_MEDIA_STATE
;
373 /* OID_GEN_SUPPORTED_GUIDS */
374 typedef struct _NDIS_GUID
{
382 } NDIS_GUID
, *PNDIS_GUID
;
384 #define NDIS_GUID_TO_OID 0x00000001
385 #define NDIS_GUID_TO_STATUS 0x00000002
386 #define NDIS_GUID_ANSI_STRING 0x00000004
387 #define NDIS_GUID_UNICODE_STRING 0x00000008
388 #define NDIS_GUID_ARRAY 0x00000010
391 typedef struct _NDIS_PACKET_POOL
{
392 NDIS_SPIN_LOCK SpinLock
;
393 struct _NDIS_PACKET
*FreeList
;
396 } NDIS_PACKET_POOL
, * PNDIS_PACKET_POOL
;
398 /* NDIS_PACKET_PRIVATE.Flags constants */
399 #define fPACKET_CONTAINS_MEDIA_SPECIFIC_INFO 0x40
400 #define fPACKET_ALLOCATED_BY_NDIS 0x80
402 typedef struct _NDIS_PACKET_PRIVATE
{
407 PNDIS_PACKET_POOL Pool
;
411 UCHAR NdisPacketFlags
;
412 USHORT NdisPacketOobOffset
;
413 } NDIS_PACKET_PRIVATE
, * PNDIS_PACKET_PRIVATE
;
415 typedef struct _NDIS_PACKET
{
416 NDIS_PACKET_PRIVATE Private
;
419 UCHAR MiniportReserved
[2 * sizeof(PVOID
)];
420 UCHAR WrapperReserved
[2 * sizeof(PVOID
)];
423 UCHAR MiniportReservedEx
[3 * sizeof(PVOID
)];
424 UCHAR WrapperReservedEx
[sizeof(PVOID
)];
427 UCHAR MacReserved
[4 * sizeof(PVOID
)];
430 ULONG_PTR Reserved
[2];
431 UCHAR ProtocolReserved
[1];
432 } NDIS_PACKET
, *PNDIS_PACKET
, **PPNDIS_PACKET
;
434 typedef enum _NDIS_CLASS_ID
{
435 NdisClass802_3Priority
,
436 NdisClassWirelessWanMbxMailbox
,
437 NdisClassIrdaPacketInfo
,
441 typedef struct MediaSpecificInformation
{
442 UINT NextEntryOffset
;
443 NDIS_CLASS_ID ClassId
;
445 UCHAR ClassInformation
[1];
446 } MEDIA_SPECIFIC_INFORMATION
;
448 typedef struct _NDIS_PACKET_OOB_DATA
{
449 _ANONYMOUS_UNION
union {
450 ULONGLONG TimeToSend
;
453 ULONGLONG TimeReceived
;
455 UINT SizeMediaSpecificInfo
;
456 PVOID MediaSpecificInformation
;
458 } NDIS_PACKET_OOB_DATA
, *PNDIS_PACKET_OOB_DATA
;
460 typedef struct _NDIS_PM_PACKET_PATTERN
{
467 } NDIS_PM_PACKET_PATTERN
, *PNDIS_PM_PACKET_PATTERN
;
470 /* Request types used by NdisRequest */
471 typedef enum _NDIS_REQUEST_TYPE
{
472 NdisRequestQueryInformation
,
473 NdisRequestSetInformation
,
474 NdisRequestQueryStatistics
,
478 NdisRequestTransferData
,
484 } NDIS_REQUEST_TYPE
, *PNDIS_REQUEST_TYPE
;
486 typedef struct _NDIS_REQUEST
{
487 UCHAR MacReserved
[4 * sizeof(PVOID
)];
488 NDIS_REQUEST_TYPE RequestType
;
490 struct QUERY_INFORMATION
{
492 PVOID InformationBuffer
;
493 UINT InformationBufferLength
;
497 struct SET_INFORMATION
{
499 PVOID InformationBuffer
;
500 UINT InformationBufferLength
;
505 #if (defined(NDIS50) || defined(NDIS51))
506 UCHAR NdisReserved
[9 * sizeof(PVOID
)];
508 UCHAR CallMgrReserved
[2 * sizeof(PVOID
)];
509 UCHAR ProtocolReserved
[2 * sizeof(PVOID
)];
511 UCHAR MiniportReserved
[2 * sizeof(PVOID
)];
513 } NDIS_REQUEST
, *PNDIS_REQUEST
;
517 /* Wide Area Networks definitions */
519 typedef struct _NDIS_WAN_PACKET
{
520 LIST_ENTRY WanPacketQueue
;
521 PUCHAR CurrentBuffer
;
525 PVOID ProtocolReserved1
;
526 PVOID ProtocolReserved2
;
527 PVOID ProtocolReserved3
;
528 PVOID ProtocolReserved4
;
533 } NDIS_WAN_PACKET
, *PNDIS_WAN_PACKET
;
537 /* DMA channel information */
539 typedef struct _NDIS_DMA_DESCRIPTION
{
541 BOOLEAN AutoInitialize
;
542 BOOLEAN DmaChannelSpecified
;
547 } NDIS_DMA_DESCRIPTION
, *PNDIS_DMA_DESCRIPTION
;
549 typedef struct _NDIS_DMA_BLOCK
{
550 PVOID MapRegisterBase
;
551 KEVENT AllocationEvent
;
552 PADAPTER_OBJECT SystemAdapterObject
;
555 } NDIS_DMA_BLOCK
, *PNDIS_DMA_BLOCK
;
557 typedef UCHAR NDIS_DMA_SIZE
;
559 #define NDIS_DMA_24BITS ((NDIS_DMA_SIZE)0)
560 #define NDIS_DMA_32BITS ((NDIS_DMA_SIZE)1)
561 #define NDIS_DMA_64BITS ((NDIS_DMA_SIZE)2)
563 typedef enum _NDIS_PROCESSOR_TYPE
{
569 } NDIS_PROCESSOR_TYPE
, *PNDIS_PROCESSOR_TYPE
;
571 typedef enum _NDIS_ENVIRONMENT_TYPE
{
572 NdisEnvironmentWindows
,
573 NdisEnvironmentWindowsNt
574 } NDIS_ENVIRONMENT_TYPE
, *PNDIS_ENVIRONMENT_TYPE
;
576 /* Possible hardware architecture */
577 typedef enum _NDIS_INTERFACE_TYPE
{
578 NdisInterfaceInternal
= Internal
,
579 NdisInterfaceIsa
= Isa
,
580 NdisInterfaceEisa
= Eisa
,
581 NdisInterfaceMca
= MicroChannel
,
582 NdisInterfaceTurboChannel
= TurboChannel
,
583 NdisInterfacePci
= PCIBus
,
584 NdisInterfacePcMcia
= PCMCIABus
,
585 NdisInterfaceCBus
= CBus
,
586 NdisInterfaceMPIBus
= MPIBus
,
587 NdisInterfaceMPSABus
= MPSABus
,
588 NdisInterfaceProcessorInternal
= ProcessorInternal
,
589 NdisInterfaceInternalPowerBus
= InternalPowerBus
,
590 NdisInterfacePNPISABus
= PNPISABus
,
591 NdisInterfacePNPBus
= PNPBus
,
592 NdisMaximumInterfaceType
593 } NDIS_INTERFACE_TYPE
, *PNDIS_INTERFACE_TYPE
;
595 #define NdisInterruptLevelSensitive LevelSensitive
596 #define NdisInterruptLatched Latched
597 typedef KINTERRUPT_MODE NDIS_INTERRUPT_MODE
, *PNDIS_INTERRUPT_MODE
;
600 typedef enum _NDIS_PARAMETER_TYPE
{
601 NdisParameterInteger
,
602 NdisParameterHexInteger
,
604 NdisParameterMultiString
,
606 } NDIS_PARAMETER_TYPE
, *PNDIS_PARAMETER_TYPE
;
613 typedef struct _NDIS_CONFIGURATION_PARAMETER
{
614 NDIS_PARAMETER_TYPE ParameterType
;
617 NDIS_STRING StringData
;
618 BINARY_DATA BinaryData
;
620 } NDIS_CONFIGURATION_PARAMETER
, *PNDIS_CONFIGURATION_PARAMETER
;
623 typedef PHYSICAL_ADDRESS NDIS_PHYSICAL_ADDRESS
, *PNDIS_PHYSICAL_ADDRESS
;
625 typedef struct _NDIS_PHYSICAL_ADDRESS_UNIT
{
626 NDIS_PHYSICAL_ADDRESS PhysicalAddress
;
628 } NDIS_PHYSICAL_ADDRESS_UNIT
, *PNDIS_PHYSICAL_ADDRESS_UNIT
;
630 typedef struct _NDIS_WAN_LINE_DOWN
{
631 UCHAR RemoteAddress
[6];
632 UCHAR LocalAddress
[6];
633 } NDIS_WAN_LINE_DOWN
, *PNDIS_WAN_LINE_DOWN
;
635 typedef struct _NDIS_WAN_LINE_UP
{
637 ULONG MaximumTotalSize
;
638 NDIS_WAN_QUALITY Quality
;
640 UCHAR RemoteAddress
[6];
641 OUT UCHAR LocalAddress
[6];
642 ULONG ProtocolBufferLength
;
643 PUCHAR ProtocolBuffer
;
645 NDIS_STRING DeviceName
;
646 } NDIS_WAN_LINE_UP
, *PNDIS_WAN_LINE_UP
;
650 (*ADAPTER_SHUTDOWN_HANDLER
)(
651 IN PVOID ShutdownContext
);
654 typedef struct _OID_LIST OID_LIST
, *POID_LIST
;
658 typedef enum _NDIS_PNP_DEVICE_STATE
{
660 NdisPnPDeviceStarted
,
661 NdisPnPDeviceQueryStopped
,
662 NdisPnPDeviceStopped
,
663 NdisPnPDeviceQueryRemoved
,
664 NdisPnPDeviceRemoved
,
665 NdisPnPDeviceSurpriseRemoved
666 } NDIS_PNP_DEVICE_STATE
;
668 #define NDIS_DEVICE_NOT_STOPPABLE 0x00000001
669 #define NDIS_DEVICE_NOT_REMOVEABLE 0x00000002
670 #define NDIS_DEVICE_NOT_SUSPENDABLE 0x00000004
671 #define NDIS_DEVICE_DISABLE_PM 0x00000008
672 #define NDIS_DEVICE_DISABLE_WAKE_UP 0x00000010
673 #define NDIS_DEVICE_DISABLE_WAKE_ON_RECONNECT 0x00000020
674 #define NDIS_DEVICE_RESERVED 0x00000040
675 #define NDIS_DEVICE_DISABLE_WAKE_ON_MAGIC_PACKET 0x00000080
676 #define NDIS_DEVICE_DISABLE_WAKE_ON_PATTERN_MATCH 0x00000100
679 /* OID_GEN_NETWORK_LAYER_ADDRESSES */
680 typedef struct _NETWORK_ADDRESS
{
681 USHORT AddressLength
;
684 } NETWORK_ADDRESS
, *PNETWORK_ADDRESS
;
686 typedef struct _NETWORK_ADDRESS_LIST
{
689 NETWORK_ADDRESS Address
[1];
690 } NETWORK_ADDRESS_LIST
, *PNETWORK_ADDRESS_LIST
;
692 /* Protocol types supported by NDIS */
693 #define NDIS_PROTOCOL_ID_DEFAULT 0x00
694 #define NDIS_PROTOCOL_ID_TCP_IP 0x02
695 #define NDIS_PROTOCOL_ID_IPX 0x06
696 #define NDIS_PROTOCOL_ID_NBF 0x07
697 #define NDIS_PROTOCOL_ID_MAX 0x0F
698 #define NDIS_PROTOCOL_ID_MASK 0x0F
701 /* OID_GEN_TRANSPORT_HEADER_OFFSET */
702 typedef struct _TRANSPORT_HEADER_OFFSET
{
705 } TRANSPORT_HEADER_OFFSET
, *PTRANSPORT_HEADER_OFFSET
;
708 /* OID_GEN_CO_LINK_SPEED / OID_GEN_CO_MINIMUM_LINK_SPEED */
709 typedef struct _NDIS_CO_LINK_SPEED
{
712 } NDIS_CO_LINK_SPEED
, *PNDIS_CO_LINK_SPEED
;
714 typedef ULONG NDIS_AF
, *PNDIS_AF
;
715 #define CO_ADDRESS_FAMILY_Q2931 ((NDIS_AF)0x1)
716 #define CO_ADDRESS_FAMILY_PSCHED ((NDIS_AF)0x2)
717 #define CO_ADDRESS_FAMILY_L2TP ((NDIS_AF)0x3)
718 #define CO_ADDRESS_FAMILY_IRDA ((NDIS_AF)0x4)
719 #define CO_ADDRESS_FAMILY_1394 ((NDIS_AF)0x5)
720 #define CO_ADDRESS_FAMILY_PPP ((NDIS_AF)0x6)
721 #define CO_ADDRESS_FAMILY_TAPI ((NDIS_AF)0x800)
722 #define CO_ADDRESS_FAMILY_TAPI_PROXY ((NDIS_AF)0x801)
724 #define CO_ADDRESS_FAMILY_PROXY 0x80000000
727 NDIS_AF AddressFamily
;
730 } CO_ADDRESS_FAMILY
, *PCO_ADDRESS_FAMILY
;
732 typedef struct _CO_FLOW_PARAMETERS
{
734 ULONG TokenBucketSize
;
737 ULONG DelayVariation
;
738 SERVICETYPE ServiceType
;
740 ULONG MinimumPolicedSize
;
741 } CO_FLOW_PARAMETERS
, *PCO_FLOW_PARAMETERS
;
743 typedef struct _CO_SPECIFIC_PARAMETERS
{
747 } CO_SPECIFIC_PARAMETERS
, *PCO_SPECIFIC_PARAMETERS
;
749 typedef struct _CO_CALL_MANAGER_PARAMETERS
{
750 CO_FLOW_PARAMETERS Transmit
;
751 CO_FLOW_PARAMETERS Receive
;
752 CO_SPECIFIC_PARAMETERS CallMgrSpecific
;
753 } CO_CALL_MANAGER_PARAMETERS
, *PCO_CALL_MANAGER_PARAMETERS
;
755 /* CO_MEDIA_PARAMETERS.Flags constants */
756 #define RECEIVE_TIME_INDICATION 0x00000001
757 #define USE_TIME_STAMPS 0x00000002
758 #define TRANSMIT_VC 0x00000004
759 #define RECEIVE_VC 0x00000008
760 #define INDICATE_ERRED_PACKETS 0x00000010
761 #define INDICATE_END_OF_TX 0x00000020
762 #define RESERVE_RESOURCES_VC 0x00000040
763 #define ROUND_DOWN_FLOW 0x00000080
764 #define ROUND_UP_FLOW 0x00000100
766 typedef struct _CO_MEDIA_PARAMETERS
{
768 ULONG ReceivePriority
;
769 ULONG ReceiveSizeHint
;
770 CO_SPECIFIC_PARAMETERS MediaSpecific
;
771 } CO_MEDIA_PARAMETERS
, *PCO_MEDIA_PARAMETERS
;
773 /* CO_CALL_PARAMETERS.Flags constants */
774 #define PERMANENT_VC 0x00000001
775 #define CALL_PARAMETERS_CHANGED 0x00000002
776 #define QUERY_CALL_PARAMETERS 0x00000004
777 #define BROADCAST_VC 0x00000008
778 #define MULTIPOINT_VC 0x00000010
780 typedef struct _CO_CALL_PARAMETERS
{
782 PCO_CALL_MANAGER_PARAMETERS CallMgrParameters
;
783 PCO_MEDIA_PARAMETERS MediaParameters
;
784 } CO_CALL_PARAMETERS
, *PCO_CALL_PARAMETERS
;
786 typedef struct _CO_SAP
{
792 typedef struct _NDIS_IPSEC_PACKET_INFO
{
793 _ANONYMOUS_UNION
union {
795 NDIS_HANDLE OffloadHandle
;
796 NDIS_HANDLE NextOffloadHandle
;
799 ULONG SA_DELETE_REQ
: 1;
800 ULONG CRYPTO_DONE
: 1;
801 ULONG NEXT_CRYPTO_DONE
: 1;
805 } NDIS_IPSEC_PACKET_INFO
, *PNDIS_IPSEC_PACKET_INFO
;
807 /* NDIS_MAC_FRAGMENT.Errors constants */
808 #define WAN_ERROR_CRC 0x00000001
809 #define WAN_ERROR_FRAMING 0x00000002
810 #define WAN_ERROR_HARDWAREOVERRUN 0x00000004
811 #define WAN_ERROR_BUFFEROVERRUN 0x00000008
812 #define WAN_ERROR_TIMEOUT 0x00000010
813 #define WAN_ERROR_ALIGNMENT 0x00000020
815 typedef struct _NDIS_MAC_FRAGMENT
{
816 NDIS_HANDLE NdisLinkContext
;
818 } NDIS_MAC_FRAGMENT
, *PNDIS_MAC_FRAGMENT
;
820 typedef struct _NDIS_MAC_LINE_DOWN
{
821 NDIS_HANDLE NdisLinkContext
;
822 } NDIS_MAC_LINE_DOWN
, *PNDIS_MAC_LINE_DOWN
;
824 typedef struct _NDIS_MAC_LINE_UP
{
826 NDIS_WAN_QUALITY Quality
;
828 NDIS_HANDLE ConnectionWrapperID
;
829 NDIS_HANDLE NdisLinkHandle
;
830 NDIS_HANDLE NdisLinkContext
;
831 } NDIS_MAC_LINE_UP
, *PNDIS_MAC_LINE_UP
;
833 typedef struct _NDIS_PACKET_8021Q_INFO
{
834 _ANONYMOUS_UNION
union {
836 UINT32 UserPriority
: 3;
837 UINT32 CanonicalFormatId
: 1;
839 UINT32 Reserved
: 16;
843 } NDIS_PACKET_8021Q_INFO
, *PNDIS_PACKET_8021Q_INFO
;
845 typedef enum _NDIS_PER_PACKET_INFO
{
846 TcpIpChecksumPacketInfo
,
848 TcpLargeSendPacketInfo
,
849 ClassificationHandlePacketInfo
,
851 ScatterGatherListPacketInfo
,
856 } NDIS_PER_PACKET_INFO
, *PNDIS_PER_PACKET_INFO
;
858 typedef struct _NDIS_PACKET_EXTENSION
{
859 PVOID NdisPacketInfo
[MaxPerPacketInfo
];
860 } NDIS_PACKET_EXTENSION
, *PNDIS_PACKET_EXTENSION
;
864 * NDIS_GET_ORIGINAL_PACKET(
865 * IN PNDIS_PACKET Packet);
867 #define NDIS_GET_ORIGINAL_PACKET(Packet) \
868 NDIS_PER_PACKET_INFO_FROM_PACKET(Packet, OriginalPacketInfo)
872 * NDIS_GET_PACKET_CANCEL_ID(
873 * IN PNDIS_PACKET Packet);
875 #define NDIS_GET_PACKET_CANCEL_ID(Packet) \
876 NDIS_PER_PACKET_INFO_FROM_PACKET(Packet, PacketCancelId)
879 * PNDIS_PACKET_EXTENSION
880 * NDIS_PACKET_EXTENSION_FROM_PACKET(
881 * IN PNDIS_PACKET Packet);
883 #define NDIS_PACKET_EXTENSION_FROM_PACKET(Packet) \
884 ((PNDIS_PACKET_EXTENSION)((PUCHAR)(Packet) \
885 + (Packet)->Private.NdisPacketOobOffset + sizeof(NDIS_PACKET_OOB_DATA)))
889 * NDIS_PER_PACKET_INFO_FROM_PACKET(
890 * IN OUT PNDIS_PACKET Packet,
891 * IN NDIS_PER_PACKET_INFO InfoType);
893 #define NDIS_PER_PACKET_INFO_FROM_PACKET(Packet, InfoType) \
894 ((PNDIS_PACKET_EXTENSION)((PUCHAR)(Packet) + (Packet)->Private.NdisPacketOobOffset \
895 + sizeof(NDIS_PACKET_OOB_DATA)))->NdisPacketInfo[(InfoType)]
899 * NDIS_SET_ORIGINAL_PACKET(
900 * IN OUT PNDIS_PACKET Packet,
901 * IN PNDIS_PACKET OriginalPacket);
903 #define NDIS_SET_ORIGINAL_PACKET(Packet, OriginalPacket) \
904 NDIS_PER_PACKET_INFO_FROM_PACKET(Packet, OriginalPacketInfo) = (OriginalPacket)
908 * NDIS_SET_PACKET_CANCEL_ID(
909 * IN PNDIS_PACKET Packet
910 * IN ULONG_PTR CancelId);
912 #define NDIS_SET_PACKET_CANCEL_ID(Packet, CancelId) \
913 NDIS_PER_PACKET_INFO_FROM_PACKET(Packet, PacketCancelId) = (CancelId)
915 typedef enum _NDIS_TASK
{
916 TcpIpChecksumNdisTask
,
918 TcpLargeSendNdisTask
,
920 } NDIS_TASK
, *PNDIS_TASK
;
922 typedef struct _NDIS_TASK_IPSEC
{
924 ULONG AH_ESP_COMBINED
;
925 ULONG TRANSPORT_TUNNEL_COMBINED
;
942 ULONG TRIPLE_DES
: 1;
949 } NDIS_TASK_IPSEC
, *PNDIS_TASK_IPSEC
;
951 typedef struct _NDIS_TASK_OFFLOAD
{
955 ULONG OffsetNextTask
;
956 ULONG TaskBufferLength
;
958 } NDIS_TASK_OFFLOAD
, *PNDIS_TASK_OFFLOAD
;
960 /* NDIS_TASK_OFFLOAD_HEADER.Version constants */
961 #define NDIS_TASK_OFFLOAD_VERSION 1
963 typedef enum _NDIS_ENCAPSULATION
{
964 UNSPECIFIED_Encapsulation
,
966 IEEE_802_3_Encapsulation
,
967 IEEE_802_5_Encapsulation
,
968 LLC_SNAP_ROUTED_Encapsulation
,
969 LLC_SNAP_BRIDGED_Encapsulation
970 } NDIS_ENCAPSULATION
;
972 typedef struct _NDIS_ENCAPSULATION_FORMAT
{
973 NDIS_ENCAPSULATION Encapsulation
;
975 ULONG FixedHeaderSize
: 1;
978 ULONG EncapsulationHeaderSize
;
979 } NDIS_ENCAPSULATION_FORMAT
, *PNDIS_ENCAPSULATION_FORMAT
;
981 typedef struct _NDIS_TASK_TCP_IP_CHECKSUM
{
983 ULONG IpOptionsSupported
:1;
984 ULONG TcpOptionsSupported
:1;
991 ULONG IpOptionsSupported
: 1;
992 ULONG TcpOptionsSupported
: 1;
993 ULONG TcpChecksum
: 1;
994 ULONG UdpChecksum
: 1;
995 ULONG IpChecksum
: 1;
999 ULONG IpOptionsSupported
: 1;
1000 ULONG TcpOptionsSupported
: 1;
1001 ULONG TcpChecksum
: 1;
1002 ULONG UdpChecksum
: 1;
1006 ULONG IpOptionsSupported
: 1;
1007 ULONG TcpOptionsSupported
: 1;
1008 ULONG TcpChecksum
: 1;
1009 ULONG UdpChecksum
: 1;
1011 } NDIS_TASK_TCP_IP_CHECKSUM
, *PNDIS_TASK_TCP_IP_CHECKSUM
;
1013 typedef struct _NDIS_TASK_TCP_LARGE_SEND
{
1015 ULONG MaxOffLoadSize
;
1016 ULONG MinSegmentCount
;
1019 } NDIS_TASK_TCP_LARGE_SEND
, *PNDIS_TASK_TCP_LARGE_SEND
;
1021 typedef struct _NDIS_TCP_IP_CHECKSUM_PACKET_INFO
{
1022 _ANONYMOUS_UNION
union {
1024 ULONG NdisPacketChecksumV4
: 1;
1025 ULONG NdisPacketChecksumV6
: 1;
1026 ULONG NdisPacketTcpChecksum
: 1;
1027 ULONG NdisPacketUdpChecksum
: 1;
1028 ULONG NdisPacketIpChecksum
: 1;
1032 ULONG NdisPacketTcpChecksumFailed
: 1;
1033 ULONG NdisPacketUdpChecksumFailed
: 1;
1034 ULONG NdisPacketIpChecksumFailed
: 1;
1035 ULONG NdisPacketTcpChecksumSucceeded
: 1;
1036 ULONG NdisPacketUdpChecksumSucceeded
: 1;
1037 ULONG NdisPacketIpChecksumSucceeded
: 1;
1038 ULONG NdisPacketLoopback
: 1;
1042 } NDIS_TCP_IP_CHECKSUM_PACKET_INFO
, *PNDIS_TCP_IP_CHECKSUM_PACKET_INFO
;
1044 typedef struct _NDIS_WAN_CO_FRAGMENT
{
1046 } NDIS_WAN_CO_FRAGMENT
, *PNDIS_WAN_CO_FRAGMENT
;
1048 typedef struct _NDIS_WAN_FRAGMENT
{
1049 UCHAR RemoteAddress
[6];
1050 UCHAR LocalAddress
[6];
1051 } NDIS_WAN_FRAGMENT
, *PNDIS_WAN_FRAGMENT
;
1053 typedef struct _WAN_CO_LINKPARAMS
{
1054 ULONG TransmitSpeed
;
1057 } WAN_CO_LINKPARAMS
, *PWAN_CO_LINKPARAMS
;
1063 (*CM_ACTIVATE_VC_COMPLETE_HANDLER
)(
1064 IN NDIS_STATUS Status
,
1065 IN NDIS_HANDLE CallMgrVcContext
,
1066 IN PCO_CALL_PARAMETERS CallParameters
);
1068 typedef NDIS_STATUS DDKAPI
1069 (*CM_ADD_PARTY_HANDLER
)(
1070 IN NDIS_HANDLE CallMgrVcContext
,
1071 IN OUT PCO_CALL_PARAMETERS CallParameters
,
1072 IN NDIS_HANDLE NdisPartyHandle
,
1073 OUT PNDIS_HANDLE CallMgrPartyContext
);
1075 typedef NDIS_STATUS DDKAPI
1076 (*CM_CLOSE_AF_HANDLER
)(
1077 IN NDIS_HANDLE CallMgrAfContext
);
1079 typedef NDIS_STATUS DDKAPI
1080 (*CM_CLOSE_CALL_HANDLER
)(
1081 IN NDIS_HANDLE CallMgrVcContext
,
1082 IN NDIS_HANDLE CallMgrPartyContext OPTIONAL
,
1083 IN PVOID CloseData OPTIONAL
,
1084 IN UINT Size OPTIONAL
);
1086 typedef NDIS_STATUS DDKAPI
1087 (*CM_DEREG_SAP_HANDLER
)(
1088 IN NDIS_HANDLE CallMgrSapContext
);
1091 (*CM_DEACTIVATE_VC_COMPLETE_HANDLER
)(
1092 IN NDIS_STATUS Status
,
1093 IN NDIS_HANDLE CallMgrVcContext
);
1095 typedef NDIS_STATUS DDKAPI
1096 (*CM_DROP_PARTY_HANDLER
)(
1097 IN NDIS_HANDLE CallMgrPartyContext
,
1098 IN PVOID CloseData OPTIONAL
,
1099 IN UINT Size OPTIONAL
);
1102 (*CM_INCOMING_CALL_COMPLETE_HANDLER
)(
1103 IN NDIS_STATUS Status
,
1104 IN NDIS_HANDLE CallMgrVcContext
,
1105 IN PCO_CALL_PARAMETERS CallParameters
);
1107 typedef NDIS_STATUS DDKAPI
1108 (*CM_MAKE_CALL_HANDLER
)(
1109 IN NDIS_HANDLE CallMgrVcContext
,
1110 IN OUT PCO_CALL_PARAMETERS CallParameters
,
1111 IN NDIS_HANDLE NdisPartyHandle OPTIONAL
,
1112 OUT PNDIS_HANDLE CallMgrPartyContext OPTIONAL
);
1114 typedef NDIS_STATUS DDKAPI
1115 (*CM_MODIFY_CALL_QOS_HANDLER
)(
1116 IN NDIS_HANDLE CallMgrVcContext
,
1117 IN PCO_CALL_PARAMETERS CallParameters
);
1119 typedef NDIS_STATUS DDKAPI
1120 (*CM_OPEN_AF_HANDLER
)(
1121 IN NDIS_HANDLE CallMgrBindingContext
,
1122 IN PCO_ADDRESS_FAMILY AddressFamily
,
1123 IN NDIS_HANDLE NdisAfHandle
,
1124 OUT PNDIS_HANDLE CallMgrAfContext
);
1126 typedef NDIS_STATUS DDKAPI
1127 (*CM_REG_SAP_HANDLER
)(
1128 IN NDIS_HANDLE CallMgrAfContext
,
1130 IN NDIS_HANDLE NdisSapHandle
,
1131 OUT PNDIS_HANDLE CallMgrSapContext
);
1133 typedef NDIS_STATUS DDKAPI
1134 (*CO_CREATE_VC_HANDLER
)(
1135 IN NDIS_HANDLE ProtocolAfContext
,
1136 IN NDIS_HANDLE NdisVcHandle
,
1137 OUT PNDIS_HANDLE ProtocolVcContext
);
1139 typedef NDIS_STATUS DDKAPI
1140 (*CO_DELETE_VC_HANDLER
)(
1141 IN NDIS_HANDLE ProtocolVcContext
);
1144 (*CO_REQUEST_COMPLETE_HANDLER
)(
1145 IN NDIS_STATUS Status
,
1146 IN NDIS_HANDLE ProtocolAfContext OPTIONAL
,
1147 IN NDIS_HANDLE ProtocolVcContext OPTIONAL
,
1148 IN NDIS_HANDLE ProtocolPartyContext OPTIONAL
,
1149 IN PNDIS_REQUEST NdisRequest
);
1151 typedef NDIS_STATUS DDKAPI
1152 (*CO_REQUEST_HANDLER
)(
1153 IN NDIS_HANDLE ProtocolAfContext
,
1154 IN NDIS_HANDLE ProtocolVcContext OPTIONAL
,
1155 IN NDIS_HANDLE ProtocolPartyContext OPTIONAL
,
1156 IN OUT PNDIS_REQUEST NdisRequest
);
1158 typedef struct _NDIS_CALL_MANAGER_CHARACTERISTICS
{
1163 CO_CREATE_VC_HANDLER CmCreateVcHandler
;
1164 CO_DELETE_VC_HANDLER CmDeleteVcHandler
;
1165 CM_OPEN_AF_HANDLER CmOpenAfHandler
;
1166 CM_CLOSE_AF_HANDLER CmCloseAfHandler
;
1167 CM_REG_SAP_HANDLER CmRegisterSapHandler
;
1168 CM_DEREG_SAP_HANDLER CmDeregisterSapHandler
;
1169 CM_MAKE_CALL_HANDLER CmMakeCallHandler
;
1170 CM_CLOSE_CALL_HANDLER CmCloseCallHandler
;
1171 CM_INCOMING_CALL_COMPLETE_HANDLER CmIncomingCallCompleteHandler
;
1172 CM_ADD_PARTY_HANDLER CmAddPartyHandler
;
1173 CM_DROP_PARTY_HANDLER CmDropPartyHandler
;
1174 CM_ACTIVATE_VC_COMPLETE_HANDLER CmActivateVcCompleteHandler
;
1175 CM_DEACTIVATE_VC_COMPLETE_HANDLER CmDeactivateVcCompleteHandler
;
1176 CM_MODIFY_CALL_QOS_HANDLER CmModifyCallQoSHandler
;
1177 CO_REQUEST_HANDLER CmRequestHandler
;
1178 CO_REQUEST_COMPLETE_HANDLER CmRequestCompleteHandler
;
1179 } NDIS_CALL_MANAGER_CHARACTERISTICS
, *PNDIS_CALL_MANAGER_CHARACTERISTICS
;
1183 /* Call Manager clients */
1185 typedef VOID (*CL_OPEN_AF_COMPLETE_HANDLER
)(
1186 IN NDIS_STATUS Status
,
1187 IN NDIS_HANDLE ProtocolAfContext
,
1188 IN NDIS_HANDLE NdisAfHandle
);
1191 (*CL_CLOSE_AF_COMPLETE_HANDLER
)(
1192 IN NDIS_STATUS Status
,
1193 IN NDIS_HANDLE ProtocolAfContext
);
1196 (*CL_REG_SAP_COMPLETE_HANDLER
)(
1197 IN NDIS_STATUS Status
,
1198 IN NDIS_HANDLE ProtocolSapContext
,
1200 IN NDIS_HANDLE NdisSapHandle
);
1203 (*CL_DEREG_SAP_COMPLETE_HANDLER
)(
1204 IN NDIS_STATUS Status
,
1205 IN NDIS_HANDLE ProtocolSapContext
);
1208 (*CL_MAKE_CALL_COMPLETE_HANDLER
)(
1209 IN NDIS_STATUS Status
,
1210 IN NDIS_HANDLE ProtocolVcContext
,
1211 IN NDIS_HANDLE NdisPartyHandle OPTIONAL
,
1212 IN PCO_CALL_PARAMETERS CallParameters
);
1215 (*CL_MODIFY_CALL_QOS_COMPLETE_HANDLER
)(
1216 IN NDIS_STATUS Status
,
1217 IN NDIS_HANDLE ProtocolVcContext
,
1218 IN PCO_CALL_PARAMETERS CallParameters
);
1221 (*CL_CLOSE_CALL_COMPLETE_HANDLER
)(
1222 IN NDIS_STATUS Status
,
1223 IN NDIS_HANDLE ProtocolVcContext
,
1224 IN NDIS_HANDLE ProtocolPartyContext OPTIONAL
);
1227 (*CL_ADD_PARTY_COMPLETE_HANDLER
)(
1228 IN NDIS_STATUS Status
,
1229 IN NDIS_HANDLE ProtocolPartyContext
,
1230 IN NDIS_HANDLE NdisPartyHandle
,
1231 IN PCO_CALL_PARAMETERS CallParameters
);
1234 (*CL_DROP_PARTY_COMPLETE_HANDLER
)(
1235 IN NDIS_STATUS Status
,
1236 IN NDIS_HANDLE ProtocolPartyContext
);
1238 typedef NDIS_STATUS DDKAPI
1239 (*CL_INCOMING_CALL_HANDLER
)(
1240 IN NDIS_HANDLE ProtocolSapContext
,
1241 IN NDIS_HANDLE ProtocolVcContext
,
1242 IN OUT PCO_CALL_PARAMETERS CallParameters
);
1245 (*CL_INCOMING_CALL_QOS_CHANGE_HANDLER
)(
1246 IN NDIS_HANDLE ProtocolVcContext
,
1247 IN PCO_CALL_PARAMETERS CallParameters
);
1250 (*CL_INCOMING_CLOSE_CALL_HANDLER
)(
1251 IN NDIS_STATUS CloseStatus
,
1252 IN NDIS_HANDLE ProtocolVcContext
,
1253 IN PVOID CloseData OPTIONAL
,
1254 IN UINT Size OPTIONAL
);
1257 (*CL_INCOMING_DROP_PARTY_HANDLER
)(
1258 IN NDIS_STATUS DropStatus
,
1259 IN NDIS_HANDLE ProtocolPartyContext
,
1260 IN PVOID CloseData OPTIONAL
,
1261 IN UINT Size OPTIONAL
);
1264 (*CL_CALL_CONNECTED_HANDLER
)(
1265 IN NDIS_HANDLE ProtocolVcContext
);
1268 typedef struct _NDIS_CLIENT_CHARACTERISTICS
{
1273 CO_CREATE_VC_HANDLER ClCreateVcHandler
;
1274 CO_DELETE_VC_HANDLER ClDeleteVcHandler
;
1275 CO_REQUEST_HANDLER ClRequestHandler
;
1276 CO_REQUEST_COMPLETE_HANDLER ClRequestCompleteHandler
;
1277 CL_OPEN_AF_COMPLETE_HANDLER ClOpenAfCompleteHandler
;
1278 CL_CLOSE_AF_COMPLETE_HANDLER ClCloseAfCompleteHandler
;
1279 CL_REG_SAP_COMPLETE_HANDLER ClRegisterSapCompleteHandler
;
1280 CL_DEREG_SAP_COMPLETE_HANDLER ClDeregisterSapCompleteHandler
;
1281 CL_MAKE_CALL_COMPLETE_HANDLER ClMakeCallCompleteHandler
;
1282 CL_MODIFY_CALL_QOS_COMPLETE_HANDLER ClModifyCallQoSCompleteHandler
;
1283 CL_CLOSE_CALL_COMPLETE_HANDLER ClCloseCallCompleteHandler
;
1284 CL_ADD_PARTY_COMPLETE_HANDLER ClAddPartyCompleteHandler
;
1285 CL_DROP_PARTY_COMPLETE_HANDLER ClDropPartyCompleteHandler
;
1286 CL_INCOMING_CALL_HANDLER ClIncomingCallHandler
;
1287 CL_INCOMING_CALL_QOS_CHANGE_HANDLER ClIncomingCallQoSChangeHandler
;
1288 CL_INCOMING_CLOSE_CALL_HANDLER ClIncomingCloseCallHandler
;
1289 CL_INCOMING_DROP_PARTY_HANDLER ClIncomingDropPartyHandler
;
1290 CL_CALL_CONNECTED_HANDLER ClCallConnectedHandler
;
1291 } NDIS_CLIENT_CHARACTERISTICS
, *PNDIS_CLIENT_CHARACTERISTICS
;
1294 /* NDIS protocol structures */
1296 /* Prototypes for NDIS 3.0 protocol characteristics */
1299 (*OPEN_ADAPTER_COMPLETE_HANDLER
)(
1300 IN NDIS_HANDLE ProtocolBindingContext
,
1301 IN NDIS_STATUS Status
,
1302 IN NDIS_STATUS OpenErrorStatus
);
1305 (*CLOSE_ADAPTER_COMPLETE_HANDLER
)(
1306 IN NDIS_HANDLE ProtocolBindingContext
,
1307 IN NDIS_STATUS Status
);
1310 (*RESET_COMPLETE_HANDLER
)(
1311 IN NDIS_HANDLE ProtocolBindingContext
,
1312 IN NDIS_STATUS Status
);
1315 (*REQUEST_COMPLETE_HANDLER
)(
1316 IN NDIS_HANDLE ProtocolBindingContext
,
1317 IN PNDIS_REQUEST NdisRequest
,
1318 IN NDIS_STATUS Status
);
1322 IN NDIS_HANDLE ProtocolBindingContext
,
1323 IN NDIS_STATUS GeneralStatus
,
1324 IN PVOID StatusBuffer
,
1325 IN UINT StatusBufferSize
);
1328 (*STATUS_COMPLETE_HANDLER
)(
1329 IN NDIS_HANDLE ProtocolBindingContext
);
1332 (*SEND_COMPLETE_HANDLER
)(
1333 IN NDIS_HANDLE ProtocolBindingContext
,
1334 IN PNDIS_PACKET Packet
,
1335 IN NDIS_STATUS Status
);
1338 (*WAN_SEND_COMPLETE_HANDLER
)(
1339 IN NDIS_HANDLE ProtocolBindingContext
,
1340 IN PNDIS_WAN_PACKET Packet
,
1341 IN NDIS_STATUS Status
);
1344 (*TRANSFER_DATA_COMPLETE_HANDLER
)(
1345 IN NDIS_HANDLE ProtocolBindingContext
,
1346 IN PNDIS_PACKET Packet
,
1347 IN NDIS_STATUS Status
,
1348 IN UINT BytesTransferred
);
1351 (*WAN_TRANSFER_DATA_COMPLETE_HANDLER
)(
1355 typedef NDIS_STATUS DDKAPI
1357 IN NDIS_HANDLE ProtocolBindingContext
,
1358 IN NDIS_HANDLE MacReceiveContext
,
1359 IN PVOID HeaderBuffer
,
1360 IN UINT HeaderBufferSize
,
1361 IN PVOID LookAheadBuffer
,
1362 IN UINT LookaheadBufferSize
,
1363 IN UINT PacketSize
);
1365 typedef NDIS_STATUS DDKAPI
1366 (*WAN_RECEIVE_HANDLER
)(
1367 IN NDIS_HANDLE NdisLinkHandle
,
1369 IN ULONG PacketSize
);
1372 (*RECEIVE_COMPLETE_HANDLER
)(
1373 IN NDIS_HANDLE ProtocolBindingContext
);
1376 /* Protocol characteristics for NDIS 3.0 protocols */
1378 #define NDIS30_PROTOCOL_CHARACTERISTICS_S \
1379 UCHAR MajorNdisVersion; \
1380 UCHAR MinorNdisVersion; \
1382 _ANONYMOUS_UNION union { \
1386 OPEN_ADAPTER_COMPLETE_HANDLER OpenAdapterCompleteHandler; \
1387 CLOSE_ADAPTER_COMPLETE_HANDLER CloseAdapterCompleteHandler; \
1388 _ANONYMOUS_UNION union { \
1389 SEND_COMPLETE_HANDLER SendCompleteHandler; \
1390 WAN_SEND_COMPLETE_HANDLER WanSendCompleteHandler; \
1391 } DUMMYUNIONNAME2; \
1392 _ANONYMOUS_UNION union { \
1393 TRANSFER_DATA_COMPLETE_HANDLER TransferDataCompleteHandler; \
1394 WAN_TRANSFER_DATA_COMPLETE_HANDLER WanTransferDataCompleteHandler; \
1395 } DUMMYUNIONNAME3; \
1396 RESET_COMPLETE_HANDLER ResetCompleteHandler; \
1397 REQUEST_COMPLETE_HANDLER RequestCompleteHandler; \
1398 _ANONYMOUS_UNION union { \
1399 RECEIVE_HANDLER ReceiveHandler; \
1400 WAN_RECEIVE_HANDLER WanReceiveHandler; \
1401 } DUMMYUNIONNAME4; \
1402 RECEIVE_COMPLETE_HANDLER ReceiveCompleteHandler; \
1403 STATUS_HANDLER StatusHandler; \
1404 STATUS_COMPLETE_HANDLER StatusCompleteHandler; \
1407 typedef struct _NDIS30_PROTOCOL_CHARACTERISTICS
{
1408 NDIS30_PROTOCOL_CHARACTERISTICS_S
1409 } NDIS30_PROTOCOL_CHARACTERISTICS
, *PNDIS30_PROTOCOL_CHARACTERISTICS
;
1412 /* Prototypes for NDIS 4.0 protocol characteristics */
1415 (*RECEIVE_PACKET_HANDLER
)(
1416 IN NDIS_HANDLE ProtocolBindingContext
,
1417 IN PNDIS_PACKET Packet
);
1421 OUT PNDIS_STATUS Status
,
1422 IN NDIS_HANDLE BindContext
,
1423 IN PNDIS_STRING DeviceName
,
1424 IN PVOID SystemSpecific1
,
1425 IN PVOID SystemSpecific2
);
1429 OUT PNDIS_STATUS Status
,
1430 IN NDIS_HANDLE ProtocolBindingContext
,
1431 IN NDIS_HANDLE UnbindContext
);
1433 typedef NDIS_STATUS DDKAPI
1434 (*PNP_EVENT_HANDLER
)(
1435 IN NDIS_HANDLE ProtocolBindingContext
,
1436 IN PNET_PNP_EVENT NetPnPEvent
);
1439 (*UNLOAD_PROTOCOL_HANDLER
)(
1443 /* Protocol characteristics for NDIS 4.0 protocols */
1447 #define NDIS40_PROTOCOL_CHARACTERISTICS_S \
1448 NDIS30_PROTOCOL_CHARACTERISTICS Ndis30Chars; \
1449 RECEIVE_PACKET_HANDLER ReceivePacketHandler; \
1450 BIND_HANDLER BindAdapterHandler; \
1451 UNBIND_HANDLER UnbindAdapterHandler; \
1452 PNP_EVENT_HANDLER PnPEventHandler; \
1453 UNLOAD_PROTOCOL_HANDLER UnloadHandler;
1455 #else /* !__cplusplus */
1457 #define NDIS40_PROTOCOL_CHARACTERISTICS_S \
1458 NDIS30_PROTOCOL_CHARACTERISTICS_S \
1459 RECEIVE_PACKET_HANDLER ReceivePacketHandler; \
1460 BIND_HANDLER BindAdapterHandler; \
1461 UNBIND_HANDLER UnbindAdapterHandler; \
1462 PNP_EVENT_HANDLER PnPEventHandler; \
1463 UNLOAD_PROTOCOL_HANDLER UnloadHandler;
1465 #endif /* __cplusplus */
1467 typedef struct _NDIS40_PROTOCOL_CHARACTERISTICS
{
1468 NDIS40_PROTOCOL_CHARACTERISTICS_S
1469 } NDIS40_PROTOCOL_CHARACTERISTICS
, *PNDIS40_PROTOCOL_CHARACTERISTICS
;
1471 /* Prototypes for NDIS 5.0 protocol characteristics */
1474 (*CO_SEND_COMPLETE_HANDLER
)(
1475 IN NDIS_STATUS Status
,
1476 IN NDIS_HANDLE ProtocolVcContext
,
1477 IN PNDIS_PACKET Packet
);
1480 (*CO_STATUS_HANDLER
)(
1481 IN NDIS_HANDLE ProtocolBindingContext
,
1482 IN NDIS_HANDLE ProtocolVcContext OPTIONAL
,
1483 IN NDIS_STATUS GeneralStatus
,
1484 IN PVOID StatusBuffer
,
1485 IN UINT StatusBufferSize
);
1488 (*CO_RECEIVE_PACKET_HANDLER
)(
1489 IN NDIS_HANDLE ProtocolBindingContext
,
1490 IN NDIS_HANDLE ProtocolVcContext
,
1491 IN PNDIS_PACKET Packet
);
1494 (*CO_AF_REGISTER_NOTIFY_HANDLER
)(
1495 IN NDIS_HANDLE ProtocolBindingContext
,
1496 IN PCO_ADDRESS_FAMILY AddressFamily
);
1498 #ifdef __cplusplus \
1500 #define NDIS50_PROTOCOL_CHARACTERISTICS_S \
1501 NDIS40_PROTOCOL_CHARACTERISTICS Ndis40Chars; \
1502 PVOID ReservedHandlers[4]; \
1503 CO_SEND_COMPLETE_HANDLER CoSendCompleteHandler; \
1504 CO_STATUS_HANDLER CoStatusHandler; \
1505 CO_RECEIVE_PACKET_HANDLER CoReceivePacketHandler; \
1506 CO_AF_REGISTER_NOTIFY_HANDLER CoAfRegisterNotifyHandler;
1508 #else /* !__cplusplus */
1510 #define NDIS50_PROTOCOL_CHARACTERISTICS_S \
1511 NDIS40_PROTOCOL_CHARACTERISTICS_S \
1512 PVOID ReservedHandlers[4]; \
1513 CO_SEND_COMPLETE_HANDLER CoSendCompleteHandler; \
1514 CO_STATUS_HANDLER CoStatusHandler; \
1515 CO_RECEIVE_PACKET_HANDLER CoReceivePacketHandler; \
1516 CO_AF_REGISTER_NOTIFY_HANDLER CoAfRegisterNotifyHandler;
1518 #endif /* !__cplusplus */
1520 typedef struct _NDIS50_PROTOCOL_CHARACTERISTICS
{
1521 NDIS50_PROTOCOL_CHARACTERISTICS_S
1522 } NDIS50_PROTOCOL_CHARACTERISTICS
, *PNDIS50_PROTOCOL_CHARACTERISTICS
;
1524 #if defined(NDIS50) || defined(NDIS51)
1525 typedef struct _NDIS_PROTOCOL_CHARACTERISTICS
{
1526 NDIS50_PROTOCOL_CHARACTERISTICS_S
;
1527 } NDIS_PROTOCOL_CHARACTERISTICS
, *PNDIS_PROTOCOL_CHARACTERISTICS
;
1528 #elif defined(NDIS40)
1529 typedef struct _NDIS_PROTOCOL_CHARACTERISTICS
{
1530 NDIS40_PROTOCOL_CHARACTERISTICS_S
;
1531 } NDIS_PROTOCOL_CHARACTERISTICS
, *PNDIS_PROTOCOL_CHARACTERISTICS
;
1533 typedef struct _NDIS_PROTOCOL_CHARACTERISTICS
{
1534 NDIS30_PROTOCOL_CHARACTERISTICS_S
1535 } NDIS_PROTOCOL_CHARACTERISTICS
, *PNDIS_PROTOCOL_CHARACTERISTICS
;
1540 /* Buffer management routines */
1546 OUT PNDIS_STATUS Status
,
1547 OUT PNDIS_BUFFER
*Buffer
,
1548 IN NDIS_HANDLE PoolHandle
,
1549 IN PVOID VirtualAddress
,
1556 NdisAllocateBufferPool(
1557 OUT PNDIS_STATUS Status
,
1558 OUT PNDIS_HANDLE PoolHandle
,
1559 IN UINT NumberOfDescriptors
);
1565 OUT PNDIS_STATUS Status
,
1566 OUT PNDIS_PACKET
*Packet
,
1567 IN NDIS_HANDLE PoolHandle
);
1572 NdisAllocatePacketPool(
1573 OUT PNDIS_STATUS Status
,
1574 OUT PNDIS_HANDLE PoolHandle
,
1575 IN UINT NumberOfDescriptors
,
1576 IN UINT ProtocolReservedLength
);
1582 OUT PNDIS_STATUS Status
,
1583 OUT PNDIS_BUFFER
*Buffer
,
1584 IN NDIS_HANDLE PoolHandle
,
1585 IN PVOID MemoryDescriptor
,
1592 NdisCopyFromPacketToPacket(
1593 IN PNDIS_PACKET Destination
,
1594 IN UINT DestinationOffset
,
1595 IN UINT BytesToCopy
,
1596 IN PNDIS_PACKET Source
,
1597 IN UINT SourceOffset
,
1598 OUT PUINT BytesCopied
);
1602 * NdisCopyLookaheadData(
1603 * IN PVOID Destination,
1606 * IN ULONG ReceiveFlags);
1610 #define NdisCopyLookaheadData(Destination, Source, Length, MacOptions) \
1611 RtlCopyMemory(Destination, Source, Length)
1613 #define NdisCopyLookaheadData(Destination, Source, Length, MacOptions) \
1615 if ((MacOptions) & NDIS_MAC_OPTION_COPY_LOOKAHEAD_DATA) \
1617 RtlCopyMemory(_Destination, _Source, _Length); \
1621 PUCHAR _Src = (PUCHAR)(Source); \
1622 PUCHAR _Dest = (PUCHAR)(Destination); \
1623 PUCHAR _End = _Dest + (Length); \
1624 while (_Dest < _End) \
1625 *_Dest++ = *_Src++; \
1633 NdisDprAllocatePacket(
1634 OUT PNDIS_STATUS Status
,
1635 OUT PNDIS_PACKET
*Packet
,
1636 IN NDIS_HANDLE PoolHandle
);
1641 NdisDprAllocatePacketNonInterlocked(
1642 OUT PNDIS_STATUS Status
,
1643 OUT PNDIS_PACKET
*Packet
,
1644 IN NDIS_HANDLE PoolHandle
);
1650 IN PNDIS_PACKET Packet
);
1655 NdisDprFreePacketNonInterlocked(
1656 IN PNDIS_PACKET Packet
);
1662 IN NDIS_HANDLE PoolHandle
);
1668 IN PNDIS_PACKET Packet
);
1674 IN NDIS_HANDLE PoolHandle
);
1680 IN PNDIS_PACKET
*PacketsToReturn
,
1681 IN UINT NumberOfPackets
);
1686 NdisUnchainBufferAtBack(
1687 IN OUT PNDIS_PACKET Packet
,
1688 OUT PNDIS_BUFFER
*Buffer
);
1693 NdisUnchainBufferAtFront(
1694 IN OUT PNDIS_PACKET Packet
,
1695 OUT PNDIS_BUFFER
*Buffer
);
1700 NdisAdjustBufferLength(
1701 IN PNDIS_BUFFER Buffer
,
1708 IN PNDIS_BUFFER Buffer
);
1713 NdisBufferVirtualAddress(
1714 IN PNDIS_BUFFER Buffer
);
1719 NDIS_BUFFER_TO_SPAN_PAGES(
1720 IN PNDIS_BUFFER Buffer
);
1726 IN PNDIS_BUFFER Buffer
);
1728 #if BINARY_COMPATIBLE
1733 NdisGetBufferPhysicalArraySize(
1734 IN PNDIS_BUFFER Buffer
,
1735 OUT PUINT ArraySize
);
1740 NdisGetFirstBufferFromPacket(
1741 IN PNDIS_PACKET _Packet
,
1742 OUT PNDIS_BUFFER
*_FirstBuffer
,
1743 OUT PVOID
*_FirstBufferVA
,
1744 OUT PUINT _FirstBufferLength
,
1745 OUT PUINT _TotalBufferLength
);
1751 IN PNDIS_BUFFER Buffer
,
1752 OUT PVOID
*VirtualAddress OPTIONAL
,
1758 NdisQueryBufferOffset(
1759 IN PNDIS_BUFFER Buffer
,
1767 * NdisGetBufferPhysicalArraySize(
1768 * IN PNDIS_BUFFER Buffer,
1769 * OUT PUINT ArraySize);
1771 #define NdisGetBufferPhysicalArraySize(Buffer, \
1774 (*(ArraySize) = NDIS_BUFFER_TO_SPAN_PAGES(Buffer)) \
1779 * NdisGetFirstBufferFromPacket(
1780 * IN PNDIS_PACKET _Packet,
1781 * OUT PNDIS_BUFFER * _FirstBuffer,
1782 * OUT PVOID * _FirstBufferVA,
1783 * OUT PUINT _FirstBufferLength,
1784 * OUT PUINT _TotalBufferLength)
1786 #define NdisGetFirstBufferFromPacket(_Packet, \
1789 _FirstBufferLength, \
1790 _TotalBufferLength) \
1792 PNDIS_BUFFER _Buffer; \
1794 _Buffer = (_Packet)->Private.Head; \
1795 *(_FirstBuffer) = _Buffer; \
1796 if (_Buffer != NULL) \
1798 *(_FirstBufferVA) = MmGetSystemAddressForMdl(_Buffer); \
1799 *(_FirstBufferLength) = MmGetMdlByteCount(_Buffer); \
1800 _Buffer = _Buffer->Next; \
1801 *(_TotalBufferLength) = *(_FirstBufferLength); \
1802 while (_Buffer != NULL) { \
1803 *(_TotalBufferLength) += MmGetMdlByteCount(_Buffer); \
1804 _Buffer = _Buffer->Next; \
1809 *(_FirstBufferVA) = 0; \
1810 *(_FirstBufferLength) = 0; \
1811 *(_TotalBufferLength) = 0; \
1818 * IN PNDIS_BUFFER Buffer,
1819 * OUT PVOID *VirtualAddress OPTIONAL,
1822 #define NdisQueryBuffer(Buffer, \
1826 if (VirtualAddress) \
1827 *((PVOID*)VirtualAddress) = MmGetSystemAddressForMdl(Buffer); \
1829 *((PUINT)Length) = MmGetMdlByteCount(Buffer); \
1835 * NdisQueryBufferOffset(
1836 * IN PNDIS_BUFFER Buffer,
1838 * OUT PUINT Length);
1840 #define NdisQueryBufferOffset(Buffer, \
1844 *((PUINT)Offset) = MmGetMdlByteOffset(Buffer); \
1845 *((PUINT)Length) = MmGetMdlByteCount(Buffer); \
1848 #endif /* BINARY_COMPATIBLE */
1852 * NDIS_BUFFER_LINKAGE(
1853 * IN PNDIS_BUFFER Buffer);
1855 #define NDIS_BUFFER_LINKAGE(Buffer)(Buffer)->Next;
1860 * NdisChainBufferAtBack(
1861 * IN OUT PNDIS_PACKET Packet,
1862 * IN OUT PNDIS_BUFFER Buffer)
1864 #define NdisChainBufferAtBack(Packet, \
1867 PNDIS_BUFFER NdisBuffer = (Buffer); \
1869 while (NdisBuffer->Next != NULL) \
1870 NdisBuffer = NdisBuffer->Next; \
1872 NdisBuffer->Next = NULL; \
1874 if ((Packet)->Private.Head != NULL) \
1875 (Packet)->Private.Tail->Next = (Buffer); \
1877 (Packet)->Private.Head = (Buffer); \
1879 (Packet)->Private.Tail = NdisBuffer; \
1880 (Packet)->Private.ValidCounts = FALSE; \
1886 * NdisChainBufferAtFront(
1887 * IN OUT PNDIS_PACKET Packet,
1888 * IN OUT PNDIS_BUFFER Buffer)
1890 #define NdisChainBufferAtFront(Packet, \
1893 PNDIS_BUFFER _NdisBuffer = (Buffer); \
1895 while (_NdisBuffer->Next != NULL) \
1896 _NdisBuffer = _NdisBuffer->Next; \
1898 if ((Packet)->Private.Head == NULL) \
1899 (Packet)->Private.Tail = _NdisBuffer; \
1901 _NdisBuffer->Next = (Packet)->Private.Head; \
1902 (Packet)->Private.Head = (Buffer); \
1903 (Packet)->Private.ValidCounts = FALSE; \
1909 * NdisGetNextBuffer(
1910 * IN PNDIS_BUFFER CurrentBuffer,
1911 * OUT PNDIS_BUFFER * NextBuffer)
1913 #define NdisGetNextBuffer(CurrentBuffer, \
1916 *(NextBuffer) = (CurrentBuffer)->Next; \
1922 * NdisGetPacketFlags(
1923 * IN PNDIS_PACKET Packet);
1925 #define NdisGetPacketFlags(Packet)(Packet)->Private.Flags;
1930 * NdisClearPacketFlags(
1931 * IN PNDIS_PACKET Packet,
1934 #define NdisClearPacketFlags(Packet, Flags) \
1935 (Packet)->Private.Flags &= ~(Flags)
1940 * NDIS_GET_PACKET_MEDIA_SPECIFIC_INFO(
1941 * IN PNDIS_PACKET Packet,
1942 * IN PPVOID pMediaSpecificInfo,
1943 * IN PUINT pSizeMediaSpecificInfo);
1945 #define NDIS_GET_PACKET_MEDIA_SPECIFIC_INFO(_Packet, \
1946 _pMediaSpecificInfo, \
1947 _pSizeMediaSpecificInfo) \
1949 if (!((_Packet)->Private.NdisPacketFlags & fPACKET_ALLOCATED_BY_NDIS) || \
1950 !((_Packet)->Private.NdisPacketFlags & fPACKET_CONTAINS_MEDIA_SPECIFIC_INFO)) \
1952 *(_pMediaSpecificInfo) = NULL; \
1953 *(_pSizeMediaSpecificInfo) = 0; \
1957 *(_pMediaSpecificInfo) = ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
1958 (_Packet)->Private.NdisPacketOobOffset))->MediaSpecificInformation; \
1959 *(_pSizeMediaSpecificInfo) = ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
1960 (_Packet)->Private.NdisPacketOobOffset))->SizeMediaSpecificInfo; \
1967 * NDIS_GET_PACKET_PROTOCOL_TYPE(
1968 * IN PNDIS_PACKET Packet);
1970 #define NDIS_GET_PACKET_PROTOCOL_TYPE(_Packet) \
1971 ((_Packet)->Private.Flags & NDIS_PROTOCOL_ID_MASK)
1975 * NDIS_GET_PACKET_HEADER_SIZE(
1976 * IN PNDIS_PACKET Packet);
1978 #define NDIS_GET_PACKET_HEADER_SIZE(_Packet) \
1979 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
1980 (_Packet)->Private.NdisPacketOobOffset))->HeaderSize
1985 * NDIS_GET_PACKET_STATUS(
1986 * IN PNDIS_PACKET Packet);
1988 #define NDIS_GET_PACKET_STATUS(_Packet) \
1989 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
1990 (_Packet)->Private.NdisPacketOobOffset))->Status
1995 * NDIS_GET_PACKET_TIME_RECEIVED(
1996 * IN PNDIS_PACKET Packet);
1998 #define NDIS_GET_PACKET_TIME_RECEIVED(_Packet) \
1999 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2000 (_Packet)->Private.NdisPacketOobOffset))->TimeReceived
2005 * NDIS_GET_PACKET_TIME_SENT(
2006 * IN PNDIS_PACKET Packet);
2008 #define NDIS_GET_PACKET_TIME_SENT(_Packet) \
2009 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2010 (_Packet)->Private.NdisPacketOobOffset))->TimeSent
2015 * NDIS_GET_PACKET_TIME_TO_SEND(
2016 * IN PNDIS_PACKET Packet);
2018 #define NDIS_GET_PACKET_TIME_TO_SEND(_Packet) \
2019 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2020 (_Packet)->Private.NdisPacketOobOffset))->TimeToSend
2024 * PNDIS_PACKET_OOB_DATA
2025 * NDIS_OOB_DATA_FROM_PACKET(
2026 * IN PNDIS_PACKET Packet);
2028 #define NDIS_OOB_DATA_FROM_PACKET(_Packet) \
2029 (PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2030 (_Packet)->Private.NdisPacketOobOffset)
2036 * IN PNDIS_PACKET Packet,
2037 * OUT PUINT PhysicalBufferCount OPTIONAL,
2038 * OUT PUINT BufferCount OPTIONAL,
2039 * OUT PNDIS_BUFFER *FirstBuffer OPTIONAL,
2040 * OUT PUINT TotalPacketLength OPTIONAL);
2042 #define NdisQueryPacket(Packet, \
2043 PhysicalBufferCount, \
2046 TotalPacketLength) \
2049 *((PNDIS_BUFFER*)FirstBuffer) = (Packet)->Private.Head; \
2050 if ((TotalPacketLength) || (BufferCount) || (PhysicalBufferCount)) \
2052 if (!(Packet)->Private.ValidCounts) { \
2054 UINT _PacketLength; \
2055 PNDIS_BUFFER _NdisBuffer; \
2056 UINT _PhysicalBufferCount = 0; \
2057 UINT _TotalPacketLength = 0; \
2060 for (_NdisBuffer = (Packet)->Private.Head; \
2061 _NdisBuffer != (PNDIS_BUFFER)NULL; \
2062 _NdisBuffer = _NdisBuffer->Next) \
2064 _PhysicalBufferCount += NDIS_BUFFER_TO_SPAN_PAGES(_NdisBuffer); \
2065 NdisQueryBufferOffset(_NdisBuffer, &_Offset, &_PacketLength); \
2066 _TotalPacketLength += _PacketLength; \
2069 (Packet)->Private.PhysicalCount = _PhysicalBufferCount; \
2070 (Packet)->Private.TotalLength = _TotalPacketLength; \
2071 (Packet)->Private.Count = _Count; \
2072 (Packet)->Private.ValidCounts = TRUE; \
2075 if (PhysicalBufferCount) \
2076 *((PUINT)PhysicalBufferCount) = (Packet)->Private.PhysicalCount; \
2079 *((PUINT)BufferCount) = (Packet)->Private.Count; \
2081 if (TotalPacketLength) \
2082 *((PUINT)TotalPacketLength) = (Packet)->Private.TotalLength; \
2088 * NdisQueryPacketLength(
2089 * IN PNDIS_PACKET Packet,
2090 * OUT PUINT PhysicalBufferCount OPTIONAL,
2091 * OUT PUINT BufferCount OPTIONAL,
2092 * OUT PNDIS_BUFFER *FirstBuffer OPTIONAL,
2093 * OUT PUINT TotalPacketLength OPTIONAL);
2095 #define NdisQueryPacketLength(Packet, \
2096 TotalPacketLength) \
2098 if ((TotalPacketLength)) \
2100 if (!(Packet)->Private.ValidCounts) { \
2102 UINT _PacketLength; \
2103 PNDIS_BUFFER _NdisBuffer; \
2104 UINT _PhysicalBufferCount = 0; \
2105 UINT _TotalPacketLength = 0; \
2108 for (_NdisBuffer = (Packet)->Private.Head; \
2109 _NdisBuffer != (PNDIS_BUFFER)NULL; \
2110 _NdisBuffer = _NdisBuffer->Next) \
2112 _PhysicalBufferCount += NDIS_BUFFER_TO_SPAN_PAGES(_NdisBuffer); \
2113 NdisQueryBufferOffset(_NdisBuffer, &_Offset, &_PacketLength); \
2114 _TotalPacketLength += _PacketLength; \
2117 (Packet)->Private.PhysicalCount = _PhysicalBufferCount; \
2118 (Packet)->Private.TotalLength = _TotalPacketLength; \
2119 (Packet)->Private.Count = _Count; \
2120 (Packet)->Private.ValidCounts = TRUE; \
2123 if (TotalPacketLength) \
2124 *((PUINT)TotalPacketLength) = (Packet)->Private.TotalLength; \
2131 * NdisRecalculatePacketCounts(
2132 * IN OUT PNDIS_PACKET Packet);
2134 #define NdisRecalculatePacketCounts(Packet) \
2136 PNDIS_BUFFER _Buffer = (Packet)->Private.Head; \
2137 if (_Buffer != NULL) \
2139 while (_Buffer->Next != NULL) \
2141 ´_Buffer = _Buffer->Next; \
2143 (Packet)->Private.Tail = _Buffer; \
2145 (Packet)->Private.ValidCounts = FALSE; \
2151 * NdisReinitializePacket(
2152 * IN OUT PNDIS_PACKET Packet);
2154 #define NdisReinitializePacketCounts(Packet) \
2156 (Packet)->Private.Head = (PNDIS_BUFFER)NULL; \
2157 (Packet)->Private.ValidCounts = FALSE; \
2163 * NdisSetPacketFlags(
2164 * IN PNDIS_PACKET Packet,
2167 #define NdisSetPacketFlags(Packet, Flags) \
2168 (Packet)->Private.Flags |= (Flags);
2173 * NDIS_SET_PACKET_HEADER_SIZE(
2174 * IN PNDIS_PACKET Packet,
2177 #define NDIS_SET_PACKET_HEADER_SIZE(_Packet, _HdrSize) \
2178 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2179 (_Packet)->Private.NdisPacketOobOffset))->HeaderSize = (_HdrSize)
2184 * NDIS_SET_PACKET_MEDIA_SPECIFIC_INFO(
2185 * IN PNDIS_PACKET Packet,
2186 * IN PVOID MediaSpecificInfo,
2187 * IN UINT SizeMediaSpecificInfo);
2189 #define NDIS_SET_PACKET_MEDIA_SPECIFIC_INFO(_Packet, \
2190 _MediaSpecificInfo, \
2191 _SizeMediaSpecificInfo) \
2193 if ((_Packet)->Private.NdisPacketFlags & fPACKET_ALLOCATED_BY_NDIS) \
2195 (_Packet)->Private.NdisPacketFlags |= fPACKET_CONTAINS_MEDIA_SPECIFIC_INFO; \
2196 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2197 (_Packet)->Private.NdisPacketOobOffset))->MediaSpecificInformation = \
2198 (_MediaSpecificInfo); \
2199 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2200 (_Packet)->Private.NdisPacketOobOffset))->SizeMediaSpecificInfo = \
2201 (_SizeMediaSpecificInfo); \
2208 * NDIS_SET_PACKET_STATUS(
2209 * IN PNDIS_PACKET Packet,
2210 * IN NDIS_STATUS Status);
2212 #define NDIS_SET_PACKET_STATUS(_Packet, _Status) \
2213 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2214 (_Packet)->Private.NdisPacketOobOffset))->Status = (_Status)
2219 * NDIS_SET_PACKET_TIME_RECEIVED(
2220 * IN PNDIS_PACKET Packet,
2221 * IN ULONGLONG TimeReceived);
2223 #define NDIS_SET_PACKET_TIME_RECEIVED(_Packet, _TimeReceived) \
2224 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2225 (_Packet)->Private.NdisPacketOobOffset))->TimeReceived = (_TimeReceived)
2230 * NDIS_SET_PACKET_TIME_SENT(
2231 * IN PNDIS_PACKET Packet,
2232 * IN ULONGLONG TimeSent);
2234 #define NDIS_SET_PACKET_TIME_SENT(_Packet, _TimeSent) \
2235 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2236 (_Packet)->Private.NdisPacketOobOffset))->TimeSent = (_TimeSent)
2241 * NDIS_SET_PACKET_TIME_TO_SEND(
2242 * IN PNDIS_PACKET Packet,
2243 * IN ULONGLONG TimeToSend);
2245 #define NDIS_SET_PACKET_TIME_TO_SEND(_Packet, _TimeToSend) \
2246 ((PNDIS_PACKET_OOB_DATA)((PUCHAR)(_Packet) + \
2247 (_Packet)->Private.NdisPacketOobOffset))->TimeToSend = (_TimeToSend)
2253 * IN PNDIS_PACKET Packet,
2256 #define NdisSetSendFlags(_Packet,_Flags)(_Packet)->Private.Flags = (_Flags)
2260 /* Memory management routines */
2262 #if BINARY_COMPATIBLE
2267 NdisCreateLookaheadBufferFromSharedMemory(
2268 IN PVOID pSharedMemory
,
2269 IN UINT LookaheadLength
,
2270 OUT PVOID
*pLookaheadBuffer
);
2275 NdisDestroyLookaheadBufferFromSharedMemory(
2276 IN PVOID pLookaheadBuffer
);
2282 * NdisCreateLookaheadBufferFromSharedMemory(
2283 * IN PVOID pSharedMemory,
2284 * IN UINT LookaheadLength,
2285 * OUT PVOID *pLookaheadBuffer)
2287 #define NdisCreateLookaheadBufferFromSharedMemory(_pSharedMemory, \
2289 _pLookaheadBuffer) \
2290 ((*(_pLookaheadBuffer)) = (_pSharedMemory))
2294 * NdisDestroyLookaheadBufferFromSharedMemory(
2295 * IN PVOID pLookaheadBuffer)
2297 #define NdisDestroyLookaheadBufferFromSharedMemory(_pLookaheadBuffer)
2301 #if defined(_M_IX86) || defined(_M_AMD64)
2305 * NdisMoveMappedMemory(
2306 * OUT PVOID Destination,
2310 #define NdisMoveMappedMemory(Destination, Source, Length) \
2311 RtlCopyMemory(Destination, Source, Length)
2315 * NdisZeroMappedMemory(
2316 * IN PVOID Destination,
2319 #define NdisZeroMappedMemory(Destination, Length) \
2320 RtlZeroMemory(Destination, Length)
2324 #define NdisMoveMappedMemory(Destination, Source, Length) \
2326 PUCHAR _Dest
= Destination
, _Src
= Source
, _End
= _Dest
+ Length
;
2327 while (_Dest
< _End
)
2331 #define NdisZeroMappedMemory(Destination, Length) \
2333 PUCHAR _Dest
= Destination
, _End
= _Dest
+ Length
;
2334 while (_Dest
< _End
)
2338 #endif /* _M_IX86 or _M_AMD64 */
2342 * NdisMoveFromMappedMemory(
2343 * OUT PVOID Destination,
2347 #define NdisMoveFromMappedMemory(Destination, Source, Length) \
2348 NdisMoveMappedMemory(Destination, Source, Length)
2352 * NdisMoveToMappedMemory(
2353 * OUT PVOID Destination,
2357 #define NdisMoveToMappedMemory(Destination, Source, Length) \
2358 NdisMoveMappedMemory(Destination, Source, Length)
2362 * NdisMUpdateSharedMemory(
2363 * IN NDIS_HANDLE MiniportAdapterHandle,
2365 * IN PVOID VirtualAddress,
2366 * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress);
2368 #define NdisMUpdateSharedMemory(_H, _L, _V, _P) \
2369 NdisUpdateSharedMemory(_H, _L, _V, _P)
2375 OUT PVOID
*VirtualAddress
,
2377 IN UINT MemoryFlags
,
2378 IN NDIS_PHYSICAL_ADDRESS HighestAcceptableAddress
);
2384 IN PVOID VirtualAddress
,
2386 IN UINT MemoryFlags
);
2391 NdisImmediateReadSharedMemory(
2392 IN NDIS_HANDLE WrapperConfigurationContext
,
2393 IN ULONG SharedMemoryAddress
,
2400 NdisImmediateWriteSharedMemory(
2401 IN NDIS_HANDLE WrapperConfigurationContext
,
2402 IN ULONG SharedMemoryAddress
,
2409 NdisMAllocateSharedMemory(
2410 IN NDIS_HANDLE MiniportAdapterHandle
,
2413 OUT PVOID
*VirtualAddress
,
2414 OUT PNDIS_PHYSICAL_ADDRESS PhysicalAddress
);
2419 NdisMAllocateSharedMemoryAsync(
2420 IN NDIS_HANDLE MiniportAdapterHandle
,
2427 #define NdisUpdateSharedMemory(NdisAdapterHandle, \
2437 NdisUpdateSharedMemory(
2438 IN NDIS_HANDLE NdisAdapterHandle
,
2440 IN PVOID VirtualAddress
,
2441 IN NDIS_PHYSICAL_ADDRESS PhysicalAddress
);
2443 #endif /* defined(NDIS50) */
2447 * NdisGetPhysicalAddressHigh(
2448 * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress);
2450 #define NdisGetPhysicalAddressHigh(PhysicalAddress) \
2451 ((PhysicalAddress).HighPart)
2455 * NdisSetPhysicalAddressHigh(
2456 * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress,
2459 #define NdisSetPhysicalAddressHigh(PhysicalAddress, Value) \
2460 ((PhysicalAddress).HighPart) = (Value)
2464 * NdisGetPhysicalAddressLow(
2465 * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress);
2467 #define NdisGetPhysicalAddressLow(PhysicalAddress) \
2468 ((PhysicalAddress).LowPart)
2473 * NdisSetPhysicalAddressLow(
2474 * IN NDIS_PHYSICAL_ADDRESS PhysicalAddress,
2477 #define NdisSetPhysicalAddressLow(PhysicalAddress, Value) \
2478 ((PhysicalAddress).LowPart) = (Value)
2482 * NDIS_PHYSICAL_ADDRESS_CONST(
2486 #define NDIS_PHYSICAL_ADDRESS_CONST(Low, High) \
2487 { {(ULONG)(Low), (LONG)(High)} }
2492 * IN CONST VOID *Source1,
2493 * IN CONST VOID *Source2,
2496 #define NdisEqualMemory(Source1, Source2, Length) \
2497 RtlEqualMemory(Source1, Source2, Length)
2502 * IN PVOID Destination,
2506 #define NdisFillMemory(Destination, Length, Fill) \
2507 RtlFillMemory(Destination, Length, Fill)
2512 * OUT PVOID Destination,
2516 #define NdisMoveMemory(Destination, Source, Length) \
2517 RtlCopyMemory(Destination, Source, Length)
2522 * NdisRetrieveUlong(
2523 * IN PULONG DestinationAddress,
2524 * IN PULONG SourceAddress);
2526 #define NdisRetrieveUlong(DestinationAddress, SourceAddress) \
2527 RtlRetrieveUlong(DestinationAddress, SourceAddress)
2533 * IN PULONG DestinationAddress,
2536 #define NdisStoreUlong(DestinationAddress, Value) \
2537 RtlStoreUlong(DestinationAddress, Value)
2543 * IN PVOID Destination,
2546 #define NdisZeroMemory(Destination, Length) \
2547 RtlZeroMemory(Destination, Length)
2551 /* Configuration routines */
2556 NdisOpenConfiguration(
2557 OUT PNDIS_STATUS Status
,
2558 OUT PNDIS_HANDLE ConfigurationHandle
,
2559 IN NDIS_HANDLE WrapperConfigurationContext
);
2564 NdisReadNetworkAddress(
2565 OUT PNDIS_STATUS Status
,
2566 OUT PVOID
*NetworkAddress
,
2567 OUT PUINT NetworkAddressLength
,
2568 IN NDIS_HANDLE ConfigurationHandle
);
2573 NdisReadEisaSlotInformation(
2574 OUT PNDIS_STATUS Status
,
2575 IN NDIS_HANDLE WrapperConfigurationContext
,
2576 OUT PUINT SlotNumber
,
2577 OUT PNDIS_EISA_FUNCTION_INFORMATION EisaData
);
2582 NdisReadEisaSlotInformationEx(
2583 OUT PNDIS_STATUS Status
,
2584 IN NDIS_HANDLE WrapperConfigurationContext
,
2585 OUT PUINT SlotNumber
,
2586 OUT PNDIS_EISA_FUNCTION_INFORMATION
*EisaData
,
2587 OUT PUINT NumberOfFunctions
);
2592 NdisReadPciSlotInformation(
2593 IN NDIS_HANDLE NdisAdapterHandle
,
2594 IN ULONG SlotNumber
,
2602 NdisWritePciSlotInformation(
2603 IN NDIS_HANDLE NdisAdapterHandle
,
2604 IN ULONG SlotNumber
,
2611 /* String management routines */
2616 NdisAnsiStringToUnicodeString(
2617 IN OUT PNDIS_STRING DestinationString
,
2618 IN PNDIS_ANSI_STRING SourceString
);
2623 * IN PNDIS_STRING String1,
2624 * IN PNDIS_STRING String2,
2625 * IN BOOLEAN CaseInsensitive);
2627 #define NdisEqualString(_String1, _String2, _CaseInsensitive) \
2628 RtlEqualUnicodeString(_String1, _String2, _CaseInsensitive)
2634 IN OUT PNDIS_ANSI_STRING DestinationString
,
2635 IN PCSTR SourceString
);
2640 NdisInitUnicodeString(
2641 IN OUT PNDIS_STRING DestinationString
,
2642 IN PCWSTR SourceString
);
2647 NdisUnicodeStringToAnsiString(
2648 IN OUT PNDIS_ANSI_STRING DestinationString
,
2649 IN PNDIS_STRING SourceString
);
2651 #define NdisFreeString(_s) NdisFreeMemory((_s).Buffer, (_s).MaximumLength, 0)
2652 #define NdisPrintString(_s) DbgPrint("%ls", (_s).Buffer)
2655 /* Spin lock reoutines */
2657 #if BINARY_COMPATIBLE
2662 NdisAllocateSpinLock(
2663 IN PNDIS_SPIN_LOCK SpinLock
);
2669 IN PNDIS_SPIN_LOCK SpinLock
);
2674 NdisAcquireSpinLock(
2675 IN PNDIS_SPIN_LOCK SpinLock
);
2680 NdisReleaseSpinLock(
2681 IN PNDIS_SPIN_LOCK SpinLock
);
2686 NdisDprAcquireSpinLock(
2687 IN PNDIS_SPIN_LOCK SpinLock
);
2692 NdisDprReleaseSpinLock(
2693 IN PNDIS_SPIN_LOCK SpinLock
);
2699 * NdisAllocateSpinLock(
2700 * IN PNDIS_SPIN_LOCK SpinLock);
2702 #define NdisAllocateSpinLock(_SpinLock) \
2703 KeInitializeSpinLock(&(_SpinLock)->SpinLock)
2708 * IN PNDIS_SPIN_LOCK SpinLock);
2710 #define NdisFreeSpinLock(_SpinLock)
2714 * NdisAcquireSpinLock(
2715 * IN PNDIS_SPIN_LOCK SpinLock);
2717 #define NdisAcquireSpinLock(_SpinLock) \
2718 KeAcquireSpinLock(&(_SpinLock)->SpinLock, &(_SpinLock)->OldIrql)
2722 * NdisReleaseSpinLock(
2723 * IN PNDIS_SPIN_LOCK SpinLock);
2725 #define NdisReleaseSpinLock(_SpinLock) \
2726 KeReleaseSpinLock(&(_SpinLock)->SpinLock, (_SpinLock)->OldIrql)
2730 * NdisDprAcquireSpinLock(
2731 * IN PNDIS_SPIN_LOCK SpinLock);
2733 #define NdisDprAcquireSpinLock(_SpinLock) \
2735 KeAcquireSpinLockAtDpcLevel(&(_SpinLock)->SpinLock); \
2736 (_SpinLock)->OldIrql = DISPATCH_LEVEL; \
2741 * NdisDprReleaseSpinLock(
2742 * IN PNDIS_SPIN_LOCK SpinLock);
2744 #define NdisDprReleaseSpinLock(_SpinLock) \
2745 KeReleaseSpinLockFromDpcLevel(&(_SpinLock)->SpinLock)
2747 #endif /* BINARY_COMPATIBLE */
2753 * NdisRawReadPortBufferUchar(
2755 * OUT PUCHAR Buffer,
2758 #define NdisRawReadPortBufferUchar(Port, Buffer, Length) \
2759 READ_PORT_BUFFER_UCHAR((PUCHAR)(Port), (PUCHAR)(Buffer), (Length))
2763 * NdisRawReadPortBufferUlong(
2765 * OUT PULONG Buffer,
2768 #define NdisRawReadPortBufferUlong(Port, Buffer, Length) \
2769 READ_PORT_BUFFER_ULONG((PULONG)(Port), (PULONG)(Buffer), (Length))
2773 * NdisRawReadPortBufferUshort(
2775 * OUT PUSHORT Buffer,
2778 #define NdisRawReadPortBufferUshort(Port, Buffer, Length) \
2779 READ_PORT_BUFFER_USHORT((PUSHORT)(Port), (PUSHORT)(Buffer), (Length))
2784 * NdisRawReadPortUchar(
2788 #define NdisRawReadPortUchar(Port, Data) \
2789 *(Data) = READ_PORT_UCHAR((PUCHAR)(Port))
2793 * NdisRawReadPortUlong(
2797 #define NdisRawReadPortUlong(Port, Data) \
2798 *(Data) = READ_PORT_ULONG((PULONG)(Port))
2802 * NdisRawReadPortUshort(
2804 * OUT PUSHORT Data);
2806 #define NdisRawReadPortUshort(Port, Data) \
2807 *(Data) = READ_PORT_USHORT((PUSHORT)(Port))
2812 * NdisRawWritePortBufferUchar(
2817 #define NdisRawWritePortBufferUchar(Port, Buffer, Length) \
2818 WRITE_PORT_BUFFER_UCHAR((PUCHAR)(Port), (PUCHAR)(Buffer), (Length))
2822 * NdisRawWritePortBufferUlong(
2827 #define NdisRawWritePortBufferUlong(Port, Buffer, Length) \
2828 WRITE_PORT_BUFFER_ULONG((PULONG)(Port), (PULONG)(Buffer), (Length))
2832 * NdisRawWritePortBufferUshort(
2834 * IN PUSHORT Buffer,
2837 #define NdisRawWritePortBufferUshort(Port, Buffer, Length) \
2838 WRITE_PORT_BUFFER_USHORT((PUSHORT)(Port), (PUSHORT)(Buffer), (Length))
2843 * NdisRawWritePortUchar(
2847 #define NdisRawWritePortUchar(Port, Data) \
2848 WRITE_PORT_UCHAR((PUCHAR)(Port), (UCHAR)(Data))
2852 * NdisRawWritePortUlong(
2856 #define NdisRawWritePortUlong(Port, Data) \
2857 WRITE_PORT_ULONG((PULONG)(Port), (ULONG)(Data))
2861 * NdisRawWritePortUshort(
2865 #define NdisRawWritePortUshort(Port, Data) \
2866 WRITE_PORT_USHORT((PUSHORT)(Port), (USHORT)(Data))
2871 * NdisReadRegisterUchar(
2872 * IN PUCHAR Register,
2875 #define NdisReadRegisterUchar(Register, Data) \
2876 *(Data) = *(Register)
2880 * NdisReadRegisterUlong(
2881 * IN PULONG Register,
2884 #define NdisReadRegisterUlong(Register, Data) \
2885 *(Data) = *(Register)
2889 * NdisReadRegisterUshort(
2890 * IN PUSHORT Register,
2891 * OUT PUSHORT Data);
2893 #define NdisReadRegisterUshort(Register, Data) \
2894 *(Data) = *(Register)
2898 * NdisReadRegisterUchar(
2899 * IN PUCHAR Register,
2902 #define NdisWriteRegisterUchar(Register, Data) \
2903 WRITE_REGISTER_UCHAR((Register), (Data))
2907 * NdisReadRegisterUlong(
2908 * IN PULONG Register,
2911 #define NdisWriteRegisterUlong(Register, Data) \
2912 WRITE_REGISTER_ULONG((Register), (Data))
2916 * NdisReadRegisterUshort(
2917 * IN PUSHORT Register,
2920 #define NdisWriteRegisterUshort(Register, Data) \
2921 WRITE_REGISTER_USHORT((Register), (Data))
2928 * NdisInitializeListHead(
2929 * IN PLIST_ENTRY ListHead);
2931 #define NdisInitializeListHead(_ListHead) \
2932 InitializeListHead(_ListHead)
2936 * NdisInterlockedInsertHeadList(
2937 * IN PLIST_ENTRY ListHead,
2938 * IN PLIST_ENTRY ListEntry,
2939 * IN PNDIS_SPIN_LOCK SpinLock);
2941 #define NdisInterlockedInsertHeadList(_ListHead, _ListEntry, _SpinLock) \
2942 ExInterlockedInsertHeadList(_ListHead, _ListEntry, &(_SpinLock)->SpinLock)
2946 * NdisInterlockedInsertTailList(
2947 * IN PLIST_ENTRY ListHead,
2948 * IN PLIST_ENTRY ListEntry,
2949 * IN PNDIS_SPIN_LOCK SpinLock);
2951 #define NdisInterlockedInsertTailList(_ListHead, _ListEntry, _SpinLock) \
2952 ExInterlockedInsertTailList(_ListHead, _ListEntry, &(_SpinLock)->SpinLock)
2956 * NdisInterlockedRemoveHeadList(
2957 * IN PLIST_ENTRY ListHead,
2958 * IN PNDIS_SPIN_LOCK SpinLock);
2960 #define NdisInterlockedRemoveHeadList(_ListHead, _SpinLock) \
2961 ExInterlockedRemoveHeadList(_ListHead, &(_SpinLock)->SpinLock)
2965 * NdisInitializeSListHead(
2966 * IN PSLIST_HEADER SListHead);
2968 #define NdisInitializeSListHead(SListHead) ExInitializeSListHead(SListHead)
2971 * USHORT NdisQueryDepthSList(
2972 * IN PSLIST_HEADER SListHead);
2974 #define NdisQueryDepthSList(SListHead) ExQueryDepthSList(SListHead)
2978 /* Interlocked routines */
2982 * NdisInterlockedDecrement(
2985 #define NdisInterlockedDecrement(Addend) InterlockedDecrement(Addend)
2989 * NdisInterlockedIncrement(
2992 #define NdisInterlockedIncrement(Addend) InterlockedIncrement(Addend)
2996 * NdisInterlockedAddUlong(
2998 * IN ULONG Increment,
2999 * IN PNDIS_SPIN_LOCK SpinLock);
3001 #define NdisInterlockedAddUlong(_Addend, _Increment, _SpinLock) \
3002 ExInterlockedAddUlong(_Addend, _Increment, &(_SpinLock)->SpinLock)
3006 /* Miscellaneous routines */
3011 NdisCloseConfiguration(
3012 IN NDIS_HANDLE ConfigurationHandle
);
3017 NdisReadConfiguration(
3018 OUT PNDIS_STATUS Status
,
3019 OUT PNDIS_CONFIGURATION_PARAMETER
*ParameterValue
,
3020 IN NDIS_HANDLE ConfigurationHandle
,
3021 IN PNDIS_STRING Keyword
,
3022 IN NDIS_PARAMETER_TYPE ParameterType
);
3027 NdisWriteConfiguration(
3028 OUT PNDIS_STATUS Status
,
3029 IN NDIS_HANDLE WrapperConfigurationContext
,
3030 IN PNDIS_STRING Keyword
,
3031 IN PNDIS_CONFIGURATION_PARAMETER ParameterValue
);
3036 NdisWriteErrorLogEntry(
3037 IN NDIS_HANDLE NdisAdapterHandle
,
3038 IN NDIS_ERROR_CODE ErrorCode
,
3039 IN ULONG NumberOfErrorValues
,
3044 * NdisStallExecution(
3045 * IN UINT MicrosecondsToStall)
3047 #define NdisStallExecution KeStallExecutionProcessor
3049 #if BINARY_COMPATIBLE
3054 NdisGetCurrentSystemTime(
3055 IN PLARGE_INTEGER pSystemTime
);
3061 * NdisGetCurrentSystemTime(
3062 * IN PLARGE_INTEGER pSystemTime);
3064 #define NdisGetCurrentSystemTime KeQuerySystemTime
3071 NdisSystemProcessorCount(VOID
);
3076 NdisGetCurrentProcessorCpuUsage(
3077 OUT PULONG pCpuUsage
);
3081 /* NDIS helper macros */
3085 * NDIS_INIT_FUNCTION(FunctionName)
3087 #define NDIS_INIT_FUNCTION(FunctionName) \
3088 alloc_text(init, FunctionName)
3092 * NDIS_PAGABLE_FUNCTION(FunctionName)
3094 #define NDIS_PAGEABLE_FUNCTION(FunctionName) \
3095 alloc_text(page, FunctionName)
3097 #define NDIS_PAGABLE_FUNCTION NDIS_PAGEABLE_FUNCTION
3100 /* NDIS 4.0 extensions */
3105 NdisMFreeSharedMemory(
3106 IN NDIS_HANDLE MiniportAdapterHandle
,
3109 IN PVOID VirtualAddress
,
3110 IN NDIS_PHYSICAL_ADDRESS PhysicalAddress
);
3115 NdisMWanIndicateReceive(
3116 OUT PNDIS_STATUS Status
,
3117 IN NDIS_HANDLE MiniportAdapterHandle
,
3118 IN NDIS_HANDLE NdisLinkContext
,
3119 IN PUCHAR PacketBuffer
,
3120 IN UINT PacketSize
);
3125 NdisMWanIndicateReceiveComplete(
3126 IN NDIS_HANDLE MiniportAdapterHandle
);
3131 NdisMWanSendComplete(
3132 IN NDIS_HANDLE MiniportAdapterHandle
,
3133 IN PNDIS_WAN_PACKET Packet
,
3134 IN NDIS_STATUS Status
);
3139 NdisPciAssignResources(
3140 IN NDIS_HANDLE NdisMacHandle
,
3141 IN NDIS_HANDLE NdisWrapperHandle
,
3142 IN NDIS_HANDLE WrapperConfigurationContext
,
3143 IN ULONG SlotNumber
,
3144 OUT PNDIS_RESOURCE_LIST
*AssignedResources
);
3147 /* NDIS 5.0 extensions */
3152 NdisAcquireReadWriteLock(
3153 IN PNDIS_RW_LOCK Lock
,
3155 IN PLOCK_STATE LockState
);
3160 NdisAllocateMemoryWithTag(
3161 OUT PVOID
*VirtualAddress
,
3168 NdisAllocatePacketPoolEx(
3169 OUT PNDIS_STATUS Status
,
3170 OUT PNDIS_HANDLE PoolHandle
,
3171 IN UINT NumberOfDescriptors
,
3172 IN UINT NumberOfOverflowDescriptors
,
3173 IN UINT ProtocolReservedLength
);
3178 NdisCompletePnPEvent(
3179 IN NDIS_STATUS Status
,
3180 IN NDIS_HANDLE NdisBindingHandle
,
3181 IN PNET_PNP_EVENT NetPnPEvent
);
3186 NdisGetCurrentProcessorCounts(
3187 OUT PULONG pIdleCount
,
3188 OUT PULONG pKernelAndUser
,
3194 NdisGetDriverHandle(
3195 IN PNDIS_HANDLE NdisBindingHandle
,
3196 OUT PNDIS_HANDLE NdisDriverHandle
);
3201 NdisGetReceivedPacket(
3202 IN PNDIS_HANDLE NdisBindingHandle
,
3203 IN PNDIS_HANDLE MacContext
);
3208 NdisGetSystemUptime(
3209 OUT PULONG pSystemUpTime
);
3214 NdisInitializeReadWriteLock(
3215 IN PNDIS_RW_LOCK Lock
);
3220 NdisMDeregisterDevice(
3221 IN NDIS_HANDLE NdisDeviceHandle
);
3226 NdisMGetDeviceProperty(
3227 IN NDIS_HANDLE MiniportAdapterHandle
,
3228 IN OUT PDEVICE_OBJECT
*PhysicalDeviceObject OPTIONAL
,
3229 IN OUT PDEVICE_OBJECT
*FunctionalDeviceObject OPTIONAL
,
3230 IN OUT PDEVICE_OBJECT
*NextDeviceObject OPTIONAL
,
3231 IN OUT PCM_RESOURCE_LIST
*AllocatedResources OPTIONAL
,
3232 IN OUT PCM_RESOURCE_LIST
*AllocatedResourcesTranslated OPTIONAL
);
3237 NdisMInitializeScatterGatherDma(
3238 IN NDIS_HANDLE MiniportAdapterHandle
,
3239 IN BOOLEAN Dma64BitAddresses
,
3240 IN ULONG MaximumPhysicalMapping
);
3245 NdisMPromoteMiniport(
3246 IN NDIS_HANDLE MiniportAdapterHandle
);
3251 NdisMQueryAdapterInstanceName(
3252 OUT PNDIS_STRING AdapterInstanceName
,
3253 IN NDIS_HANDLE MiniportAdapterHandle
);
3258 NdisMRegisterDevice(
3259 IN NDIS_HANDLE NdisWrapperHandle
,
3260 IN PNDIS_STRING DeviceName
,
3261 IN PNDIS_STRING SymbolicName
,
3262 IN PDRIVER_DISPATCH MajorFunctions
[],
3263 OUT PDEVICE_OBJECT
*pDeviceObject
,
3264 OUT NDIS_HANDLE
*NdisDeviceHandle
);
3269 NdisMRegisterUnloadHandler(
3270 IN NDIS_HANDLE NdisWrapperHandle
,
3271 IN PDRIVER_UNLOAD UnloadHandler
);
3276 NdisMRemoveMiniport(
3277 IN NDIS_HANDLE MiniportAdapterHandle
);
3282 NdisMSetMiniportSecondary(
3283 IN NDIS_HANDLE MiniportAdapterHandle
,
3284 IN NDIS_HANDLE PrimaryMiniportAdapterHandle
);
3289 NdisOpenConfigurationKeyByIndex(
3290 OUT PNDIS_STATUS Status
,
3291 IN NDIS_HANDLE ConfigurationHandle
,
3293 OUT PNDIS_STRING KeyName
,
3294 OUT PNDIS_HANDLE KeyHandle
);
3299 NdisOpenConfigurationKeyByName(
3300 OUT PNDIS_STATUS Status
,
3301 IN NDIS_HANDLE ConfigurationHandle
,
3302 IN PNDIS_STRING SubKeyName
,
3303 OUT PNDIS_HANDLE SubKeyHandle
);
3308 NdisPacketPoolUsage(
3309 IN NDIS_HANDLE PoolHandle
);
3314 NdisQueryAdapterInstanceName(
3315 OUT PNDIS_STRING AdapterInstanceName
,
3316 IN NDIS_HANDLE NdisBindingHandle
);
3321 NdisReadPcmciaAttributeMemory(
3322 IN NDIS_HANDLE NdisAdapterHandle
,
3330 NdisReleaseReadWriteLock(
3331 IN PNDIS_RW_LOCK Lock
,
3332 IN PLOCK_STATE LockState
);
3337 NdisWriteEventLogEntry(
3339 IN NDIS_STATUS EventCode
,
3340 IN ULONG UniqueEventValue
,
3341 IN USHORT NumStrings
,
3342 IN PVOID StringsList OPTIONAL
,
3344 IN PVOID Data OPTIONAL
);
3349 NdisWritePcmciaAttributeMemory(
3350 IN NDIS_HANDLE NdisAdapterHandle
,
3356 /* Connectionless services */
3362 IN NDIS_HANDLE NdisVcHandle
,
3363 IN NDIS_HANDLE ProtocolPartyContext
,
3364 IN OUT PCO_CALL_PARAMETERS CallParameters
,
3365 OUT PNDIS_HANDLE NdisPartyHandle
);
3370 NdisClCloseAddressFamily(
3371 IN NDIS_HANDLE NdisAfHandle
);
3377 IN NDIS_HANDLE NdisVcHandle
,
3378 IN NDIS_HANDLE NdisPartyHandle OPTIONAL
,
3379 IN PVOID Buffer OPTIONAL
,
3385 NdisClDeregisterSap(
3386 IN NDIS_HANDLE NdisSapHandle
);
3392 IN NDIS_HANDLE NdisPartyHandle
,
3393 IN PVOID Buffer OPTIONAL
,
3399 NdisClIncomingCallComplete(
3400 IN NDIS_STATUS Status
,
3401 IN NDIS_HANDLE NdisVcHandle
,
3402 IN PCO_CALL_PARAMETERS CallParameters
);
3408 IN NDIS_HANDLE NdisVcHandle
,
3409 IN OUT PCO_CALL_PARAMETERS CallParameters
,
3410 IN NDIS_HANDLE ProtocolPartyContext OPTIONAL
,
3411 OUT PNDIS_HANDLE NdisPartyHandle OPTIONAL
);
3416 NdisClModifyCallQoS(
3417 IN NDIS_HANDLE NdisVcHandle
,
3418 IN PCO_CALL_PARAMETERS CallParameters
);
3424 NdisClOpenAddressFamily(
3425 IN NDIS_HANDLE NdisBindingHandle
,
3426 IN PCO_ADDRESS_FAMILY AddressFamily
,
3427 IN NDIS_HANDLE ProtocolAfContext
,
3428 IN PNDIS_CLIENT_CHARACTERISTICS ClCharacteristics
,
3429 IN UINT SizeOfClCharacteristics
,
3430 OUT PNDIS_HANDLE NdisAfHandle
);
3436 IN NDIS_HANDLE NdisAfHandle
,
3437 IN NDIS_HANDLE ProtocolSapContext
,
3439 OUT PNDIS_HANDLE NdisSapHandle
);
3442 /* Call Manager services */
3448 IN NDIS_HANDLE NdisVcHandle
,
3449 IN OUT PCO_CALL_PARAMETERS CallParameters
);
3454 NdisCmAddPartyComplete(
3455 IN NDIS_STATUS Status
,
3456 IN NDIS_HANDLE NdisPartyHandle
,
3457 IN NDIS_HANDLE CallMgrPartyContext OPTIONAL
,
3458 IN PCO_CALL_PARAMETERS CallParameters
);
3463 NdisCmCloseAddressFamilyComplete(
3464 IN NDIS_STATUS Status
,
3465 IN NDIS_HANDLE NdisAfHandle
);
3470 NdisCmCloseCallComplete(
3471 IN NDIS_STATUS Status
,
3472 IN NDIS_HANDLE NdisVcHandle
,
3473 IN NDIS_HANDLE NdisPartyHandle OPTIONAL
);
3479 IN NDIS_HANDLE NdisVcHandle
);
3484 NdisCmDeregisterSapComplete(
3485 IN NDIS_STATUS Status
,
3486 IN NDIS_HANDLE NdisSapHandle
);
3491 NdisCmDispatchCallConnected(
3492 IN NDIS_HANDLE NdisVcHandle
);
3497 NdisCmDispatchIncomingCall(
3498 IN NDIS_HANDLE NdisSapHandle
,
3499 IN NDIS_HANDLE NdisVcHandle
,
3500 IN PCO_CALL_PARAMETERS CallParameters
);
3505 NdisCmDispatchIncomingCallQoSChange(
3506 IN NDIS_HANDLE NdisVcHandle
,
3507 IN PCO_CALL_PARAMETERS CallParameters
);
3512 NdisCmDispatchIncomingCloseCall(
3513 IN NDIS_STATUS CloseStatus
,
3514 IN NDIS_HANDLE NdisVcHandle
,
3515 IN PVOID Buffer OPTIONAL
,
3521 NdisCmDispatchIncomingDropParty(
3522 IN NDIS_STATUS DropStatus
,
3523 IN NDIS_HANDLE NdisPartyHandle
,
3524 IN PVOID Buffer OPTIONAL
,
3530 NdisCmDropPartyComplete(
3531 IN NDIS_STATUS Status
,
3532 IN NDIS_HANDLE NdisPartyHandle
);
3537 NdisCmMakeCallComplete(
3538 IN NDIS_STATUS Status
,
3539 IN NDIS_HANDLE NdisVcHandle
,
3540 IN NDIS_HANDLE NdisPartyHandle OPTIONAL
,
3541 IN NDIS_HANDLE CallMgrPartyContext OPTIONAL
,
3542 IN PCO_CALL_PARAMETERS CallParameters
);
3547 NdisCmModifyCallQoSComplete(
3548 IN NDIS_STATUS Status
,
3549 IN NDIS_HANDLE NdisVcHandle
,
3550 IN PCO_CALL_PARAMETERS CallParameters
);
3555 NdisCmOpenAddressFamilyComplete(
3556 IN NDIS_STATUS Status
,
3557 IN NDIS_HANDLE NdisAfHandle
,
3558 IN NDIS_HANDLE CallMgrAfContext
);
3563 NdisCmRegisterAddressFamily(
3564 IN NDIS_HANDLE NdisBindingHandle
,
3565 IN PCO_ADDRESS_FAMILY AddressFamily
,
3566 IN PNDIS_CALL_MANAGER_CHARACTERISTICS CmCharacteristics
,
3567 IN UINT SizeOfCmCharacteristics
);
3572 NdisCmRegisterSapComplete(
3573 IN NDIS_STATUS Status
,
3574 IN NDIS_HANDLE NdisSapHandle
,
3575 IN NDIS_HANDLE CallMgrSapContext
);
3582 IN NDIS_HANDLE NdisVcHandle
,
3583 IN PCO_CALL_PARAMETERS CallParameters
);
3589 IN NDIS_HANDLE MiniportAdapterHandle
,
3590 IN NDIS_HANDLE NdisAfHandle
,
3591 IN NDIS_HANDLE MiniportVcContext
,
3592 OUT PNDIS_HANDLE NdisVcHandle
);
3597 NdisMCmDeactivateVc(
3598 IN NDIS_HANDLE NdisVcHandle
);
3604 IN NDIS_HANDLE NdisVcHandle
);
3609 NdisMCmRegisterAddressFamily(
3610 IN NDIS_HANDLE MiniportAdapterHandle
,
3611 IN PCO_ADDRESS_FAMILY AddressFamily
,
3612 IN PNDIS_CALL_MANAGER_CHARACTERISTICS CmCharacteristics
,
3613 IN UINT SizeOfCmCharacteristics
);
3619 IN NDIS_HANDLE NdisAfHandle
,
3620 IN NDIS_HANDLE NdisVcHandle OPTIONAL
,
3621 IN NDIS_HANDLE NdisPartyHandle OPTIONAL
,
3622 IN OUT PNDIS_REQUEST NdisRequest
);
3625 /* Connection-oriented services */
3631 IN NDIS_HANDLE NdisBindingHandle
,
3632 IN NDIS_HANDLE NdisAfHandle OPTIONAL
,
3633 IN NDIS_HANDLE ProtocolVcContext
,
3634 IN OUT PNDIS_HANDLE NdisVcHandle
);
3640 IN NDIS_HANDLE NdisVcHandle
);
3646 IN NDIS_HANDLE NdisBindingHandle
,
3647 IN NDIS_HANDLE NdisAfHandle OPTIONAL
,
3648 IN NDIS_HANDLE NdisVcHandle OPTIONAL
,
3649 IN NDIS_HANDLE NdisPartyHandle OPTIONAL
,
3650 IN OUT PNDIS_REQUEST NdisRequest
);
3655 NdisCoRequestComplete(
3656 IN NDIS_STATUS Status
,
3657 IN NDIS_HANDLE NdisAfHandle
,
3658 IN NDIS_HANDLE NdisVcHandle OPTIONAL
,
3659 IN NDIS_HANDLE NdisPartyHandle OPTIONAL
,
3660 IN PNDIS_REQUEST NdisRequest
);
3666 IN NDIS_HANDLE NdisVcHandle
,
3667 IN PPNDIS_PACKET PacketArray
,
3668 IN UINT NumberOfPackets
);
3673 NdisMCoActivateVcComplete(
3674 IN NDIS_STATUS Status
,
3675 IN NDIS_HANDLE NdisVcHandle
,
3676 IN PCO_CALL_PARAMETERS CallParameters
);
3681 NdisMCoDeactivateVcComplete(
3682 IN NDIS_STATUS Status
,
3683 IN NDIS_HANDLE NdisVcHandle
);
3688 NdisMCoIndicateReceivePacket(
3689 IN NDIS_HANDLE NdisVcHandle
,
3690 IN PPNDIS_PACKET PacketArray
,
3691 IN UINT NumberOfPackets
);
3696 NdisMCoIndicateStatus(
3697 IN NDIS_HANDLE MiniportAdapterHandle
,
3698 IN NDIS_HANDLE NdisVcHandle OPTIONAL
,
3699 IN NDIS_STATUS GeneralStatus
,
3700 IN PVOID StatusBuffer OPTIONAL
,
3701 IN ULONG StatusBufferSize
);
3706 NdisMCoReceiveComplete(
3707 IN NDIS_HANDLE MiniportAdapterHandle
);
3712 NdisMCoRequestComplete(
3713 IN NDIS_STATUS Status
,
3714 IN NDIS_HANDLE MiniportAdapterHandle
,
3715 IN PNDIS_REQUEST Request
);
3720 NdisMCoSendComplete(
3721 IN NDIS_STATUS Status
,
3722 IN NDIS_HANDLE NdisVcHandle
,
3723 IN PNDIS_PACKET Packet
);
3726 /* NDIS 5.0 extensions for intermediate drivers */
3731 NdisIMAssociateMiniport(
3732 IN NDIS_HANDLE DriverHandle
,
3733 IN NDIS_HANDLE ProtocolHandle
);
3738 NdisIMCancelInitializeDeviceInstance(
3739 IN NDIS_HANDLE DriverHandle
,
3740 IN PNDIS_STRING DeviceInstance
);
3745 NdisIMCopySendCompletePerPacketInfo(
3746 IN PNDIS_PACKET DstPacket
,
3747 IN PNDIS_PACKET SrcPacket
);
3752 NdisIMCopySendPerPacketInfo(
3753 IN PNDIS_PACKET DstPacket
,
3754 IN PNDIS_PACKET SrcPacket
);
3759 NdisIMDeregisterLayeredMiniport(
3760 IN NDIS_HANDLE DriverHandle
);
3765 NdisIMGetBindingContext(
3766 IN NDIS_HANDLE NdisBindingHandle
);
3771 NdisIMGetDeviceContext(
3772 IN NDIS_HANDLE MiniportAdapterHandle
);
3777 NdisIMInitializeDeviceInstanceEx(
3778 IN NDIS_HANDLE DriverHandle
,
3779 IN PNDIS_STRING DriverInstance
,
3780 IN NDIS_HANDLE DeviceContext OPTIONAL
);
3785 NdisInterlockedPopEntrySList(
3786 IN PSLIST_HEADER ListHead
,
3787 IN PKSPIN_LOCK Lock
);
3792 NdisInterlockedPushEntrySList(
3793 IN PSLIST_HEADER ListHead
,
3794 IN PSINGLE_LIST_ENTRY ListEntry
,
3795 IN PKSPIN_LOCK Lock
);
3800 NdisQueryBufferSafe(
3801 IN PNDIS_BUFFER Buffer
,
3802 OUT PVOID
*VirtualAddress OPTIONAL
,
3806 /* Prototypes for NDIS_MINIPORT_CHARACTERISTICS */
3808 typedef BOOLEAN DDKAPI
3809 (*W_CHECK_FOR_HANG_HANDLER
)(
3810 IN NDIS_HANDLE MiniportAdapterContext
);
3813 (*W_DISABLE_INTERRUPT_HANDLER
)(
3814 IN NDIS_HANDLE MiniportAdapterContext
);
3817 (*W_ENABLE_INTERRUPT_HANDLER
)(
3818 IN NDIS_HANDLE MiniportAdapterContext
);
3822 IN NDIS_HANDLE MiniportAdapterContext
);
3825 (*W_HANDLE_INTERRUPT_HANDLER
)(
3826 IN NDIS_HANDLE MiniportAdapterContext
);
3828 typedef NDIS_STATUS DDKAPI
3829 (*W_INITIALIZE_HANDLER
)(
3830 OUT PNDIS_STATUS OpenErrorStatus
,
3831 OUT PUINT SelectedMediumIndex
,
3832 IN PNDIS_MEDIUM MediumArray
,
3833 IN UINT MediumArraySize
,
3834 IN NDIS_HANDLE MiniportAdapterContext
,
3835 IN NDIS_HANDLE WrapperConfigurationContext
);
3839 OUT PBOOLEAN InterruptRecognized
,
3840 OUT PBOOLEAN QueueMiniportHandleInterrupt
,
3841 IN NDIS_HANDLE MiniportAdapterContext
);
3843 typedef NDIS_STATUS DDKAPI
3844 (*W_QUERY_INFORMATION_HANDLER
)(
3845 IN NDIS_HANDLE MiniportAdapterContext
,
3847 IN PVOID InformationBuffer
,
3848 IN ULONG InformationBufferLength
,
3849 OUT PULONG BytesWritten
,
3850 OUT PULONG BytesNeeded
);
3852 typedef NDIS_STATUS DDKAPI
3853 (*W_RECONFIGURE_HANDLER
)(
3854 OUT PNDIS_STATUS OpenErrorStatus
,
3855 IN NDIS_HANDLE MiniportAdapterContext
,
3856 IN NDIS_HANDLE WrapperConfigurationContext
);
3858 typedef NDIS_STATUS DDKAPI
3860 OUT PBOOLEAN AddressingReset
,
3861 IN NDIS_HANDLE MiniportAdapterContext
);
3863 typedef NDIS_STATUS DDKAPI
3865 IN NDIS_HANDLE MiniportAdapterContext
,
3866 IN PNDIS_PACKET Packet
,
3869 typedef NDIS_STATUS DDKAPI
3871 IN NDIS_HANDLE MiniportAdapterContext
,
3872 IN NDIS_HANDLE NdisLinkHandle
,
3873 IN PNDIS_WAN_PACKET Packet
);
3875 typedef NDIS_STATUS DDKAPI
3876 (*W_SET_INFORMATION_HANDLER
)(
3877 IN NDIS_HANDLE MiniportAdapterContext
,
3879 IN PVOID InformationBuffer
,
3880 IN ULONG InformationBufferLength
,
3881 OUT PULONG BytesRead
,
3882 OUT PULONG BytesNeeded
);
3884 typedef NDIS_STATUS DDKAPI
3885 (*W_TRANSFER_DATA_HANDLER
)(
3886 OUT PNDIS_PACKET Packet
,
3887 OUT PUINT BytesTransferred
,
3888 IN NDIS_HANDLE MiniportAdapterContext
,
3889 IN NDIS_HANDLE MiniportReceiveContext
,
3891 IN UINT BytesToTransfer
);
3893 typedef NDIS_STATUS DDKAPI
3894 (*WM_TRANSFER_DATA_HANDLER
)(
3898 /* NDIS structures available only to miniport drivers */
3900 #define NDIS30_MINIPORT_CHARACTERISTICS_S \
3901 UCHAR MajorNdisVersion; \
3902 UCHAR MinorNdisVersion; \
3905 W_CHECK_FOR_HANG_HANDLER CheckForHangHandler; \
3906 W_DISABLE_INTERRUPT_HANDLER DisableInterruptHandler; \
3907 W_ENABLE_INTERRUPT_HANDLER EnableInterruptHandler; \
3908 W_HALT_HANDLER HaltHandler; \
3909 W_HANDLE_INTERRUPT_HANDLER HandleInterruptHandler; \
3910 W_INITIALIZE_HANDLER InitializeHandler; \
3911 W_ISR_HANDLER ISRHandler; \
3912 W_QUERY_INFORMATION_HANDLER QueryInformationHandler; \
3913 W_RECONFIGURE_HANDLER ReconfigureHandler; \
3914 W_RESET_HANDLER ResetHandler; \
3915 _ANONYMOUS_UNION union { \
3916 W_SEND_HANDLER SendHandler; \
3917 WM_SEND_HANDLER WanSendHandler; \
3918 } _UNION_NAME(u1); \
3919 W_SET_INFORMATION_HANDLER SetInformationHandler; \
3920 _ANONYMOUS_UNION union { \
3921 W_TRANSFER_DATA_HANDLER TransferDataHandler; \
3922 WM_TRANSFER_DATA_HANDLER WanTransferDataHandler; \
3925 typedef struct _NDIS30_MINIPORT_CHARACTERISTICS
{
3926 NDIS30_MINIPORT_CHARACTERISTICS_S
3927 } NDIS30_MINIPORT_CHARACTERISTICS
, *PSNDIS30_MINIPORT_CHARACTERISTICS
;
3930 /* Extensions for NDIS 4.0 miniports */
3933 (*W_SEND_PACKETS_HANDLER
)(
3934 IN NDIS_HANDLE MiniportAdapterContext
,
3935 IN PPNDIS_PACKET PacketArray
,
3936 IN UINT NumberOfPackets
);
3939 (*W_RETURN_PACKET_HANDLER
)(
3940 IN NDIS_HANDLE MiniportAdapterContext
,
3941 IN PNDIS_PACKET Packet
);
3944 (*W_ALLOCATE_COMPLETE_HANDLER
)(
3945 IN NDIS_HANDLE MiniportAdapterContext
,
3946 IN PVOID VirtualAddress
,
3947 IN PNDIS_PHYSICAL_ADDRESS PhysicalAddress
,
3953 #define NDIS40_MINIPORT_CHARACTERISTICS_S \
3954 NDIS30_MINIPORT_CHARACTERISTICS Ndis30Chars; \
3955 W_RETURN_PACKET_HANDLER ReturnPacketHandler; \
3956 W_SEND_PACKETS_HANDLER SendPacketsHandler; \
3957 W_ALLOCATE_COMPLETE_HANDLER AllocateCompleteHandler;
3959 #else /* !__cplusplus */
3961 #define NDIS40_MINIPORT_CHARACTERISTICS_S \
3962 NDIS30_MINIPORT_CHARACTERISTICS_S \
3963 W_RETURN_PACKET_HANDLER ReturnPacketHandler; \
3964 W_SEND_PACKETS_HANDLER SendPacketsHandler; \
3965 W_ALLOCATE_COMPLETE_HANDLER AllocateCompleteHandler;
3967 #endif /* !__cplusplus */
3969 typedef struct _NDIS40_MINIPORT_CHARACTERISTICS
{
3970 NDIS40_MINIPORT_CHARACTERISTICS_S
3971 } NDIS40_MINIPORT_CHARACTERISTICS
, *PNDIS40_MINIPORT_CHARACTERISTICS
;
3974 /* Extensions for NDIS 5.0 miniports */
3976 typedef NDIS_STATUS DDKAPI
3977 (*W_CO_CREATE_VC_HANDLER
)(
3978 IN NDIS_HANDLE MiniportAdapterContext
,
3979 IN NDIS_HANDLE NdisVcHandle
,
3980 OUT PNDIS_HANDLE MiniportVcContext
);
3982 typedef NDIS_STATUS DDKAPI
3983 (*W_CO_DELETE_VC_HANDLER
)(
3984 IN NDIS_HANDLE MiniportVcContext
);
3986 typedef NDIS_STATUS DDKAPI
3987 (*W_CO_ACTIVATE_VC_HANDLER
)(
3988 IN NDIS_HANDLE MiniportVcContext
,
3989 IN OUT PCO_CALL_PARAMETERS CallParameters
);
3991 typedef NDIS_STATUS DDKAPI
3992 (*W_CO_DEACTIVATE_VC_HANDLER
)(
3993 IN NDIS_HANDLE MiniportVcContext
);
3996 (*W_CO_SEND_PACKETS_HANDLER
)(
3997 IN NDIS_HANDLE MiniportVcContext
,
3998 IN PPNDIS_PACKET PacketArray
,
3999 IN UINT NumberOfPackets
);
4001 typedef NDIS_STATUS DDKAPI
4002 (*W_CO_REQUEST_HANDLER
)(
4003 IN NDIS_HANDLE MiniportAdapterContext
,
4004 IN NDIS_HANDLE MiniportVcContext OPTIONAL
,
4005 IN OUT PNDIS_REQUEST NdisRequest
);
4009 #define NDIS50_MINIPORT_CHARACTERISTICS_S \
4010 NDIS40_MINIPORT_CHARACTERISTICS Ndis40Chars; \
4011 W_CO_CREATE_VC_HANDLER CoCreateVcHandler; \
4012 W_CO_DELETE_VC_HANDLER CoDeleteVcHandler; \
4013 W_CO_ACTIVATE_VC_HANDLER CoActivateVcHandler; \
4014 W_CO_DEACTIVATE_VC_HANDLER CoDeactivateVcHandler; \
4015 W_CO_SEND_PACKETS_HANDLER CoSendPacketsHandler; \
4016 W_CO_REQUEST_HANDLER CoRequestHandler;
4018 #else /* !__cplusplus */
4020 #define NDIS50_MINIPORT_CHARACTERISTICS_S \
4021 NDIS40_MINIPORT_CHARACTERISTICS_S \
4022 W_CO_CREATE_VC_HANDLER CoCreateVcHandler; \
4023 W_CO_DELETE_VC_HANDLER CoDeleteVcHandler; \
4024 W_CO_ACTIVATE_VC_HANDLER CoActivateVcHandler; \
4025 W_CO_DEACTIVATE_VC_HANDLER CoDeactivateVcHandler; \
4026 W_CO_SEND_PACKETS_HANDLER CoSendPacketsHandler; \
4027 W_CO_REQUEST_HANDLER CoRequestHandler;
4029 #endif /* !__cplusplus */
4031 typedef struct _NDIS50_MINIPORT_CHARACTERISTICS
{
4032 NDIS50_MINIPORT_CHARACTERISTICS_S
4033 } NDIS50_MINIPORT_CHARACTERISTICS
, *PSNDIS50_MINIPORT_CHARACTERISTICS
;
4036 /* Extensions for NDIS 5.1 miniports */
4039 (*W_CANCEL_SEND_PACKETS_HANDLER
)(
4040 IN NDIS_HANDLE MiniportAdapterContext
,
4044 #if defined(NDIS51_MINIPORT)
4045 typedef struct _NDIS_MINIPORT_CHARACTERISTICS
{
4046 NDIS50_MINIPORT_CHARACTERISTICS_S
4047 } NDIS_MINIPORT_CHARACTERISTICS
, *PNDIS_MINIPORT_CHARACTERISTICS
;
4048 #elif defined(NDIS50_MINIPORT)
4049 typedef struct _NDIS_MINIPORT_CHARACTERISTICS
{
4050 NDIS50_MINIPORT_CHARACTERISTICS_S
4051 } NDIS_MINIPORT_CHARACTERISTICS
, *PNDIS_MINIPORT_CHARACTERISTICS
;
4052 #elif defined(NDIS40_MINIPORT)
4053 typedef struct _NDIS_MINIPORT_CHARACTERISTICS
{
4054 NDIS40_MINIPORT_CHARACTERISTICS_S
4055 } NDIS_MINIPORT_CHARACTERISTICS
, *PNDIS_MINIPORT_CHARACTERISTICS
;
4057 typedef struct _NDIS_MINIPORT_CHARACTERISTICS
{
4058 NDIS30_MINIPORT_CHARACTERISTICS_S
4059 } NDIS_MINIPORT_CHARACTERISTICS
, *PNDIS_MINIPORT_CHARACTERISTICS
;
4063 typedef NDIS_STATUS DDKAPI
4065 IN NDIS_HANDLE MacBindingHandle
,
4066 IN PNDIS_PACKET Packet
);
4068 typedef NDIS_STATUS DDKAPI
4069 (*TRANSFER_DATA_HANDLER
)(
4070 IN NDIS_HANDLE MacBindingHandle
,
4071 IN NDIS_HANDLE MacReceiveContext
,
4073 IN UINT BytesToTransfer
,
4074 OUT PNDIS_PACKET Packet
,
4075 OUT PUINT BytesTransferred
);
4077 typedef NDIS_STATUS DDKAPI
4079 IN NDIS_HANDLE MacBindingHandle
);
4081 typedef NDIS_STATUS DDKAPI
4083 IN NDIS_HANDLE MacBindingHandle
,
4084 IN PNDIS_REQUEST NdisRequest
);
4088 /* Structures available only to full MAC drivers */
4090 typedef BOOLEAN DDKAPI
4091 (*PNDIS_INTERRUPT_SERVICE
)(
4092 IN PVOID InterruptContext
);
4095 (*PNDIS_DEFERRED_PROCESSING
)(
4096 IN PVOID SystemSpecific1
,
4097 IN PVOID InterruptContext
,
4098 IN PVOID SystemSpecific2
,
4099 IN PVOID SystemSpecific3
);
4103 typedef struct _NDIS_MINIPORT_BLOCK NDIS_MINIPORT_BLOCK
, *PNDIS_MINIPORT_BLOCK
;
4104 typedef struct _NDIS_PROTOCOL_BLOCK NDIS_PROTOCOL_BLOCK
, *PNDIS_PROTOCOL_BLOCK
;
4105 typedef struct _NDIS_OPEN_BLOCK NDIS_OPEN_BLOCK
, *PNDIS_OPEN_BLOCK
;
4106 typedef struct _NDIS_M_DRIVER_BLOCK NDIS_M_DRIVER_BLOCK
, *PNDIS_M_DRIVER_BLOCK
;
4107 typedef struct _NDIS_AF_LIST NDIS_AF_LIST
, *PNDIS_AF_LIST
;
4110 typedef struct _NDIS_MINIPORT_INTERRUPT
{
4111 PKINTERRUPT InterruptObject
;
4112 KSPIN_LOCK DpcCountLock
;
4113 PVOID MiniportIdField
;
4114 W_ISR_HANDLER MiniportIsr
;
4115 W_HANDLE_INTERRUPT_HANDLER MiniportDpc
;
4117 PNDIS_MINIPORT_BLOCK Miniport
;
4120 KEVENT DpcsCompletedEvent
;
4121 BOOLEAN SharedInterrupt
;
4122 BOOLEAN IsrRequested
;
4123 } NDIS_MINIPORT_INTERRUPT
, *PNDIS_MINIPORT_INTERRUPT
;
4125 typedef struct _NDIS_MINIPORT_TIMER
{
4128 PNDIS_TIMER_FUNCTION MiniportTimerFunction
;
4129 PVOID MiniportTimerContext
;
4130 PNDIS_MINIPORT_BLOCK Miniport
;
4131 struct _NDIS_MINIPORT_TIMER
*NextDeferredTimer
;
4132 } NDIS_MINIPORT_TIMER
, *PNDIS_MINIPORT_TIMER
;
4134 typedef struct _NDIS_INTERRUPT
{
4135 PKINTERRUPT InterruptObject
;
4136 KSPIN_LOCK DpcCountLock
;
4137 PNDIS_INTERRUPT_SERVICE MacIsr
;
4138 PNDIS_DEFERRED_PROCESSING MacDpc
;
4140 PVOID InterruptContext
;
4143 KEVENT DpcsCompletedEvent
;
4144 } NDIS_INTERRUPT
, *PNDIS_INTERRUPT
;
4147 typedef struct _MAP_REGISTER_ENTRY
{
4149 BOOLEAN WriteToDevice
;
4150 } MAP_REGISTER_ENTRY
, *PMAP_REGISTER_ENTRY
;
4153 typedef enum _NDIS_WORK_ITEM_TYPE
{
4154 NdisWorkItemRequest
,
4156 NdisWorkItemReturnPackets
,
4157 NdisWorkItemResetRequested
,
4158 NdisWorkItemResetInProgress
,
4160 NdisWorkItemSendLoopback
,
4161 NdisWorkItemMiniportCallback
,
4163 } NDIS_WORK_ITEM_TYPE
, *PNDIS_WORK_ITEM_TYPE
;
4165 #define NUMBER_OF_WORK_ITEM_TYPES NdisMaxWorkItems
4166 #define NUMBER_OF_SINGLE_WORK_ITEMS 6
4168 typedef struct _NDIS_MINIPORT_WORK_ITEM
{
4169 SINGLE_LIST_ENTRY Link
;
4170 NDIS_WORK_ITEM_TYPE WorkItemType
;
4171 PVOID WorkItemContext
;
4172 } NDIS_MINIPORT_WORK_ITEM
, *PNDIS_MINIPORT_WORK_ITEM
;
4175 typedef struct _NDIS_BIND_PATHS
{
4177 NDIS_STRING Paths
[1];
4178 } NDIS_BIND_PATHS
, *PNDIS_BIND_PATHS
;
4180 #define DECLARE_UNKNOWN_STRUCT(BaseName) \
4181 typedef struct _##BaseName BaseName, *P##BaseName;
4183 #define DECLARE_UNKNOWN_PROTOTYPE(Name) \
4184 typedef VOID (*(Name))(VOID);
4186 #define ETH_LENGTH_OF_ADDRESS 6
4188 DECLARE_UNKNOWN_STRUCT(ETH_BINDING_INFO
)
4190 DECLARE_UNKNOWN_PROTOTYPE(ETH_ADDRESS_CHANGE
)
4191 DECLARE_UNKNOWN_PROTOTYPE(ETH_FILTER_CHANGE
)
4192 DECLARE_UNKNOWN_PROTOTYPE(ETH_DEFERRED_CLOSE
)
4194 typedef struct _ETH_FILTER
{
4195 PNDIS_SPIN_LOCK Lock
;
4196 CHAR (*MCastAddressBuf
)[ETH_LENGTH_OF_ADDRESS
];
4197 struct _NDIS_MINIPORT_BLOCK
*Miniport
;
4198 UINT CombinedPacketFilter
;
4199 PETH_BINDING_INFO OpenList
;
4200 ETH_ADDRESS_CHANGE AddressChangeAction
;
4201 ETH_FILTER_CHANGE FilterChangeAction
;
4202 ETH_DEFERRED_CLOSE CloseAction
;
4203 UINT MaxMulticastAddresses
;
4205 UCHAR AdapterAddress
[ETH_LENGTH_OF_ADDRESS
];
4206 UINT OldCombinedPacketFilter
;
4207 CHAR (*OldMCastAddressBuf
)[ETH_LENGTH_OF_ADDRESS
];
4208 UINT OldNumAddresses
;
4209 PETH_BINDING_INFO DirectedList
;
4210 PETH_BINDING_INFO BMList
;
4211 PETH_BINDING_INFO MCastSet
;
4212 #if defined(NDIS_WRAPPER)
4216 } ETH_FILTER
, *PETH_FILTER
;
4219 (*ETH_RCV_COMPLETE_HANDLER
)(
4220 IN PETH_FILTER Filter
);
4223 (*ETH_RCV_INDICATE_HANDLER
)(
4224 IN PETH_FILTER Filter
,
4225 IN NDIS_HANDLE MacReceiveContext
,
4227 IN PVOID HeaderBuffer
,
4228 IN UINT HeaderBufferSize
,
4229 IN PVOID LookaheadBuffer
,
4230 IN UINT LookaheadBufferSize
,
4231 IN UINT PacketSize
);
4234 (*FDDI_RCV_COMPLETE_HANDLER
)(
4235 IN PFDDI_FILTER Filter
);
4238 (*FDDI_RCV_INDICATE_HANDLER
)(
4239 IN PFDDI_FILTER Filter
,
4240 IN NDIS_HANDLE MacReceiveContext
,
4242 IN UINT AddressLength
,
4243 IN PVOID HeaderBuffer
,
4244 IN UINT HeaderBufferSize
,
4245 IN PVOID LookaheadBuffer
,
4246 IN UINT LookaheadBufferSize
,
4247 IN UINT PacketSize
);
4250 (*FILTER_PACKET_INDICATION_HANDLER
)(
4251 IN NDIS_HANDLE Miniport
,
4252 IN PPNDIS_PACKET PacketArray
,
4253 IN UINT NumberOfPackets
);
4256 (*TR_RCV_COMPLETE_HANDLER
)(
4257 IN PTR_FILTER Filter
);
4260 (*TR_RCV_INDICATE_HANDLER
)(
4261 IN PTR_FILTER Filter
,
4262 IN NDIS_HANDLE MacReceiveContext
,
4263 IN PVOID HeaderBuffer
,
4264 IN UINT HeaderBufferSize
,
4265 IN PVOID LookaheadBuffer
,
4266 IN UINT LookaheadBufferSize
,
4267 IN UINT PacketSize
);
4270 (*WAN_RCV_COMPLETE_HANDLER
)(
4271 IN NDIS_HANDLE MiniportAdapterHandle
,
4272 IN NDIS_HANDLE NdisLinkContext
);
4276 OUT PNDIS_STATUS Status
,
4277 IN NDIS_HANDLE MiniportAdapterHandle
,
4278 IN NDIS_HANDLE NdisLinkContext
,
4280 IN ULONG PacketSize
);
4282 typedef VOID DDKFASTAPI
4283 (*NDIS_M_DEQUEUE_WORK_ITEM
)(
4284 IN PNDIS_MINIPORT_BLOCK Miniport
,
4285 IN NDIS_WORK_ITEM_TYPE WorkItemType
,
4286 OUT PVOID
*WorkItemContext
);
4288 typedef NDIS_STATUS DDKFASTAPI
4289 (*NDIS_M_QUEUE_NEW_WORK_ITEM
)(
4290 IN PNDIS_MINIPORT_BLOCK Miniport
,
4291 IN NDIS_WORK_ITEM_TYPE WorkItemType
,
4292 IN PVOID WorkItemContext
);
4294 typedef NDIS_STATUS DDKFASTAPI
4295 (*NDIS_M_QUEUE_WORK_ITEM
)(
4296 IN PNDIS_MINIPORT_BLOCK Miniport
,
4297 IN NDIS_WORK_ITEM_TYPE WorkItemType
,
4298 IN PVOID WorkItemContext
);
4301 (*NDIS_M_REQ_COMPLETE_HANDLER
)(
4302 IN NDIS_HANDLE MiniportAdapterHandle
,
4303 IN NDIS_STATUS Status
);
4306 (*NDIS_M_RESET_COMPLETE_HANDLER
)(
4307 IN NDIS_HANDLE MiniportAdapterHandle
,
4308 IN NDIS_STATUS Status
,
4309 IN BOOLEAN AddressingReset
);
4312 (*NDIS_M_SEND_COMPLETE_HANDLER
)(
4313 IN NDIS_HANDLE MiniportAdapterHandle
,
4314 IN PNDIS_PACKET Packet
,
4315 IN NDIS_STATUS Status
);
4318 (*NDIS_M_SEND_RESOURCES_HANDLER
)(
4319 IN NDIS_HANDLE MiniportAdapterHandle
);
4321 typedef BOOLEAN DDKFASTAPI
4322 (*NDIS_M_START_SENDS
)(
4323 IN PNDIS_MINIPORT_BLOCK Miniport
);
4326 (*NDIS_M_STATUS_HANDLER
)(
4327 IN NDIS_HANDLE MiniportHandle
,
4328 IN NDIS_STATUS GeneralStatus
,
4329 IN PVOID StatusBuffer
,
4330 IN UINT StatusBufferSize
);
4333 (*NDIS_M_STS_COMPLETE_HANDLER
)(
4334 IN NDIS_HANDLE MiniportAdapterHandle
);
4337 (*NDIS_M_TD_COMPLETE_HANDLER
)(
4338 IN NDIS_HANDLE MiniportAdapterHandle
,
4339 IN PNDIS_PACKET Packet
,
4340 IN NDIS_STATUS Status
,
4341 IN UINT BytesTransferred
);
4343 typedef VOID (DDKAPI
*NDIS_WM_SEND_COMPLETE_HANDLER
)(
4344 IN NDIS_HANDLE MiniportAdapterHandle
,
4346 IN NDIS_STATUS Status
);
4351 #define ARC_SEND_BUFFERS 8
4352 #define ARC_HEADER_SIZE 4
4354 typedef struct _NDIS_ARC_BUF
{
4355 NDIS_HANDLE ArcnetBufferPool
;
4356 PUCHAR ArcnetLookaheadBuffer
;
4358 ARC_BUFFER_LIST ArcnetBuffers
[ARC_SEND_BUFFERS
];
4359 } NDIS_ARC_BUF
, *PNDIS_ARC_BUF
;
4363 #define NDIS_MINIPORT_WORK_QUEUE_SIZE 10
4365 typedef struct _NDIS_LOG
{
4366 PNDIS_MINIPORT_BLOCK Miniport
;
4374 } NDIS_LOG
, *PNDIS_LOG
;
4376 typedef struct _FILTERDBS
{
4377 _ANONYMOUS_UNION
union {
4379 PNULL_FILTER NullDB
;
4382 PFDDI_FILTER FddiDB
;
4387 #endif /* !ARCNET */
4388 } FILTERDBS
, *PFILTERDBS
;
4391 struct _NDIS_MINIPORT_BLOCK
{
4393 PNDIS_MINIPORT_BLOCK NextMiniport
;
4394 PNDIS_M_DRIVER_BLOCK DriverHandle
;
4395 NDIS_HANDLE MiniportAdapterContext
;
4396 UNICODE_STRING MiniportName
;
4397 PNDIS_BIND_PATHS BindPaths
;
4398 NDIS_HANDLE OpenQueue
;
4400 NDIS_HANDLE DeviceContext
;
4404 UCHAR AssignedProcessor
;
4406 PNDIS_REQUEST MediaRequest
;
4407 PNDIS_MINIPORT_INTERRUPT Interrupt
;
4410 LIST_ENTRY PacketList
;
4411 PNDIS_PACKET FirstPendingPacket
;
4412 PNDIS_PACKET ReturnPacketsQueue
;
4413 ULONG RequestBuffer
;
4414 PVOID SetMCastBuffer
;
4415 PNDIS_MINIPORT_BLOCK PrimaryMiniport
;
4416 PVOID WrapperContext
;
4417 PVOID BusDataContext
;
4418 ULONG PnPCapabilities
;
4419 PCM_RESOURCE_LIST Resources
;
4420 NDIS_TIMER WakeUpDpcTimer
;
4421 UNICODE_STRING BaseName
;
4422 UNICODE_STRING SymbolicLinkName
;
4423 ULONG CheckForHangSeconds
;
4425 USHORT CFHangCurrentTick
;
4426 NDIS_STATUS ResetStatus
;
4427 NDIS_HANDLE ResetOpen
;
4428 FILTERDBS FilterDbs
;
4429 FILTER_PACKET_INDICATION_HANDLER PacketIndicateHandler
;
4430 NDIS_M_SEND_COMPLETE_HANDLER SendCompleteHandler
;
4431 NDIS_M_SEND_RESOURCES_HANDLER SendResourcesHandler
;
4432 NDIS_M_RESET_COMPLETE_HANDLER ResetCompleteHandler
;
4433 NDIS_MEDIUM MediaType
;
4435 NDIS_INTERFACE_TYPE BusType
;
4436 NDIS_INTERFACE_TYPE AdapterType
;
4437 PDEVICE_OBJECT DeviceObject
;
4438 PDEVICE_OBJECT PhysicalDeviceObject
;
4439 PDEVICE_OBJECT NextDeviceObject
;
4440 PMAP_REGISTER_ENTRY MapRegisters
;
4441 PNDIS_AF_LIST CallMgrAfList
;
4442 PVOID MiniportThread
;
4444 USHORT SetInfoBufLen
;
4445 USHORT MaxSendPackets
;
4446 NDIS_STATUS FakeStatus
;
4448 PUNICODE_STRING pAdapterInstanceName
;
4449 PNDIS_MINIPORT_TIMER TimerQueue
;
4451 PNDIS_REQUEST PendingRequest
;
4452 UINT MaximumLongAddresses
;
4453 UINT MaximumShortAddresses
;
4454 UINT CurrentLookahead
;
4455 UINT MaximumLookahead
;
4456 W_HANDLE_INTERRUPT_HANDLER HandleInterruptHandler
;
4457 W_DISABLE_INTERRUPT_HANDLER DisableInterruptHandler
;
4458 W_ENABLE_INTERRUPT_HANDLER EnableInterruptHandler
;
4459 W_SEND_PACKETS_HANDLER SendPacketsHandler
;
4460 NDIS_M_START_SENDS DeferredSendHandler
;
4461 ETH_RCV_INDICATE_HANDLER EthRxIndicateHandler
;
4462 TR_RCV_INDICATE_HANDLER TrRxIndicateHandler
;
4463 FDDI_RCV_INDICATE_HANDLER FddiRxIndicateHandler
;
4464 ETH_RCV_COMPLETE_HANDLER EthRxCompleteHandler
;
4465 TR_RCV_COMPLETE_HANDLER TrRxCompleteHandler
;
4466 FDDI_RCV_COMPLETE_HANDLER FddiRxCompleteHandler
;
4467 NDIS_M_STATUS_HANDLER StatusHandler
;
4468 NDIS_M_STS_COMPLETE_HANDLER StatusCompleteHandler
;
4469 NDIS_M_TD_COMPLETE_HANDLER TDCompleteHandler
;
4470 NDIS_M_REQ_COMPLETE_HANDLER QueryCompleteHandler
;
4471 NDIS_M_REQ_COMPLETE_HANDLER SetCompleteHandler
;
4472 NDIS_WM_SEND_COMPLETE_HANDLER WanSendCompleteHandler
;
4473 WAN_RCV_HANDLER WanRcvHandler
;
4474 WAN_RCV_COMPLETE_HANDLER WanRcvCompleteHandler
;
4475 #if defined(NDIS_WRAPPER)
4476 PNDIS_MINIPORT_BLOCK NextGlobalMiniport
;
4477 SINGLE_LIST_ENTRY WorkQueue
[NUMBER_OF_WORK_ITEM_TYPES
];
4478 SINGLE_LIST_ENTRY SingleWorkItems
[NUMBER_OF_SINGLE_WORK_ITEMS
];
4481 UCHAR ArcnetAddress
;
4483 _ANONYMOUS_UNION
union {
4485 PNDIS_ARC_BUF ArcBuf
;
4491 PCM_RESOURCE_LIST AllocatedResources
;
4492 PCM_RESOURCE_LIST AllocatedResourcesTranslated
;
4493 SINGLE_LIST_ENTRY PatternList
;
4494 NDIS_PNP_CAPABILITIES PMCapabilities
;
4495 DEVICE_CAPABILITIES DeviceCaps
;
4497 DEVICE_POWER_STATE CurrentDevicePowerState
;
4499 SYSTEM_POWER_STATE WaitWakeSystemState
;
4500 LARGE_INTEGER VcIndex
;
4501 KSPIN_LOCK VcCountLock
;
4502 LIST_ENTRY WmiEnabledVcs
;
4503 PNDIS_GUID pNdisGuidMap
;
4504 PNDIS_GUID pCustomGuidMap
;
4506 USHORT cNdisGuidMap
;
4507 USHORT cCustomGuidMap
;
4508 USHORT CurrentMapRegister
;
4509 PKEVENT AllocationEvent
;
4510 USHORT BaseMapRegistersNeeded
;
4511 USHORT SGMapRegistersNeeded
;
4512 ULONG MaximumPhysicalMapping
;
4513 NDIS_TIMER MediaDisconnectTimer
;
4514 USHORT MediaDisconnectTimeOut
;
4515 USHORT InstanceNumber
;
4516 NDIS_EVENT OpenReadyEvent
;
4517 NDIS_PNP_DEVICE_STATE PnPDeviceState
;
4518 NDIS_PNP_DEVICE_STATE OldPnPDeviceState
;
4519 PGET_SET_DEVICE_DATA SetBusData
;
4520 PGET_SET_DEVICE_DATA GetBusData
;
4524 NDIS_STATS NdisStats
;
4528 PNDIS_PACKET IndicatedPacket
[MAXIMUM_PROCESSORS
];
4529 PKEVENT RemoveReadyEvent
;
4530 PKEVENT AllOpensClosedEvent
;
4531 PKEVENT AllRequestsCompletedEvent
;
4533 NDIS_MINIPORT_WORK_ITEM WorkItemBuffer
[NUMBER_OF_SINGLE_WORK_ITEMS
];
4534 PDMA_ADAPTER SystemAdapterObject
;
4535 ULONG DriverVerifyFlags
;
4537 USHORT InternalResetCount
;
4538 USHORT MiniportResetCount
;
4539 USHORT MediaSenseConnectCount
;
4540 USHORT MediaSenseDisconnectCount
;
4541 PNDIS_PACKET
*xPackets
;
4542 ULONG UserModeOpenReferences
;
4543 _ANONYMOUS_UNION
union {
4544 PVOID SavedSendHandler
;
4545 PVOID SavedWanSendHandler
;
4547 PVOID SavedSendPacketsHandler
;
4548 PVOID SavedCancelSendPacketsHandler
;
4549 W_SEND_PACKETS_HANDLER WSendPacketsHandler
;
4550 ULONG MiniportAttributes
;
4551 PDMA_ADAPTER SavedSystemAdapterObject
;
4553 USHORT CFHangXTicks
;
4555 ULONG IndicatedPacketsCount
;
4556 ULONG PhysicalMediumType
;
4557 PNDIS_REQUEST LastRequest
;
4558 LONG DmaAdapterRefCount
;
4564 KSPIN_LOCK TimerQueueLock
;
4565 PKEVENT ResetCompletedEvent
;
4566 PKEVENT QueuedBindingCompletedEvent
;
4567 PKEVENT DmaResourcesReleasedEvent
;
4568 FILTER_PACKET_INDICATION_HANDLER SavedPacketIndicateHandler
;
4569 ULONG RegisteredInterrupts
;
4570 PNPAGED_LOOKASIDE_LIST SGListLookasideList
;
4571 ULONG ScatterGatherListSize
;
4576 /* Handler prototypes for NDIS_OPEN_BLOCK */
4578 typedef NDIS_STATUS (DDKAPI
*WAN_SEND_HANDLER
)(
4579 IN NDIS_HANDLE MacBindingHandle
,
4580 IN NDIS_HANDLE LinkHandle
,
4583 /* NDIS 4.0 extension */
4585 typedef VOID (DDKAPI
*SEND_PACKETS_HANDLER
)(
4586 IN NDIS_HANDLE MiniportAdapterContext
,
4587 IN PPNDIS_PACKET PacketArray
,
4588 IN UINT NumberOfPackets
);
4591 typedef struct _NDIS_COMMON_OPEN_BLOCK
{
4593 NDIS_HANDLE BindingHandle
;
4594 PNDIS_MINIPORT_BLOCK MiniportHandle
;
4595 PNDIS_PROTOCOL_BLOCK ProtocolHandle
;
4596 NDIS_HANDLE ProtocolBindingContext
;
4597 PNDIS_OPEN_BLOCK MiniportNextOpen
;
4598 PNDIS_OPEN_BLOCK ProtocolNextOpen
;
4599 NDIS_HANDLE MiniportAdapterContext
;
4604 PNDIS_STRING BindDeviceName
;
4605 KSPIN_LOCK Reserved5
;
4606 PNDIS_STRING RootDeviceName
;
4607 _ANONYMOUS_UNION
union {
4608 SEND_HANDLER SendHandler
;
4609 WAN_SEND_HANDLER WanSendHandler
;
4611 TRANSFER_DATA_HANDLER TransferDataHandler
;
4612 SEND_COMPLETE_HANDLER SendCompleteHandler
;
4613 TRANSFER_DATA_COMPLETE_HANDLER TransferDataCompleteHandler
;
4614 RECEIVE_HANDLER ReceiveHandler
;
4615 RECEIVE_COMPLETE_HANDLER ReceiveCompleteHandler
;
4616 WAN_RECEIVE_HANDLER WanReceiveHandler
;
4617 REQUEST_COMPLETE_HANDLER RequestCompleteHandler
;
4618 RECEIVE_PACKET_HANDLER ReceivePacketHandler
;
4619 SEND_PACKETS_HANDLER SendPacketsHandler
;
4620 RESET_HANDLER ResetHandler
;
4621 REQUEST_HANDLER RequestHandler
;
4622 RESET_COMPLETE_HANDLER ResetCompleteHandler
;
4623 STATUS_HANDLER StatusHandler
;
4624 STATUS_COMPLETE_HANDLER StatusCompleteHandler
;
4625 #if defined(NDIS_WRAPPER)
4628 KSPIN_LOCK SpinLock
;
4629 NDIS_HANDLE FilterHandle
;
4630 ULONG ProtocolOptions
;
4631 USHORT CurrentLookahead
;
4632 USHORT ConnectDampTicks
;
4633 USHORT DisconnectDampTicks
;
4634 W_SEND_HANDLER WSendHandler
;
4635 W_TRANSFER_DATA_HANDLER WTransferDataHandler
;
4636 W_SEND_PACKETS_HANDLER WSendPacketsHandler
;
4637 W_CANCEL_SEND_PACKETS_HANDLER CancelSendPacketsHandler
;
4639 PKEVENT CloseCompleteEvent
;
4642 PNDIS_OPEN_BLOCK NextGlobalOpen
;
4644 } NDIS_COMMON_OPEN_BLOCK
;
4646 struct _NDIS_OPEN_BLOCK
4648 NDIS_COMMON_OPEN_BLOCK NdisCommonOpenBlock
;
4649 #if defined(NDIS_WRAPPER)
4650 struct _NDIS_OPEN_CO
4652 struct _NDIS_CO_AF_BLOCK
* NextAf
;
4653 W_CO_CREATE_VC_HANDLER MiniportCoCreateVcHandler
;
4654 W_CO_REQUEST_HANDLER MiniportCoRequestHandler
;
4655 CO_CREATE_VC_HANDLER CoCreateVcHandler
;
4656 CO_DELETE_VC_HANDLER CoDeleteVcHandler
;
4657 PVOID CmActivateVcCompleteHandler
;
4658 PVOID CmDeactivateVcCompleteHandler
;
4659 PVOID CoRequestCompleteHandler
;
4660 LIST_ENTRY ActiveVcHead
;
4661 LIST_ENTRY InactiveVcHead
;
4662 LONG PendingAfNotifications
;
4663 PKEVENT AfNotifyCompleteEvent
;
4670 /* Routines for NDIS miniport drivers */
4675 NdisInitializeWrapper(
4676 OUT PNDIS_HANDLE NdisWrapperHandle
,
4677 IN PVOID SystemSpecific1
,
4678 IN PVOID SystemSpecific2
,
4679 IN PVOID SystemSpecific3
);
4684 NdisMAllocateMapRegisters(
4685 IN NDIS_HANDLE MiniportAdapterHandle
,
4687 IN NDIS_DMA_SIZE DmaSize
,
4688 IN ULONG PhysicalMapRegistersNeeded
,
4689 IN ULONG MaximumPhysicalMapping
);
4693 * NdisMArcIndicateReceive(
4694 * IN NDIS_HANDLE MiniportAdapterHandle,
4695 * IN PUCHAR HeaderBuffer,
4696 * IN PUCHAR DataBuffer,
4699 #define NdisMArcIndicateReceive(MiniportAdapterHandle, \
4704 ArcFilterDprIndicateReceive( \
4705 (((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->FilterDbs.ArcDB), \
4713 * NdisMArcIndicateReceiveComplete(
4714 * IN NDIS_HANDLE MiniportAdapterHandle);
4716 #define NdisMArcIndicateReceiveComplete(MiniportAdapterHandle) \
4718 if (((PNDIS_MINIPORT_BLOCK)MiniportAdapterHandle)->EthDB) \
4720 NdisMEthIndicateReceiveComplete(_H); \
4723 ArcFilterDprIndicateReceiveComplete( \
4724 ((PNDIS_MINIPORT_BLOCK)MiniportAdapterHandle)->ArcDB); \
4731 IN NDIS_HANDLE LogHandle
);
4737 IN NDIS_HANDLE MiniportAdapterHandle
,
4739 OUT PNDIS_HANDLE LogHandle
);
4744 NdisMDeregisterAdapterShutdownHandler(
4745 IN NDIS_HANDLE MiniportHandle
);
4750 NdisMDeregisterInterrupt(
4751 IN PNDIS_MINIPORT_INTERRUPT Interrupt
);
4756 NdisMDeregisterIoPortRange(
4757 IN NDIS_HANDLE MiniportAdapterHandle
,
4758 IN UINT InitialPort
,
4759 IN UINT NumberOfPorts
,
4760 IN PVOID PortOffset
);
4764 * NdisMEthIndicateReceive(
4765 * IN NDIS_HANDLE MiniportAdapterHandle,
4766 * IN NDIS_HANDLE MiniportReceiveContext,
4767 * IN PVOID HeaderBuffer,
4768 * IN UINT HeaderBufferSize,
4769 * IN PVOID LookaheadBuffer,
4770 * IN UINT LookaheadBufferSize,
4771 * IN UINT PacketSize);
4773 #define NdisMEthIndicateReceive(MiniportAdapterHandle, \
4774 MiniportReceiveContext, \
4778 LookaheadBufferSize, \
4781 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->EthRxIndicateHandler)( \
4782 ((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->FilterDbs.EthDB, \
4783 (MiniportReceiveContext), \
4786 (HeaderBufferSize), \
4787 (LookaheadBuffer), \
4788 (LookaheadBufferSize), \
4794 * NdisMEthIndicateReceiveComplete(
4795 * IN NDIS_HANDLE MiniportAdapterHandle);
4797 #define NdisMEthIndicateReceiveComplete(MiniportAdapterHandle) \
4799 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->EthRxCompleteHandler)( \
4800 ((PNDIS_MINIPORT_BLOCK)MiniportAdapterHandle)->FilterDbs.EthDB); \
4805 * NdisMFddiIndicateReceive(
4806 * IN NDIS_HANDLE MiniportAdapterHandle,
4807 * IN NDIS_HANDLE MiniportReceiveContext,
4808 * IN PVOID HeaderBuffer,
4809 * IN UINT HeaderBufferSize,
4810 * IN PVOID LookaheadBuffer,
4811 * IN UINT LookaheadBufferSize,
4812 * IN UINT PacketSize);
4814 #define NdisMFddiIndicateReceive(MiniportAdapterHandle, \
4815 MiniportReceiveContext, \
4819 LookaheadBufferSize, \
4822 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->FddiRxIndicateHandler)( \
4823 (((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->FilterDbs.FddiDB), \
4824 (MiniportReceiveContext), \
4825 (PUCHAR)(HeaderBuffer) + 1, \
4826 (((*(PUCHAR*)(HeaderBuffer)) & 0x40) ? \
4827 FDDI_LENGTH_OF_LONG_ADDRESS : \
4828 FDDI_LENGTH_OF_SHORT_ADDRESS), \
4830 (HeaderBufferSize), \
4831 (LookaheadBuffer), \
4832 (LookaheadBufferSize), \
4840 * NdisMFddiIndicateReceiveComplete(
4841 * IN NDIS_HANDLE MiniportAdapterHandle);
4843 #define NdisMFddiIndicateReceiveComplete(MiniportAdapterHandle) \
4845 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->FddiRxCompleteHandler)( \
4846 ((PNDIS_MINIPORT_BLOCK)MiniportAdapterHandle)->FilterDbs.FddiDB); \
4853 IN NDIS_HANDLE LogHandle
);
4858 NdisMFreeMapRegisters(
4859 IN NDIS_HANDLE MiniportAdapterHandle
);
4863 * NdisMIndicateStatus(
4864 * IN NDIS_HANDLE MiniportAdapterHandle,
4865 * IN NDIS_STATUS GeneralStatus,
4866 * IN PVOID StatusBuffer,
4867 * IN UINT StatusBufferSize);
4870 #define NdisMIndicateStatus(MiniportAdapterHandle, \
4871 GeneralStatus, StatusBuffer, StatusBufferSize) \
4872 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->StatusHandler)( \
4873 MiniportAdapterHandle, GeneralStatus, StatusBuffer, StatusBufferSize)
4877 * NdisMIndicateStatusComplete(
4878 * IN NDIS_HANDLE MiniportAdapterHandle);
4880 #define NdisMIndicateStatusComplete(MiniportAdapterHandle) \
4881 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->StatusCompleteHandler)( \
4882 MiniportAdapterHandle)
4886 * NdisMInitializeWrapper(
4887 * OUT PNDIS_HANDLE NdisWrapperHandle,
4888 * IN PVOID SystemSpecific1,
4889 * IN PVOID SystemSpecific2,
4890 * IN PVOID SystemSpecific3);
4892 #define NdisMInitializeWrapper(NdisWrapperHandle, \
4896 NdisInitializeWrapper((NdisWrapperHandle), \
4897 (SystemSpecific1), \
4898 (SystemSpecific2), \
4905 OUT PVOID
*VirtualAddress
,
4906 IN NDIS_HANDLE MiniportAdapterHandle
,
4907 IN NDIS_PHYSICAL_ADDRESS PhysicalAddress
,
4912 * NdisMQueryInformationComplete(
4913 * IN NDIS_HANDLE MiniportAdapterHandle,
4914 * IN NDIS_STATUS Status);
4916 #define NdisMQueryInformationComplete(MiniportAdapterHandle, Status) \
4917 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->QueryCompleteHandler)(MiniportAdapterHandle, Status)
4922 NdisMRegisterAdapterShutdownHandler(
4923 IN NDIS_HANDLE MiniportHandle
,
4924 IN PVOID ShutdownContext
,
4925 IN ADAPTER_SHUTDOWN_HANDLER ShutdownHandler
);
4930 NdisMRegisterInterrupt(
4931 OUT PNDIS_MINIPORT_INTERRUPT Interrupt
,
4932 IN NDIS_HANDLE MiniportAdapterHandle
,
4933 IN UINT InterruptVector
,
4934 IN UINT InterruptLevel
,
4935 IN BOOLEAN RequestIsr
,
4936 IN BOOLEAN SharedInterrupt
,
4937 IN NDIS_INTERRUPT_MODE InterruptMode
);
4942 NdisMRegisterIoPortRange(
4943 OUT PVOID
*PortOffset
,
4944 IN NDIS_HANDLE MiniportAdapterHandle
,
4945 IN UINT InitialPort
,
4946 IN UINT NumberOfPorts
);
4951 NdisMRegisterMiniport(
4952 IN NDIS_HANDLE NdisWrapperHandle
,
4953 IN PNDIS_MINIPORT_CHARACTERISTICS MiniportCharacteristics
,
4954 IN UINT CharacteristicsLength
);
4960 IN PNDIS_MINIPORT_TIMER Timer
,
4961 IN UINT MillisecondsToDelay
);
4966 NdisMInitializeTimer(
4967 IN OUT PNDIS_MINIPORT_TIMER Timer
,
4968 IN NDIS_HANDLE MiniportAdapterHandle
,
4969 IN PNDIS_TIMER_FUNCTION TimerFunction
,
4970 IN PVOID FunctionContext
);
4975 NdisMSetPeriodicTimer(
4976 IN PNDIS_MINIPORT_TIMER Timer
,
4977 IN UINT MillisecondPeriod
);
4983 IN PNDIS_MINIPORT_TIMER Timer
,
4984 OUT PBOOLEAN TimerCancelled
);
4986 #if !defined(NDIS_WRAPPER)
4990 * NdisMResetComplete(
4991 * IN NDIS_HANDLE MiniportAdapterHandle,
4992 * IN NDIS_STATUS Status,
4993 * IN BOOLEAN AddressingReset);
4995 #define NdisMResetComplete(MiniportAdapterHandle, \
4999 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->ResetCompleteHandler)( \
5000 MiniportAdapterHandle, Status, AddressingReset); \
5005 * NdisMSendComplete(
5006 * IN NDIS_HANDLE MiniportAdapterHandle,
5007 * IN PNDIS_PACKET Packet,
5008 * IN NDIS_STATUS Status);
5010 #define NdisMSendComplete(MiniportAdapterHandle, \
5014 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->SendCompleteHandler)( \
5015 MiniportAdapterHandle, Packet, Status); \
5020 * NdisMSendResourcesAvailable(
5021 * IN NDIS_HANDLE MiniportAdapterHandle);
5023 #define NdisMSendResourcesAvailable(MiniportAdapterHandle) \
5025 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->SendResourcesHandler)( \
5026 MiniportAdapterHandle); \
5031 * NdisMTransferDataComplete(
5032 * IN NDIS_HANDLE MiniportAdapterHandle,
5033 * IN PNDIS_PACKET Packet,
5034 * IN NDIS_STATUS Status,
5035 * IN UINT BytesTransferred);
5037 #define NdisMTransferDataComplete(MiniportAdapterHandle, \
5042 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->TDCompleteHandler)( \
5043 MiniportAdapterHandle, Packet, Status, BytesTransferred) \
5046 #endif /* !_NDIS_ */
5051 * NdisMSetAttributes(
5052 * IN NDIS_HANDLE MiniportAdapterHandle,
5053 * IN NDIS_HANDLE MiniportAdapterContext,
5054 * IN BOOLEAN BusMaster,
5055 * IN NDIS_INTERFACE_TYPE AdapterType);
5057 #define NdisMSetAttributes(MiniportAdapterHandle, \
5058 MiniportAdapterContext, \
5061 NdisMSetAttributesEx(MiniportAdapterHandle, \
5062 MiniportAdapterContext, \
5064 (BusMaster) ? NDIS_ATTRIBUTE_BUS_MASTER : 0, \
5070 NdisMSetAttributesEx(
5071 IN NDIS_HANDLE MiniportAdapterHandle
,
5072 IN NDIS_HANDLE MiniportAdapterContext
,
5073 IN UINT CheckForHangTimeInSeconds OPTIONAL
,
5074 IN ULONG AttributeFlags
,
5075 IN NDIS_INTERFACE_TYPE AdapterType
);
5079 * NdisMSetInformationComplete(
5080 * IN NDIS_HANDLE MiniportAdapterHandle,
5081 * IN NDIS_STATUS Status);
5083 #define NdisMSetInformationComplete(MiniportAdapterHandle, \
5085 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->SetCompleteHandler)( \
5086 MiniportAdapterHandle, Status)
5092 IN ULONG MicrosecondsToSleep
);
5097 NdisMSynchronizeWithInterrupt(
5098 IN PNDIS_MINIPORT_INTERRUPT Interrupt
,
5099 IN PVOID SynchronizeFunction
,
5100 IN PVOID SynchronizeContext
);
5104 * NdisMTrIndicateReceive(
5105 * IN NDIS_HANDLE MiniportAdapterHandle,
5106 * IN NDIS_HANDLE MiniportReceiveContext,
5107 * IN PVOID HeaderBuffer,
5108 * IN UINT HeaderBufferSize,
5109 * IN PVOID LookaheadBuffer,
5110 * IN UINT LookaheadBufferSize,
5111 * IN UINT PacketSize);
5113 #define NdisMTrIndicateReceive(MiniportAdapterHandle, \
5114 MiniportReceiveContext, \
5118 LookaheadBufferSize, \
5121 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->TrRxIndicateHandler)( \
5122 (((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->FilterDbs.TrDB), \
5123 (MiniportReceiveContext), \
5126 (HeaderBufferSize), \
5127 (LookaheadBuffer), \
5128 (LookaheadBufferSize), \
5134 * NdisMTrIndicateReceiveComplete(
5135 * IN NDIS_HANDLE MiniportAdapterHandle);
5137 #define NdisMTrIndicateReceiveComplete(MiniportAdapterHandle) \
5139 (*((PNDIS_MINIPORT_BLOCK)(MiniportAdapterHandle))->TrRxCompleteHandler)( \
5140 ((PNDIS_MINIPORT_BLOCK)MiniportAdapterHandle)->FilterDbs.TrDB); \
5147 IN NDIS_HANDLE LogHandle
,
5149 IN UINT LogBufferSize
);
5154 NdisMQueryAdapterResources(
5155 OUT PNDIS_STATUS Status
,
5156 IN NDIS_HANDLE WrapperConfigurationContext
,
5157 OUT PNDIS_RESOURCE_LIST ResourceList
,
5158 IN OUT PUINT BufferSize
);
5163 NdisTerminateWrapper(
5164 IN NDIS_HANDLE NdisWrapperHandle
,
5165 IN PVOID SystemSpecific
);
5171 IN NDIS_HANDLE MiniportAdapterHandle
,
5172 IN PVOID VirtualAddress
,
5177 /* Event functions */
5182 NdisInitializeEvent(
5183 IN PNDIS_EVENT Event
);
5189 IN PNDIS_EVENT Event
);
5195 IN PNDIS_EVENT Event
);
5201 IN PNDIS_EVENT Event
,
5206 /* NDIS intermediate miniport structures */
5208 typedef VOID (DDKAPI
*W_MINIPORT_CALLBACK
)(
5209 IN NDIS_HANDLE MiniportAdapterContext
,
5210 IN PVOID CallbackContext
);
5214 /* Routines for intermediate miniport drivers */
5219 NdisIMDeInitializeDeviceInstance(
5220 IN NDIS_HANDLE NdisMiniportHandle
);
5224 * NdisIMInitializeDeviceInstance(
5225 * IN NDIS_HANDLE DriverHandle,
5226 * IN PNDIS_STRING DeviceInstance);
5228 #define NdisIMInitializeDeviceInstance(DriverHandle, DeviceInstance) \
5229 NdisIMInitializeDeviceInstanceEx(DriverHandle, DeviceInstance, NULL)
5234 NdisIMRegisterLayeredMiniport(
5235 IN NDIS_HANDLE NdisWrapperHandle
,
5236 IN PNDIS_MINIPORT_CHARACTERISTICS MiniportCharacteristics
,
5237 IN UINT CharacteristicsLength
,
5238 OUT PNDIS_HANDLE DriverHandle
);
5241 /* Functions obsoleted by NDIS 5.0 */
5247 IN PNDIS_HANDLE NdisDmaHandle
);
5252 NdisSetupDmaTransfer(
5253 OUT PNDIS_STATUS Status
,
5254 IN PNDIS_HANDLE NdisDmaHandle
,
5255 IN PNDIS_BUFFER Buffer
,
5258 IN BOOLEAN WriteToDevice
);
5263 NdisUpcaseUnicodeString(
5264 OUT PUNICODE_STRING DestinationString
,
5265 IN PUNICODE_STRING SourceString
);
5268 /* Routines for NDIS protocol drivers */
5274 OUT PNDIS_STATUS Status
,
5275 IN NDIS_HANDLE NdisBindingHandle
,
5276 IN PNDIS_REQUEST NdisRequest
);
5282 OUT PNDIS_STATUS Status
,
5283 IN NDIS_HANDLE NdisBindingHandle
);
5289 OUT PNDIS_STATUS Status
,
5290 IN NDIS_HANDLE NdisBindingHandle
,
5291 IN PNDIS_PACKET Packet
);
5297 IN NDIS_HANDLE NdisBindingHandle
,
5298 IN PPNDIS_PACKET PacketArray
,
5299 IN UINT NumberOfPackets
);
5305 OUT PNDIS_STATUS Status
,
5306 IN NDIS_HANDLE NdisBindingHandle
,
5307 IN NDIS_HANDLE MacReceiveContext
,
5309 IN UINT BytesToTransfer
,
5310 IN OUT PNDIS_PACKET Packet
,
5311 OUT PUINT BytesTransferred
);
5317 OUT PNDIS_STATUS Status
,
5318 IN NDIS_HANDLE NdisBindingHandle
);
5323 NdisCompleteBindAdapter(
5324 IN NDIS_HANDLE BindAdapterContext
,
5325 IN NDIS_STATUS Status
,
5326 IN NDIS_STATUS OpenStatus
);
5331 NdisCompleteUnbindAdapter(
5332 IN NDIS_HANDLE UnbindAdapterContext
,
5333 IN NDIS_STATUS Status
);
5338 NdisDeregisterProtocol(
5339 OUT PNDIS_STATUS Status
,
5340 IN NDIS_HANDLE NdisProtocolHandle
);
5346 OUT PNDIS_STATUS Status
,
5347 OUT PNDIS_STATUS OpenErrorStatus
,
5348 OUT PNDIS_HANDLE NdisBindingHandle
,
5349 OUT PUINT SelectedMediumIndex
,
5350 IN PNDIS_MEDIUM MediumArray
,
5351 IN UINT MediumArraySize
,
5352 IN NDIS_HANDLE NdisProtocolHandle
,
5353 IN NDIS_HANDLE ProtocolBindingContext
,
5354 IN PNDIS_STRING AdapterName
,
5355 IN UINT OpenOptions
,
5356 IN PSTRING AddressingInformation
);
5361 NdisOpenProtocolConfiguration(
5362 OUT PNDIS_STATUS Status
,
5363 OUT PNDIS_HANDLE ConfigurationHandle
,
5364 IN PNDIS_STRING ProtocolSection
);
5369 NdisRegisterProtocol(
5370 OUT PNDIS_STATUS Status
,
5371 OUT PNDIS_HANDLE NdisProtocolHandle
,
5372 IN PNDIS_PROTOCOL_CHARACTERISTICS ProtocolCharacteristics
,
5373 IN UINT CharacteristicsLength
);
5375 /* Obsoleted in Windows XP */
5377 /* Prototypes for NDIS_MAC_CHARACTERISTICS */
5379 typedef NDIS_STATUS (*OPEN_ADAPTER_HANDLER
)(
5380 OUT PNDIS_STATUS OpenErrorStatus
,
5381 OUT NDIS_HANDLE
*MacBindingHandle
,
5382 OUT PUINT SelectedMediumIndex
,
5383 IN PNDIS_MEDIUM MediumArray
,
5384 IN UINT MediumArraySize
,
5385 IN NDIS_HANDLE NdisBindingContext
,
5386 IN NDIS_HANDLE MacAdapterContext
,
5387 IN UINT OpenOptions
,
5388 IN PSTRING AddressingInformation OPTIONAL
);
5390 typedef NDIS_STATUS (DDKAPI
*CLOSE_ADAPTER_HANDLER
)(
5391 IN NDIS_HANDLE MacBindingHandle
);
5393 typedef NDIS_STATUS (DDKAPI
*WAN_TRANSFER_DATA_HANDLER
)(
5396 typedef NDIS_STATUS (DDKAPI
*QUERY_GLOBAL_STATISTICS_HANDLER
)(
5397 IN NDIS_HANDLE MacAdapterContext
,
5398 IN PNDIS_REQUEST NdisRequest
);
5400 typedef VOID (DDKAPI
*UNLOAD_MAC_HANDLER
)(
5401 IN NDIS_HANDLE MacMacContext
);
5403 typedef NDIS_STATUS (DDKAPI
*ADD_ADAPTER_HANDLER
)(
5404 IN NDIS_HANDLE MacMacContext
,
5405 IN NDIS_HANDLE WrapperConfigurationContext
,
5406 IN PNDIS_STRING AdapterName
);
5408 typedef VOID (*REMOVE_ADAPTER_HANDLER
)(
5409 IN NDIS_HANDLE MacAdapterContext
);
5411 typedef struct _NDIS_MAC_CHARACTERISTICS
{
5412 UCHAR MajorNdisVersion
;
5413 UCHAR MinorNdisVersion
;
5416 OPEN_ADAPTER_HANDLER OpenAdapterHandler
;
5417 CLOSE_ADAPTER_HANDLER CloseAdapterHandler
;
5418 SEND_HANDLER SendHandler
;
5419 TRANSFER_DATA_HANDLER TransferDataHandler
;
5420 RESET_HANDLER ResetHandler
;
5421 REQUEST_HANDLER RequestHandler
;
5422 QUERY_GLOBAL_STATISTICS_HANDLER QueryGlobalStatisticsHandler
;
5423 UNLOAD_MAC_HANDLER UnloadMacHandler
;
5424 ADD_ADAPTER_HANDLER AddAdapterHandler
;
5425 REMOVE_ADAPTER_HANDLER RemoveAdapterHandler
;
5427 } NDIS_MAC_CHARACTERISTICS
, *PNDIS_MAC_CHARACTERISTICS
;
5429 typedef NDIS_MAC_CHARACTERISTICS NDIS_WAN_MAC_CHARACTERISTICS
;
5430 typedef NDIS_WAN_MAC_CHARACTERISTICS
*PNDIS_WAN_MAC_CHARACTERISTICS
;
5436 #endif /* __NDIS_H */