VirtualBox

source: vbox/trunk/src/VBox/HostDrivers/VBoxNetFlt/win/drv/VBoxNetFltCmn-win.h@ 56846

Last change on this file since 56846 was 56846, checked in by vboxsync, 10 years ago

NetFlt/Win: Host IP address notifications (#7661)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 20.8 KB
Line 
1/* $Id: VBoxNetFltCmn-win.h 56846 2015-07-07 20:09:37Z vboxsync $ */
2/** @file
3 * VBoxNetFltCmn-win.h - Bridged Networking Driver, Windows Specific Code.
4 * Common header with configuration defines and global defs
5 */
6
7/*
8 * Copyright (C) 2011-2015 Oracle Corporation
9 *
10 * This file is part of VirtualBox Open Source Edition (OSE), as
11 * available from http://www.virtualbox.org. This file is free software;
12 * you can redistribute it and/or modify it under the terms of the GNU
13 * General Public License (GPL) as published by the Free Software
14 * Foundation, in version 2 as it comes in the "COPYING" file of the
15 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
16 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
17 */
18
19#ifndef ___VBoxNetFltCmn_win_h___
20#define ___VBoxNetFltCmn_win_h___
21
22#define LOG_GROUP LOG_GROUP_NET_FLT_DRV
23
24/* debugging flags */
25#ifdef DEBUG
26//# define DEBUG_NETFLT_PACKETS
27# ifndef DEBUG_misha
28# define RT_NO_STRICT
29# endif
30/* # define DEBUG_NETFLT_LOOPBACK */
31/* receive logic has several branches */
32/* the DEBUG_NETFLT_RECV* macros used to debug the ProtocolReceive callback
33 * which is typically not used in case the underlying miniport indicates the packets with NdisMIndicateReceivePacket
34 * the best way to debug the ProtocolReceive (which in turn has several branches) is to enable the DEBUG_NETFLT_RECV
35 * one by one in the below order, i.e.
36 * first DEBUG_NETFLT_RECV
37 * then DEBUG_NETFLT_RECV + DEBUG_NETFLT_RECV_NOPACKET */
38//# define DEBUG_NETFLT_RECV
39//# define DEBUG_NETFLT_RECV_NOPACKET
40//# define DEBUG_NETFLT_RECV_TRANSFERDATA
41/* use ExAllocatePoolWithTag instead of NdisAllocateMemoryWithTag */
42// #define DEBUG_NETFLT_USE_EXALLOC
43#endif
44
45#include <VBox/intnet.h>
46#include <VBox/log.h>
47#include <VBox/err.h>
48#include <VBox/version.h>
49#include <iprt/initterm.h>
50#include <iprt/assert.h>
51#include <iprt/spinlock.h>
52#include <iprt/semaphore.h>
53#include <iprt/process.h>
54#include <iprt/alloc.h>
55#include <iprt/alloca.h>
56#include <iprt/time.h>
57#include <iprt/net.h>
58#include <iprt/list.h>
59
60RT_C_DECLS_BEGIN
61/* ntddk.h has a missing #pragma pack(), work around it
62 * see #ifdef VBOX_WITH_WORKAROUND_MISSING_PACK below for detail */
63#define VBOX_WITH_WORKAROUND_MISSING_PACK
64#if (_MSC_VER >= 1400) && !defined(VBOX_WITH_PATCHED_DDK)
65# define _InterlockedExchange _InterlockedExchange_StupidDDKVsCompilerCrap
66# define _InterlockedExchangeAdd _InterlockedExchangeAdd_StupidDDKVsCompilerCrap
67# define _InterlockedCompareExchange _InterlockedCompareExchange_StupidDDKVsCompilerCrap
68# define _InterlockedAddLargeStatistic _InterlockedAddLargeStatistic_StupidDDKVsCompilerCrap
69# define _interlockedbittestandset _interlockedbittestandset_StupidDDKVsCompilerCrap
70# define _interlockedbittestandreset _interlockedbittestandreset_StupidDDKVsCompilerCrap
71# define _interlockedbittestandset64 _interlockedbittestandset64_StupidDDKVsCompilerCrap
72# define _interlockedbittestandreset64 _interlockedbittestandreset64_StupidDDKVsCompilerCrap
73# pragma warning(disable : 4163)
74# ifdef VBOX_WITH_WORKAROUND_MISSING_PACK
75# pragma warning(disable : 4103)
76# endif
77# include <ntddk.h>
78# pragma warning(default : 4163)
79# ifdef VBOX_WITH_WORKAROUND_MISSING_PACK
80# pragma pack()
81# pragma warning(default : 4103)
82# endif
83# undef _InterlockedExchange
84# undef _InterlockedExchangeAdd
85# undef _InterlockedCompareExchange
86# undef _InterlockedAddLargeStatistic
87# undef _interlockedbittestandset
88# undef _interlockedbittestandreset
89# undef _interlockedbittestandset64
90# undef _interlockedbittestandreset64
91# include <ndis.h>
92#else
93//# include <ntddk.h>
94/* can include ndis.h right away */
95# include <ndis.h>
96#endif
97RT_C_DECLS_END
98
99#define VBOXNETFLT_OS_SPECFIC 1
100
101/** version
102 * NOTE: we are NOT using NDIS 5.1 features now */
103#ifdef NDIS51_MINIPORT
104# define VBOXNETFLT_VERSION_MP_NDIS_MAJOR 5
105# define VBOXNETFLT_VERSION_MP_NDIS_MINOR 1
106#else
107# define VBOXNETFLT_VERSION_MP_NDIS_MAJOR 5
108# define VBOXNETFLT_VERSION_MP_NDIS_MINOR 0
109#endif
110
111#ifndef VBOXNETADP
112#ifdef NDIS51
113# define VBOXNETFLT_VERSION_PT_NDIS_MAJOR 5
114# define VBOXNETFLT_VERSION_PT_NDIS_MINOR 1 /* todo: use 0 here as well ? */
115#else
116# define VBOXNETFLT_VERSION_PT_NDIS_MAJOR 5
117# define VBOXNETFLT_VERSION_PT_NDIS_MINOR 0
118#endif
119
120# define VBOXNETFLT_NAME_PROTOCOL L"VBoxNetFlt"
121/** device to be used to prevent the driver unload & ioctl interface (if necessary in the future) */
122# define VBOXNETFLT_NAME_LINK L"\\DosDevices\\Global\\VBoxNetFlt"
123# define VBOXNETFLT_NAME_DEVICE L"\\Device\\VBoxNetFlt"
124#else
125# define VBOXNETFLT_NAME_LINK L"\\DosDevices\\Global\\VBoxNetAdp"
126# define VBOXNETFLT_NAME_DEVICE L"\\Device\\VBoxNetAdp"
127#endif
128
129typedef struct VBOXNETFLTINS *PVBOXNETFLTINS;
130
131/** configuration */
132
133/** Ndis Packet pool settings
134 * these are applied to both receive and send packet pools */
135/* number of packets for normal used */
136#define VBOXNETFLT_PACKET_POOL_SIZE_NORMAL 0x000000FF
137/* number of additional overflow packets */
138#define VBOXNETFLT_PACKET_POOL_SIZE_OVERFLOW 0x0000FF00
139
140/** packet queue size used when the driver is working in the "active" mode */
141#define VBOXNETFLT_PACKET_INFO_POOL_SIZE 0x0000FFFF
142
143#ifndef VBOXNETADP
144/** memory tag used for memory allocations
145 * (VBNF stands for VBox NetFlt) */
146# define VBOXNETFLT_MEM_TAG 'FNBV'
147#else
148/** memory tag used for memory allocations
149 * (VBNA stands for VBox NetAdp) */
150# define VBOXNETFLT_MEM_TAG 'ANBV'
151#endif
152
153/** receive and transmit Ndis buffer pool size */
154#define VBOXNETFLT_BUFFER_POOL_SIZE_TX 128
155#define VBOXNETFLT_BUFFER_POOL_SIZE_RX 128
156
157#define VBOXNETFLT_PACKET_ETHEADER_SIZE 14
158#define VBOXNETFLT_PACKET_HEADER_MATCH_SIZE 24
159#define VBOXNETFLT_PACKET_QUEUE_SG_SEGS_ALLOC 32
160
161
162#if defined(DEBUG_NETFLT_PACKETS) || !defined(VBOX_LOOPBACK_USEFLAGS)
163# define VBOXNETFLT_PACKETMATCH_LENGTH (VBOXNETFLT_PACKET_ETHEADER_SIZE + 2)
164#endif
165
166#ifdef VBOXNETADP
167#define VBOXNETADP_HEADER_SIZE 14
168#define VBOXNETADP_MAX_DATA_SIZE 1500
169#define VBOXNETADP_MAX_PACKET_SIZE (VBOXNETADP_HEADER_SIZE + VBOXNETADP_MAX_DATA_SIZE)
170#define VBOXNETADP_MIN_PACKET_SIZE 60
171/* link speed 100Mbps (measured in 100 bps) */
172#define VBOXNETADP_LINK_SPEED 1000000
173#define VBOXNETADP_MAX_LOOKAHEAD_SIZE VBOXNETADP_MAX_DATA_SIZE
174#define VBOXNETADP_VENDOR_ID 0x080027
175#define VBOXNETADP_VENDOR_DRIVER_VERSION 0x00010000
176#define VBOXNETADP_VENDOR_DESC "Sun"
177#define VBOXNETADP_MAX_MCAST_LIST 32
178#define VBOXNETADP_ETH_ADDRESS_LENGTH 6
179
180//#define VBOXNETADP_REPORT_DISCONNECTED
181#endif
182/* type defs */
183
184/** Flag specifying that the type of enqueued packet
185 * if set the info contains the PINTNETSG packet
186 * if clear the packet info contains the PNDIS_PACKET packet
187 * Typically the packet queue we are maintaining contains PNDIS_PACKETs only,
188 * however in case the underlying miniport indicates a packet with the NDIS_STATUS_RESOURCES status
189 * we MUST return the packet back to the miniport immediately
190 * this is why we are creating the INTNETSG, copying the ndis packet info there and enqueueing it */
191#define VBOXNETFLT_PACKET_SG 0x00000001
192
193/** the flag specifying that the packet source
194 * if set the packet comes from the host (upperlying protocol)
195 * if clear the packet comes from the wire (underlying miniport) */
196#define VBOXNETFLT_PACKET_SRC_HOST 0x00000002
197
198#ifndef VBOXNETFLT_NO_PACKET_QUEUE
199/** flag specifying the packet was originated by our driver
200 * i.e. we could use it on our needs and should not return it
201 * we are enqueueing "our" packets on ProtocolReceive call-back when
202 * Ndis does not give us a receive packet (the driver below us has called NdisM..IndicateReceive)
203 * this is supported for Ndis Packet only */
204#define VBOXNETFLT_PACKET_MINE 0x00000004
205
206/** flag passed to vboxNetFltWinQuEnqueuePacket specifying that the packet should be copied
207 * this is supported for Ndis Packet only */
208#define VBOXNETFLT_PACKET_COPY 0x00000008
209#endif
210
211/** packet queue element containing the packet info */
212typedef struct VBOXNETFLT_PACKET_INFO
213{
214 /** list entry used for enqueueing the info */
215 LIST_ENTRY ListEntry;
216 /** pointer to the pool containing this packet info */
217 struct VBOXNETFLT_PACKET_INFO_POOL *pPool;
218 /** flags describing the referenced packet. Contains PACKET_xxx flags (i.e. PACKET_SG, PACKET_SRC_HOST) */
219 uint32_t fFlags;
220 /** pointer to the packet this info represents */
221 PVOID pPacket;
222} VBOXNETFLT_PACKET_INFO, *PVBOXNETFLT_PACKET_INFO;
223
224/* paranoid check to make sure the elements in the packet info array are properly aligned */
225AssertCompile((sizeof(VBOXNETFLT_PACKET_INFO) & (sizeof(PVOID) - 1)) == 0);
226
227/** represents the packet queue */
228typedef LIST_ENTRY PVBOXNETFLT_ACKET_QUEUE, *PVBOXNETFLT_PACKET_QUEUE;
229
230/*
231 * we are using non-interlocked versions of LIST_ENTRY-related operations macros and synchronize
232 * access to the queue and its elements by acquiring/releasing a spinlock using Ndis[Acquire,Release]Spinlock
233 *
234 * we are NOT using interlocked versions of insert/remove head/tail list functions because we need to iterate though
235 * the queue elements as well as remove elements from the midle of the queue
236 *
237 * * @todo: it seems that we can switch to using interlocked versions of list-entry functions
238 * since we have removed all functionality (mentioned above, i.e. queue elements iteration, etc.) that might prevent us from doing this
239 */
240typedef struct VBOXNETFLT_INTERLOCKED_PACKET_QUEUE
241{
242 /** queue */
243 PVBOXNETFLT_ACKET_QUEUE Queue;
244 /** queue lock */
245 NDIS_SPIN_LOCK Lock;
246} VBOXNETFLT_INTERLOCKED_PACKET_QUEUE, *PVBOXNETFLT_INTERLOCKED_PACKET_QUEUE;
247
248typedef struct VBOXNETFLT_SINGLE_LIST
249{
250 /** queue */
251 SINGLE_LIST_ENTRY Head;
252 /** pointer to the list tail. used to enqueue elements to the tail of the list */
253 PSINGLE_LIST_ENTRY pTail;
254} VBOXNETFLT_SINGLE_LIST, *PVBOXNETFLT_SINGLE_LIST;
255
256typedef struct VBOXNETFLT_INTERLOCKED_SINGLE_LIST
257{
258 /** queue */
259 VBOXNETFLT_SINGLE_LIST List;
260 /** queue lock */
261 NDIS_SPIN_LOCK Lock;
262} VBOXNETFLT_INTERLOCKED_SINGLE_LIST, *PVBOXNETFLT_INTERLOCKED_SINGLE_LIST;
263
264/** packet info pool contains free packet info elements to be used for the packet queue
265 * we are using the pool mechanism to allocate packet queue elements
266 * the pool mechanism is pretty simple now, we are allocating a bunch of memory
267 * for maintaining VBOXNETFLT_PACKET_INFO_POOL_SIZE queue elements and just returning null when the pool is exhausted
268 * This mechanism seems to be enough for now since we are using VBOXNETFLT_PACKET_INFO_POOL_SIZE = 0xffff which is
269 * the maximum size of packets the ndis packet pool supports */
270typedef struct VBOXNETFLT_PACKET_INFO_POOL
271{
272 /** free packet info queue */
273 VBOXNETFLT_INTERLOCKED_PACKET_QUEUE Queue;
274 /** memory bugger used by the pool */
275 PVOID pBuffer;
276} VBOXNETFLT_PACKET_INFO_POOL, *PVBOXNETFLT_PACKET_INFO_POOL;
277
278typedef enum VBOXNETDEVOPSTATE
279{
280 kVBoxNetDevOpState_InvalidValue = 0,
281 kVBoxNetDevOpState_Initializing,
282 kVBoxNetDevOpState_Initialized,
283 kVBoxNetDevOpState_Deinitializing,
284 kVBoxNetDevOpState_Deinitialized,
285
286} VBOXNETDEVOPSTATE;
287
288typedef enum VBOXNETFLT_WINIFSTATE
289{
290 /** The usual invalid state. */
291 kVBoxWinIfState_Invalid = 0,
292 /** Initialization. */
293 kVBoxWinIfState_Connecting,
294 /** Connected fuly functional state */
295 kVBoxWinIfState_Connected,
296 /** Disconnecting */
297 kVBoxWinIfState_Disconnecting,
298 /** Disconnected */
299 kVBoxWinIfState_Disconnected,
300} VBOXNETFLT_WINIFSTATE;
301
302/** structure used to maintain the state and reference count of the miniport and protocol */
303typedef struct VBOXNETFLT_WINIF_DEVICE
304{
305 /** initialize state */
306 VBOXNETDEVOPSTATE OpState;
307 /** ndis power state */
308 NDIS_DEVICE_POWER_STATE PowerState;
309 /** reference count */
310 uint32_t cReferences;
311} VBOXNETFLT_WINIF_DEVICE, *PVBOXNETFLT_WINIF_DEVICE;
312
313#define VBOXNDISREQUEST_INPROGRESS 1
314#define VBOXNDISREQUEST_QUEUED 2
315
316typedef struct VBOXNETFLTWIN_STATE
317{
318 union
319 {
320 struct
321 {
322 UINT fRequestInfo : 2;
323 UINT fInterfaceClosing : 1;
324 UINT fStandBy : 1;
325 UINT fProcessingPacketFilter : 1;
326 UINT fPPFNetFlt : 1;
327 UINT fUpperProtSetFilterInitialized : 1;
328 UINT Reserved : 25;
329 };
330 UINT Value;
331 };
332} VBOXNETFLTWIN_STATE, *PVBOXNETFLTWIN_STATE;
333
334DECLINLINE(VBOXNETFLTWIN_STATE) vboxNetFltWinAtomicUoReadWinState(VBOXNETFLTWIN_STATE State)
335{
336 UINT fValue = ASMAtomicUoReadU32((volatile uint32_t *)&State.Value);
337 return *((PVBOXNETFLTWIN_STATE)((void*)&fValue));
338}
339
340/* miniport layer globals */
341typedef struct VBOXNETFLTGLOBALS_MP
342{
343 /** our miniport handle */
344 NDIS_HANDLE hMiniport;
345 /** ddis wrapper handle */
346 NDIS_HANDLE hNdisWrapper;
347} VBOXNETFLTGLOBALS_MP, *PVBOXNETFLTGLOBALS_MP;
348
349#ifndef VBOXNETADP
350/* protocol layer globals */
351typedef struct VBOXNETFLTGLOBALS_PT
352{
353 /** our protocol handle */
354 NDIS_HANDLE hProtocol;
355} VBOXNETFLTGLOBALS_PT, *PVBOXNETFLTGLOBALS_PT;
356#endif /* #ifndef VBOXNETADP */
357
358typedef struct VBOXNETFLTGLOBALS_WIN
359{
360 /** synch event used for device creation synchronization */
361 KEVENT SynchEvent;
362 /** Device reference count */
363 int cDeviceRefs;
364 /** ndis device */
365 NDIS_HANDLE hDevice;
366 /** device object */
367 PDEVICE_OBJECT pDevObj;
368 /* loopback flags */
369 /* ndis packet flags to disable packet loopback */
370 UINT fPacketDontLoopBack;
371 /* ndis packet flags specifying whether the packet is looped back */
372 UINT fPacketIsLoopedBack;
373 /* Minport info */
374 VBOXNETFLTGLOBALS_MP Mp;
375#ifndef VBOXNETADP
376 /* Protocol info */
377 VBOXNETFLTGLOBALS_PT Pt;
378 /** lock protecting the filter list */
379 NDIS_SPIN_LOCK lockFilters;
380 /** the head of filter list */
381 RTLISTANCHOR listFilters;
382 /** IP address change notifier handle */
383 HANDLE hNotifier;
384#endif
385} VBOXNETFLTGLOBALS_WIN, *PVBOXNETFLTGLOBALS_WIN;
386
387extern VBOXNETFLTGLOBALS_WIN g_VBoxNetFltGlobalsWin;
388
389/** represents filter driver device context*/
390typedef struct VBOXNETFLTWIN
391{
392 /** handle used by miniport edge for ndis calls */
393 NDIS_HANDLE hMiniport;
394 /** miniport edge state */
395 VBOXNETFLT_WINIF_DEVICE MpState;
396 /** ndis packet pool used for receives */
397 NDIS_HANDLE hRecvPacketPool;
398 /** ndis buffer pool used for receives */
399 NDIS_HANDLE hRecvBufferPool;
400 /** driver bind adapter state. */
401 VBOXNETFLT_WINIFSTATE enmState;
402#ifndef VBOXNETADP
403 /* misc state flags */
404 VBOXNETFLTWIN_STATE StateFlags;
405 /** handle used by protocol edge for ndis calls */
406 NDIS_HANDLE hBinding;
407 /** protocol edge state */
408 VBOXNETFLT_WINIF_DEVICE PtState;
409 /** ndis packet pool used for receives */
410 NDIS_HANDLE hSendPacketPool;
411 /** ndis buffer pool used for receives */
412 NDIS_HANDLE hSendBufferPool;
413 /** used for maintaining the pending send packets for handling packet loopback */
414 VBOXNETFLT_INTERLOCKED_SINGLE_LIST SendPacketQueue;
415 /** used for serializing calls to the NdisRequest in the vboxNetFltWinSynchNdisRequest */
416 RTSEMFASTMUTEX hSynchRequestMutex;
417 /** event used to synchronize with the Ndis Request completion in the vboxNetFltWinSynchNdisRequest */
418 KEVENT hSynchCompletionEvent;
419 /** status of the Ndis Request initiated by the vboxNetFltWinSynchNdisRequest */
420 NDIS_STATUS volatile SynchCompletionStatus;
421 /** pointer to the Ndis Request being executed by the vboxNetFltWinSynchNdisRequest */
422 PNDIS_REQUEST volatile pSynchRequest;
423 /** open/close adapter status.
424 * Since ndis adapter open and close requests may complete asynchronously,
425 * we are using event mechanism to wait for open/close completion
426 * the status field is being set by the completion call-back */
427 NDIS_STATUS OpenCloseStatus;
428 /** open/close adaptor completion event */
429 NDIS_EVENT OpenCloseEvent;
430 /** medium we are attached to */
431 NDIS_MEDIUM enmMedium;
432 /**
433 * Passdown request info
434 */
435 /** ndis request we pass down to the miniport below */
436 NDIS_REQUEST PassDownRequest;
437 /** Ndis pass down request bytes read or written original pointer */
438 PULONG pcPDRBytesRW;
439 /** Ndis pass down request bytes needed original pointer */
440 PULONG pcPDRBytesNeeded;
441 /** true if we should indicate the receive complete used by the ProtocolReceive mechanism.
442 * We need to indicate it only with the ProtocolReceive + NdisMEthIndicateReceive path.
443 * Note: we're using KeGetCurrentProcessorNumber, which is not entirely correct in case
444 * we're running on 64bit win7+, which can handle > 64 CPUs, however since KeGetCurrentProcessorNumber
445 * always returns the number < than the number of CPUs in the first group, we're guaranteed to have CPU index < 64
446 * @todo: use KeGetCurrentProcessorNumberEx for Win7+ 64 and dynamically extended array */
447 bool abIndicateRxComplete[64];
448 /** Pending transfer data packet queue (i.e. packets that were indicated as pending on NdisTransferData call */
449 VBOXNETFLT_INTERLOCKED_SINGLE_LIST TransferDataList;
450 /* mac options initialized on OID_GEN_MAC_OPTIONS */
451 ULONG fMacOptions;
452 /** our miniport devuice name */
453 NDIS_STRING MpDeviceName;
454 /** synchronize with unbind with Miniport initialization */
455 NDIS_EVENT MpInitCompleteEvent;
456 /** media connect status that we indicated */
457 NDIS_STATUS MpIndicatedMediaStatus;
458 /** media connect status pending to indicate */
459 NDIS_STATUS MpUnindicatedMediaStatus;
460 /** packet filter flags set by the upper protocols */
461 ULONG fUpperProtocolSetFilter;
462 /** packet filter flags set by the upper protocols */
463 ULONG fSetFilterBuffer;
464 /** packet filter flags set by us */
465 ULONG fOurSetFilter;
466 /** our own list of filters, needed by notifier */
467 RTLISTNODE node;
468#else
469 volatile ULONG cTxSuccess;
470 volatile ULONG cRxSuccess;
471 volatile ULONG cTxError;
472 volatile ULONG cRxError;
473#endif
474} VBOXNETFLTWIN, *PVBOXNETFLTWIN;
475
476typedef struct VBOXNETFLT_PACKET_QUEUE_WORKER
477{
478 /** this event is used to initiate a packet queue worker thread kill */
479 KEVENT KillEvent;
480 /** this event is used to notify a worker thread that the packets are added to the queue */
481 KEVENT NotifyEvent;
482 /** pointer to the packet queue worker thread object */
483 PKTHREAD pThread;
484 /** pointer to the SG used by the packet queue for IntNet receive notifications */
485 PINTNETSG pSG;
486 /** Packet queue */
487 VBOXNETFLT_INTERLOCKED_PACKET_QUEUE PacketQueue;
488 /** Packet info pool, i.e. the pool for the packet queue elements */
489 VBOXNETFLT_PACKET_INFO_POOL PacketInfoPool;
490} VBOXNETFLT_PACKET_QUEUE_WORKER, *PVBOXNETFLT_PACKET_QUEUE_WORKER;
491
492/* protocol reserved data held in ndis packet */
493typedef struct VBOXNETFLT_PKTRSVD_PT
494{
495 /** original packet received from the upperlying protocol
496 * can be null if the packet was originated by intnet */
497 PNDIS_PACKET pOrigPacket;
498 /** pointer to the buffer to be freed on send completion
499 * can be null if no buffer is to be freed */
500 PVOID pBufToFree;
501#if !defined(VBOX_LOOPBACK_USEFLAGS) || defined(DEBUG_NETFLT_PACKETS)
502 SINGLE_LIST_ENTRY ListEntry;
503 /* true if the packet is from IntNet */
504 bool bFromIntNet;
505#endif
506} VBOXNETFLT_PKTRSVD_PT, *PVBOXNETFLT_PKTRSVD_PT;
507
508/** miniport reserved data held in ndis packet */
509typedef struct VBOXNETFLT_PKTRSVD_MP
510{
511 /** original packet received from the underling miniport
512 * can be null if the packet was originated by intnet */
513 PNDIS_PACKET pOrigPacket;
514 /** pointer to the buffer to be freed on receive completion
515 * can be null if no buffer is to be freed */
516 PVOID pBufToFree;
517} VBOXNETFLT_PKTRSVD_MP, *PVBOXNETFLT_PKTRSVD_MP;
518
519/** represents the data stored in the protocol reserved field of ndis packet on NdisTransferData processing */
520typedef struct VBOXNETFLT_PKTRSVD_TRANSFERDATA_PT
521{
522 /** next packet in a list */
523 SINGLE_LIST_ENTRY ListEntry;
524 /* packet buffer start */
525 PNDIS_BUFFER pOrigBuffer;
526} VBOXNETFLT_PKTRSVD_TRANSFERDATA_PT, *PVBOXNETFLT_PKTRSVD_TRANSFERDATA_PT;
527
528/* VBOXNETFLT_PKTRSVD_TRANSFERDATA_PT should fit into PROTOCOL_RESERVED_SIZE_IN_PACKET because we use protocol reserved part
529 * of our miniport edge on transfer data processing for honding our own info */
530AssertCompile(sizeof (VBOXNETFLT_PKTRSVD_TRANSFERDATA_PT) <= PROTOCOL_RESERVED_SIZE_IN_PACKET);
531/* this should fit in MiniportReserved */
532AssertCompile(sizeof (VBOXNETFLT_PKTRSVD_MP) <= RT_SIZEOFMEMB(NDIS_PACKET, MiniportReserved));
533/* we use RTAsmAtomic*U32 for those, make sure we're correct */
534AssertCompile(sizeof (NDIS_DEVICE_POWER_STATE) == sizeof (uint32_t));
535AssertCompile(sizeof (UINT) == sizeof (uint32_t));
536
537
538#define NDIS_FLAGS_SKIP_LOOPBACK_W2K 0x400
539
540#include "../../VBoxNetFltInternal.h"
541#include "VBoxNetFltRt-win.h"
542#ifndef VBOXNETADP
543# include "VBoxNetFltP-win.h"
544#endif
545#include "VBoxNetFltM-win.h"
546
547#endif /* #ifndef ___VBoxNetFltCmn_win_h___ */
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette