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

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

?? dns.c

?? 基于STM32F107的UDP服務器程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
      pEntry->numdns  = 0;
      pEntry->tmr     = 1;
      pEntry->retries = 0;
      
      /* send DNS packet for this entry */
      dns_send(pEntry->numdns, pEntry->name, i);
      break;
    }

    case DNS_STATE_ASKING: {
      if (--pEntry->tmr == 0) {
        if (++pEntry->retries == DNS_MAX_RETRIES) {
          if ((pEntry->numdns+1<DNS_MAX_SERVERS) && (dns_servers[pEntry->numdns+1].addr!=0)) {
            /* change of server */
            pEntry->numdns++;
            pEntry->tmr     = 1;
            pEntry->retries = 0;
            break;
          } else {
            LWIP_DEBUGF(DNS_DEBUG, ("dns_check_entry: \"%s\": timeout\n", pEntry->name));
            /* call specified callback function if provided */
            if (pEntry->found)
              (*pEntry->found)(pEntry->name, NULL, pEntry->arg);
            /* flush this entry */
            pEntry->state   = DNS_STATE_UNUSED;
            pEntry->found   = NULL;
            break;
          }
        }

        /* wait longer for the next retry */
        pEntry->tmr = pEntry->retries;

        /* send DNS packet for this entry */
        dns_send(pEntry->numdns, pEntry->name, i);
      }
      break;
    }

    case DNS_STATE_DONE: {
      /* if the time to live is nul */
      if (--pEntry->ttl == 0) {
        LWIP_DEBUGF(DNS_DEBUG, ("dns_check_entry: \"%s\": flush\n", pEntry->name));
        /* flush this entry */
        pEntry->state = DNS_STATE_UNUSED;
        pEntry->found = NULL;
      }
      break;
    }
    case DNS_STATE_UNUSED:
      /* nothing to do */
      break;
    default:
      LWIP_ASSERT("unknown dns_table entry state:", 0);
      break;
  }
}

/**
 * Call dns_check_entry for each entry in dns_table - check all entries.
 */
static void
dns_check_entries(void)
{
  u8_t i;

  for (i = 0; i < DNS_TABLE_SIZE; ++i) {
    dns_check_entry(i);
  }
}

/**
 * Receive input function for DNS response packets arriving for the dns UDP pcb.
 *
 * @params see udp.h
 */
