亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? tpipv6.h

?? IP協(xié)議分析工具ipdog開(kāi)源代碼 好東西
?? H
字號(hào):
/*++

Copyright (c) 2000 Microsoft Corporation

Module Name:

    tpipv6.h

Abstract:

    This module contains IPv6-specific extensions, and address family
    independent extensions to Winsock for the IPv6 Technology Preview.

--*/

#ifndef _TPIPV6_
#define _TPIPV6_

#ifdef _MSC_VER
#define TPIPV6_INLINE __inline
#else
#define TPIPV6_INLINE extern inline /* GNU style */
#endif

#ifdef __cplusplus
#define TPIPV6_EXTERN extern "C"
#else
#define TPIPV6_EXTERN extern
#endif

#ifdef _WINSOCK2API_ 
/* This section gets included if winsock2.h is included */

#ifndef IPPROTO_IPV6

#define IPPROTO_IPV6 41

typedef unsigned __int64 u_int64;

//
// Portable socket structure.
//

//
// Desired design of maximum size and alignment.
// These are implementation specific.
//
#define _SS_MAXSIZE 128                  // Maximum size.
#define _SS_ALIGNSIZE (sizeof(__int64))  // Desired alignment. 

//
// Definitions used for sockaddr_storage structure paddings design.
//
#define _SS_PAD1SIZE (_SS_ALIGNSIZE - sizeof (short))
#define _SS_PAD2SIZE (_SS_MAXSIZE - (sizeof (short) + _SS_PAD1SIZE \
                                                    + _SS_ALIGNSIZE))

struct sockaddr_storage {
    short ss_family;               // Address family.
    char __ss_pad1[_SS_PAD1SIZE];  // 6 byte pad, this is to make
                                   // implementation specific pad up to
                                   // alignment field that follows explicit
                                   // in the data structure.
    __int64 __ss_align;            // Field to force desired structure.
    char __ss_pad2[_SS_PAD2SIZE];  // 112 byte pad to achieve desired size;
                                   // _SS_MAXSIZE value minus size of
                                   // ss_family, __ss_pad1, and
                                   // __ss_align fields is 112.
};

typedef struct sockaddr_storage SOCKADDR_STORAGE;
typedef struct sockaddr_storage *PSOCKADDR_STORAGE;
typedef struct sockaddr_storage FAR *LPSOCKADDR_STORAGE;

#endif /* !IPPROTO_IPV6 */
#endif /* _WINSOCK2API_ */

#ifdef _WS2TCPIP_H_ 
/* This section gets included if ws2tcpip.h is included */

#ifndef IPV6_JOIN_GROUP

#define in6_addr in_addr6

// Macro that works for both IPv4 and IPv6
#define SS_PORT(ssp) (((struct sockaddr_in*)(ssp))->sin_port)

#define IN6ADDR_ANY_INIT        { 0 }
#define IN6ADDR_LOOPBACK_INIT   { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1 }

TPIPV6_EXTERN const struct in6_addr in6addr_any;
TPIPV6_EXTERN const struct in6_addr in6addr_loopback;

TPIPV6_INLINE int
IN6_ADDR_EQUAL(const struct in6_addr *a, const struct in6_addr *b)
{
    return (memcmp(a, b, sizeof(struct in6_addr)) == 0);
}

TPIPV6_INLINE int
IN6_IS_ADDR_UNSPECIFIED(const struct in6_addr *a)
{
    return IN6_ADDR_EQUAL(a, &in6addr_any);
}

TPIPV6_INLINE int
IN6_IS_ADDR_LOOPBACK(const struct in6_addr *a)
{
    return IN6_ADDR_EQUAL(a, &in6addr_loopback);
}

TPIPV6_INLINE int
IN6_IS_ADDR_MULTICAST(const struct in6_addr *a)
{
    return (a->s6_addr[0] == 0xff);
}

TPIPV6_INLINE int
IN6_IS_ADDR_LINKLOCAL(const struct in6_addr *a)
{
    return ((a->s6_addr[0] == 0xfe) &&
            ((a->s6_addr[1] & 0xc0) == 0x80));
}

TPIPV6_INLINE int
IN6_IS_ADDR_SITELOCAL(const struct in6_addr *a)
{
    return ((a->s6_addr[0] == 0xfe) &&
            ((a->s6_addr[1] & 0xc0) == 0xc0));
}

