mirror of
https://github.com/FreeRTOS/FreeRTOS-Kernel.git
synced 2025-10-26 23:36:32 -04:00
Use CI-CD-Github-Actions for spelling and formatting, add in the bot formatting action, update the CI-CD workflow files. Fix incorrect spelling and formatting on files. (#1083)
* Use new version of CI-CD Actions, checkout@v3 instead of checkout@v2 on all jobs * Use cSpell spell check, and use ubuntu-20.04 for formatting check * Add in bot formatting action * Update freertos_demo.yml and freertos_plus_demo.yml files to increase github log readability * Add in a Qemu demo onto the workflows.
This commit is contained in:
parent
537007d96c
commit
3a2f6646f0
1036 changed files with 134568 additions and 127281 deletions
|
|
@ -12,9 +12,9 @@
|
|||
* 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
|
||||
* 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
|
||||
|
|
@ -32,7 +32,7 @@
|
|||
*/
|
||||
|
||||
/** @ingroup packetapi
|
||||
* @{
|
||||
* @{
|
||||
*/
|
||||
|
||||
/** @defgroup packet32h Packet.dll definitions and data structures
|
||||
|
|
@ -43,317 +43,356 @@
|
|||
*/
|
||||
|
||||
#ifndef __PACKET32
|
||||
#define __PACKET32
|
||||
#define __PACKET32
|
||||
|
||||
#include <winsock2.h>
|
||||
#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_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 */
|
||||
#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
|
||||
/* 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))
|
||||
/*/ 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
|
||||
#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
|
||||
/* 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;
|
||||
* \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
|
||||
/*some definitions stolen from libpcap */
|
||||
|
||||
#ifndef BPF_MAJOR_VERSION
|
||||
#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 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 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 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 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).
|
||||
};
|
||||
* \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
|
||||
#endif /* ifndef BPF_MAJOR_VERSION */
|
||||
|
||||
struct bpf_stat;
|
||||
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
|
||||
#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;
|
||||
* \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.
|
||||
#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
|
||||
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
|
||||
#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.
|
||||
* \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. */
|
||||
|
||||
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.
|
||||
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_AIRPCAP_API
|
||||
PAirpcapHandle AirpcapAd;
|
||||
#endif // HAVE_AIRPCAP_API
|
||||
|
||||
#ifdef HAVE_NPFIM_API
|
||||
void* NpfImHandle;
|
||||
#endif // HAVE_NPFIM_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;
|
||||
#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 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.
|
||||
* \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-length field that contains the information passed to or received */
|
||||
/*/< from the adapter. */
|
||||
};
|
||||
typedef struct _PACKET_OID_DATA PACKET_OID_DATA, * PPACKET_OID_DATA;
|
||||
|
||||
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
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/**
|
||||
* @}
|
||||
*/
|
||||
|
||||
/*
|
||||
BOOLEAN QueryWinPcapRegistryStringA(CHAR *SubKeyName,
|
||||
CHAR *Value,
|
||||
UINT *pValueLen,
|
||||
CHAR *DefaultVal);
|
||||
* BOOLEAN QueryWinPcapRegistryStringA(CHAR *SubKeyName,
|
||||
* CHAR *Value,
|
||||
* UINT *pValueLen,
|
||||
* CHAR *DefaultVal);
|
||||
*
|
||||
* BOOLEAN QueryWinPcapRegistryStringW(WCHAR *SubKeyName,
|
||||
* WCHAR *Value,
|
||||
* UINT *pValueLen,
|
||||
* WCHAR *DefaultVal);
|
||||
*/
|
||||
|
||||
BOOLEAN QueryWinPcapRegistryStringW(WCHAR *SubKeyName,
|
||||
WCHAR *Value,
|
||||
UINT *pValueLen,
|
||||
WCHAR *DefaultVal);
|
||||
*/
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// EXPORTED FUNCTIONS
|
||||
//---------------------------------------------------------------------------
|
||||
/*--------------------------------------------------------------------------- */
|
||||
/* 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);
|
||||
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
|
||||
/* */
|
||||
/* Used by PacketStartOemEx */
|
||||
/* */
|
||||
#define PACKET_START_OEM_NO_NETMON 0x00000001
|
||||
|
||||
#ifdef __cplusplus
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#endif //__PACKET32
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue