#pragma once #ifdef __cplusplus extern "C" { #endif #ifndef ASSERT #define MSTCPIP_ASSERT_UNDEFINED #define ASSERT(exp) ((VOID) 0) #endif #ifdef _MSC_VER #define MSTCPIP_INLINE __inline #else #define MSTCPIP_INLINE static inline #endif #include struct tcp_keepalive { ULONG onoff; ULONG keepalivetime; ULONG keepaliveinterval; }; #define SIO_RCVALL _WSAIOW(IOC_VENDOR,1) #define SIO_RCVALL_MCAST _WSAIOW(IOC_VENDOR,2) #define SIO_RCVALL_IGMPMCAST _WSAIOW(IOC_VENDOR,3) #define SIO_KEEPALIVE_VALS _WSAIOW(IOC_VENDOR,4) #define SIO_ABSORB_RTRALERT _WSAIOW(IOC_VENDOR,5) #define SIO_UCAST_IF _WSAIOW(IOC_VENDOR,6) #define SIO_LIMIT_BROADCASTS _WSAIOW(IOC_VENDOR,7) #define SIO_INDEX_BIND _WSAIOW(IOC_VENDOR,8) #define SIO_INDEX_MCASTIF _WSAIOW(IOC_VENDOR,9) #define SIO_INDEX_ADD_MCAST _WSAIOW(IOC_VENDOR,10) #define SIO_INDEX_DEL_MCAST _WSAIOW(IOC_VENDOR,11) #define SIO_RCVALL_MCAST_IF _WSAIOW(IOC_VENDOR,13) #define SIO_RCVALL_IF _WSAIOW(IOC_VENDOR,14) typedef enum { RCVALL_OFF = 0, RCVALL_ON = 1, RCVALL_SOCKETLEVELONLY = 2, RCVALL_IPLEVEL = 3, } RCVALL_VALUE, *PRCVALL_VALUE; #define RCVALL_MAX RCVALL_IPLEVEL typedef struct { RCVALL_VALUE Mode; ULONG Interface; } RCVALL_IF, *PRCVALL_IF; #if (NTDDI_VERSION >= NTDDI_WIN7) DEFINE_GUID(SOCKET_DEFAULT2_QM_POLICY, 0xaec2ef9c, 0x3a4d, 0x4d3e, 0x88, 0x42, 0x23, 0x99, 0x42, 0xe3, 0x9a, 0x47); #endif #define SIO_ACQUIRE_PORT_RESERVATION _WSAIOW(IOC_VENDOR, 100) #define SIO_RELEASE_PORT_RESERVATION _WSAIOW(IOC_VENDOR, 101) #define SIO_ASSOCIATE_PORT_RESERVATION _WSAIOW(IOC_VENDOR, 102) typedef struct _INET_PORT_RANGE { USHORT StartPort; USHORT NumberOfPorts; } INET_PORT_RANGE, *PINET_PORT_RANGE; typedef struct _INET_PORT_RANGE INET_PORT_RESERVATION, *PINET_PORT_RESERVATION; typedef struct { ULONG64 Token; } INET_PORT_RESERVATION_TOKEN, *PINET_PORT_RESERVATION_TOKEN; #define INVALID_PORT_RESERVATION_TOKEN ((ULONG64)0) typedef struct { #ifdef __cplusplus INET_PORT_RESERVATION Reservation; INET_PORT_RESERVATION_TOKEN Token; #else INET_PORT_RESERVATION; INET_PORT_RESERVATION_TOKEN; #endif } INET_PORT_RESERVATION_INSTANCE, *PINET_PORT_RESERVATION_INSTANCE; typedef struct { ULONG AssignmentCount; ULONG OwningPid; } INET_PORT_RESERVATION_INFORMATION, *PINET_PORT_RESERVATION_INFORMATION; #ifdef _WS2DEF_ #if (NTDDI_VERSION >= NTDDI_VISTA) #define _SECURE_SOCKET_TYPES_DEFINED_ #define SIO_SET_SECURITY _WSAIOW(IOC_VENDOR, 200) #define SIO_QUERY_SECURITY _WSAIORW(IOC_VENDOR, 201) #define SIO_SET_PEER_TARGET_NAME _WSAIOW(IOC_VENDOR, 202) #define SIO_DELETE_PEER_TARGET_NAME _WSAIOW(IOC_VENDOR, 203) #define SIO_SOCKET_USAGE_NOTIFICATION _WSAIOW(IOC_VENDOR, 204) typedef enum _SOCKET_USAGE_TYPE { SYSTEM_CRITICAL_SOCKET = 1 }SOCKET_USAGE_TYPE; typedef enum _SOCKET_SECURITY_PROTOCOL { SOCKET_SECURITY_PROTOCOL_DEFAULT, SOCKET_SECURITY_PROTOCOL_IPSEC, #if (NTDDI_VERSION >= NTDDI_WIN7) SOCKET_SECURITY_PROTOCOL_IPSEC2, #endif SOCKET_SECURITY_PROTOCOL_INVALID } SOCKET_SECURITY_PROTOCOL; #define SOCKET_SETTINGS_GUARANTEE_ENCRYPTION 0x1 #define SOCKET_SETTINGS_ALLOW_INSECURE 0x2 typedef struct _SOCKET_SECURITY_SETTINGS { SOCKET_SECURITY_PROTOCOL SecurityProtocol; ULONG SecurityFlags; } SOCKET_SECURITY_SETTINGS; #define SOCKET_SETTINGS_IPSEC_SKIP_FILTER_INSTANTIATION 0x1 #if (NTDDI_VERSION >= NTDDI_WIN7) #define SOCKET_SETTINGS_IPSEC_OPTIONAL_PEER_NAME_VERIFICATION 0x2 #define SOCKET_SETTINGS_IPSEC_ALLOW_FIRST_INBOUND_PKT_UNENCRYPTED 0x4 #define SOCKET_SETTINGS_IPSEC_PEER_NAME_IS_RAW_FORMAT 0x8 #endif /* (NTDDI_VERSION >= NTDDI_WIN7) */ typedef struct _SOCKET_SECURITY_SETTINGS_IPSEC { SOCKET_SECURITY_PROTOCOL SecurityProtocol; ULONG SecurityFlags; ULONG IpsecFlags; GUID AuthipMMPolicyKey; GUID AuthipQMPolicyKey; GUID Reserved; UINT64 Reserved2; ULONG UserNameStringLen; ULONG DomainNameStringLen; ULONG PasswordStringLen; wchar_t AllStrings[0]; } SOCKET_SECURITY_SETTINGS_IPSEC; typedef struct _SOCKET_PEER_TARGET_NAME { SOCKET_SECURITY_PROTOCOL SecurityProtocol; SOCKADDR_STORAGE PeerAddress; ULONG PeerTargetNameStringLen; wchar_t AllStrings[0]; } SOCKET_PEER_TARGET_NAME; typedef struct _SOCKET_SECURITY_QUERY_TEMPLATE { SOCKET_SECURITY_PROTOCOL SecurityProtocol; SOCKADDR_STORAGE PeerAddress; ULONG PeerTokenAccessMask; } SOCKET_SECURITY_QUERY_TEMPLATE; #if (NTDDI_VERSION >= NTDDI_WIN7) #define SOCKET_QUERY_IPSEC2_ABORT_CONNECTION_ON_FIELD_CHANGE 0x1 #define SOCKET_QUERY_IPSEC2_FIELD_MASK_MM_SA_ID 0x1 #define SOCKET_QUERY_IPSEC2_FIELD_MASK_QM_SA_ID 0x2 typedef struct _SOCKET_SECURITY_QUERY_TEMPLATE_IPSEC2 { SOCKET_SECURITY_PROTOCOL SecurityProtocol; SOCKADDR_STORAGE PeerAddress; ULONG PeerTokenAccessMask; ULONG Flags; ULONG FieldMask; } SOCKET_SECURITY_QUERY_TEMPLATE_IPSEC2; #endif /* (NTDDI_VERSION >= NTDDI_WIN7) */ #define SOCKET_INFO_CONNECTION_SECURED 0x1 #define SOCKET_INFO_CONNECTION_ENCRYPTED 0x2 #define SOCKET_INFO_CONNECTION_IMPERSONATED 0x4 typedef struct _SOCKET_SECURITY_QUERY_INFO { SOCKET_SECURITY_PROTOCOL SecurityProtocol; ULONG Flags; UINT64 PeerApplicationAccessTokenHandle; UINT64 PeerMachineAccessTokenHandle; } SOCKET_SECURITY_QUERY_INFO; #if (NTDDI_VERSION >= NTDDI_WIN7) typedef struct _SOCKET_SECURITY_QUERY_INFO_IPSEC2 { SOCKET_SECURITY_PROTOCOL SecurityProtocol; ULONG Flags; UINT64 PeerApplicationAccessTokenHandle; UINT64 PeerMachineAccessTokenHandle; UINT64 MmSaId; UINT64 QmSaId; UINT32 NegotiationWinerr; GUID SaLookupContext; } SOCKET_SECURITY_QUERY_INFO_IPSEC2; #endif #define SIO_QUERY_WFP_ALE_ENDPOINT_HANDLE _WSAIOR(IOC_VENDOR, 205) #define SIO_QUERY_RSS_SCALABILITY_INFO _WSAIOR(IOC_VENDOR, 210) typedef struct _RSS_SCALABILITY_INFO { BOOLEAN RssEnabled; } RSS_SCALABILITY_INFO, *PRSS_SCALABILITY_INFO; #endif /* (NTDDI_VERSION >= NTDDI_VISTA) */ #define IN4_CLASSA(i) (((LONG)(i) & 0x00000080) == 0) #define IN4_CLASSB(i) (((LONG)(i) & 0x000000c0) == 0x00000080) #define IN4_CLASSC(i) (((LONG)(i) & 0x000000e0) == 0x000000c0) #define IN4_CLASSD(i) (((LONG)(i) & 0x000000f0) == 0x000000e0) #define IN4_MULTICAST(i) IN4_CLASSD(i) #define IN4ADDR_ANY INADDR_ANY #define IN4ADDR_LOOPBACK 0x0100007f #define IN4ADDR_BROADCAST INADDR_BROADCAST #define IN4ADDR_NONE INADDR_NONE #define IN4ADDR_ANY_INIT { 0 } #define IN4ADDR_LOOPBACK_INIT { 0x7f, 0, 0, 1 } #define IN4ADDR_BROADCAST_INIT { 0xff, 0xff, 0xff, 0xff } #define IN4ADDR_ALLNODESONLINK_INIT { 0xe0, 0, 0, 1 } #define IN4ADDR_ALLROUTERSONLINK_INIT { 0xe0, 0, 0, 2 } #define IN4ADDR_ALLIGMPV3ROUTERSONLINK_INIT { 0xe0, 0, 0, 0x16 } #define IN4ADDR_ALLTEREDONODESONLINK_INIT { 0xe0, 0, 0, 0xfd } #define IN4ADDR_LINKLOCALPREFIX_INIT { 0xa9, 0xfe, } #define IN4ADDR_MULTICASTPREFIX_INIT { 0xe0, } #define IN4ADDR_LOOPBACKPREFIX_LENGTH 8 #define IN4ADDR_LINKLOCALPREFIX_LENGTH 16 #define IN4ADDR_MULTICASTPREFIX_LENGTH 4 #if (NTDDI_VERSION >= NTDDI_WIN2KSP1) MSTCPIP_INLINE BOOLEAN IN4_ADDR_EQUAL( _In_ CONST IN_ADDR *a, _In_ CONST IN_ADDR *b) { return (BOOLEAN)(a->s_addr == b->s_addr); } MSTCPIP_INLINE BOOLEAN IN4_UNALIGNED_ADDR_EQUAL( _In_ CONST IN_ADDR UNALIGNED *a, _In_ CONST IN_ADDR UNALIGNED *b) { return (BOOLEAN)(a->s_addr == b->s_addr); } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_UNSPECIFIED( _In_ CONST IN_ADDR *a) { return (BOOLEAN)(a->s_addr == IN4ADDR_ANY); } MSTCPIP_INLINE BOOLEAN IN4_IS_UNALIGNED_ADDR_UNSPECIFIED( _In_ CONST IN_ADDR UNALIGNED *a) { return (BOOLEAN)(a->s_addr == IN4ADDR_ANY); } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_LOOPBACK( _In_ CONST IN_ADDR *a) { return (BOOLEAN)(*((PUCHAR) a) == 0x7f); } MSTCPIP_INLINE BOOLEAN IN4_IS_UNALIGNED_ADDR_LOOPBACK( _In_ CONST IN_ADDR UNALIGNED *a) { return (BOOLEAN)(*((PUCHAR) a) == 0x7f); } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_BROADCAST( _In_ CONST IN_ADDR *a) { return (BOOLEAN)(a->s_addr == IN4ADDR_BROADCAST); } MSTCPIP_INLINE BOOLEAN IN4_IS_UNALIGNED_ADDR_BROADCAST( _In_ CONST IN_ADDR UNALIGNED *a) { return (BOOLEAN)(a->s_addr == IN4ADDR_BROADCAST); } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_MULTICAST( _In_ CONST IN_ADDR *a) { return (BOOLEAN)IN4_MULTICAST(a->s_addr); } MSTCPIP_INLINE BOOLEAN IN4_IS_UNALIGNED_ADDR_MULTICAST( _In_ CONST IN_ADDR UNALIGNED *a) { return (BOOLEAN)IN4_MULTICAST(a->s_addr); } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_LINKLOCAL( _In_ CONST IN_ADDR *a) { return (BOOLEAN)((a->s_addr & 0xffff) == 0xfea9); } MSTCPIP_INLINE BOOLEAN IN4_IS_UNALIGNED_ADDR_LINKLOCAL( _In_ CONST IN_ADDR UNALIGNED *a) { return (BOOLEAN)((a->s_addr & 0xffff) == 0xfea9); // 169.254/16 } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_SITELOCAL( _In_ CONST IN_ADDR *a) { UNREFERENCED_PARAMETER(a); return FALSE; } #define IN4_IS_UNALIGNED_ADDR_SITELOCAL IN4_IS_ADDR_SITELOCAL MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_RFC1918( _In_ CONST IN_ADDR *a) { return (BOOLEAN)(((a->s_addr & 0x00ff) == 0x0a) || ((a->s_addr & 0xf0ff) == 0x10ac) || ((a->s_addr & 0xffff) == 0xa8c0)); } MSTCPIP_INLINE BOOLEAN IN4_IS_UNALIGNED_ADDR_RFC1918( _In_ CONST IN_ADDR UNALIGNED *a) { IN_ADDR Ipv4Address = *a; return IN4_IS_ADDR_RFC1918(&Ipv4Address); } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_MC_LINKLOCAL( _In_ CONST IN_ADDR *a) { return (BOOLEAN)((a->s_addr & 0xffffff) == 0xe0); } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_MC_ADMINLOCAL( _In_ CONST IN_ADDR *a) { return (BOOLEAN)((a->s_addr & 0xffff) == 0xffef); } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_MC_SITELOCAL( _In_ CONST IN_ADDR *a) { return (BOOLEAN)((a->s_addr & 0xff) == 0xef) && !IN4_IS_ADDR_MC_ADMINLOCAL(a); } MSTCPIP_INLINE VOID IN4ADDR_SETSOCKADDR( _Out_ PSOCKADDR_IN a, _In_ CONST IN_ADDR *addr, _In_ USHORT port) { a->sin_family = AF_INET; a->sin_port = port; a->sin_addr = *addr; memset(a->sin_zero, 0, sizeof(a->sin_zero)); } MSTCPIP_INLINE VOID IN4ADDR_SETANY( _Out_ PSOCKADDR_IN a) { a->sin_family = AF_INET; a->sin_port = 0; a->sin_addr.s_addr = IN4ADDR_ANY; memset(a->sin_zero, 0, sizeof(a->sin_zero)); } MSTCPIP_INLINE VOID IN4ADDR_SETLOOPBACK( _Out_ PSOCKADDR_IN a) { a->sin_family = AF_INET; a->sin_port = 0; a->sin_addr.s_addr = IN4ADDR_LOOPBACK; memset(a->sin_zero, 0, sizeof(a->sin_zero)); } MSTCPIP_INLINE BOOLEAN IN4ADDR_ISANY( _In_ CONST SOCKADDR_IN *a) { ASSERT(a->sin_family == AF_INET); return IN4_IS_ADDR_UNSPECIFIED(&a->sin_addr); } MSTCPIP_INLINE BOOLEAN IN4ADDR_ISLOOPBACK( _In_ CONST SOCKADDR_IN *a) { ASSERT(a->sin_family == AF_INET); return IN4_IS_ADDR_LOOPBACK(&a->sin_addr); } MSTCPIP_INLINE SCOPE_ID IN4ADDR_SCOPE_ID( _In_ CONST SOCKADDR_IN *a) { SCOPE_ID UnspecifiedScopeId = {{{0}}}; UNREFERENCED_PARAMETER(a); return UnspecifiedScopeId; } MSTCPIP_INLINE BOOLEAN IN4ADDR_ISEQUAL( _In_ CONST SOCKADDR_IN *a, _In_ CONST SOCKADDR_IN *b) { ASSERT(a->sin_family == AF_INET); return (BOOLEAN)(IN4ADDR_SCOPE_ID(a).Value == IN4ADDR_SCOPE_ID(b).Value && IN4_ADDR_EQUAL(&a->sin_addr, &b->sin_addr)); } MSTCPIP_INLINE BOOLEAN IN4ADDR_ISUNSPECIFIED( _In_ CONST SOCKADDR_IN *a) { ASSERT(a->sin_family == AF_INET); return (BOOLEAN)(IN4ADDR_SCOPE_ID(a).Value == 0 && IN4_IS_ADDR_UNSPECIFIED(&a->sin_addr)); } #define INET_IS_ALIGNED(Pointer, Type) \ (((ULONG_PTR)Pointer & (TYPE_ALIGNMENT(Type)-1)) == 0) MSTCPIP_INLINE SCOPE_LEVEL Ipv4UnicastAddressScope( _In_ CONST UCHAR *Address) { IN_ADDR Ipv4Address; if (!INET_IS_ALIGNED(Address, IN_ADDR)) { Ipv4Address = *(CONST IN_ADDR UNALIGNED *)Address; Address = (CONST UCHAR *) &Ipv4Address; } if (IN4_IS_ADDR_LINKLOCAL((PIN_ADDR) Address) || IN4_IS_ADDR_LOOPBACK((PIN_ADDR) Address)) { return ScopeLevelLink; } return ScopeLevelGlobal; } MSTCPIP_INLINE SCOPE_LEVEL Ipv4MulticastAddressScope( _In_ CONST UCHAR *Address) { IN_ADDR Ipv4Address; if (!INET_IS_ALIGNED(Address, IN_ADDR)) { Ipv4Address = *(CONST IN_ADDR UNALIGNED *)Address; Address = (CONST UCHAR *) &Ipv4Address; } if (IN4_IS_ADDR_MC_LINKLOCAL((PIN_ADDR) Address)) { return ScopeLevelLink; } else if (IN4_IS_ADDR_MC_ADMINLOCAL((PIN_ADDR) Address)) { return ScopeLevelAdmin; } else if (IN4_IS_ADDR_MC_SITELOCAL((PIN_ADDR) Address)) { return ScopeLevelSite; } else { return ScopeLevelGlobal; } } MSTCPIP_INLINE SCOPE_LEVEL Ipv4AddressScope( _In_ CONST UCHAR *Address) { CONST IN_ADDR Ipv4Address = *(CONST IN_ADDR UNALIGNED *)Address; if (IN4_IS_ADDR_BROADCAST(&Ipv4Address)) { return ScopeLevelLink; } else if (IN4_IS_ADDR_MULTICAST(&Ipv4Address)) { return Ipv4MulticastAddressScope((UCHAR *) &Ipv4Address); } else { return Ipv4UnicastAddressScope((UCHAR *) &Ipv4Address); } } MSTCPIP_INLINE NL_ADDRESS_TYPE Ipv4AddressType( _In_ CONST UCHAR *Address) { IN_ADDR Ipv4Address = *(CONST IN_ADDR UNALIGNED *) Address; if (IN4_IS_ADDR_MULTICAST(&Ipv4Address)) { return NlatMulticast; } if (IN4_IS_ADDR_BROADCAST(&Ipv4Address)) { return NlatBroadcast; } if (IN4_IS_ADDR_UNSPECIFIED(&Ipv4Address)) { return NlatUnspecified; } if (((Ipv4Address.s_addr & 0x000000ff) == 0) || ((Ipv4Address.s_addr & 0x000000f0) == 240)) { return NlatInvalid; } return NlatUnicast; } MSTCPIP_INLINE VOID IN4_UNCANONICALIZE_SCOPE_ID( _In_ CONST IN_ADDR *Address, _Inout_ SCOPE_ID *ScopeId) { SCOPE_LEVEL ScopeLevel = Ipv4AddressScope((CONST UCHAR *)Address); if ((IN4_IS_ADDR_LOOPBACK(Address)) || (ScopeLevel == ScopeLevelGlobal)) { ScopeId->Value = 0; } if ((SCOPE_LEVEL)ScopeId->Level == ScopeLevel) { ScopeId->Level = 0; } } MSTCPIP_INLINE BOOLEAN IN4_IS_ADDR_6TO4ELIGIBLE( _In_ CONST IN_ADDR *a) { return (BOOLEAN)((Ipv4AddressType((CONST UCHAR *) a) == NlatUnicast) && !(IN4_IS_ADDR_LOOPBACK(a) || IN4_IS_ADDR_LINKLOCAL(a) || IN4_IS_ADDR_SITELOCAL(a) || IN4_IS_ADDR_RFC1918(a))); } MSTCPIP_INLINE BOOLEAN IN4_IS_UNALIGNED_ADDR_6TO4ELIGIBLE( _In_ CONST IN_ADDR UNALIGNED *a) { IN_ADDR Ipv4Address = *a; return IN4_IS_ADDR_6TO4ELIGIBLE(&Ipv4Address); } #endif /* (NTDDI_VERSION >= NTDDI_WIN2KSP1) */ #endif /* _WS2DEF_ */ #ifdef _WS2IPDEF_ MSTCPIP_INLINE BOOLEAN IN6_PREFIX_EQUAL( _In_ CONST IN6_ADDR *a, _In_ CONST IN6_ADDR *b, _In_ UINT8 len) { UINT8 Bytes = len / 8; UINT8 Bits = len % 8; UINT8 Mask = 0xff << (8 - Bits); ASSERT(len <= (sizeof(IN6_ADDR) * 8)); return (BOOLEAN) (((memcmp(a, b, Bytes)) == 0) && ((Bits == 0) || ((a->s6_bytes[Bytes] | Mask) == (b->s6_bytes[Bytes] | Mask)))); } MSTCPIP_INLINE BOOLEAN IN6_IS_ADDR_ALLNODESONNODE( _In_ CONST IN6_ADDR *a) { return IN6_ADDR_EQUAL(a, &in6addr_allnodesonnode); } MSTCPIP_INLINE BOOLEAN IN6_IS_ADDR_ALLNODESONLINK( _In_ CONST IN6_ADDR *a) { return IN6_ADDR_EQUAL(a, &in6addr_allnodesonlink); } MSTCPIP_INLINE BOOLEAN IN6_IS_ADDR_ALLROUTERSONLINK( _In_ CONST IN6_ADDR *a) { return IN6_ADDR_EQUAL(a, &in6addr_allroutersonlink); } MSTCPIP_INLINE BOOLEAN IN6_IS_ADDR_SOLICITEDNODE( _In_ CONST IN6_ADDR *a) { return IN6_PREFIX_EQUAL(a, &in6addr_solicitednodemulticastprefix, IN6ADDR_SOLICITEDNODEMULTICASTPREFIX_LENGTH); } MSTCPIP_INLINE BOOLEAN IN6_IS_ADDR_ISATAP( _In_ CONST IN6_ADDR *a) { return (BOOLEAN)(((a->s6_words[4] & 0xfffd) == 0x0000) && (a->s6_words[5] == 0xfe5e)); } MSTCPIP_INLINE BOOLEAN IN6_IS_ADDR_6TO4( _In_ CONST IN6_ADDR *a) { C_ASSERT(IN6ADDR_6TO4PREFIX_LENGTH == RTL_BITS_OF(USHORT)); return (BOOLEAN)(a->s6_words[0] == in6addr_6to4prefix.s6_words[0]); } MSTCPIP_INLINE BOOLEAN IN6_IS_ADDR_TEREDO( _In_ CONST IN6_ADDR *a) { C_ASSERT(IN6ADDR_TEREDOPREFIX_LENGTH == 2 * RTL_BITS_OF(USHORT)); return (BOOLEAN) (((a->s6_words[0] == in6addr_teredoprefix.s6_words[0]) && (a->s6_words[1] == in6addr_teredoprefix.s6_words[1])) || ((a->s6_words[0] == in6addr_teredoprefix_old.s6_words[0]) && (a->s6_words[1] == in6addr_teredoprefix_old.s6_words[1]))); } MSTCPIP_INLINE BOOLEAN IN6ADDR_ISV4MAPPED( _In_ CONST SOCKADDR_IN6 *a) { ASSERT(a->sin6_family == AF_INET6); return IN6_IS_ADDR_V4MAPPED(&a->sin6_addr); } MSTCPIP_INLINE BOOLEAN IN6ADDR_ISISATAP( _In_ CONST SOCKADDR_IN6 *a) { ASSERT(a->sin6_family == AF_INET6); return IN6_IS_ADDR_ISATAP(&a->sin6_addr); } MSTCPIP_INLINE BOOLEAN IN6ADDR_IS6TO4( _In_ CONST SOCKADDR_IN6 *a) { ASSERT(a->sin6_family == AF_INET6); return IN6_IS_ADDR_6TO4(&a->sin6_addr); } MSTCPIP_INLINE BOOLEAN IN6ADDR_ISTEREDO( _In_ CONST SOCKADDR_IN6 *a) { ASSERT(a->sin6_family == AF_INET6); return IN6_IS_ADDR_TEREDO(&a->sin6_addr); } MSTCPIP_INLINE CONST UCHAR* IN6_GET_ADDR_V4MAPPED( _In_ CONST IN6_ADDR *Ipv6Address) { return (CONST UCHAR *) (Ipv6Address->s6_words + 6); } MSTCPIP_INLINE CONST UCHAR* IN6_GET_ADDR_V4COMPAT( _In_ CONST IN6_ADDR *Ipv6Address) { return (CONST UCHAR *) (Ipv6Address->s6_words + 6); } MSTCPIP_INLINE CONST UCHAR* IN6_EXTRACT_V4ADDR_FROM_ISATAP( _In_ CONST IN6_ADDR *Ipv6Address) { return (CONST UCHAR *) (Ipv6Address->s6_words + 6); } MSTCPIP_INLINE CONST UCHAR* IN6_EXTRACT_V4ADDR_FROM_6TO4( _In_ CONST IN6_ADDR *Ipv6Address) { return (CONST UCHAR *) (Ipv6Address->s6_words + 1); } MSTCPIP_INLINE VOID IN6_SET_ADDR_V4MAPPED( _Out_ PIN6_ADDR a6, _In_ CONST IN_ADDR* a4) { *a6 = in6addr_v4mappedprefix; a6->s6_bytes[12] = ((CONST UCHAR *) a4)[0]; a6->s6_bytes[13] = ((CONST UCHAR *) a4)[1]; a6->s6_bytes[14] = ((CONST UCHAR *) a4)[2]; a6->s6_bytes[15] = ((CONST UCHAR *) a4)[3]; } MSTCPIP_INLINE VOID IN6_SET_ADDR_V4COMPAT( _Out_ PIN6_ADDR a6, _In_ CONST IN_ADDR* a4) { *a6 = in6addr_any; a6->s6_bytes[12] = ((CONST UCHAR *) a4)[0]; a6->s6_bytes[13] = ((CONST UCHAR *) a4)[1]; a6->s6_bytes[14] = ((CONST UCHAR *) a4)[2]; a6->s6_bytes[15] = ((CONST UCHAR *) a4)[3]; } MSTCPIP_INLINE VOID IN6_SET_ADDR_SOLICITEDNODE( _Out_ PIN6_ADDR Multicast, _In_ CONST IN6_ADDR *Unicast) { *Multicast = in6addr_solicitednodemulticastprefix; Multicast->s6_bytes[13] = Unicast->s6_bytes[13]; Multicast->s6_bytes[14] = Unicast->s6_bytes[14]; Multicast->s6_bytes[15] = Unicast->s6_bytes[15]; } MSTCPIP_INLINE VOID IN6_SET_ISATAP_IDENTIFIER( _Inout_ IN6_ADDR *Ipv6Address, _In_ CONST IN_ADDR *Ipv4Address) { if (IN4_IS_ADDR_6TO4ELIGIBLE(Ipv4Address)) { Ipv6Address->s6_words[4] = 0x0002; } else { Ipv6Address->s6_words[4] = 0x0000; } Ipv6Address->s6_words[5] = 0xFE5E; *((UNALIGNED IN_ADDR *) (Ipv6Address->s6_words + 6)) = *Ipv4Address; } MSTCPIP_INLINE VOID IN6_SET_6TO4_PREFIX( _Inout_ IN6_ADDR *Ipv6Address, _In_ CONST IN_ADDR *Ipv4Address) { Ipv6Address->s6_words[0] = 0x0220; *((UNALIGNED IN_ADDR *) (Ipv6Address->s6_words + 1)) = *Ipv4Address; Ipv6Address->s6_words[3] = 0x0000; } MSTCPIP_INLINE SCOPE_LEVEL Ipv6UnicastAddressScope( _In_ CONST UCHAR *Address) { IN6_ADDR Ipv6Address; if (!INET_IS_ALIGNED(Address, IN6_ADDR)) { Ipv6Address = *(CONST IN6_ADDR UNALIGNED *)Address; Address = (CONST UCHAR *) &Ipv6Address; } if (IN6_IS_ADDR_LINKLOCAL((PIN6_ADDR) Address) || IN6_IS_ADDR_LOOPBACK((PIN6_ADDR) Address)) { return ScopeLevelLink; } else if (IN6_IS_ADDR_SITELOCAL((PIN6_ADDR) Address)) { return ScopeLevelSite; } else { return ScopeLevelGlobal; } } MSTCPIP_INLINE SCOPE_LEVEL IN6_MULTICAST_SCOPE( _In_ CONST UCHAR *Address) { PIN6_ADDR Ipv6Address = (PIN6_ADDR) Address; return (SCOPE_LEVEL)(Ipv6Address->s6_bytes[1] & 0xf); } MSTCPIP_INLINE SCOPE_LEVEL Ipv6AddressScope( _In_ CONST UCHAR *Address) { if (IN6_IS_ADDR_MULTICAST((CONST IN6_ADDR *) Address)) { return IN6_MULTICAST_SCOPE(Address); } else { return Ipv6UnicastAddressScope(Address); } } MSTCPIP_INLINE NL_ADDRESS_TYPE Ipv6AddressType( _In_ CONST UCHAR *Address) { CONST IN6_ADDR *Ipv6Address = (CONST IN6_ADDR *) Address; CONST UCHAR *Ipv4Address; if (IN6_IS_ADDR_MULTICAST(Ipv6Address)) { return NlatMulticast; } if (IN6_IS_ADDR_UNSPECIFIED(Ipv6Address)) { return NlatUnspecified; } if (IN6_IS_ADDR_ISATAP(Ipv6Address) || IN6_IS_ADDR_V4COMPAT(Ipv6Address) || IN6_IS_ADDR_V4MAPPED(Ipv6Address) || IN6_IS_ADDR_V4TRANSLATED(Ipv6Address)) { Ipv4Address = IN6_EXTRACT_V4ADDR_FROM_ISATAP(Ipv6Address); } else if (IN6_IS_ADDR_6TO4(Ipv6Address)) { Ipv4Address = IN6_EXTRACT_V4ADDR_FROM_6TO4(Ipv6Address); } else { return NlatUnicast; } if (Ipv4AddressType(Ipv4Address) != NlatUnicast) { return NlatInvalid; } return NlatUnicast; } MSTCPIP_INLINE VOID IN6_UNCANONICALIZE_SCOPE_ID( _In_ CONST IN6_ADDR *Address, _Inout_ SCOPE_ID *ScopeId) { SCOPE_LEVEL ScopeLevel = Ipv6AddressScope((CONST UCHAR *)Address); if ((IN6_IS_ADDR_LOOPBACK(Address)) || (ScopeLevel == ScopeLevelGlobal)) { ScopeId->Value = 0; } if ((SCOPE_LEVEL)ScopeId->Level == ScopeLevel) { ScopeId->Level = 0; } } #if (NTDDI_VERSION >= NTDDI_VISTA) MSTCPIP_INLINE VOID IN6ADDR_SETSOCKADDR( _Out_ PSOCKADDR_IN6 a, _In_ CONST IN6_ADDR *addr, _In_ SCOPE_ID scope, _In_ USHORT port) { a->sin6_family = AF_INET6; a->sin6_port = port; a->sin6_flowinfo = 0; RtlCopyMemory(&a->sin6_addr, addr, sizeof(IN6_ADDR)); a->sin6_scope_struct = scope; IN6_UNCANONICALIZE_SCOPE_ID(&a->sin6_addr, &a->sin6_scope_struct); } MSTCPIP_INLINE VOID IN6ADDR_SETV4MAPPED( _Out_ PSOCKADDR_IN6 a6, _In_ CONST IN_ADDR* a4, _In_ SCOPE_ID scope, _In_ USHORT port) { a6->sin6_family = AF_INET6; a6->sin6_port = port; a6->sin6_flowinfo = 0; IN6_SET_ADDR_V4MAPPED(&a6->sin6_addr, a4); a6->sin6_scope_struct = scope; IN4_UNCANONICALIZE_SCOPE_ID(a4, &a6->sin6_scope_struct); } #endif /* (NTDDI_VERSION >= NTDDI_VISTA) */ MSTCPIP_INLINE BOOLEAN INET_ADDR_EQUAL( _In_ ADDRESS_FAMILY af, _In_ CONST VOID* a, _In_ CONST VOID* b) { if (af == AF_INET6) { return IN6_ADDR_EQUAL((CONST IN6_ADDR*)a, (CONST IN6_ADDR*)b); } else { ASSERT(af == AF_INET); return IN4_ADDR_EQUAL((CONST IN_ADDR*)a, (CONST IN_ADDR*)b); } } MSTCPIP_INLINE BOOLEAN INET_UNALIGNED_ADDR_EQUAL( _In_ ADDRESS_FAMILY af, _In_ CONST VOID* a, _In_ CONST VOID* b) { if (af == AF_INET6) { return IN6_ADDR_EQUAL((CONST IN6_ADDR*)a, (CONST IN6_ADDR*)b); } else { ASSERT(af == AF_INET); return IN4_UNALIGNED_ADDR_EQUAL((CONST IN_ADDR*)a, (CONST IN_ADDR*)b); } } MSTCPIP_INLINE BOOLEAN INET_IS_ADDR_UNSPECIFIED( _In_ ADDRESS_FAMILY af, _In_ CONST VOID* a) { if (af == AF_INET6) { return IN6_IS_ADDR_UNSPECIFIED((CONST IN6_ADDR*)a); } else { ASSERT(af == AF_INET); return IN4_IS_ADDR_UNSPECIFIED((CONST IN_ADDR*)a); } } MSTCPIP_INLINE BOOLEAN INET_IS_UNALIGNED_ADDR_UNSPECIFIED( _In_ ADDRESS_FAMILY af, _In_ CONST VOID* a) { if (af == AF_INET6) { return IN6_IS_ADDR_UNSPECIFIED((CONST IN6_ADDR*)a); } else { ASSERT(af == AF_INET); return IN4_IS_UNALIGNED_ADDR_UNSPECIFIED((CONST IN_ADDR UNALIGNED*)a); } } MSTCPIP_INLINE BOOLEAN INET_IS_ADDR_LOOPBACK( _In_ ADDRESS_FAMILY af, _In_ CONST VOID* a) { if (af == AF_INET6) { return IN6_IS_ADDR_LOOPBACK((CONST IN6_ADDR*)a); } else { ASSERT(af == AF_INET); return IN4_IS_ADDR_LOOPBACK((CONST IN_ADDR*)a); } } MSTCPIP_INLINE BOOLEAN INET_IS_ADDR_BROADCAST( _In_ ADDRESS_FAMILY af, _In_ CONST VOID* a) { if (af == AF_INET6) { return FALSE; } else { ASSERT(af == AF_INET); return IN4_IS_ADDR_BROADCAST((CONST IN_ADDR*)a); } } MSTCPIP_INLINE BOOLEAN INET_IS_ADDR_MULTICAST( _In_ ADDRESS_FAMILY af, _In_ CONST VOID* a) { if (af == AF_INET6) { return IN6_IS_ADDR_MULTICAST((CONST IN6_ADDR*)a); } else { ASSERT(af == AF_INET); return IN4_IS_ADDR_MULTICAST((CONST IN_ADDR*)a); } } MSTCPIP_INLINE CONST UCHAR* INET_ADDR_UNSPECIFIED( _In_ ADDRESS_FAMILY af) { if (af == AF_INET6) { return (CONST UCHAR*)&in6addr_any; } else { ASSERT(af == AF_INET); return (CONST UCHAR*)&in4addr_any; } } MSTCPIP_INLINE VOID INET_SET_ADDRESS( _In_ ADDRESS_FAMILY Family, _Out_ PUCHAR Address, _In_ CONST UCHAR *Value) { if (Family == AF_INET6) { *((PIN6_ADDR)Address) = *((PIN6_ADDR)Value); } else { ASSERT(Family == AF_INET); *((PIN_ADDR)Address) = *((PIN_ADDR)Value); } } MSTCPIP_INLINE SIZE_T INET_ADDR_LENGTH( _In_ ADDRESS_FAMILY af) { if (af == AF_INET6) { return sizeof(IN6_ADDR); } else { ASSERT(af == AF_INET); return sizeof(IN_ADDR); } } MSTCPIP_INLINE SIZE_T INET_SOCKADDR_LENGTH( _In_ ADDRESS_FAMILY af) { if (af == AF_INET6) { return sizeof(SOCKADDR_IN6); } else { ASSERT(af == AF_INET); return sizeof(SOCKADDR_IN); } } #if (NTDDI_VERSION >= NTDDI_VISTA) MSTCPIP_INLINE VOID INETADDR_SETSOCKADDR( _In_ ADDRESS_FAMILY af, _Out_ PSOCKADDR a, _In_ CONST VOID* addr, _In_ SCOPE_ID scope, _In_ USHORT port) { if (af == AF_INET6) { IN6ADDR_SETSOCKADDR((PSOCKADDR_IN6) a, (CONST IN6_ADDR *) addr, scope, port); } else { CONST IN_ADDR addr4 = *((IN_ADDR UNALIGNED *) addr); ASSERT(af == AF_INET); IN4ADDR_SETSOCKADDR((PSOCKADDR_IN) a, (CONST IN_ADDR *) &addr4, port); } } #endif /* (NTDDI_VERSION >= NTDDI_VISTA) */ MSTCPIP_INLINE VOID INETADDR_SETANY( _Inout_ PSOCKADDR a) { if (a->sa_family == AF_INET6) { IN6ADDR_SETANY((PSOCKADDR_IN6)a); } else { ASSERT(a->sa_family == AF_INET); IN4ADDR_SETANY((PSOCKADDR_IN)a); } } MSTCPIP_INLINE VOID INETADDR_SETLOOPBACK( _Inout_ PSOCKADDR a) { if (a->sa_family == AF_INET6) { IN6ADDR_SETLOOPBACK((PSOCKADDR_IN6)a); } else { ASSERT(a->sa_family == AF_INET); IN4ADDR_SETLOOPBACK((PSOCKADDR_IN)a); } } MSTCPIP_INLINE BOOLEAN INETADDR_ISANY( _In_ CONST SOCKADDR *a) { if (a->sa_family == AF_INET6) { return IN6ADDR_ISANY((CONST SOCKADDR_IN6*)a); } else { ASSERT(a->sa_family == AF_INET); return IN4ADDR_ISANY((CONST SOCKADDR_IN*)a); } } MSTCPIP_INLINE BOOLEAN INETADDR_ISLOOPBACK( _In_ CONST SOCKADDR *a) { if (a->sa_family == AF_INET6) { return IN6ADDR_ISLOOPBACK((CONST SOCKADDR_IN6*)a); } else { ASSERT(a->sa_family == AF_INET); return IN4ADDR_ISLOOPBACK((CONST SOCKADDR_IN*)a); } } MSTCPIP_INLINE BOOLEAN INETADDR_ISV4MAPPED( _In_ CONST SOCKADDR *a) { if (a->sa_family == AF_INET6) { return IN6ADDR_ISV4MAPPED((CONST SOCKADDR_IN6*)a); } else { return FALSE; } } MSTCPIP_INLINE BOOLEAN NL_ADDR_EQUAL( _In_ ADDRESS_FAMILY af, _In_ SCOPE_ID sa, _In_ CONST UCHAR* aa, _In_ SCOPE_ID sb, _In_ CONST UCHAR* ab) { return (BOOLEAN)((sa.Value == sb.Value) && INET_ADDR_EQUAL(af, aa, ab)); } MSTCPIP_INLINE BOOLEAN NL_IS_ADDR_UNSPECIFIED( _In_ ADDRESS_FAMILY af, _In_ SCOPE_ID s, _In_ CONST UCHAR* a) { return (BOOLEAN)((s.Value == 0) && INET_IS_ADDR_UNSPECIFIED(af, a)); } MSTCPIP_INLINE BOOLEAN INETADDR_ISEQUAL( _In_ CONST SOCKADDR *a, _In_ CONST SOCKADDR *b) { if (a->sa_family == AF_INET6) { return (BOOLEAN) (b->sa_family == AF_INET6 && IN6ADDR_ISEQUAL((CONST SOCKADDR_IN6*)a, (CONST SOCKADDR_IN6*)b)); } else { ASSERT(a->sa_family == AF_INET); return (BOOLEAN) (b->sa_family == AF_INET && IN4ADDR_ISEQUAL((CONST SOCKADDR_IN*)a, (CONST SOCKADDR_IN*)b)); } } MSTCPIP_INLINE BOOLEAN INETADDR_ISUNSPECIFIED( _In_ CONST SOCKADDR *a) { if (a->sa_family == AF_INET6) { return IN6ADDR_ISUNSPECIFIED((CONST SOCKADDR_IN6*)a); } else { ASSERT(a->sa_family == AF_INET); return IN4ADDR_ISUNSPECIFIED((CONST SOCKADDR_IN*)a); } } #if (NTDDI_VERSION >= NTDDI_VISTA) MSTCPIP_INLINE SCOPE_ID INETADDR_SCOPE_ID( _In_ CONST SOCKADDR *a) { if (a->sa_family == AF_INET6) { return ((CONST SOCKADDR_IN6*)a)->sin6_scope_struct; } else { ASSERT(a->sa_family == AF_INET); return IN4ADDR_SCOPE_ID((CONST SOCKADDR_IN*)a); } } #endif MSTCPIP_INLINE USHORT INETADDR_PORT( _In_ CONST SOCKADDR *a) { if (a->sa_family == AF_INET6) { return ((CONST SOCKADDR_IN6*)a)->sin6_port; } else { ASSERT(a->sa_family == AF_INET); return ((CONST SOCKADDR_IN*)a)->sin_port; } } MSTCPIP_INLINE PUCHAR INETADDR_ADDRESS( _In_ CONST SOCKADDR* a) { if (a->sa_family == AF_INET6) { return (PUCHAR)&((PSOCKADDR_IN6)a)->sin6_addr; } else { ASSERT(a->sa_family == AF_INET); return (PUCHAR)&((PSOCKADDR_IN)a)->sin_addr; } } MSTCPIP_INLINE VOID INETADDR_SET_PORT( _Inout_ PSOCKADDR a, _In_ USHORT Port) { SS_PORT(a) = Port; } MSTCPIP_INLINE VOID INETADDR_SET_ADDRESS( _Inout_ PSOCKADDR a, _In_ CONST UCHAR *Address) { if (a->sa_family == AF_INET6) { ((PSOCKADDR_IN6)a)->sin6_addr = *((CONST IN6_ADDR*)Address); } else { ASSERT(a->sa_family == AF_INET); ((PSOCKADDR_IN)a)->sin_addr = *((CONST IN_ADDR*)Address); } } MSTCPIP_INLINE VOID INET_UNCANONICALIZE_SCOPE_ID( _In_ ADDRESS_FAMILY AddressFamily, _In_ CONST UCHAR *Address, _Inout_ SCOPE_ID *ScopeId) { if (AddressFamily == AF_INET6) { IN6_UNCANONICALIZE_SCOPE_ID((CONST IN6_ADDR*) Address, ScopeId); } else { IN4_UNCANONICALIZE_SCOPE_ID((CONST IN_ADDR*) Address, ScopeId); } } #endif /* _WS2IPDEF_ */ #ifndef __IP2STRING__ #define __IP2STRING__ #if (NTDDI_VERSION >= NTDDI_VISTA) #ifdef _WS2DEF_ NTSYSAPI PSTR NTAPI RtlIpv4AddressToStringA( _In_ const struct in_addr *Addr, _Out_writes_(16) PSTR S); NTSYSAPI LONG NTAPI RtlIpv4AddressToStringExA( _In_ const struct in_addr *Address, _In_ USHORT Port, _Out_writes_to_(*AddressStringLength, *AddressStringLength) PSTR AddressString, _Inout_ PULONG AddressStringLength); NTSYSAPI PWSTR NTAPI RtlIpv4AddressToStringW( _In_ const struct in_addr *Addr, _Out_writes_(16) PWSTR S); NTSYSAPI LONG NTAPI RtlIpv4AddressToStringExW( _In_ const struct in_addr *Address, _In_ USHORT Port, _Out_writes_to_(*AddressStringLength, *AddressStringLength) PWSTR AddressString, _Inout_ PULONG AddressStringLength); NTSYSAPI LONG NTAPI RtlIpv4StringToAddressA( _In_ PCSTR String, _In_ BOOLEAN Strict, _Out_ PCSTR *Terminator, _Out_ struct in_addr *Addr); NTSYSAPI LONG NTAPI RtlIpv4StringToAddressExA( _In_ PCSTR AddressString, _In_ BOOLEAN Strict, _Out_ struct in_addr *Address, _Out_ PUSHORT Port); NTSYSAPI LONG NTAPI RtlIpv4StringToAddressW( _In_ PCWSTR String, _In_ BOOLEAN Strict, _Out_ PCWSTR *Terminator, _Out_ struct in_addr *Addr); NTSYSAPI LONG NTAPI RtlIpv4StringToAddressExW( _In_ PCWSTR AddressString, _In_ BOOLEAN Strict, _Out_ struct in_addr *Address, _Out_ PUSHORT Port); #ifdef UNICODE #define RtlIpv4AddressToString RtlIpv4AddressToStringW #define RtlIpv4StringToAddress RtlIpv4StringToAddressW #define RtlIpv4AddressToStringEx RtlIpv4AddressToStringExW #define RtlIpv4StringToAddressEx RtlIpv4StringToAddressExW #else #define RtlIpv4AddressToString RtlIpv4AddressToStringA #define RtlIpv4StringToAddress RtlIpv4StringToAddressA #define RtlIpv4AddressToStringEx RtlIpv4AddressToStringExA #define RtlIpv4StringToAddressEx RtlIpv4StringToAddressExA #endif #endif /* _WS2DEF_ */ #ifdef _WS2IPDEF_ NTSYSAPI PSTR NTAPI RtlIpv6AddressToStringA( _In_ const struct in6_addr *Addr, _Out_writes_(46) PSTR S); NTSYSAPI LONG NTAPI RtlIpv6AddressToStringExA( _In_ const struct in6_addr *Address, _In_ ULONG ScopeId, _In_ USHORT Port, _Out_writes_to_(*AddressStringLength, *AddressStringLength) PSTR AddressString, _Inout_ PULONG AddressStringLength); NTSYSAPI PWSTR NTAPI RtlIpv6AddressToStringW( _In_ const struct in6_addr *Addr, _Out_writes_(46) PWSTR S); NTSYSAPI LONG NTAPI RtlIpv6AddressToStringExW( _In_ const struct in6_addr *Address, _In_ ULONG ScopeId, _In_ USHORT Port, _Out_writes_to_(*AddressStringLength, *AddressStringLength) PWSTR AddressString, _Inout_ PULONG AddressStringLength); NTSYSAPI LONG NTAPI RtlIpv6StringToAddressA( _In_ PCSTR S, _Out_ PCSTR *Terminator, _Out_ struct in6_addr *Addr); NTSYSAPI LONG NTAPI RtlIpv6StringToAddressExA( _In_ PCSTR AddressString, _Out_ struct in6_addr *Address, _Out_ PULONG ScopeId, _Out_ PUSHORT Port); NTSYSAPI LONG NTAPI RtlIpv6StringToAddressW( _In_ PCWSTR S, _Out_ PCWSTR *Terminator, _Out_ struct in6_addr *Addr); NTSYSAPI LONG NTAPI RtlIpv6StringToAddressExW( _In_ PCWSTR AddressString, _Out_ struct in6_addr *Address, _Out_ PULONG ScopeId, _Out_ PUSHORT Port); #ifdef UNICODE #define RtlIpv6AddressToString RtlIpv6AddressToStringW #define RtlIpv6StringToAddress RtlIpv6StringToAddressW #define RtlIpv6StringToAddressEx RtlIpv6StringToAddressExW #define RtlIpv6AddressToStringEx RtlIpv6AddressToStringExW #else #define RtlIpv6AddressToString RtlIpv6AddressToStringA #define RtlIpv6StringToAddress RtlIpv6StringToAddressA #define RtlIpv6StringToAddressEx RtlIpv6StringToAddressExA #define RtlIpv6AddressToStringEx RtlIpv6AddressToStringExA #endif #endif /* __WS2IPDEF__ */ #ifdef _WS2DEF_ union _DL_EUI48; typedef union _DL_EUI48 DL_EUI48, *PDL_EUI48; NTSYSAPI PSTR NTAPI RtlEthernetAddressToStringA( _In_ const DL_EUI48 *Addr, _Out_writes_(18) PSTR S); NTSYSAPI PWSTR NTAPI RtlEthernetAddressToStringW( _In_ const DL_EUI48 *Addr, _Out_writes_(18) PWSTR S); NTSYSAPI LONG NTAPI RtlEthernetStringToAddressA( _In_ PCSTR S, _Out_ PCSTR *Terminator, _Out_ DL_EUI48 *Addr); NTSYSAPI LONG NTAPI RtlEthernetStringToAddressW( _In_ PCWSTR S, _Out_ LPCWSTR *Terminator, _Out_ DL_EUI48 *Addr); #ifdef UNICODE #define RtlEthernetAddressToString RtlEthernetAddressToStringW #define RtlEthernetStringToAddress RtlEthernetStringToAddressW #else #define RtlEthernetAddressToString RtlEthernetAddressToStringA #define RtlEthernetStringToAddress RtlEthernetStringToAddressA #endif #endif /* _WS2DEF_ */ #endif /* (NTDDI >= NTDDI_VISTA) */ #endif /* __IP2STRING__ */ #ifdef __cplusplus } #endif