TPIPV6_INLINE int
IN6_IS_ADDR_V4MAPPED(const struct in6_addr *a)
{
    return ((a->s6_addr[0] == 0) &&
            (a->s6_addr[1] == 0) &&
            (a->s6_addr[2] == 0) &&
            (a->s6_addr[3] == 0) &&
            (a->s6_addr[4] == 0) &&
            (a->s6_addr[5] == 0) &&
            (a->s6_addr[6] == 0) &&
            (a->s6_addr[7] == 0) &&
            (a->s6_addr[8] == 0) &&
            (a->s6_addr[9] == 0) &&
            (a->s6_addr[10] == 0xff) &&
            (a->s6_addr[11] == 0xff));
}

TPIPV6_INLINE int
IN6_IS_ADDR_V4COMPAT(const struct in6_addr *a)
{
    return ((a->s6_addr[0] == 0) &&
            (a->s6_addr[1] == 0) &&
            (a->s6_addr[2] == 0) &&
            (a->s6_addr[3] == 0) &&
            (a->s6_addr[4] == 0) &&
            (a->s6_addr[5] == 0) &&
            (a->s6_addr[6] == 0) &&
            (a->s6_addr[7] == 0) &&
            (a->s6_addr[8] == 0) &&
            (a->s6_addr[9] == 0) &&
            (a->s6_addr[10] == 0) &&
            (a->s6_addr[11] == 0) &&
            !((a->s6_addr[12] == 0) &&
              (a->s6_addr[13] == 0) &&
              (a->s6_addr[14] == 0) &&
              ((a->s6_addr[15] == 0) ||
               (a->s6_addr[15] == 1))));
}

TPIPV6_INLINE int
IN6_IS_ADDR_MC_NODELOCAL(const struct in6_addr *a)
{
    return IN6_IS_ADDR_MULTICAST(a) && ((a->s6_addr[1] & 0xf) == 1);
}

TPIPV6_INLINE int
IN6_IS_ADDR_MC_LINKLOCAL(const struct in6_addr *a)
{
    return IN6_IS_ADDR_MULTICAST(a) && ((a->s6_addr[1] & 0xf) == 2);
}

TPIPV6_INLINE int
IN6_IS_ADDR_MC_SITELOCAL(const struct in6_addr *a)
{
    return IN6_IS_ADDR_MULTICAST(a) && ((a->s6_addr[1] & 0xf) == 5);
}

TPIPV6_INLINE int
IN6_IS_ADDR_MC_ORGLOCAL(const struct in6_addr *a)
{
    return IN6_IS_ADDR_MULTICAST(a) && ((a->s6_addr[1] & 0xf) == 8);
}

TPIPV6_INLINE int
IN6_IS_ADDR_MC_GLOBAL(const struct in6_addr *a)
{
    return IN6_IS_ADDR_MULTICAST(a) && ((a->s6_addr[1] & 0xf) == 0xe);
}

/* Argument structure for IPV6_JOIN_GROUP and IPV6_LEAVE_GROUP */

typedef struct ipv6_mreq {
    struct in6_addr ipv6mr_multiaddr;  // IPv6 multicast address.
    unsigned int    ipv6mr_interface;  // Interface index.
} IPV6_MREQ;

//
// Socket options at the IPPROTO_IPV6 level.
//
#define IPV6_UNICAST_HOPS       4  // Set/get IP unicast hop limit.
#define IPV6_MULTICAST_IF       9  // Set/get IP multicast interface.
#define IPV6_MULTICAST_HOPS     10 // Set/get IP multicast ttl.
#define IPV6_MULTICAST_LOOP     11 // Set/get IP multicast loopback.
#define IPV6_ADD_MEMBERSHIP     12 // Add an IP group membership.
#define IPV6_DROP_MEMBERSHIP    13 // Drop an IP group membership.
#define IPV6_JOIN_GROUP         IPV6_ADD_MEMBERSHIP
#define IPV6_LEAVE_GROUP        IPV6_DROP_MEMBERSHIP

//
// Socket options at the IPPROTO_UDP level.
//
#define UDP_CHECKSUM_COVERAGE   20  // Set/get UDP-Lite checksum coverage.

