mirror of
https://github.com/zerotier/ZeroTierOne.git
synced 2024-12-21 05:53:09 +00:00
More tap driver cleanup, and add IOCTL to get L2 multicast ethernet address subscriptions.
This commit is contained in:
parent
fbb40b98ad
commit
3375363d93
@ -4,7 +4,7 @@ Class=Net
|
|||||||
ClassGuid={4d36e972-e325-11ce-bfc1-08002be10318}
|
ClassGuid={4d36e972-e325-11ce-bfc1-08002be10318}
|
||||||
Provider=%Provider%
|
Provider=%Provider%
|
||||||
CatalogFile=ztTap100.cat
|
CatalogFile=ztTap100.cat
|
||||||
DriverVer=08/24/2013,16.12.30.608
|
DriverVer=01/20/2014,14.30.21.864
|
||||||
|
|
||||||
|
|
||||||
[Strings]
|
[Strings]
|
||||||
|
Binary file not shown.
BIN
ext/bin/tap-windows/x64/zttap100.cat
Normal file
BIN
ext/bin/tap-windows/x64/zttap100.cat
Normal file
Binary file not shown.
@ -4,7 +4,7 @@ Class=Net
|
|||||||
ClassGuid={4d36e972-e325-11ce-bfc1-08002be10318}
|
ClassGuid={4d36e972-e325-11ce-bfc1-08002be10318}
|
||||||
Provider=%Provider%
|
Provider=%Provider%
|
||||||
CatalogFile=ztTap100.cat
|
CatalogFile=ztTap100.cat
|
||||||
DriverVer=08/24/2013,16.12.37.14
|
DriverVer=01/20/2014,14.30.31.745
|
||||||
|
|
||||||
|
|
||||||
[Strings]
|
[Strings]
|
||||||
|
Binary file not shown.
BIN
ext/bin/tap-windows/x86/zttap100.cat
Normal file
BIN
ext/bin/tap-windows/x86/zttap100.cat
Normal file
Binary file not shown.
@ -124,7 +124,9 @@
|
|||||||
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
</ImportGroup>
|
</ImportGroup>
|
||||||
<PropertyGroup Label="UserMacros" />
|
<PropertyGroup Label="UserMacros" />
|
||||||
<PropertyGroup />
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Vista Debug|x64'">
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
|
</PropertyGroup>
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<DebuggerFlavor>DbgengKernelDebugger</DebuggerFlavor>
|
<DebuggerFlavor>DbgengKernelDebugger</DebuggerFlavor>
|
||||||
<EnableDeployment>False</EnableDeployment>
|
<EnableDeployment>False</EnableDeployment>
|
||||||
@ -139,6 +141,21 @@
|
|||||||
<VerifyFlags>133563</VerifyFlags>
|
<VerifyFlags>133563</VerifyFlags>
|
||||||
<PackageDir>$(OutDir)TapDriver Package</PackageDir>
|
<PackageDir>$(OutDir)TapDriver Package</PackageDir>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win8 Debug|x64'">
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Vista Release|x64'">
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|x64'">
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Release|x64'">
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win8 Release|x64'">
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
|
</PropertyGroup>
|
||||||
<ItemDefinitionGroup>
|
<ItemDefinitionGroup>
|
||||||
</ItemDefinitionGroup>
|
</ItemDefinitionGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
@ -147,8 +164,43 @@
|
|||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ProjectReference Include="..\TapDriver\TapDriver.vcxproj">
|
<ProjectReference Include="..\TapDriver\TapDriver.vcxproj">
|
||||||
<Project>{689210b1-467c-4850-bb7d-2e10d5b4a3da}</Project>
|
<Project>{689210b1-467c-4850-bb7d-2e10d5b4a3da}</Project>
|
||||||
|
<Private>true</Private>
|
||||||
|
<ReferenceOutputAssembly>true</ReferenceOutputAssembly>
|
||||||
|
<CopyLocalSatelliteAssemblies>false</CopyLocalSatelliteAssemblies>
|
||||||
|
<LinkLibraryDependencies>true</LinkLibraryDependencies>
|
||||||
|
<UseLibraryDependencyInputs>false</UseLibraryDependencyInputs>
|
||||||
</ProjectReference>
|
</ProjectReference>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<None Include="..\Build\Win32\VistaRelease\ztTap100.sys">
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Vista Debug|Win32'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win8 Debug|Win32'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Vista Release|Win32'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|Win32'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win7 Release|Win32'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win8 Release|Win32'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Vista Debug|x64'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win8 Debug|x64'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Vista Release|x64'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|x64'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win7 Release|x64'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win8 Release|x64'">true</ExcludedFromBuild>
|
||||||
|
</None>
|
||||||
|
<None Include="..\Build\x64\VistaRelease\ztTap100.sys">
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Vista Debug|Win32'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win8 Debug|Win32'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Vista Release|Win32'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|Win32'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win7 Release|Win32'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win8 Release|Win32'">true</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Vista Debug|x64'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win8 Debug|x64'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Vista Release|x64'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|x64'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win7 Release|x64'">false</ExcludedFromBuild>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Win8 Release|x64'">false</ExcludedFromBuild>
|
||||||
|
</None>
|
||||||
|
</ItemGroup>
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
<ImportGroup Label="ExtensionTargets">
|
<ImportGroup Label="ExtensionTargets">
|
||||||
</ImportGroup>
|
</ImportGroup>
|
||||||
|
@ -6,4 +6,12 @@
|
|||||||
<Extensions>inf;inv;inx;mof;mc;</Extensions>
|
<Extensions>inf;inv;inx;mof;mc;</Extensions>
|
||||||
</Filter>
|
</Filter>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<None Include="..\Build\x64\VistaRelease\ztTap100.sys">
|
||||||
|
<Filter>Driver Files</Filter>
|
||||||
|
</None>
|
||||||
|
<None Include="..\Build\Win32\VistaRelease\ztTap100.sys">
|
||||||
|
<Filter>Driver Files</Filter>
|
||||||
|
</None>
|
||||||
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
@ -127,6 +127,7 @@
|
|||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<DebuggerFlavor>DbgengKernelDebugger</DebuggerFlavor>
|
<DebuggerFlavor>DbgengKernelDebugger</DebuggerFlavor>
|
||||||
@ -135,50 +136,61 @@
|
|||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Vista Release|Win32'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Vista Release|Win32'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|Win32'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|Win32'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Release|Win32'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Release|Win32'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win8 Release|Win32'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win8 Release|Win32'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
<IntDir>$(Platform)\$(ConfigurationName)\</IntDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Vista Debug|x64'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Vista Debug|x64'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win8 Debug|x64'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win8 Debug|x64'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Vista Release|x64'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Vista Release|x64'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|x64'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Debug|x64'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Release|x64'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win7 Release|x64'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win8 Release|x64'">
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Win8 Release|x64'">
|
||||||
<TargetName>ztTap100</TargetName>
|
<TargetName>ztTap100</TargetName>
|
||||||
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
<OutDir>$(SolutionDir)\Build\$(Platform)\$(ConfigurationName)\</OutDir>
|
||||||
|
<TimeStampServer>http://timestamp.digicert.com/</TimeStampServer>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<ItemDefinitionGroup>
|
<ItemDefinitionGroup>
|
||||||
<ClCompile>
|
<ClCompile>
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
#define PRODUCT_TAP_WIN_MINOR 0
|
#define PRODUCT_TAP_WIN_MINOR 0
|
||||||
#define PRODUCT_TAP_WIN_PROVIDER "ZeroTier Networks"
|
#define PRODUCT_TAP_WIN_PROVIDER "ZeroTier Networks"
|
||||||
#define PRODUCT_TAP_WIN_DEVICE_DESCRIPTION PRODUCT_NAME
|
#define PRODUCT_TAP_WIN_DEVICE_DESCRIPTION PRODUCT_NAME
|
||||||
#define PRODUCT_TAP_WIN_RELDATE "08/01/2013"
|
#define PRODUCT_TAP_WIN_RELDATE "01/20/2014"
|
||||||
|
|
||||||
#define TAP_DRIVER_MAJOR_VERSION PRODUCT_TAP_WIN_MAJOR
|
#define TAP_DRIVER_MAJOR_VERSION PRODUCT_TAP_WIN_MAJOR
|
||||||
#define TAP_DRIVER_MINOR_VERSION PRODUCT_TAP_WIN_MINOR
|
#define TAP_DRIVER_MINOR_VERSION PRODUCT_TAP_WIN_MINOR
|
||||||
|
@ -40,7 +40,7 @@
|
|||||||
#define ETHERNET_PACKET_SIZE (ETHERNET_MTU + ETHERNET_HEADER_SIZE)
|
#define ETHERNET_PACKET_SIZE (ETHERNET_MTU + ETHERNET_HEADER_SIZE)
|
||||||
#define DEFAULT_PACKET_LOOKAHEAD (ETHERNET_PACKET_SIZE)
|
#define DEFAULT_PACKET_LOOKAHEAD (ETHERNET_PACKET_SIZE)
|
||||||
|
|
||||||
#define NIC_MAX_MCAST_LIST 32 // Max length of multicast address list
|
#define NIC_MAX_MCAST_LIST 128 // Max length of multicast address list
|
||||||
|
|
||||||
#define MINIMUM_MTU 576 // USE TCP Minimum MTU
|
#define MINIMUM_MTU 576 // USE TCP Minimum MTU
|
||||||
#define MAXIMUM_MTU 65536 // IP maximum MTU
|
#define MAXIMUM_MTU 65536 // IP maximum MTU
|
||||||
|
@ -28,12 +28,7 @@
|
|||||||
|
|
||||||
#pragma pack(1)
|
#pragma pack(1)
|
||||||
|
|
||||||
#define IP_HEADER_SIZE 20
|
|
||||||
#define IPV6_HEADER_SIZE 40
|
|
||||||
|
|
||||||
typedef unsigned char MACADDR [6];
|
typedef unsigned char MACADDR [6];
|
||||||
typedef unsigned long IPADDR;
|
|
||||||
typedef unsigned char IPV6ADDR [16];
|
|
||||||
|
|
||||||
//-----------------
|
//-----------------
|
||||||
// Ethernet address
|
// Ethernet address
|
||||||
@ -62,163 +57,4 @@ typedef struct
|
|||||||
USHORT proto; /* packet type ID field */
|
USHORT proto; /* packet type ID field */
|
||||||
} ETH_HEADER, *PETH_HEADER;
|
} ETH_HEADER, *PETH_HEADER;
|
||||||
|
|
||||||
//----------------
|
|
||||||
// ARP packet
|
|
||||||
//----------------
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
MACADDR m_MAC_Destination; // Reverse these two
|
|
||||||
MACADDR m_MAC_Source; // to answer ARP requests
|
|
||||||
USHORT m_Proto; // 0x0806
|
|
||||||
|
|
||||||
# define MAC_ADDR_TYPE 0x0001
|
|
||||||
USHORT m_MAC_AddressType; // 0x0001
|
|
||||||
|
|
||||||
USHORT m_PROTO_AddressType; // 0x0800
|
|
||||||
UCHAR m_MAC_AddressSize; // 0x06
|
|
||||||
UCHAR m_PROTO_AddressSize; // 0x04
|
|
||||||
|
|
||||||
# define ARP_REQUEST 0x0001
|
|
||||||
# define ARP_REPLY 0x0002
|
|
||||||
USHORT m_ARP_Operation; // 0x0001 for ARP request, 0x0002 for ARP reply
|
|
||||||
|
|
||||||
MACADDR m_ARP_MAC_Source;
|
|
||||||
IPADDR m_ARP_IP_Source;
|
|
||||||
MACADDR m_ARP_MAC_Destination;
|
|
||||||
IPADDR m_ARP_IP_Destination;
|
|
||||||
}
|
|
||||||
ARP_PACKET, *PARP_PACKET;
|
|
||||||
|
|
||||||
//----------
|
|
||||||
// IP Header
|
|
||||||
//----------
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
# define IPH_GET_VER(v) (((v) >> 4) & 0x0F)
|
|
||||||
# define IPH_GET_LEN(v) (((v) & 0x0F) << 2)
|
|
||||||
UCHAR version_len;
|
|
||||||
|
|
||||||
UCHAR tos;
|
|
||||||
USHORT tot_len;
|
|
||||||
USHORT id;
|
|
||||||
|
|
||||||
# define IP_OFFMASK 0x1fff
|
|
||||||
USHORT frag_off;
|
|
||||||
|
|
||||||
UCHAR ttl;
|
|
||||||
|
|
||||||
# define IPPROTO_UDP 17 /* UDP protocol */
|
|
||||||
# define IPPROTO_TCP 6 /* TCP protocol */
|
|
||||||
# define IPPROTO_ICMP 1 /* ICMP protocol */
|
|
||||||
# define IPPROTO_IGMP 2 /* IGMP protocol */
|
|
||||||
UCHAR protocol;
|
|
||||||
|
|
||||||
USHORT check;
|
|
||||||
ULONG saddr;
|
|
||||||
ULONG daddr;
|
|
||||||
/* The options start here. */
|
|
||||||
} IPHDR;
|
|
||||||
|
|
||||||
//-----------
|
|
||||||
// UDP header
|
|
||||||
//-----------
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
USHORT source;
|
|
||||||
USHORT dest;
|
|
||||||
USHORT len;
|
|
||||||
USHORT check;
|
|
||||||
} UDPHDR;
|
|
||||||
|
|
||||||
//--------------------------
|
|
||||||
// TCP header, per RFC 793.
|
|
||||||
//--------------------------
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
USHORT source; /* source port */
|
|
||||||
USHORT dest; /* destination port */
|
|
||||||
ULONG seq; /* sequence number */
|
|
||||||
ULONG ack_seq; /* acknowledgement number */
|
|
||||||
|
|
||||||
# define TCPH_GET_DOFF(d) (((d) & 0xF0) >> 2)
|
|
||||||
UCHAR doff_res;
|
|
||||||
|
|
||||||
# define TCPH_FIN_MASK (1<<0)
|
|
||||||
# define TCPH_SYN_MASK (1<<1)
|
|
||||||
# define TCPH_RST_MASK (1<<2)
|
|
||||||
# define TCPH_PSH_MASK (1<<3)
|
|
||||||
# define TCPH_ACK_MASK (1<<4)
|
|
||||||
# define TCPH_URG_MASK (1<<5)
|
|
||||||
# define TCPH_ECE_MASK (1<<6)
|
|
||||||
# define TCPH_CWR_MASK (1<<7)
|
|
||||||
UCHAR flags;
|
|
||||||
|
|
||||||
USHORT window;
|
|
||||||
USHORT check;
|
|
||||||
USHORT urg_ptr;
|
|
||||||
} TCPHDR;
|
|
||||||
|
|
||||||
#define TCPOPT_EOL 0
|
|
||||||
#define TCPOPT_NOP 1
|
|
||||||
#define TCPOPT_MAXSEG 2
|
|
||||||
#define TCPOLEN_MAXSEG 4
|
|
||||||
|
|
||||||
//------------
|
|
||||||
// IPv6 Header
|
|
||||||
//------------
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
UCHAR version_prio;
|
|
||||||
UCHAR flow_lbl[3];
|
|
||||||
USHORT payload_len;
|
|
||||||
# define IPPROTO_ICMPV6 0x3a /* ICMP protocol v6 */
|
|
||||||
UCHAR nexthdr;
|
|
||||||
UCHAR hop_limit;
|
|
||||||
IPV6ADDR saddr;
|
|
||||||
IPV6ADDR daddr;
|
|
||||||
} IPV6HDR;
|
|
||||||
|
|
||||||
//--------------------------------------------
|
|
||||||
// IPCMPv6 NS/NA Packets (RFC4443 and RFC4861)
|
|
||||||
//--------------------------------------------
|
|
||||||
|
|
||||||
// Neighbor Solictiation - RFC 4861, 4.3
|
|
||||||
// (this is just the ICMPv6 part of the packet)
|
|
||||||
typedef struct {
|
|
||||||
UCHAR type;
|
|
||||||
# define ICMPV6_TYPE_NS 135 // neighbour solicitation
|
|
||||||
UCHAR code;
|
|
||||||
# define ICMPV6_CODE_0 0 // no specific sub-code for NS/NA
|
|
||||||
USHORT checksum;
|
|
||||||
ULONG reserved;
|
|
||||||
IPV6ADDR target_addr;
|
|
||||||
} ICMPV6_NS;
|
|
||||||
|
|
||||||
// Neighbor Advertisement - RFC 4861, 4.4 + 4.6/4.6.1
|
|
||||||
// (this is just the ICMPv6 payload)
|
|
||||||
typedef struct {
|
|
||||||
UCHAR type;
|
|
||||||
# define ICMPV6_TYPE_NA 136 // neighbour advertisement
|
|
||||||
UCHAR code;
|
|
||||||
# define ICMPV6_CODE_0 0 // no specific sub-code for NS/NA
|
|
||||||
USHORT checksum;
|
|
||||||
UCHAR rso_bits; // Router(0), Solicited(2), Ovrrd(4)
|
|
||||||
UCHAR reserved[3];
|
|
||||||
IPV6ADDR target_addr;
|
|
||||||
// always include "Target Link-layer Address" option (RFC 4861 4.6.1)
|
|
||||||
UCHAR opt_type;
|
|
||||||
#define ICMPV6_OPTION_TLLA 2
|
|
||||||
UCHAR opt_length;
|
|
||||||
#define ICMPV6_LENGTH_TLLA 1 // multiplied by 8 -> 1 = 8 bytes
|
|
||||||
MACADDR target_macaddr;
|
|
||||||
} ICMPV6_NA;
|
|
||||||
|
|
||||||
// this is the complete packet with Ethernet and IPv6 headers
|
|
||||||
typedef struct {
|
|
||||||
ETH_HEADER eth;
|
|
||||||
IPV6HDR ipv6;
|
|
||||||
ICMPV6_NA icmpv6;
|
|
||||||
} ICMPV6_NA_PKT;
|
|
||||||
|
|
||||||
#pragma pack()
|
#pragma pack()
|
||||||
|
@ -146,58 +146,12 @@ VOID FlushQueues
|
|||||||
TapExtensionPointer p_Extension
|
TapExtensionPointer p_Extension
|
||||||
);
|
);
|
||||||
|
|
||||||
VOID ResetTapAdapterState
|
|
||||||
(
|
|
||||||
TapAdapterPointer p_Adapter
|
|
||||||
);
|
|
||||||
|
|
||||||
BOOLEAN ProcessARP
|
|
||||||
(
|
|
||||||
TapAdapterPointer p_Adapter,
|
|
||||||
const PARP_PACKET src,
|
|
||||||
const IPADDR adapter_ip,
|
|
||||||
const IPADDR ip_network,
|
|
||||||
const IPADDR ip_netmask,
|
|
||||||
const MACADDR mac
|
|
||||||
);
|
|
||||||
|
|
||||||
VOID SetMediaStatus
|
VOID SetMediaStatus
|
||||||
(
|
(
|
||||||
TapAdapterPointer p_Adapter,
|
TapAdapterPointer p_Adapter,
|
||||||
BOOLEAN state
|
BOOLEAN state
|
||||||
);
|
);
|
||||||
|
|
||||||
VOID InjectPacketDeferred
|
|
||||||
(
|
|
||||||
TapAdapterPointer p_Adapter,
|
|
||||||
UCHAR *packet,
|
|
||||||
const unsigned int len
|
|
||||||
);
|
|
||||||
|
|
||||||
VOID InjectPacketNow
|
|
||||||
(
|
|
||||||
TapAdapterPointer p_Adapter,
|
|
||||||
UCHAR *packet,
|
|
||||||
const unsigned int len
|
|
||||||
);
|
|
||||||
|
|
||||||
// for KDEFERRED_ROUTINE and Static Driver Verifier
|
|
||||||
//#include <wdm.h>
|
|
||||||
//KDEFERRED_ROUTINE InjectPacketDpc;
|
|
||||||
|
|
||||||
VOID InjectPacketDpc
|
|
||||||
(
|
|
||||||
KDPC *Dpc,
|
|
||||||
PVOID DeferredContext,
|
|
||||||
PVOID SystemArgument1,
|
|
||||||
PVOID SystemArgument2
|
|
||||||
);
|
|
||||||
|
|
||||||
VOID CheckIfDhcpAndTunMode
|
|
||||||
(
|
|
||||||
TapAdapterPointer p_Adapter
|
|
||||||
);
|
|
||||||
|
|
||||||
VOID HookDispatchFunctions();
|
VOID HookDispatchFunctions();
|
||||||
|
|
||||||
struct WIN2K_NDIS_MINIPORT_BLOCK
|
struct WIN2K_NDIS_MINIPORT_BLOCK
|
||||||
@ -206,17 +160,4 @@ struct WIN2K_NDIS_MINIPORT_BLOCK
|
|||||||
UNICODE_STRING MiniportName; // how mini-port refers to us
|
UNICODE_STRING MiniportName; // how mini-port refers to us
|
||||||
};
|
};
|
||||||
|
|
||||||
#if PACKET_TRUNCATION_CHECK
|
|
||||||
|
|
||||||
VOID IPv4PacketSizeVerify
|
|
||||||
(
|
|
||||||
const UCHAR *data,
|
|
||||||
ULONG length,
|
|
||||||
BOOLEAN tun,
|
|
||||||
const char *prefix,
|
|
||||||
LONG *counter
|
|
||||||
);
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -38,6 +38,13 @@
|
|||||||
#define TAP_WIN_IOCTL_GET_MTU TAP_WIN_CONTROL_CODE (3, METHOD_BUFFERED)
|
#define TAP_WIN_IOCTL_GET_MTU TAP_WIN_CONTROL_CODE (3, METHOD_BUFFERED)
|
||||||
#define TAP_WIN_IOCTL_SET_MEDIA_STATUS TAP_WIN_CONTROL_CODE (6, METHOD_BUFFERED)
|
#define TAP_WIN_IOCTL_SET_MEDIA_STATUS TAP_WIN_CONTROL_CODE (6, METHOD_BUFFERED)
|
||||||
#define TAP_WIN_IOCTL_GET_LOG_LINE TAP_WIN_CONTROL_CODE (8, METHOD_BUFFERED)
|
#define TAP_WIN_IOCTL_GET_LOG_LINE TAP_WIN_CONTROL_CODE (8, METHOD_BUFFERED)
|
||||||
|
#define TAP_WIN_IOCTL_GET_MULTICAST_MEMBERSHIPS TAP_WIN_CONTROL_CODE (11, METHOD_BUFFERED)
|
||||||
|
|
||||||
|
// Must be the same as NIC_MAX_MCAST_LIST in constants.h
|
||||||
|
#define TAP_MAX_MCAST_LIST 128
|
||||||
|
|
||||||
|
// Amount of memory that must be provided to ioctl TAP_WIN_IOCTL_GET_MULTICAST_MEMBERSHIPS
|
||||||
|
#define TAP_WIN_IOCTL_GET_MULTICAST_MEMBERSHIPS_OUTPUT_BUF_SIZE (TAP_MAX_MCAST_LIST * 6)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* =================
|
* =================
|
||||||
|
@ -1523,6 +1523,7 @@ NTSTATUS
|
|||||||
PIO_STACK_LOCATION l_IrpSp;
|
PIO_STACK_LOCATION l_IrpSp;
|
||||||
NTSTATUS l_Status = STATUS_SUCCESS;
|
NTSTATUS l_Status = STATUS_SUCCESS;
|
||||||
BOOLEAN accessible;
|
BOOLEAN accessible;
|
||||||
|
ULONG i,j;
|
||||||
|
|
||||||
l_IrpSp = IoGetCurrentIrpStackLocation (p_IRP);
|
l_IrpSp = IoGetCurrentIrpStackLocation (p_IRP);
|
||||||
|
|
||||||
@ -1633,6 +1634,39 @@ NTSTATUS
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Allow ZeroTier One to get multicast memberships at the L2 level in a
|
||||||
|
// protocol-neutral manner.
|
||||||
|
case TAP_WIN_IOCTL_GET_MULTICAST_MEMBERSHIPS:
|
||||||
|
{
|
||||||
|
if (&l_Adapter->m_MCLockAllocated)
|
||||||
|
NdisAcquireSpinLock (&l_Adapter->m_MCLock);
|
||||||
|
if (l_IrpSp->Parameters.DeviceIoControl.OutputBufferLength < TAP_WIN_IOCTL_GET_MULTICAST_MEMBERSHIPS_OUTPUT_BUF_SIZE) {
|
||||||
|
/* output buffer too small */
|
||||||
|
NOTE_ERROR ();
|
||||||
|
p_IRP->IoStatus.Status = l_Status = STATUS_INVALID_PARAMETER;
|
||||||
|
} else {
|
||||||
|
char *out = (char *)p_IRP->AssociatedIrp.SystemBuffer;
|
||||||
|
char *end = out + TAP_WIN_IOCTL_GET_MULTICAST_MEMBERSHIPS_OUTPUT_BUF_SIZE;
|
||||||
|
for(i=0;i<l_Adapter->m_MCListSize;++i) {
|
||||||
|
if (i >= TAP_MAX_MCAST_LIST)
|
||||||
|
break;
|
||||||
|
for(j=0;j<6;++j)
|
||||||
|
*(out++) = l_Adapter->m_MCList.list[i].addr[j];
|
||||||
|
if (out >= end)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
while (out < end)
|
||||||
|
*(out++) = (char)0;
|
||||||
|
p_IRP->IoStatus.Information
|
||||||
|
= l_IrpSp->Parameters.DeviceIoControl.OutputBufferLength;
|
||||||
|
p_IRP->IoStatus.Status = l_Status = STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
if (&l_Adapter->m_MCLockAllocated)
|
||||||
|
NdisReleaseSpinLock (&l_Adapter->m_MCLock);
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case TAP_WIN_IOCTL_SET_MEDIA_STATUS:
|
case TAP_WIN_IOCTL_SET_MEDIA_STATUS:
|
||||||
{
|
{
|
||||||
if (l_IrpSp->Parameters.DeviceIoControl.InputBufferLength >=
|
if (l_IrpSp->Parameters.DeviceIoControl.InputBufferLength >=
|
||||||
|
@ -82,14 +82,6 @@ typedef struct _TapExtension
|
|||||||
// Flags
|
// Flags
|
||||||
BOOLEAN m_TapIsRunning;
|
BOOLEAN m_TapIsRunning;
|
||||||
BOOLEAN m_CalledTapDeviceFreeResources;
|
BOOLEAN m_CalledTapDeviceFreeResources;
|
||||||
|
|
||||||
#if 0
|
|
||||||
// DPC queue for deferred packet injection
|
|
||||||
BOOLEAN m_InjectDpcInitialized;
|
|
||||||
KDPC m_InjectDpc;
|
|
||||||
NDIS_SPIN_LOCK m_InjectLock;
|
|
||||||
Queue *m_InjectQueue;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
TapExtension, *TapExtensionPointer;
|
TapExtension, *TapExtensionPointer;
|
||||||
|
|
||||||
@ -103,17 +95,6 @@ typedef struct _TapPacket
|
|||||||
}
|
}
|
||||||
TapPacket, *TapPacketPointer;
|
TapPacket, *TapPacketPointer;
|
||||||
|
|
||||||
#if 0
|
|
||||||
typedef struct _InjectPacket
|
|
||||||
{
|
|
||||||
# define INJECT_PACKET_SIZE(data_size) (sizeof (InjectPacket) + (data_size))
|
|
||||||
# define INJECT_PACKET_FREE(ib) NdisFreeMemory ((ib), INJECT_PACKET_SIZE ((ib)->m_Size), 0)
|
|
||||||
ULONG m_Size;
|
|
||||||
UCHAR m_Data []; // m_Data must be the last struct member
|
|
||||||
}
|
|
||||||
InjectPacket, *InjectPacketPointer;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct _TapAdapter
|
typedef struct _TapAdapter
|
||||||
{
|
{
|
||||||
# define NAME(a) ((a)->m_NameAnsi.Buffer)
|
# define NAME(a) ((a)->m_NameAnsi.Buffer)
|
||||||
@ -122,9 +103,6 @@ typedef struct _TapAdapter
|
|||||||
BOOLEAN m_InterfaceIsRunning;
|
BOOLEAN m_InterfaceIsRunning;
|
||||||
NDIS_HANDLE m_MiniportAdapterHandle;
|
NDIS_HANDLE m_MiniportAdapterHandle;
|
||||||
LONG m_Rx, m_Tx, m_RxErr, m_TxErr;
|
LONG m_Rx, m_Tx, m_RxErr, m_TxErr;
|
||||||
#if PACKET_TRUNCATION_CHECK
|
|
||||||
LONG m_RxTrunc, m_TxTrunc;
|
|
||||||
#endif
|
|
||||||
NDIS_MEDIUM m_Medium;
|
NDIS_MEDIUM m_Medium;
|
||||||
ULONG m_Lookahead;
|
ULONG m_Lookahead;
|
||||||
ULONG m_MTU;
|
ULONG m_MTU;
|
||||||
|
Loading…
Reference in New Issue
Block a user