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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dns.c

?? eCos操作系統源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
            addr->sin_len = sizeof(*addr);            memcpy(&addr->sin_addr, rdata, sizeof(struct in_addr));            used++;            break;        }#ifdef CYGPKG_NET_INET6        case AF_INET6: {            struct sockaddr_in6 * addr = (struct sockaddr_in6 *) &addrs[used];            addr->sin6_len = sizeof(*addr);            memcpy(&addr->sin6_addr, rdata, sizeof(struct in6_addr));            used++;            break;        }#endif        default:            used = -EAI_FAMILY;        }    }    return used;}      /* This decodes the answer and puts the results into the addrs   array. This function can deal with IPv6 AAAA records as well as A   records. Thus its more complex than the parse_answer function in   the inline code. This complexity is only needed by getaddrinfo, so   i decided to leave parse_anser alone. */static intdecode(char *msg, short rr_type, int family,        struct sockaddr addrs[], int num, int used, char **canon) {      struct dns_header *dns_hdr;    struct resource_record rr, *rr_p = NULL;    char *qname = NULL;    char *ptr;        dns_hdr = (struct dns_header *)msg;        if (DNS_REPLY_NAME_ERROR == dns_hdr->rcode) {        h_errno = HOST_NOT_FOUND;        return -EAI_NONAME;    }        if ((dns_hdr->qr != 1) ||        (dns_hdr->opcode != DNS_QUERY)) {      return -EAI_FAIL;    }        if (dns_hdr->rcode != DNS_REPLY_NOERR) {      return -EAI_NONAME;    }    dns_hdr->ancount = ntohs(dns_hdr->ancount);    dns_hdr->qdcount = ntohs(dns_hdr->qdcount);    ptr = (char *)&dns_hdr[1];        /* Skip over the query section */    if (dns_hdr->qdcount > 0) {        while (dns_hdr->qdcount) {            ptr += qname_len(ptr);            ptr += 4;                   /* skip type & class */            dns_hdr->qdcount--;        }    }          /* Read the answers resource records to find an answer of the       correct type. */    while (dns_hdr->ancount && (used >= 0) && (used < num)) {        qname = ptr;        ptr += qname_len(ptr);        rr_p = (struct resource_record *)ptr;        memcpy(&rr, ptr, sizeof(rr));        if ((rr.rr_type == htons(rr_type)) &&             (rr.class == htons(DNS_CLASS_IN))) {            used = add_answer(rr_p->rdata, rr_type, family, addrs, num, used);            if (canon && !*canon) {                *canon = real_name(msg,qname);            }        }        ptr += sizeof(struct resource_record) -             sizeof(rr.rdata) + ntohs(rr.rdlength);        dns_hdr->ancount--;    }    if (used == 0) {        return -EAI_NONAME;    }    return used;}/* Do a lookup for a particular type of resource record. */static int do_lookup (const char * hostname,            struct sockaddr addrs[], int num, int used,            short rr_type, int family, char **canon) {    unsigned char msg[MAXDNSMSGSIZE];    int error;    int len;    /* First try the name as passed in */    memset(msg, 0, sizeof(msg));    len = build_query(msg, hostname, rr_type);    if (len < 0) {        return -EAI_FAIL;    }        /* Send the query and wait for an answer */    len = send_recv(msg, len, sizeof(msg));    if (len < 0) {        return -EAI_FAIL;    }        /* Decode the answer */    error = decode(msg, rr_type, family, addrs, num, used, canon);    return error;}static int do_lookups(const char * hostname,                       struct sockaddr addrs[], int num,                       int family, char ** canon) {    int error;#ifdef CYGPKG_NET_INET6    int error6;#endif    switch (family) {    case AF_INET:        error = do_lookup(hostname, addrs, num, 0, DNS_TYPE_A, AF_INET, canon);        break;#ifdef CYGPKG_NET_INET6    case AF_INET6:        error = do_lookup(hostname, addrs, num, 0, DNS_TYPE_AAAA, AF_INET6, canon);        break;#endif    case PF_UNSPEC:#ifndef CYGPKG_NET_INET6        error = do_lookup(hostname, addrs, num, 0, DNS_TYPE_A, AF_INET, canon);#else #ifdef CYGOPT_NS_DNS_FIRST_FAMILTY_AF_INET        error = do_lookup(hostname, addrs, num, 0, DNS_TYPE_A, AF_INET, canon);        if (error > 0 ) {            error6 = do_lookup(hostname, addrs, num, error, DNS_TYPE_AAAA,                                AF_INET6, canon);        } else {            error6 = do_lookup(hostname, addrs, num, 0, DNS_TYPE_AAAA,                                AF_INET6, canon);        }        if (error6 > 0) {            error = error6;        }#else // CYGOPT_NS_DNS_FIRST_FAMILY_AF_INET        error6 = do_lookup(hostname, addrs, num, 0, DNS_TYPE_AAAA,                            AF_INET6, canon);        if (error6> 0 ) {            error = do_lookup(hostname, addrs, num, error6, DNS_TYPE_A,                                AF_INET, canon);        } else {            error = do_lookup(hostname, addrs, num, 0, DNS_TYPE_A,                                AF_INET, canon);        }#endif // CYGOPT_NS_DNS_FIRST_FAMILY_AF_INET#endif // CYGPKG_NET_INET6        break;    default:        error = -EAI_FAMILY;    }    return error;}/* This implements the interface between getaddrinfo and the dns   client. hostent is not used here since that only works with IPv4   addresses, where as this function needs to be protocol   independent. */int cyg_dns_getaddrinfo(const char * hostname,                     struct sockaddr addrs[], int num,                    int family,                    char ** canon){    int error;    char name[256];    char * dot;    CYG_REPORT_FUNCNAMETYPE( "cyg_dns_getaddrinfo", "returning %08x" );    CYG_REPORT_FUNCARG3( "hostname=%08x, addrs=%08x, num=%2d",                          hostname, addrs, num );        if ( !hostname || !addrs || !num ) {        CYG_REPORT_RETVAL( NULL );        return -EAI_FAIL;    }        CYG_CHECK_DATA_PTR( hostname, "hostname is not a valid pointer!" );    CYG_CHECK_DATA_PTR( addrs, "addrs is not a valid pointer!");    CYG_ASSERT( num > 0, "Invalid number of sockaddr stuctures");        if (!valid_hostname(hostname)) {        /* it could be a dot address */        struct sockaddr_in * sa4 = (struct sockaddr_in *)&addrs[0];        memset(&addrs[0],0,sizeof(struct sockaddr));        if (inet_pton(AF_INET, hostname, (char *)&sa4->sin_addr.s_addr)) {            sa4->sin_family = AF_INET;            sa4->sin_len = sizeof(*sa4);            CYG_REPORT_RETVAL (1);            return 1;        }#ifdef CYGPKG_NET_INET6        {            /* it could be a colon address */            struct sockaddr_in6 * sa6 = (struct sockaddr_in6 *)&addrs[0];            memset(&addrs[0],0,sizeof(struct sockaddr));            if (inet_pton(AF_INET6, hostname, (char *)&sa6->sin6_addr.s6_addr)) {                sa6->sin6_family = AF_INET6;                sa6->sin6_len = sizeof(*sa6);                CYG_REPORT_RETVAL (1);                return 1;            }        }#endif        CYG_REPORT_RETVAL (-EAI_NONAME);        return -EAI_NONAME;    }        /* Has the socket to the DNS server been opened? */    if (s < 0) {        CYG_REPORT_RETVAL( -EIA_FAIL );        return -EAI_FAIL;    }        if (domainname) {        if ((strlen(hostname) + strlen(domainname)) > 254) {            cyg_drv_mutex_unlock(&dns_mutex);            CYG_REPORT_RETVAL( -EAI_FAIL );            return -EAI_FAIL;        }        strcpy(name, hostname);        strcat(name, ".");        strcat(name, domainname);    }    cyg_drv_mutex_lock(&dns_mutex);    /* If the hostname ends with . it a FQDN. Don't bother adding the    domainname. If it does not contain a . , try appending with the    domainname first. If it does have a . , try without a domain name    first. */    dot = rindex(hostname,'.');    if (dot) {        if (*(dot+1) == '\0') {            /* FQDN */            error = do_lookups(hostname, addrs, num, family, canon);        } else {          /* Dot somewhere */          error = do_lookups(hostname, addrs, num, family, canon);          if (domainname && (error == -EAI_NONAME)) {             error = do_lookups(name, addrs, num, family, canon);          }        }    } else {    /* No Dot. Try adding domainname first */        error = -EAI_NONAME;        if (domainname) {            error = do_lookups(name, addrs, num, family, canon);        }        if (error == -EAI_NONAME) {            error = do_lookups(hostname, addrs, num, family, canon);        }    }    cyg_drv_mutex_unlock(&dns_mutex);    CYG_REPORT_RETVAL( error );    return error;}/* This implements the interface between getnameinfo and the dns   client. */externC intcyg_dns_getnameinfo(const struct sockaddr * sa, char * host, size_t hostlen) {    char hostname[80];    unsigned char msg[MAXDNSMSGSIZE];    struct hostent * hent;    int len;    CYG_REPORT_FUNCNAMETYPE( "cyg_dns_getnameinfo", "returning %08x" );    CYG_REPORT_FUNCARG3( "sa=%08x, host=%08x, hostlen=%3d",                          sa, host, hostlen );        CYG_CHECK_DATA_PTR( sa, "sa is not a valid pointer");    CYG_CHECK_DATA_PTR( host, "host is not a valid data pointer");    CYG_ASSERT(hostlen >0, "Invalid host length");        /* Has the socket to the DNS server been opened? */    if (s < 0) {        CYG_REPORT_RETVAL( -EIA_FAIL );        return -EAI_FAIL;    }        cyg_drv_mutex_lock(&dns_mutex);        switch (sa->sa_family) {    case AF_INET: {        struct sockaddr_in * sa4 = (struct sockaddr_in *)sa;        unsigned char * addr = (char *)&sa4->sin_addr.s_addr;        sprintf(hostname, "%d.%d.%d.%d.IN-ADDR.ARPA.",                addr[3],addr[2],addr[1],addr[0]);        break;    }#ifdef CYGPKG_NET_INET6    case AF_INET6: {        struct sockaddr_in6 * sa6 = (struct sockaddr_in6 *)sa;        int i;                for (i=15; i >= 0; i--) {            sprintf(&hostname[(15*2*2) - (i*2*2)], "%x.%x.",                    sa6->sin6_addr.s6_addr[i] & 0x0f,                    (sa6->sin6_addr.s6_addr[i] & 0xf0) >> 4);        }        sprintf(&hostname[16*2*2],"IP6.INT");        break;    }#endif    default:        cyg_drv_mutex_lock(&dns_mutex);        CYG_REPORT_RETVAL( -EAI_FAMILY);        return -EAI_FAMILY;    }    memset(msg, 0, sizeof(msg));      /* Build a PTR type request using the hostname */    len = build_query(msg, hostname, DNS_TYPE_PTR);    if (len < 0) {        cyg_drv_mutex_unlock(&dns_mutex);        CYG_REPORT_RETVAL( -EAI_FAIL );        return -EAI_FAIL;    }    /* Send the request and wait for an answer */    len = send_recv(msg, len, sizeof(msg));    if (len < 0) {        cyg_drv_mutex_unlock(&dns_mutex);        CYG_REPORT_RETVAL( -EAI_FAIL );        return -EAI_FAIL;    }     /* Parse the answer for the host name */    hent = parse_answer(msg, DNS_TYPE_PTR);        /* If no name is known return an error */    if (!hent) {        cyg_drv_mutex_unlock(&dns_mutex);        CYG_REPORT_RETVAL( -EAI_NONAME );        return -EAI_NONAME;    }        /* Otherwise copy it into our results buffer and tidy up */    strncpy(host, hent->h_name,hostlen);    free_hent(hent);        cyg_drv_mutex_unlock(&dns_mutex);    CYG_REPORT_RETVAL( -EAI_NONE );    return -EAI_NONE;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看免费亚洲| 欧美精品18+| 狠狠色丁香婷综合久久| 蜜臀av性久久久久蜜臀av麻豆| 婷婷中文字幕综合| 天天射综合影视| 全部av―极品视觉盛宴亚洲| 日韩电影在线免费观看| 免费高清在线视频一区·| 极品美女销魂一区二区三区免费| 天堂成人免费av电影一区| 日韩国产欧美三级| 国产精品18久久久久久久久 | 亚洲精品日韩综合观看成人91| 中文字幕在线不卡视频| 亚洲精品成人精品456| 亚洲成a人v欧美综合天堂下载| 日韩国产精品久久久| 激情深爱一区二区| 91亚洲精品久久久蜜桃| 欧美日韩亚洲另类| 26uuu国产在线精品一区二区| 国产拍揄自揄精品视频麻豆| 亚洲欧美国产77777| 日本aⅴ亚洲精品中文乱码| 国产精品一卡二卡在线观看| 99视频在线精品| 91麻豆精品国产91久久久资源速度| 欧美电影免费观看高清完整版| 欧美国产日韩亚洲一区| 亚洲综合在线观看视频| 人人爽香蕉精品| www.成人网.com| 欧美r级在线观看| 亚洲欧美日韩国产综合在线| 久久99精品一区二区三区三区| yourporn久久国产精品| 日韩一级视频免费观看在线| 国产精品理论在线观看| 日本欧美大码aⅴ在线播放| 成人免费精品视频| 日韩一区二区免费在线电影| 亚洲视频中文字幕| 国产在线观看一区二区| 欧美日韩视频一区二区| 国产精品人成在线观看免费| 美国欧美日韩国产在线播放| 在线观看欧美黄色| 国产精品初高中害羞小美女文| 亚洲电影第三页| 成人在线视频一区| 久久综合久久鬼色| 日韩成人精品在线| 欧美午夜精品理论片a级按摩| 国产精品美女久久久久aⅴ| 极品少妇xxxx偷拍精品少妇| 欧美一级日韩免费不卡| 亚洲午夜久久久久久久久电影网 | 夜夜精品视频一区二区 | 国产综合色在线| 777亚洲妇女| 亚洲国产人成综合网站| 色综合婷婷久久| 国产精品美女久久久久高潮| 高清久久久久久| 久久久av毛片精品| 国内精品写真在线观看| 久久综合色婷婷| 久久爱www久久做| 日韩免费视频线观看| 久久精品av麻豆的观看方式| 日韩一级免费一区| 六月丁香婷婷色狠狠久久| 91精品国产欧美一区二区18| 日韩福利电影在线观看| 91.com视频| 久久爱www久久做| 久久久久综合网| 国产mv日韩mv欧美| 国产精品久久综合| 91国在线观看| 午夜av一区二区| 欧美一二三区在线| 精品中文字幕一区二区| 久久精品视频免费观看| 成人性生交大片免费看中文 | 日韩视频在线一区二区| 玖玖九九国产精品| 国产日产精品一区| 99re66热这里只有精品3直播 | 日日夜夜免费精品视频| 91精品一区二区三区久久久久久 | 欧美日韩免费在线视频| 亚洲va韩国va欧美va| 日韩一区国产二区欧美三区| 国产在线观看一区二区| 中文字幕在线不卡一区二区三区| 色先锋资源久久综合| 日本亚洲电影天堂| 国产欧美一区视频| 欧美体内she精视频| 精品一区二区久久| 亚洲日本在线天堂| 欧美大度的电影原声| 国产成人午夜精品5599 | 国产一区在线精品| 亚洲乱码国产乱码精品精小说 | 欧美国产精品一区二区三区| 在线视频中文字幕一区二区| 精品在线一区二区| 亚洲精品成人少妇| 久久久精品国产99久久精品芒果| 91视频一区二区| 精品一区二区三区在线播放视频| 亚洲人午夜精品天堂一二香蕉| 欧美一区二区在线免费观看| 成人av在线一区二区| 日韩主播视频在线| 国产精品久久二区二区| 精品日韩一区二区| 欧美性猛交一区二区三区精品| 国产精品自拍在线| 蜜臀精品久久久久久蜜臀| 亚洲色图视频网| 国产欧美一区二区精品秋霞影院| 欧美日韩一区二区不卡| 色哟哟国产精品| www.欧美精品一二区| 国产在线视频不卡二| 日本成人在线一区| 夜夜嗨av一区二区三区中文字幕| 国产校园另类小说区| 日韩精品一区二区三区老鸭窝| 欧美视频精品在线| 色综合久久99| 色哟哟一区二区在线观看| 国产精品88av| 国产精品影视在线观看| 久久99精品久久久久久动态图| 视频一区二区三区中文字幕| 一区二区三区影院| 夜夜嗨av一区二区三区网页| 亚洲免费观看高清| 亚洲精品视频在线| 伊人色综合久久天天人手人婷| 国产精品久久久久久久久晋中| 国产欧美一二三区| 国产精品女主播在线观看| 国产欧美精品一区aⅴ影院 | 国产专区综合网| 精品一区二区日韩| 国产一区在线看| 国产精品一区三区| 成人黄页毛片网站| 91在线观看污| 在线免费观看一区| 欧美男男青年gay1069videost| 色综合色综合色综合色综合色综合 | 日本一区二区不卡视频| 国产色产综合产在线视频| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国产精品996| bt7086福利一区国产| 在线免费一区三区| 欧美一级专区免费大片| 久久嫩草精品久久久精品一| 国产日韩精品一区二区浪潮av| 中文字幕制服丝袜一区二区三区| 国产精品黄色在线观看 | xfplay精品久久| 国产亚洲欧美日韩在线一区| 中文字幕精品一区二区三区精品| 中文字幕一区二区三区av| 性久久久久久久| 国产一区视频导航| 91国产成人在线| 精品国免费一区二区三区| 中文字幕亚洲一区二区av在线 | 一区二区三区在线观看欧美| 日韩电影在线免费看| 国产成人精品三级麻豆| 欧美日韩一级黄| 欧美国产欧美综合| 日韩高清不卡一区| 99久久婷婷国产| 日韩欧美三级在线| 亚洲另类在线视频| 韩国视频一区二区| 欧美综合天天夜夜久久| 久久精品人人爽人人爽| 亚洲一区二区欧美激情| 国产1区2区3区精品美女| 欧美色男人天堂| 国产精品麻豆一区二区 | 99国产精品久久久| 欧美一级搡bbbb搡bbbb| 亚洲免费资源在线播放| 国产毛片精品视频| 欧美巨大另类极品videosbest| 国产精品久久三区|