//
// Error codes from getaddrinfo().
//
#define EAI_AGAIN       WSATRY_AGAIN
#define EAI_BADFLAGS    WSAEINVAL
#define EAI_FAIL        WSANO_RECOVERY
#define EAI_FAMILY      WSAEAFNOSUPPORT
#define EAI_MEMORY      WSA_NOT_ENOUGH_MEMORY
#define EAI_NODATA      WSANO_DATA
#define EAI_NONAME      WSAHOST_NOT_FOUND
#define EAI_SERVICE     WSATYPE_NOT_FOUND
#define EAI_SOCKTYPE    WSAESOCKTNOSUPPORT

//
// Structure used in getaddrinfo() call.
//
typedef struct addrinfo {
    int ai_flags;              // AI_PASSIVE, AI_CANONNAME, AI_NUMERICHOST.
    int ai_family;             // PF_xxx.
    int ai_socktype;           // SOCK_xxx.
    int ai_protocol;           // 0 or IPPROTO_xxx for IPv4 and IPv6.
    size_t ai_addrlen;         // Length of ai_addr.
    char *ai_canonname;        // Canonical name for nodename.
    struct sockaddr *ai_addr;  // Binary address.
    struct addrinfo *ai_next;  // Next structure in linked list.
} ADDRINFO, FAR * LPADDRINFO;

//
// Flags used in "hints" argument to getaddrinfo().
//
#define AI_PASSIVE     0x1  // Socket address will be used in bind() call.
#define AI_CANONNAME   0x2  // Return canonical name in first ai_canonname.
#define AI_NUMERICHOST 0x4  // Nodename must be a numeric address string.

#ifdef __cplusplus
extern "C" {
#endif

WINSOCK_API_LINKAGE
int
WSAAPI
getaddrinfo(
    IN const char FAR * nodename,
    IN const char FAR * servname,
    IN const struct addrinfo FAR * hints,
    OUT struct addrinfo FAR * FAR * res
    );

#if INCL_WINSOCK_API_TYPEDEFS
typedef
int
(WSAAPI * LPFN_GETADDRINFO)(
    IN const char FAR * nodename,
    IN const char FAR * servname,
    IN const struct addrinfo FAR * hints,
    OUT struct addrinfo FAR * FAR * res
    );
#endif

WINSOCK_API_LINKAGE
void
WSAAPI
freeaddrinfo(
    IN struct addrinfo FAR * ai
    );

#if INCL_WINSOCK_API_TYPEDEFS
typedef
void
(WSAAPI * LPFN_FREEADDRINFO)(
    IN struct addrinfo FAR * ai
    );
#endif

#ifdef UNICODE
#define gai_strerror   gai_strerrorW
#else
#define gai_strerror   gai_strerrorA
#endif  /* UNICODE */

// WARNING: The gai_strerror inline functions below use static buffers, 
// and hence are not thread-safe.  We'll use buffers long enough to hold 
// 1k characters.  Any system error messages longer than this will be 
// returned as empty strings.  However 1k should work for the error codes 
// used by getaddrinfo().
#define GAI_STRERROR_BUFFER_SIZE 1024

TPIPV6_INLINE 
char *
gai_strerrorA(
    IN int ecode)
{
    DWORD dwMsgLen;
    static char buff[GAI_STRERROR_BUFFER_SIZE + 1];

    dwMsgLen = FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM
                             |FORMAT_MESSAGE_IGNORE_INSERTS,
                              NULL,
                              ecode,
                              MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
                              (LPSTR)buff,
                              GAI_STRERROR_BUFFER_SIZE,
                              NULL);

    return buff;
}

TPIPV6_INLINE 
WCHAR *
gai_strerrorW(
    IN int ecode
    )
{
    DWORD dwMsgLen;
    static WCHAR buff[GAI_STRERROR_BUFFER_SIZE + 1];

    dwMsgLen = FormatMessageW(FORMAT_MESSAGE_FROM_SYSTEM
                             |FORMAT_MESSAGE_IGNORE_INSERTS,
                              NULL,
                              ecode,
                              MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
                              (LPWSTR)buff,
                              GAI_STRERROR_BUFFER_SIZE,
                              NULL);

    return buff;
}

