summaryrefslogtreecommitdiff
path: root/FreeRTOS-Plus/Demo/FreeRTOS_Cellular_Interface_Windows_Simulator/Common/WinPCap/Packet32.h
diff options
context:
space:
mode:
Diffstat (limited to 'FreeRTOS-Plus/Demo/FreeRTOS_Cellular_Interface_Windows_Simulator/Common/WinPCap/Packet32.h')
-rw-r--r--FreeRTOS-Plus/Demo/FreeRTOS_Cellular_Interface_Windows_Simulator/Common/WinPCap/Packet32.h398
1 files changed, 0 insertions, 398 deletions
diff --git a/FreeRTOS-Plus/Demo/FreeRTOS_Cellular_Interface_Windows_Simulator/Common/WinPCap/Packet32.h b/FreeRTOS-Plus/Demo/FreeRTOS_Cellular_Interface_Windows_Simulator/Common/WinPCap/Packet32.h
deleted file mode 100644
index e8a444dee..000000000
--- a/FreeRTOS-Plus/Demo/FreeRTOS_Cellular_Interface_Windows_Simulator/Common/WinPCap/Packet32.h
+++ /dev/null
@@ -1,398 +0,0 @@
-/*
- * Copyright (c) 1999 - 2005 NetGroup, Politecnico di Torino (Italy)
- * Copyright (c) 2005 - 2007 CACE Technologies, Davis (California)
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * 3. Neither the name of the Politecnico di Torino, CACE Technologies
- * nor the names of its contributors may be used to endorse or promote
- * products derived from this software without specific prior written
- * permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- */
-
-/** @ingroup packetapi
- * @{
- */
-
-/** @defgroup packet32h Packet.dll definitions and data structures
- * Packet32.h contains the data structures and the definitions used by packet.dll.
- * The file is used both by the Win9x and the WinNTx versions of packet.dll, and can be included
- * by the applications that use the functions of this library
- * @{
- */
-
-#ifndef __PACKET32
- #define __PACKET32
-
- #include <winsock2.h>
-
- #ifdef HAVE_AIRPCAP_API
- #include <airpcap.h>
- #else
- #if !defined( AIRPCAP_HANDLE__EAE405F5_0171_9592_B3C2_C19EC426AD34__DEFINED_ )
- #define AIRPCAP_HANDLE__EAE405F5_0171_9592_B3C2_C19EC426AD34__DEFINED_
- typedef struct _AirpcapHandle * PAirpcapHandle;
- #endif /* AIRPCAP_HANDLE__EAE405F5_0171_9592_B3C2_C19EC426AD34__DEFINED_ */
- #endif /* HAVE_AIRPCAP_API */
-
- #ifdef HAVE_DAG_API
- #include <dagc.h>
- #endif /* HAVE_DAG_API */
-
-/* Working modes */
- #define PACKET_MODE_CAPT 0x0 /*/< Capture mode */
- #define PACKET_MODE_STAT 0x1 /*/< Statistical mode */
- #define PACKET_MODE_MON 0x2 /*/< Monitoring mode */
- #define PACKET_MODE_DUMP 0x10 /*/< Dump mode */
- #define PACKET_MODE_STAT_DUMP MODE_DUMP | MODE_STAT /*/< Statistical dump Mode */
-
-
-/*/ Alignment macro. Defines the alignment size. */
- #define Packet_ALIGNMENT sizeof( int )
-/*/ Alignment macro. Rounds up to the next even multiple of Packet_ALIGNMENT. */
- #define Packet_WORDALIGN( x ) ( ( ( x ) + ( Packet_ALIGNMENT - 1 ) ) & ~( Packet_ALIGNMENT - 1 ) )
-
- #define NdisMediumNull -1 /*/< Custom linktype: NDIS doesn't provide an equivalent */
- #define NdisMediumCHDLC -2 /*/< Custom linktype: NDIS doesn't provide an equivalent */
- #define NdisMediumPPPSerial -3 /*/< Custom linktype: NDIS doesn't provide an equivalent */
- #define NdisMediumBare80211 -4 /*/< Custom linktype: NDIS doesn't provide an equivalent */
- #define NdisMediumRadio80211 -5 /*/< Custom linktype: NDIS doesn't provide an equivalent */
- #define NdisMediumPpi -6 /*/< Custom linktype: NDIS doesn't provide an equivalent */
-
-/* Loopback behaviour definitions */
- #define NPF_DISABLE_LOOPBACK 1 /*/< Drop the packets sent by the NPF driver */
- #define NPF_ENABLE_LOOPBACK 2 /*/< Capture the packets sent by the NPF driver */
-
-/*!
- * \brief Network type structure.
- *
- * This structure is used by the PacketGetNetType() function to return information on the current adapter's type and speed.
- */
- typedef struct NetType
- {
- UINT LinkType; /*/< The MAC of the current network adapter (see function PacketGetNetType() for more information) */
- ULONGLONG LinkSpeed; /*/< The speed of the network in bits per second */
- } NetType;
-
-
-/*some definitions stolen from libpcap */
-
- #ifndef BPF_MAJOR_VERSION
-
-/*!
- * \brief A BPF pseudo-assembly program.
- *
- * The program will be injected in the kernel by the PacketSetBPF() function and applied to every incoming packet.
- */
- struct bpf_program
- {
- UINT bf_len; /*/< Indicates the number of instructions of the program, i.e. the number of struct bpf_insn that will follow. */
- struct bpf_insn * bf_insns; /*/< A pointer to the first instruction of the program. */
- };
-
-/*!
- * \brief A single BPF pseudo-instruction.
- *
- * bpf_insn contains a single instruction for the BPF register-machine. It is used to send a filter program to the driver.
- */
- struct bpf_insn
- {
- USHORT code; /*/< Instruction type and addressing mode. */
- UCHAR jt; /*/< Jump if true */
- UCHAR jf; /*/< Jump if false */
- int k; /*/< Generic field used for various purposes. */
- };
-
-/*!
- * \brief Structure that contains a couple of statistics values on the current capture.
- *
- * It is used by packet.dll to return statistics about a capture session.
- */
- struct bpf_stat
- {
- UINT bs_recv; /*/< Number of packets that the driver received from the network adapter */
- /*/< from the beginning of the current capture. This value includes the packets */
- /*/< lost by the driver. */
- UINT bs_drop; /*/< number of packets that the driver lost from the beginning of a capture. */
- /*/< Basically, a packet is lost when the the buffer of the driver is full. */
- /*/< In this situation the packet cannot be stored and the driver rejects it. */
- UINT ps_ifdrop; /*/< drops by interface. XXX not yet supported */
- UINT bs_capt; /*/< number of packets that pass the filter, find place in the kernel buffer and */
- /*/< thus reach the application. */
- };
-
-/*!
- * \brief Packet header.
- *
- * This structure defines the header associated with every packet delivered to the application.
- */
- struct bpf_hdr
- {
- struct timeval bh_tstamp; /*/< The timestamp associated with the captured packet. */
- /*/< It is stored in a TimeVal structure. */
- UINT bh_caplen; /*/< Length of captured portion. The captured portion <b>can be different</b> */
- /*/< from the original packet, because it is possible (with a proper filter) */
- /*/< to instruct the driver to capture only a portion of the packets. */
- UINT bh_datalen; /*/< Original length of packet */
- USHORT bh_hdrlen; /*/< Length of bpf header (this struct plus alignment padding). In some cases, */
- /*/< a padding could be added between the end of this structure and the packet */
- /*/< data for performance reasons. This filed can be used to retrieve the actual data */
- /*/< of the packet. */
- };
-
-/*!
- * \brief Dump packet header.
- *
- * This structure defines the header associated with the packets in a buffer to be used with PacketSendPackets().
- * It is simpler than the bpf_hdr, because it corresponds to the header associated by WinPcap and libpcap to a
- * packet in a dump file. This makes straightforward sending WinPcap dump files to the network.
- */
- struct dump_bpf_hdr
- {
- struct timeval ts; /*/< Time stamp of the packet */
- UINT caplen; /*/< Length of captured portion. The captured portion can smaller than the */
- /*/< the original packet, because it is possible (with a proper filter) to */
- /*/< instruct the driver to capture only a portion of the packets. */
- UINT len; /*/< Length of the original packet (off wire). */
- };
-
-
- #endif /* ifndef BPF_MAJOR_VERSION */
-
- struct bpf_stat;
-
- #define DOSNAMEPREFIX TEXT( "Packet_" ) /*/< Prefix added to the adapters device names to create the WinPcap devices */
- #define MAX_LINK_NAME_LENGTH 64 /*< Maximum length of the devices symbolic links */
- #define NMAX_PACKET 65535
-
-/*!
- * \brief Addresses of a network adapter.
- *
- * This structure is used by the PacketGetNetInfoEx() function to return the IP addresses associated with
- * an adapter.
- */
- typedef struct npf_if_addr
- {
- struct sockaddr_storage IPAddress; /*/< IP address. */
- struct sockaddr_storage SubnetMask; /*/< Netmask for that address. */
- struct sockaddr_storage Broadcast; /*/< Broadcast address. */
- } npf_if_addr;
-
-
- #define ADAPTER_NAME_LENGTH 256 + 12 /*/< Maximum length for the name of an adapter. The value is the same used by the IP Helper API. */
- #define ADAPTER_DESC_LENGTH 128 /*/< Maximum length for the description of an adapter. The value is the same used by the IP Helper API. */
- #define MAX_MAC_ADDR_LENGTH 8 /*/< Maximum length for the link layer address of an adapter. The value is the same used by the IP Helper API. */
- #define MAX_NETWORK_ADDRESSES 16 /*/< Maximum length for the link layer address of an adapter. The value is the same used by the IP Helper API. */
-
-
- typedef struct WAN_ADAPTER_INT WAN_ADAPTER; /*/< Describes an opened wan (dialup, VPN...) network adapter using the NetMon API */
- typedef WAN_ADAPTER * PWAN_ADAPTER; /*/< Describes an opened wan (dialup, VPN...) network adapter using the NetMon API */
-
- #define INFO_FLAG_NDIS_ADAPTER 0 /*/< Flag for ADAPTER_INFO: this is a traditional ndis adapter */
- #define INFO_FLAG_NDISWAN_ADAPTER 1 /*/< Flag for ADAPTER_INFO: this is a NdisWan adapter, and it's managed by WANPACKET */
- #define INFO_FLAG_DAG_CARD 2 /*/< Flag for ADAPTER_INFO: this is a DAG card */
- #define INFO_FLAG_DAG_FILE 6 /*/< Flag for ADAPTER_INFO: this is a DAG file */
- #define INFO_FLAG_DONT_EXPORT 8 /*/< Flag for ADAPTER_INFO: when this flag is set, the adapter will not be listed or openend by winpcap. This allows to prevent exporting broken network adapters, like for example FireWire ones. */
- #define INFO_FLAG_AIRPCAP_CARD 16 /*/< Flag for ADAPTER_INFO: this is an airpcap card */
- #define INFO_FLAG_NPFIM_DEVICE 32
-
-/*!
- * \brief Describes an opened network adapter.
- *
- * This structure is the most important for the functioning of packet.dll, but the great part of its fields
- * should be ignored by the user, since the library offers functions that avoid to cope with low-level parameters
- */
- typedef struct _ADAPTER
- {
- HANDLE hFile; /*/< \internal Handle to an open instance of the NPF driver. */
- CHAR SymbolicLink[ MAX_LINK_NAME_LENGTH ]; /*/< \internal A string containing the name of the network adapter currently opened. */
- int NumWrites; /*/< \internal Number of times a packets written on this adapter will be repeated */
- /*/< on the wire. */
- HANDLE ReadEvent; /*/< A notification event associated with the read calls on the adapter. */
- /*/< It can be passed to standard Win32 functions (like WaitForSingleObject */
- /*/< or WaitForMultipleObjects) to wait until the driver's buffer contains some */
- /*/< data. It is particularly useful in GUI applications that need to wait */
- /*/< concurrently on several events. In Windows NT/2000 the PacketSetMinToCopy() */
- /*/< function can be used to define the minimum amount of data in the kernel buffer */
- /*/< that will cause the event to be signalled. */
-
- UINT ReadTimeOut; /*/< \internal The amount of time after which a read on the driver will be released and */
- /*/< ReadEvent will be signaled, also if no packets were captured */
- CHAR Name[ ADAPTER_NAME_LENGTH ];
- PWAN_ADAPTER pWanAdapter;
- UINT Flags; /*/< Adapter's flags. Tell if this adapter must be treated in a different way, using the Netmon API or the dagc API. */
-
- #ifdef HAVE_AIRPCAP_API
- PAirpcapHandle AirpcapAd;
- #endif // HAVE_AIRPCAP_API
-
- #ifdef HAVE_NPFIM_API
- void * NpfImHandle;
- #endif // HAVE_NPFIM_API
-
- #ifdef HAVE_DAG_API
- dagc_t * pDagCard; /*/< Pointer to the dagc API adapter descriptor for this adapter */
- PCHAR DagBuffer; /*/< Pointer to the buffer with the packets that is received from the DAG card */
- struct timeval DagReadTimeout; /*/< Read timeout. The dagc API requires a timeval structure */
- unsigned DagFcsLen; /*/< Length of the frame check sequence attached to any packet by the card. Obtained from the registry */
- DWORD DagFastProcess; /*/< True if the user requests fast capture processing on this card. Higher level applications can use this value to provide a faster but possibly unprecise capture (for example, libpcap doesn't convert the timestamps). */
- #endif // HAVE_DAG_API
- } ADAPTER, * LPADAPTER;
-
-/*!
- * \brief Structure that contains a group of packets coming from the driver.
- *
- * This structure defines the header associated with every packet delivered to the application.
- */
- typedef struct _PACKET
- {
- HANDLE hEvent; /*/< \deprecated Still present for compatibility with old applications. */
- OVERLAPPED OverLapped; /*/< \deprecated Still present for compatibility with old applications. */
- PVOID Buffer; /*/< Buffer with containing the packets. See the PacketReceivePacket() for */
- /*/< details about the organization of the data in this buffer */
- UINT Length; /*/< Length of the buffer */
- DWORD ulBytesReceived; /*/< Number of valid bytes present in the buffer, i.e. amount of data */
- /*/< received by the last call to PacketReceivePacket() */
- BOOLEAN bIoComplete; /*/< \deprecated Still present for compatibility with old applications. */
- } PACKET, * LPPACKET;
-
-/*!
- * \brief Structure containing an OID request.
- *
- * It is used by the PacketRequest() function to send an OID to the interface card driver.
- * It can be used, for example, to retrieve the status of the error counters on the adapter, its MAC address,
- * the list of the multicast groups defined on it, and so on.
- */
- struct _PACKET_OID_DATA
- {
- ULONG Oid; /*/< OID code. See the Microsoft DDK documentation or the file ntddndis.h */
- /*/< for a complete list of valid codes. */
- ULONG Length; /*/< Length of the data field */
- UCHAR Data[ 1 ]; /*/< variable-lenght field that contains the information passed to or received */
- /*/< from the adapter. */
- };
- typedef struct _PACKET_OID_DATA PACKET_OID_DATA, * PPACKET_OID_DATA;
-
- #ifdef __cplusplus
- extern "C" {
- #endif
-
-/**
- * @}
- */
-
-/*
- * BOOLEAN QueryWinPcapRegistryStringA(CHAR *SubKeyName,
- * CHAR *Value,
- * UINT *pValueLen,
- * CHAR *DefaultVal);
- *
- * BOOLEAN QueryWinPcapRegistryStringW(WCHAR *SubKeyName,
- * WCHAR *Value,
- * UINT *pValueLen,
- * WCHAR *DefaultVal);
- */
-
-/*--------------------------------------------------------------------------- */
-/* EXPORTED FUNCTIONS */
-/*--------------------------------------------------------------------------- */
-
- PCHAR PacketGetVersion();
- PCHAR PacketGetDriverVersion();
- BOOLEAN PacketSetMinToCopy( LPADAPTER AdapterObject,
- int nbytes );
- BOOLEAN PacketSetNumWrites( LPADAPTER AdapterObject,
- int nwrites );
- BOOLEAN PacketSetMode( LPADAPTER AdapterObject,
- int mode );
- BOOLEAN PacketSetReadTimeout( LPADAPTER AdapterObject,
- int timeout );
- BOOLEAN PacketSetBpf( LPADAPTER AdapterObject,
- struct bpf_program * fp );
- BOOLEAN PacketSetLoopbackBehavior( LPADAPTER AdapterObject,
- UINT LoopbackBehavior );
- INT PacketSetSnapLen( LPADAPTER AdapterObject,
- int snaplen );
- BOOLEAN PacketGetStats( LPADAPTER AdapterObject,
- struct bpf_stat * s );
- BOOLEAN PacketGetStatsEx( LPADAPTER AdapterObject,
- struct bpf_stat * s );
- BOOLEAN PacketSetBuff( LPADAPTER AdapterObject,
- int dim );
- BOOLEAN PacketGetNetType( LPADAPTER AdapterObject,
- NetType * type );
- LPADAPTER PacketOpenAdapter( PCHAR AdapterName );
- BOOLEAN PacketSendPacket( LPADAPTER AdapterObject,
- LPPACKET pPacket,
- BOOLEAN Sync );
- INT PacketSendPackets( LPADAPTER AdapterObject,
- PVOID PacketBuff,
- ULONG Size,
- BOOLEAN Sync );
- LPPACKET PacketAllocatePacket( void );
- VOID PacketInitPacket( LPPACKET lpPacket,
- PVOID Buffer,
- UINT Length );
- VOID PacketFreePacket( LPPACKET lpPacket );
- BOOLEAN PacketReceivePacket( LPADAPTER AdapterObject,
- LPPACKET lpPacket,
- BOOLEAN Sync );
- BOOLEAN PacketSetHwFilter( LPADAPTER AdapterObject,
- ULONG Filter );
- BOOLEAN PacketGetAdapterNames( PTSTR pStr,
- PULONG BufferSize );
- BOOLEAN PacketGetNetInfoEx( PCHAR AdapterName,
- npf_if_addr * buffer,
- PLONG NEntries );
- BOOLEAN PacketRequest( LPADAPTER AdapterObject,
- BOOLEAN Set,
- PPACKET_OID_DATA OidData );
- HANDLE PacketGetReadEvent( LPADAPTER AdapterObject );
- BOOLEAN PacketSetDumpName( LPADAPTER AdapterObject,
- void * name,
- int len );
- BOOLEAN PacketSetDumpLimits( LPADAPTER AdapterObject,
- UINT maxfilesize,
- UINT maxnpacks );
- BOOLEAN PacketIsDumpEnded( LPADAPTER AdapterObject,
- BOOLEAN sync );
- BOOL PacketStopDriver();
- VOID PacketCloseAdapter( LPADAPTER lpAdapter );
- BOOLEAN PacketStartOem( PCHAR errorString,
- UINT errorStringLength );
- BOOLEAN PacketStartOemEx( PCHAR errorString,
- UINT errorStringLength,
- ULONG flags );
- PAirpcapHandle PacketGetAirPcapHandle( LPADAPTER AdapterObject );
-
-/* */
-/* Used by PacketStartOemEx */
-/* */
- #define PACKET_START_OEM_NO_NETMON 0x00000001
-
- #ifdef __cplusplus
- }
- #endif
-
-#endif //__PACKET32