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

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

?? resolv.c

?? uip1.0原代碼和用戶(hù)手冊(cè),適用于單片機(jī)嵌入tcp/ip協(xié)議棧.
?? C
字號(hào):
/** * \addtogroup apps * @{ *//** * \defgroup resolv DNS resolver * @{ * * The uIP DNS resolver functions are used to lookup a hostname and * map it to a numerical IP address. It maintains a list of resolved * hostnames that can be queried with the resolv_lookup() * function. New hostnames can be resolved using the resolv_query() * function. * * When a hostname has been resolved (or found to be non-existant), * the resolver code calls a callback function called resolv_found() * that must be implemented by the module that uses the resolver. *//** * \file * DNS host name to IP address resolver. * \author Adam Dunkels <adam@dunkels.com> * * This file implements a DNS host name to IP address resolver. *//* * Copyright (c) 2002-2003, Adam Dunkels. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 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. The name of the author may not be used to endorse or promote *    products derived from this software without specific prior *    written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * This file is part of the uIP TCP/IP stack. * * $Id: resolv.c,v 1.5 2006/06/11 21:46:37 adam Exp $ * */#include "resolv.h"#include "uip.h"#include <string.h>#ifndef NULL#define NULL (void *)0#endif /* NULL *//** \internal The maximum number of retries when asking for a name. */#define MAX_RETRIES 8/** \internal The DNS message header. */struct dns_hdr {  u16_t id;  u8_t flags1, flags2;#define DNS_FLAG1_RESPONSE        0x80#define DNS_FLAG1_OPCODE_STATUS   0x10#define DNS_FLAG1_OPCODE_INVERSE  0x08#define DNS_FLAG1_OPCODE_STANDARD 0x00#define DNS_FLAG1_AUTHORATIVE     0x04#define DNS_FLAG1_TRUNC           0x02#define DNS_FLAG1_RD              0x01#define DNS_FLAG2_RA              0x80#define DNS_FLAG2_ERR_MASK        0x0f#define DNS_FLAG2_ERR_NONE        0x00#define DNS_FLAG2_ERR_NAME        0x03  u16_t numquestions;  u16_t numanswers;  u16_t numauthrr;  u16_t numextrarr;};/** \internal The DNS answer message structure. */struct dns_answer {  /* DNS answer record starts with either a domain name or a pointer     to a name already present somewhere in the packet. */  u16_t type;  u16_t class;  u16_t ttl[2];  u16_t len;  uip_ipaddr_t ipaddr;};struct namemap {#define STATE_UNUSED 0#define STATE_NEW    1#define STATE_ASKING 2#define STATE_DONE   3#define STATE_ERROR  4  u8_t state;  u8_t tmr;  u8_t retries;  u8_t seqno;  u8_t err;  char name[32];  uip_ipaddr_t ipaddr;};#ifndef UIP_CONF_RESOLV_ENTRIES#define RESOLV_ENTRIES 4#else /* UIP_CONF_RESOLV_ENTRIES */#define RESOLV_ENTRIES UIP_CONF_RESOLV_ENTRIES#endif /* UIP_CONF_RESOLV_ENTRIES */static struct namemap names[RESOLV_ENTRIES];static u8_t seqno;static struct uip_udp_conn *resolv_conn = NULL;/*---------------------------------------------------------------------------*//** \internal * Walk through a compact encoded DNS name and return the end of it. * * \return The end of the name. *//*---------------------------------------------------------------------------*/static unsigned char *parse_name(unsigned char *query){  unsigned char n;  do {    n = *query++;        while(n > 0) {      /*      printf("%c", *query);*/      ++query;      --n;    };    /*    printf(".");*/  } while(*query != 0);  /*  printf("\n");*/  return query + 1;}/*---------------------------------------------------------------------------*//** \internal * Runs through the list of names to see if there are any that have * not yet been queried and, if so, sends out a query. *//*---------------------------------------------------------------------------*/static voidcheck_entries(void){  register struct dns_hdr *hdr;  char *query, *nptr, *nameptr;  static u8_t i;  static u8_t n;  register struct namemap *namemapptr;    for(i = 0; i < RESOLV_ENTRIES; ++i) {    namemapptr = &names[i];    if(namemapptr->state == STATE_NEW ||       namemapptr->state == STATE_ASKING) {      if(namemapptr->state == STATE_ASKING) {	if(--namemapptr->tmr == 0) {	  if(++namemapptr->retries == MAX_RETRIES) {	    namemapptr->state = STATE_ERROR;	    resolv_found(namemapptr->name, NULL);	    continue;	  }	  namemapptr->tmr = namemapptr->retries;	} else {	  /*	  printf("Timer %d\n", namemapptr->tmr);*/	  /* Its timer has not run out, so we move on to next	     entry. */	  continue;	}      } else {	namemapptr->state = STATE_ASKING;	namemapptr->tmr = 1;	namemapptr->retries = 0;      }      hdr = (struct dns_hdr *)uip_appdata;      memset(hdr, 0, sizeof(struct dns_hdr));      hdr->id = htons(i);      hdr->flags1 = DNS_FLAG1_RD;      hdr->numquestions = HTONS(1);      query = (char *)uip_appdata + 12;      nameptr = namemapptr->name;      --nameptr;      /* Convert hostname into suitable query format. */      do {	++nameptr;	nptr = query;	++query;	for(n = 0; *nameptr != '.' && *nameptr != 0; ++nameptr) {	  *query = *nameptr;	  ++query;	  ++n;	}	*nptr = n;      } while(*nameptr != 0);      {	static unsigned char endquery[] =	  {0,0,1,0,1};	memcpy(query, endquery, 5);      }      uip_udp_send((unsigned char)(query + 5 - (char *)uip_appdata));      break;    }  }}/*---------------------------------------------------------------------------*//** \internal * Called when new UDP data arrives. *//*---------------------------------------------------------------------------*/static voidnewdata(void){  char *nameptr;  struct dns_answer *ans;  struct dns_hdr *hdr;  static u8_t nquestions, nanswers;  static u8_t i;  register struct namemap *namemapptr;    hdr = (struct dns_hdr *)uip_appdata;  /*  printf("ID %d\n", htons(hdr->id));      printf("Query %d\n", hdr->flags1 & DNS_FLAG1_RESPONSE);      printf("Error %d\n", hdr->flags2 & DNS_FLAG2_ERR_MASK);      printf("Num questions %d, answers %d, authrr %d, extrarr %d\n",      htons(hdr->numquestions),      htons(hdr->numanswers),      htons(hdr->numauthrr),      htons(hdr->numextrarr));  */  /* The ID in the DNS header should be our entry into the name     table. */  i = htons(hdr->id);  namemapptr = &names[i];  if(i < RESOLV_ENTRIES &&     namemapptr->state == STATE_ASKING) {    /* This entry is now finished. */    namemapptr->state = STATE_DONE;    namemapptr->err = hdr->flags2 & DNS_FLAG2_ERR_MASK;    /* Check for error. If so, call callback to inform. */    if(namemapptr->err != 0) {      namemapptr->state = STATE_ERROR;      resolv_found(namemapptr->name, NULL);      return;    }    /* We only care about the question(s) and the answers. The authrr       and the extrarr are simply discarded. */    nquestions = htons(hdr->numquestions);    nanswers = htons(hdr->numanswers);    /* Skip the name in the question. XXX: This should really be       checked agains the name in the question, to be sure that they       match. */    nameptr = parse_name((char *)uip_appdata + 12) + 4;    while(nanswers > 0) {      /* The first byte in the answer resource record determines if it	 is a compressed record or a normal one. */      if(*nameptr & 0xc0) {	/* Compressed name. */	nameptr +=2;	/*	printf("Compressed anwser\n");*/      } else {	/* Not compressed name. */	nameptr = parse_name((char *)nameptr);      }      ans = (struct dns_answer *)nameptr;      /*      printf("Answer: type %x, class %x, ttl %x, length %x\n",	     htons(ans->type), htons(ans->class), (htons(ans->ttl[0])	     << 16) | htons(ans->ttl[1]), htons(ans->len));*/      /* Check for IP address type and Internet class. Others are	 discarded. */      if(ans->type == HTONS(1) &&	 ans->class == HTONS(1) &&	 ans->len == HTONS(4)) {	/*	printf("IP address %d.%d.%d.%d\n",	       htons(ans->ipaddr[0]) >> 8,	       htons(ans->ipaddr[0]) & 0xff,	       htons(ans->ipaddr[1]) >> 8,	       htons(ans->ipaddr[1]) & 0xff);*/	/* XXX: we should really check that this IP address is the one	   we want. */	namemapptr->ipaddr[0] = ans->ipaddr[0];	namemapptr->ipaddr[1] = ans->ipaddr[1];		resolv_found(namemapptr->name, namemapptr->ipaddr);	return;      } else {	nameptr = nameptr + 10 + htons(ans->len);      }      --nanswers;    }  }}/*---------------------------------------------------------------------------*//** \internal * The main UDP function. *//*---------------------------------------------------------------------------*/voidresolv_appcall(void){  if(uip_udp_conn->rport == HTONS(53)) {    if(uip_poll()) {      check_entries();    }    if(uip_newdata()) {      newdata();    }  }}/*---------------------------------------------------------------------------*//** * Queues a name so that a question for the name will be sent out. * * \param name The hostname that is to be queried. *//*---------------------------------------------------------------------------*/voidresolv_query(char *name){  static u8_t i;  static u8_t lseq, lseqi;  register struct namemap *nameptr;        lseq = lseqi = 0;    for(i = 0; i < RESOLV_ENTRIES; ++i) {    nameptr = &names[i];    if(nameptr->state == STATE_UNUSED) {      break;    }    if(seqno - nameptr->seqno > lseq) {      lseq = seqno - nameptr->seqno;      lseqi = i;    }  }  if(i == RESOLV_ENTRIES) {    i = lseqi;    nameptr = &names[i];  }  /*  printf("Using entry %d\n", i);*/  strcpy(nameptr->name, name);  nameptr->state = STATE_NEW;  nameptr->seqno = seqno;  ++seqno;}/*---------------------------------------------------------------------------*//** * Look up a hostname in the array of known hostnames. * * \note This function only looks in the internal array of known * hostnames, it does not send out a query for the hostname if none * was found. The function resolv_query() can be used to send a query * for a hostname. * * \return A pointer to a 4-byte representation of the hostname's IP * address, or NULL if the hostname was not found in the array of * hostnames. *//*---------------------------------------------------------------------------*/u16_t *resolv_lookup(char *name){  static u8_t i;  struct namemap *nameptr;    /* Walk through the list to see if the name is in there. If it is     not, we return NULL. */  for(i = 0; i < RESOLV_ENTRIES; ++i) {    nameptr = &names[i];    if(nameptr->state == STATE_DONE &&       strcmp(name, nameptr->name) == 0) {      return nameptr->ipaddr;    }  }  return NULL;}/*---------------------------------------------------------------------------*//** * Obtain the currently configured DNS server. * * \return A pointer to a 4-byte representation of the IP address of * the currently configured DNS server or NULL if no DNS server has * been configured. *//*---------------------------------------------------------------------------*/u16_t *resolv_getserver(void){  if(resolv_conn == NULL) {    return NULL;  }  return resolv_conn->ripaddr;}/*---------------------------------------------------------------------------*//** * Configure which DNS server to use for queries. * * \param dnsserver A pointer to a 4-byte representation of the IP * address of the DNS server to be configured. *//*---------------------------------------------------------------------------*/voidresolv_conf(u16_t *dnsserver){  if(resolv_conn != NULL) {    uip_udp_remove(resolv_conn);  }    resolv_conn = uip_udp_new(dnsserver, HTONS(53));}/*---------------------------------------------------------------------------*//** * Initalize the resolver. *//*---------------------------------------------------------------------------*/voidresolv_init(void){  static u8_t i;    for(i = 0; i < RESOLV_ENTRIES; ++i) {    names[i].state = STATE_DONE;  }}/*---------------------------------------------------------------------------*//** @} *//** @} */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本欧美一区二区三区乱码| 欧美成人福利视频| 国内国产精品久久| 日韩久久久久久| 国产真实精品久久二三区| 亚洲人精品一区| 在线欧美一区二区| 亚洲高清在线视频| 日韩欧美国产系列| 国产sm精品调教视频网站| 1区2区3区国产精品| 欧美中文字幕一区二区三区| 五月天婷婷综合| 日韩精品中午字幕| av在线一区二区| 亚洲国产精品欧美一二99| 91精品国产91久久综合桃花 | 亚洲成av人影院| 欧美电影免费观看高清完整版在线| 国产麻豆一精品一av一免费| 亚洲欧美综合在线精品| 欧美日免费三级在线| 国产精品白丝jk黑袜喷水| 一区二区三区在线观看欧美| 日韩欧美中文字幕制服| 91一区在线观看| 青青青伊人色综合久久| 国产精品视频麻豆| 欧美精品三级在线观看| 成人免费视频视频在线观看免费| 亚洲综合在线观看视频| 欧美成人三级在线| 91久久精品一区二区三| 国产伦精品一区二区三区免费| 最新欧美精品一区二区三区| 欧美一级黄色片| 91精品办公室少妇高潮对白| 国产精品系列在线播放| 亚洲成人综合网站| 中文字幕第一区| 日韩午夜av一区| 欧美中文字幕一区二区三区亚洲| 国产.精品.日韩.另类.中文.在线.播放| 亚洲mv在线观看| 综合精品久久久| 久久五月婷婷丁香社区| 欧美日本一道本在线视频| 成人精品视频网站| 国产在线不卡一区| 免费在线欧美视频| 亚洲男帅同性gay1069| 国产亚洲精品福利| 91精品国产综合久久精品| 在线亚洲欧美专区二区| www.在线成人| 国产ts人妖一区二区| 激情欧美一区二区三区在线观看| 日日噜噜夜夜狠狠视频欧美人| 国产精品全国免费观看高清| 久久久久高清精品| 精品国产一区二区三区忘忧草| 欧美欧美欧美欧美| 91福利国产精品| 色妞www精品视频| av在线播放一区二区三区| 国产不卡免费视频| 欧美福利视频一区| 欧美性猛交一区二区三区精品| 99在线热播精品免费| 成人免费视频一区| www.综合网.com| av午夜一区麻豆| 99这里只有精品| 成人精品视频一区二区三区| 大陆成人av片| 99久久综合精品| 色94色欧美sute亚洲线路二| 91久久精品午夜一区二区| 91国模大尺度私拍在线视频| 色狠狠综合天天综合综合| 色就色 综合激情| 欧美日韩你懂得| 884aa四虎影成人精品一区| 欧美精品九九99久久| 欧美夫妻性生活| 精品国产伦一区二区三区观看体验| 精品嫩草影院久久| 国产欧美精品一区二区三区四区| 亚洲国产精品v| 亚洲欧美日韩一区| 亚洲大尺度视频在线观看| 青青青伊人色综合久久| 国产精品1区2区3区| av动漫一区二区| 91捆绑美女网站| 欧美挠脚心视频网站| 精品国产成人系列| 中文字幕一区免费在线观看| 亚洲精品乱码久久久久久黑人| 亚洲国产精品久久不卡毛片| 麻豆一区二区三区| 福利一区二区在线观看| 色乱码一区二区三区88| 日韩视频一区二区三区| 亚洲国产精品99久久久久久久久| 亚洲欧洲综合另类| 午夜视频久久久久久| 精品一区二区三区视频| av欧美精品.com| 欧美精品视频www在线观看 | 91精品国产色综合久久| 国产色综合一区| 亚洲综合在线第一页| 久久精品久久99精品久久| 国产a视频精品免费观看| 欧美中文字幕一区二区三区 | 国产高清精品网站| 色婷婷精品久久二区二区蜜臂av| 7878成人国产在线观看| 中文字幕一区免费在线观看| 日韩高清电影一区| 9i在线看片成人免费| 欧美va亚洲va在线观看蝴蝶网| 中文字幕一区二区三区不卡| 三级影片在线观看欧美日韩一区二区 | 成人aa视频在线观看| 欧美一激情一区二区三区| 国产精品欧美一级免费| 久久精品国产99国产精品| 色综合久久九月婷婷色综合| 久久久久国产精品免费免费搜索| 狠狠色丁香婷婷综合| 欧美丝袜第三区| 国产精品拍天天在线| 日本不卡一二三区黄网| 色av综合在线| 中文字幕日韩一区| 国产一区二区三区av电影| 欧美日韩国产美女| 亚洲女厕所小便bbb| 成人爽a毛片一区二区免费| 精品久久人人做人人爰| 亚洲成人激情综合网| 97se亚洲国产综合自在线 | 波多野结衣中文字幕一区二区三区 | 国产亚洲成av人在线观看导航| 亚洲成人免费观看| 欧美一a一片一级一片| 亚洲国产精华液网站w | 日韩国产精品久久久| 91久久免费观看| 一区二区三区在线影院| eeuss鲁片一区二区三区 | 97久久精品人人澡人人爽| 国产欧美一二三区| 国产精品一区二区久久精品爱涩| 欧美精品一区二区在线播放| 奇米精品一区二区三区在线观看一| 在线亚洲免费视频| 亚洲国产成人91porn| 在线免费不卡电影| 亚洲一区二区欧美日韩| 在线观看日韩毛片| 亚洲综合丝袜美腿| 欧美日韩国产高清一区二区三区 | 亚洲精品一区二区三区蜜桃下载| 热久久久久久久| 欧美一区二区播放| 日韩av高清在线观看| 日韩一区二区三区电影在线观看| 免费观看在线色综合| 日韩欧美在线网站| 国产在线播放一区| 久久久久国产精品麻豆| 成人免费高清在线| 国产精品毛片久久久久久久| jvid福利写真一区二区三区| 中文字幕亚洲一区二区av在线| 成人aa视频在线观看| 伊人婷婷欧美激情| 欧美另类久久久品| 蜜臀av一区二区三区| 精品第一国产综合精品aⅴ| 国产福利91精品一区二区三区| 中文欧美字幕免费| 色综合色综合色综合色综合色综合 | 日本成人在线看| 久久综合久久综合亚洲| 国产**成人网毛片九色| 亚洲精品久久7777| 3d动漫精品啪啪一区二区竹菊| 欧美性大战xxxxx久久久| 日韩在线卡一卡二| 精品捆绑美女sm三区| gogogo免费视频观看亚洲一| 亚洲自拍偷拍九九九| 日韩精品中文字幕在线不卡尤物 | 亚洲h动漫在线| 26uuu色噜噜精品一区| av电影在线观看一区|