typedef int socklen_t;

WINSOCK_API_LINKAGE
int
WSAAPI
getnameinfo(
    IN  const struct sockaddr FAR * sa,
    IN  socklen_t       salen,
    OUT char FAR *      host,
    IN  DWORD           hostlen,
    OUT char FAR *      serv,
    IN  DWORD           servlen,
    IN  int             flags
    );

#if INCL_WINSOCK_API_TYPEDEFS
typedef
int
(WSAAPI * LPFN_GETNAMEINFO)(
    IN  const struct sockaddr FAR * sa,
    IN  socklen_t       salen,
    OUT char FAR *      host,
    IN  DWORD           hostlen,
    OUT char FAR *      serv,
    IN  DWORD           servlen,
    IN  int             flags
    );
#endif

#define NI_MAXHOST  1025  // Max size of a fully-qualified domain name.
#define NI_MAXSERV    32  // Max size of a service name.

//
// Flags for getnameinfo().
//
#define NI_NOFQDN       0x01  // Only return nodename portion for local hosts. 
#define NI_NUMERICHOST  0x02  // Return numeric form of the host's address.
#define NI_NAMEREQD     0x04  // Error if the host's name not in DNS.
#define NI_NUMERICSERV  0x08  // Return numeric form of the service (port #).
#define NI_DGRAM        0x10  // Service is a datagram service.

#ifdef __cplusplus
}
#endif

#endif /* !IPV6_JOIN_GROUP */
#endif /* _WS2TCPIP_H_ */

//
// Unless the build environment is explicitly targeting
// platforms that include built-in getaddrinfo() support,
// include the backwards-compatibility version of the APIs.
//
#if !defined(_WIN32_WINNT) || (_WIN32_WINNT <= 0x0500)
#include "wspiapi.h"
#endif

#endif /* _TPIPV6_ */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精选在线播放| 欧美三级在线播放| xvideos.蜜桃一区二区| 亚洲激情自拍视频| 色综合久久久久| 欧美国产1区2区| 97精品超碰一区二区三区| 在线视频亚洲一区| 免费在线视频一区| 91天堂素人约啪| 性做久久久久久久久| 欧美成人性福生活免费看| 成人一二三区视频| 午夜精品久久久久| 欧美激情一区不卡| 欧美性色欧美a在线播放| 日本中文在线一区| 一区二区成人在线视频| 中文字幕免费在线观看视频一区| 91视频精品在这里| 国产九色sp调教91| 亚洲国产中文字幕| 亚洲欧洲99久久| 久久色在线视频| 精品国产凹凸成av人导航| 高清国产午夜精品久久久久久| 亚洲乱码国产乱码精品精的特点| 精品国产一区二区三区忘忧草| 91女人视频在线观看| 黄色日韩三级电影| 美女一区二区三区| 麻豆精品国产91久久久久久| 中文字幕欧美三区| 久久久精品黄色| 久久久精品国产99久久精品芒果 | 麻豆精品新av中文字幕| 蜜桃久久精品一区二区| 狠狠色狠狠色综合| 国产一区二区三区精品视频| 99久久婷婷国产综合精品电影 | www.视频一区| 日本不卡123| eeuss鲁片一区二区三区| 欧美一三区三区四区免费在线看| 免费在线观看精品| 北岛玲一区二区三区四区| 欧美美女bb生活片| 一区二区三区在线免费视频| 亚洲成人777| 国产成人精品三级| 欧美一区二区在线不卡| 国产精品视频线看| 91精品国产综合久久蜜臀| 精品sm捆绑视频| 视频一区欧美精品| 色播五月激情综合网| 欧美极品美女视频| 精品久久人人做人人爱| 亚洲国产视频一区| 91传媒视频在线播放| 欧美国产精品一区二区| 国产一区二区福利| 激情都市一区二区| 欧美巨大另类极品videosbest | 视频一区二区中文字幕| 午夜精品一区二区三区电影天堂 | 91色婷婷久久久久合中文| 日韩欧美一二区| 亚洲午夜激情网页| 欧美精品日韩精品| www久久久久| 九色综合国产一区二区三区| 欧美日韩电影在线播放| 亚洲国产欧美一区二区三区丁香婷| 国产99精品在线观看| 国产欧美视频一区二区| 久久久久久久久久久99999| 丝袜美腿成人在线| 3d成人动漫网站| 久国产精品韩国三级视频| 日韩欧美色综合| 国产成人三级在线观看| 久久久久国产免费免费| 成人午夜视频网站| 亚洲欧美日韩久久精品| 色婷婷久久久亚洲一区二区三区| √…a在线天堂一区| 欧美性猛交xxxxxx富婆| 麻豆精品视频在线观看免费| 国产亚洲短视频| 欧美日韩亚州综合| 成人影视亚洲图片在线| 水野朝阳av一区二区三区| 国产女人水真多18毛片18精品视频 | 欧美变态tickling挠脚心| 不卡av免费在线观看| 欧洲精品一区二区| 国产麻豆精品视频| 丝袜a∨在线一区二区三区不卡| 日韩欧美的一区二区| 国产不卡高清在线观看视频| 99国产精品国产精品毛片| 麻豆精品视频在线| 国内久久婷婷综合| 亚洲第一福利视频在线| 国产精品国产馆在线真实露脸| 日韩一区二区免费电影| 最新日韩av在线| 亚洲情趣在线观看| 亚洲免费av在线| 亚洲欧美色一区| 亚洲乱码国产乱码精品精的特点| 亚洲精品一区二区三区影院 | 午夜免费久久看| 午夜精品久久久久久久久| 婷婷综合五月天| 麻豆精品久久久| 99视频精品在线| 91福利国产成人精品照片| 日本精品一区二区三区高清| 欧美专区日韩专区| 亚洲精品一区二区三区影院| 欧美一区二区三区喷汁尤物| 欧美tickle裸体挠脚心vk| 久久久久久久久久久久久久久99| 精品久久五月天| 欧美国产日韩亚洲一区| 激情五月婷婷综合| 欧美在线短视频| 91麻豆精品在线观看| 欧美日韩一区二区欧美激情| 亚洲人精品午夜| 99久久亚洲一区二区三区青草 | 日本一区二区三区四区| 美女一区二区久久| 欧美一区二区三区四区高清| 夜夜精品视频一区二区 | 亚洲日本中文字幕区| 婷婷综合久久一区二区三区| 高清日韩电视剧大全免费| 久久99久久99| 色综合视频在线观看| 亚洲一区二区欧美日韩| 欧美一区二区精品在线| 国产精品一卡二卡在线观看| 国产午夜亚洲精品理论片色戒| 日av在线不卡| 日韩免费在线观看| 蜜桃久久av一区| 久久久99精品久久| 99这里只有精品| 亚洲成人三级小说| 欧美一区二区在线看| 国内成+人亚洲+欧美+综合在线| 欧美第一区第二区| 国产一区三区三区| 国产精品天干天干在观线| 不卡影院免费观看| 天涯成人国产亚洲精品一区av| 欧美一区二区视频在线观看2022 | 久久99国产精品麻豆| 久久久综合视频| 69堂国产成人免费视频| 蜜桃91丨九色丨蝌蚪91桃色| 国产亚洲精品中文字幕| 91美女福利视频| 国产91精品露脸国语对白| 亚洲妇女屁股眼交7| 国产区在线观看成人精品| 色综合久久久久| 欧美成人猛片aaaaaaa| hitomi一区二区三区精品| 青青草一区二区三区| 国产精品资源在线观看| 亚洲靠逼com| 国产精品全国免费观看高清| 欧美高清dvd| 欧美夫妻性生活| 在线播放视频一区| 91精品国产欧美一区二区| 在线观看亚洲a| 欧美日韩不卡一区二区| 欧美中文字幕一区| 日本国产一区二区| 亚洲视频一区在线| 亚洲精品乱码久久久久久| 亚洲高清免费观看 | 5566中文字幕一区二区电影| 日本va欧美va欧美va精品| 日本欧美一区二区在线观看| 一二三区精品福利视频| 亚洲日本欧美天堂| 欧美激情在线免费观看| 久久精品亚洲乱码伦伦中文| 欧美变态口味重另类| 精品久久久久久久久久久久包黑料 | 日韩一级成人av| 久久理论电影网| 国产精品久久久久7777按摩| 国产精品丝袜久久久久久app|