static void
dns_recv(void *arg, struct udp_pcb *pcb, struct pbuf *p, struct ip_addr *addr, u16_t port)
{
  u8_t i;
  char *pHostname;
  struct dns_hdr *hdr;
  struct dns_answer ans;
  struct dns_table_entry *pEntry;
  u8_t nquestions, nanswers;
#if (DNS_USES_STATIC_BUF == 0)
  u8_t dns_payload[DNS_MSG_SIZE];
#endif /* (DNS_USES_STATIC_BUF == 0) */
#if (DNS_USES_STATIC_BUF == 2)
  u8_t* dns_payload;
#endif /* (DNS_USES_STATIC_BUF == 2) */

  LWIP_UNUSED_ARG(arg);
  LWIP_UNUSED_ARG(pcb);
  LWIP_UNUSED_ARG(addr);
  LWIP_UNUSED_ARG(port);

  /* is the dns message too big ? */
  if (p->tot_len > DNS_MSG_SIZE) {
    LWIP_DEBUGF(DNS_DEBUG, ("dns_recv: pbuf too big\n"));
    /* free pbuf and return */
    goto memerr1;
  }

  /* is the dns message big enough ? */
  if (p->tot_len < (SIZEOF_DNS_HDR + SIZEOF_DNS_QUERY + SIZEOF_DNS_ANSWER)) {
    LWIP_DEBUGF(DNS_DEBUG, ("dns_recv: pbuf too small\n"));
    /* free pbuf and return */
    goto memerr1;
  }

#if (DNS_USES_STATIC_BUF == 2)
  dns_payload = mem_malloc(p->tot_len);
  if (dns_payload == NULL) {
    LWIP_DEBUGF(DNS_DEBUG, ("dns_recv: mem_malloc error\n"));
    /* free pbuf and return */
    goto memerr1;
  }
#endif /* (DNS_USES_STATIC_BUF == 2) */

  /* copy dns payload inside static buffer for processing */ 
  if (pbuf_copy_partial(p, dns_payload, p->tot_len, 0) == p->tot_len) {
    /* The ID in the DNS header should be our entry into the name table. */
    hdr = (struct dns_hdr*)dns_payload;
    i = htons(hdr->id);
    if (i < DNS_TABLE_SIZE) {
      pEntry = &dns_table[i];
      if(pEntry->state == DNS_STATE_ASKING) {
        /* This entry is now completed. */
        pEntry->state = DNS_STATE_DONE;
        pEntry->err   = hdr->flags2 & DNS_FLAG2_ERR_MASK;

        /* 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);

        /* Check for error. If so, call callback to inform. */
        if (((hdr->flags1 & DNS_FLAG1_RESPONSE) == 0) || (pEntry->err != 0) || (nquestions != 1)) {
          LWIP_DEBUGF(DNS_DEBUG, ("dns_recv: \"%s\": error in flags\n", pEntry->name));
          /* call callback to indicate error, clean up memory and return */
          goto responseerr;
        }

#if DNS_DOES_NAME_CHECK
        /* Check if the name in the "question" part match with the name in the entry. */
        if (dns_compare_name((unsigned char *)(pEntry->name), (unsigned char *)dns_payload + SIZEOF_DNS_HDR) != 0) {
          LWIP_DEBUGF(DNS_DEBUG, ("dns_recv: \"%s\": response not match to query\n", pEntry->name));
          /* call callback to indicate error, clean up memory and return */
          goto responseerr;
        }
#endif /* DNS_DOES_NAME_CHECK */

        /* Skip the name in the "question" part */
        pHostname = (char *) dns_parse_name((unsigned char *)dns_payload + SIZEOF_DNS_HDR) + SIZEOF_DNS_QUERY;

        while(nanswers > 0) {
          /* skip answer resource record's host name */
          pHostname = (char *) dns_parse_name((unsigned char *)pHostname);

          /* Check for IP address type and Internet class. Others are discarded. */
          MEMCPY(&ans, pHostname, SIZEOF_DNS_ANSWER);
          if((ntohs(ans.type) == DNS_RRTYPE_A) && (ntohs(ans.class) == DNS_RRCLASS_IN) && (ntohs(ans.len) == sizeof(struct ip_addr)) ) {
            /* read the answer resource record's TTL, and maximize it if needed */
            pEntry->ttl = ntohl(ans.ttl);
            if (pEntry->ttl > DNS_MAX_TTL) {
              pEntry->ttl = DNS_MAX_TTL;
            }
            /* read the IP address after answer resource record's header */
            MEMCPY( &(pEntry->ipaddr), (pHostname+SIZEOF_DNS_ANSWER), sizeof(struct ip_addr));
            LWIP_DEBUGF(DNS_DEBUG, ("dns_recv: \"%s\": response = ", pEntry->name));
            ip_addr_debug_print(DNS_DEBUG, (&(pEntry->ipaddr)));
            LWIP_DEBUGF(DNS_DEBUG, ("\n"));
            /* call specified callback function if provided */
            if (pEntry->found) {
              (*pEntry->found)(pEntry->name, &pEntry->ipaddr, pEntry->arg);
            }
            /* deallocate memory and return */
            goto memerr2;
          } else {
            pHostname = pHostname + SIZEOF_DNS_ANSWER + htons(ans.len);
          }
          --nanswers;
        }
        LWIP_DEBUGF(DNS_DEBUG, ("dns_recv: \"%s\": error in response\n", pEntry->name));
        /* call callback to indicate error, clean up memory and return */
        goto responseerr;
      }
    }
  }

  /* deallocate memory and return */
  goto memerr2;

responseerr:
  /* ERROR: call specified callback function with NULL as name to indicate an error */
  if (pEntry->found) {
    (*pEntry->found)(pEntry->name, NULL, pEntry->arg);
  }
  /* flush this entry */
  pEntry->state = DNS_STATE_UNUSED;
  pEntry->found = NULL;

memerr2:
#if (DNS_USES_STATIC_BUF == 2)
  /* free dns buffer */
  mem_free(dns_payload);
#endif /* (DNS_USES_STATIC_BUF == 2) */

memerr1:
  /* free pbuf */
  pbuf_free(p);
  return;
}

/**
 * Queues a new hostname to resolve and sends out a DNS query for that hostname
 *
 * @param name the hostname that is to be queried
 * @param found a callback founction to be called on success, failure or timeout
 * @param callback_arg argument to pass to the callback function
 * @return @return a err_t return code.
 */
static err_t
dns_enqueue(const char *name, dns_found_callback found, void *callback_arg)
{
  u8_t i;
  u8_t lseq, lseqi;
  struct dns_table_entry *pEntry = NULL;

  /* search an unused entry, or the oldest one */
  lseq = lseqi = 0;
  for (i = 0; i < DNS_TABLE_SIZE; ++i) {
    pEntry = &dns_table[i];
    /* is it an unused entry ? */
    if (pEntry->state == DNS_STATE_UNUSED)
      break;

    /* check if this is the oldest completed entry */
    if (pEntry->state == DNS_STATE_DONE) {
      if ((dns_seqno - pEntry->seqno) > lseq) {
        lseq = dns_seqno - pEntry->seqno;
        lseqi = i;
      }
    }
  }

  /* if we don't have found an unused entry, use the oldest completed one */
  if (i == DNS_TABLE_SIZE) {
    if ((lseqi >= DNS_TABLE_SIZE) || (dns_table[lseqi].state != DNS_STATE_DONE)) {
      /* no entry can't be used now, table is full */
      LWIP_DEBUGF(DNS_DEBUG, ("dns_enqueue: \"%s\": DNS entries table is full\n", name));
      return ERR_MEM;
    } else {
      /* use the oldest completed one */
      i = lseqi;
      pEntry = &dns_table[i];
    }
  }

  /* use this entry */
  LWIP_DEBUGF(DNS_DEBUG, ("dns_enqueue: \"%s\": use DNS entry %"U16_F"\n", name, (u16_t)(i)));

  /* fill the entry */
  pEntry->state = DNS_STATE_NEW;
  pEntry->seqno = dns_seqno++;
  pEntry->found = found;
  pEntry->arg   = callback_arg;
  strcpy(pEntry->name, name);

  /* force to send query without waiting timer */
  dns_check_entry(i);

  /* dns query is enqueued */
  return ERR_INPROGRESS;
}

/**
 * Resolve a hostname (string) into an IP address.
 * NON-BLOCKING callback version for use with raw API!!!
 *
 * Returns immediately with one of err_t return codes:
 * - ERR_OK if hostname is a valid IP address string or the host
 *   name is already in the local names table.
 * - ERR_INPROGRESS enqueue a request to be sent to the DNS server
 *   for resolution if no errors are present.
 *
 * @param hostname the hostname that is to be queried
 * @param addr pointer to a struct ip_addr where to store the address if it is already
 *             cached in the dns_table (only valid if ERR_OK is returned!)
 * @param found a callback function to be called on success, failure or timeout (only if
 *              ERR_INPROGRESS is returned!)
 * @param callback_arg argument to pass to the callback function
 * @return a err_t return code.
 */
