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

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

?? dns.c

?? LWIP在STM32裸機上的移植
?? 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一区二区三区免费野_久草精品视频
国产在线视频精品一区| 亚洲视频免费在线观看| 亚洲男同性视频| 欧美在线综合视频| 亚洲一级二级在线| 欧美精选午夜久久久乱码6080| 视频在线观看一区二区三区| 日韩欧美久久一区| 99久久伊人精品| 亚洲一区二区三区视频在线| 亚洲精品v日韩精品| 久久综合99re88久久爱| 日本韩国一区二区| 韩国成人精品a∨在线观看| 久久精品国产77777蜜臀| 亚洲精品美国一| 亚洲一区二区三区四区五区黄 | 欧美精品乱码久久久久久| 欧美日韩电影在线| 国产91精品一区二区麻豆亚洲| 亚洲人午夜精品天堂一二香蕉| 亚洲日本va午夜在线影院| 亚洲国产美国国产综合一区二区| 久久久久成人黄色影片| 欧美顶级少妇做爰| 久久女同性恋中文字幕| 亚洲天堂免费在线观看视频| 亚洲成人手机在线| 亚洲综合一区在线| 蜜臀va亚洲va欧美va天堂| 一区二区三区高清| 亚洲精品视频一区| 美女视频黄 久久| 99久久精品情趣| 91精品久久久久久蜜臀| 欧美日韩成人在线一区| 国产日韩av一区二区| 久久综合久久99| 依依成人精品视频| 裸体健美xxxx欧美裸体表演| 成人午夜看片网址| 99热国产精品| 99久久久精品免费观看国产蜜| 欧美一区二区视频免费观看| 这里只有精品电影| 亚洲图片激情小说| 免费国产亚洲视频| 激情综合五月婷婷| 国产成人综合在线| 国产精品一区二区三区网站| 国产一区二三区| 国产精品一级片在线观看| 欧美色成人综合| 91超碰这里只有精品国产| 国产精品剧情在线亚洲| 亚洲精品国产一区二区三区四区在线 | 奇米一区二区三区| 日本乱人伦aⅴ精品| 亚洲国产精品成人综合| 国产精品国产三级国产aⅴ入口 | 欧美猛男男办公室激情| 亚洲精品v日韩精品| 91视视频在线观看入口直接观看www| 91啪亚洲精品| 国产精品入口麻豆九色| 玉米视频成人免费看| av一区二区不卡| 欧美极品aⅴ影院| 国产黄色成人av| 久久精品日产第一区二区三区高清版| 中文字幕色av一区二区三区| 亚洲第一综合色| 精品视频999| 亚洲一区二区三区激情| 欧美日本免费一区二区三区| 一区二区三区欧美日韩| 在线观看日韩电影| 亚洲va欧美va天堂v国产综合| 欧美性感一区二区三区| 亚洲精品一区二区精华| 国产精品欧美一区二区三区| 国产成人av福利| 亚洲国产成人午夜在线一区| 成人免费av在线| 最新国产成人在线观看| 一本一道久久a久久精品综合蜜臀| 欧美高清视频一二三区| 日本欧美在线观看| 在线中文字幕一区| 香蕉av福利精品导航| 日韩一区二区三区观看| 一区二区三区在线免费观看| 欧美亚洲愉拍一区二区| 日本大胆欧美人术艺术动态| 精品国产99国产精品| 国产精品中文字幕一区二区三区| 国产午夜精品一区二区三区视频| 99久久伊人精品| 亚洲成人综合网站| 日韩欧美精品在线| 成人久久久精品乱码一区二区三区| 亚洲女性喷水在线观看一区| 日韩欧美一级特黄在线播放| 国产成人夜色高潮福利影视| 亚洲蜜臀av乱码久久精品| 欧美一级生活片| 99国产欧美另类久久久精品| 热久久国产精品| 成人免费一区二区三区在线观看| 欧美日韩免费不卡视频一区二区三区| 麻豆精品视频在线观看免费| 亚洲另类春色国产| 久久综合久久99| 欧美电影在线免费观看| av在线播放一区二区三区| 日本不卡在线视频| 亚洲素人一区二区| 久久免费偷拍视频| 欧美日韩精品电影| 99久久久精品| 国产精品123区| 亚洲成av人在线观看| 国产精品毛片大码女人| 欧美精品一区视频| 欧美三区在线视频| 色婷婷av一区| 成人丝袜18视频在线观看| 奇米色777欧美一区二区| 亚洲一区影音先锋| 亚洲欧美电影一区二区| 国产无人区一区二区三区| 宅男在线国产精品| 欧美三日本三级三级在线播放| 99久久伊人久久99| 不卡影院免费观看| 亚洲欧美二区三区| 国产精品久久精品日日| 久久久蜜桃精品| 欧美大片日本大片免费观看| 欧美日韩视频在线第一区| 色综合天天狠狠| 成人免费毛片a| 成人18视频日本| 成人黄色免费短视频| 国产91丝袜在线播放| 国产一区视频在线看| 韩国v欧美v日本v亚洲v| 国内精品国产成人国产三级粉色| 日韩国产高清在线| 日本不卡123| 美日韩一区二区| 久久精品国产亚洲a| 韩国成人福利片在线播放| 激情综合亚洲精品| 国产精品一卡二卡| 亚洲大片在线观看| 麻豆成人综合网| 激情五月播播久久久精品| 国产专区欧美精品| 成人综合在线视频| 99国产精品国产精品毛片| 91老司机福利 在线| 欧美少妇xxx| 91精品国产综合久久久蜜臀图片 | 日本道色综合久久| 欧美亚洲动漫制服丝袜| 欧美精品在线一区二区| 日韩无一区二区| 中文字幕高清不卡| 一区二区三区四区在线免费观看| 亚洲成人精品影院| 精品一区二区三区免费播放| 成人免费va视频| 欧美精品免费视频| 国产精品久久午夜| 亚洲高清不卡在线观看| 国内成人精品2018免费看| 9i在线看片成人免费| 欧美日韩精品久久久| 久久九九国产精品| 一区二区在线免费| 久草中文综合在线| 91麻豆国产福利在线观看| 欧美一区二区播放| 成人欧美一区二区三区白人| 日韩精品久久久久久| 国产91在线|亚洲| 欧美熟乱第一页| 亚洲精品一线二线三线| 亚洲综合色视频| 国产精品资源在线看| 欧美体内she精高潮| 久久尤物电影视频在线观看| 亚洲精品菠萝久久久久久久| 国内精品国产三级国产a久久| 欧美网站一区二区| 中文字幕中文乱码欧美一区二区| 日精品一区二区| 91色porny| 国产女同互慰高潮91漫画|