err_t
dns_gethostbyname(const char *hostname, struct ip_addr *addr, dns_found_callback found,
                  void *callback_arg)
{
  /* not initialized or no valid server yet, or invalid addr pointer
   * or invalid hostname or invalid hostname length */
  if ((dns_pcb == NULL) || (addr == NULL) ||
      (!hostname) || (!hostname[0]) ||
      (strlen(hostname) >= DNS_MAX_NAME_LENGTH)) {
    return ERR_VAL;
  }

#if LWIP_HAVE_LOOPIF
  if (strcmp(hostname,"localhost")==0) {
    addr->addr = INADDR_LOOPBACK;
    return ERR_OK;
  }
#endif /* LWIP_HAVE_LOOPIF */

  /* host name already in octet notation? set ip addr and return ERR_OK
   * already have this address cached? */
  if (((addr->addr = inet_addr(hostname)) != INADDR_NONE) ||
      ((addr->addr = dns_lookup(hostname)) != INADDR_NONE)) {
    return ERR_OK;
  }

  /* queue query with specified callback */
  return dns_enqueue(hostname, found, callback_arg);
}

#endif /* LWIP_DNS */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人综合在线观看| 久久成人免费网站| 久久精品视频免费观看| 欧美不卡一区二区三区四区| 91精品国产一区二区人妖| 在线亚洲一区观看| 欧美在线视频全部完| 欧美日韩一区久久| 欧美蜜桃一区二区三区| 日韩午夜电影在线观看| 欧美成人三级电影在线| 欧美刺激午夜性久久久久久久| 日韩欧美一级二级| 欧美激情综合五月色丁香小说| 国产三级久久久| 亚洲欧美激情小说另类| 午夜久久久影院| 国产一区欧美二区| 国产福利不卡视频| 色悠悠亚洲一区二区| 7777精品伊人久久久大香线蕉超级流畅 | 午夜精品一区在线观看| 日本欧美久久久久免费播放网| 看电视剧不卡顿的网站| 成人性生交大片免费看在线播放 | 亚洲视频在线一区| 亚洲成人中文在线| 久久精品国产**网站演员| 国产精品亚洲视频| 欧美天天综合网| 欧美xxxx老人做受| 亚洲色图清纯唯美| 麻豆极品一区二区三区| 国产成人综合在线观看| 在线国产亚洲欧美| 精品福利一区二区三区免费视频| 久久久久国产精品厨房| 亚洲一区免费视频| 国产美女精品人人做人人爽 | 美女一区二区三区在线观看| 国产精品系列在线观看| 在线观看视频一区二区| 久久久激情视频| 日韩成人一区二区| 91丝袜美腿高跟国产极品老师 | 国产一区激情在线| 色欧美片视频在线观看在线视频| 日韩精品一区二区三区中文精品| 亚洲图片欧美激情| 国模套图日韩精品一区二区| 欧美日韩综合不卡| 亚洲欧洲一区二区三区| 国产精品一区二区无线| 欧美精品久久一区| 一区二区三区四区精品在线视频| 激情深爱一区二区| 69堂精品视频| 亚洲一二三四区不卡| 91色porny蝌蚪| 国产亚洲短视频| 国产精品影视在线| 日韩天堂在线观看| 日韩av电影免费观看高清完整版在线观看| 国产乱一区二区| 久久综合成人精品亚洲另类欧美| 日韩精品欧美精品| 91国偷自产一区二区开放时间 | 国产精品中文字幕日韩精品| 4438x成人网最大色成网站| 亚洲女与黑人做爰| 91女神在线视频| 中文字幕亚洲欧美在线不卡| 国产福利视频一区二区三区| 久久嫩草精品久久久精品一| 六月丁香婷婷久久| 日韩欧美一区在线观看| 青青青伊人色综合久久| 欧美一区二区播放| 美女高潮久久久| 精品国产精品一区二区夜夜嗨| 免费看欧美女人艹b| 精品少妇一区二区| 国产精品456| 国产精品大尺度| 一本一道综合狠狠老| 亚洲一区二区在线视频| 欧美在线观看一二区| 午夜a成v人精品| 91精品国产色综合久久ai换脸| 免费国产亚洲视频| 国产亚洲女人久久久久毛片| 岛国一区二区在线观看| 国产精品久久久久久久久果冻传媒| bt7086福利一区国产| 一区二区三区av电影| 3751色影院一区二区三区| 韩国三级中文字幕hd久久精品| 久久久九九九九| 在线免费不卡电影| 久久精品理论片| 国产精品久久久久永久免费观看| 91老师国产黑色丝袜在线| 天堂在线亚洲视频| 精品久久免费看| 91色九色蝌蚪| 精品在线一区二区三区| 中文字幕制服丝袜一区二区三区| 欧美日韩在线观看一区二区| 成人av网址在线观看| 天堂va蜜桃一区二区三区漫画版| 久久综合九色综合欧美就去吻| 972aa.com艺术欧美| 男女视频一区二区| 亚洲天堂免费看| 日韩视频一区二区三区在线播放 | 一区二区激情视频| 欧美电影免费提供在线观看| 99久久伊人精品| 国产在线国偷精品免费看| 一区二区三区影院| 国产欧美日韩综合| 日韩一区二区三区在线| 色999日韩国产欧美一区二区| 国产一区二区三区综合| 日韩精品一二三区| 中文字幕在线观看一区二区| 日韩丝袜情趣美女图片| 在线观看av不卡| 99r精品视频| 国产成人精品网址| 美女视频黄久久| 亚洲尤物在线视频观看| 国产精品每日更新在线播放网址| 制服.丝袜.亚洲.中文.综合| 91免费看`日韩一区二区| 国产精品一区二区无线| 久国产精品韩国三级视频| 亚洲福利一区二区| 亚洲欧美日韩小说| 国产精品久久久一本精品| 久久―日本道色综合久久| 欧美日韩一区二区在线观看| 国产99久久久国产精品免费看| 久久66热re国产| 五月综合激情网| 日韩中文字幕区一区有砖一区| 一区二区三区欧美视频| 中文字幕佐山爱一区二区免费| 国产无一区二区| 国产偷国产偷精品高清尤物 | 欧美精品 日韩| 欧美日韩国产乱码电影| 欧美在线一二三四区| 欧美这里有精品| 欧美日韩情趣电影| 欧美日韩中文另类| 欧美精选一区二区| 欧美精品一二三区| 在线成人免费观看| 日韩欧美国产麻豆| 精品国产伦一区二区三区免费| 成人欧美一区二区三区白人| 国产精品天美传媒| 国产精品日韩成人| 国产精品国产精品国产专区不蜜| 亚洲欧洲成人av每日更新| 亚洲人成小说网站色在线| 亚洲免费电影在线| 亚洲成人精品影院| 麻豆精品久久久| 成熟亚洲日本毛茸茸凸凹| 91亚洲精品久久久蜜桃网站| 色综合网色综合| 欧美美女喷水视频| 精品国产伦理网| 国产精品久久久久国产精品日日| 一区二区三区四区蜜桃| 日本va欧美va精品发布| 国产·精品毛片| 欧美性猛交xxxx乱大交退制版| 51久久夜色精品国产麻豆| 久久老女人爱爱| 一区二区三区四区亚洲| 久久超级碰视频| 色婷婷综合激情| 欧美日韩国产大片| 国产精品网曝门| 亚洲第一综合色| 国产精品亚洲第一区在线暖暖韩国| 99re热这里只有精品免费视频| 欧美日韩精品二区第二页| 精品国产sm最大网站免费看| 国产精品久久久久久久午夜片| 一区二区三区欧美日| 久久91精品国产91久久小草| 一本大道久久a久久精品综合| 欧美成人精品二区三区99精品| 日本中文在线一区| 国产suv一区二区三区88区| 欧美精品日韩精品|