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

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

?? api_lib.c

?? Modbus協(xié)議的源代碼 Modbus協(xié)議的源代碼、 Modbus協(xié)議的源代碼 Modbus協(xié)議的源代碼
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*
 * Copyright (c) 2001-2004 Swedish Institute of Computer Science.
 * 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 lwIP TCP/IP stack.
 * 
 * Author: Adam Dunkels <adam@sics.se>
 *
 */

/* This is the part of the API that is linked with
   the application */

#include "lwip/opt.h"
#include "lwip/api.h"
#include "lwip/api_msg.h"
#include "lwip/memp.h"


struct
netbuf *netbuf_new(void)
{
  struct netbuf *buf;

  buf = memp_malloc(MEMP_NETBUF);
  if (buf != NULL) {
    buf->p = NULL;
    buf->ptr = NULL;
    return buf;
  } else {
    return NULL;
  }
}

void
netbuf_delete(struct netbuf *buf)
{
  if (buf != NULL) {
    if (buf->p != NULL) {
      pbuf_free(buf->p);
      buf->p = buf->ptr = NULL;
    }
    memp_free(MEMP_NETBUF, buf);
  }
}

void *
netbuf_alloc(struct netbuf *buf, u16_t size)
{
  /* Deallocate any previously allocated memory. */
  if (buf->p != NULL) {
    pbuf_free(buf->p);
  }
  buf->p = pbuf_alloc(PBUF_TRANSPORT, size, PBUF_RAM);
  if (buf->p == NULL) {
     return NULL;
  }
  buf->ptr = buf->p;
  return buf->p->payload;
}

void
netbuf_free(struct netbuf *buf)
{
  if (buf->p != NULL) {
    pbuf_free(buf->p);
  }
  buf->p = buf->ptr = NULL;
}

void
netbuf_ref(struct netbuf *buf, void *dataptr, u16_t size)
{
  if (buf->p != NULL) {
    pbuf_free(buf->p);
  }
  buf->p = pbuf_alloc(PBUF_TRANSPORT, 0, PBUF_REF);
  buf->p->payload = dataptr;
  buf->p->len = buf->p->tot_len = size;
  buf->ptr = buf->p;
}

void
netbuf_chain(struct netbuf *head, struct netbuf *tail)
{
  pbuf_chain(head->p, tail->p);
  head->ptr = head->p;
  memp_free(MEMP_NETBUF, tail);
}

u16_t
netbuf_len(struct netbuf *buf)
{
  return buf->p->tot_len;
}

err_t
netbuf_data(struct netbuf *buf, void **dataptr, u16_t *len)
{
  if (buf->ptr == NULL) {
    return ERR_BUF;
  }
  *dataptr = buf->ptr->payload;
  *len = buf->ptr->len;
  return ERR_OK;
}

s8_t
netbuf_next(struct netbuf *buf)
{
  if (buf->ptr->next == NULL) {
    return -1;
  }
  buf->ptr = buf->ptr->next;
  if (buf->ptr->next == NULL) {
    return 1;
  }
  return 0;
}

void
netbuf_first(struct netbuf *buf)
{
  buf->ptr = buf->p;
}

void
netbuf_copy_partial(struct netbuf *buf, void *dataptr, u16_t len, u16_t offset)
{
  struct pbuf *p;
  u16_t i, left;

  left = 0;

  if(buf == NULL || dataptr == NULL) {
    return;
  }
  
  /* This implementation is bad. It should use bcopy
     instead. */
  for(p = buf->p; left < len && p != NULL; p = p->next) {
    if (offset != 0 && offset >= p->len) {
      offset -= p->len;
    } else {    
      for(i = offset; i < p->len; ++i) {
  ((u8_t *)dataptr)[left] = ((u8_t *)p->payload)[i];
  if (++left >= len) {
    return;
  }
      }
      offset = 0;
    }
  }
}

void
netbuf_copy(struct netbuf *buf, void *dataptr, u16_t len)
{
  netbuf_copy_partial(buf, dataptr, len, 0);
}

struct ip_addr *
netbuf_fromaddr(struct netbuf *buf)
{
  return buf->fromaddr;
}

u16_t
netbuf_fromport(struct netbuf *buf)
{
  return buf->fromport;
}

struct
netconn *netconn_new_with_proto_and_callback(enum netconn_type t, u16_t proto,
                                   void (*callback)(struct netconn *, enum netconn_evt, u16_t len))
{
  struct netconn *conn;
  struct api_msg *msg;

  conn = memp_malloc(MEMP_NETCONN);
  if (conn == NULL) {
    return NULL;
  }
  
  conn->err = ERR_OK;
  conn->type = t;
  conn->pcb.tcp = NULL;

  if ((conn->mbox = sys_mbox_new()) == SYS_MBOX_NULL) {
    memp_free(MEMP_NETCONN, conn);
    return NULL;
  }
  conn->recvmbox = SYS_MBOX_NULL;
  conn->acceptmbox = SYS_MBOX_NULL;
  conn->sem = SYS_SEM_NULL;
  conn->state = NETCONN_NONE;
  conn->socket = 0;
  conn->callback = callback;
  conn->recv_avail = 0;

  if((msg = memp_malloc(MEMP_API_MSG)) == NULL) {
    memp_free(MEMP_NETCONN, conn);
    return NULL;
  }
  
  msg->type = API_MSG_NEWCONN;
  msg->msg.msg.bc.port = proto; /* misusing the port field */
  msg->msg.conn = conn;
  api_msg_post(msg);  
  sys_mbox_fetch(conn->mbox, NULL);
  memp_free(MEMP_API_MSG, msg);

  if ( conn->err != ERR_OK ) {
    memp_free(MEMP_NETCONN, conn);
    return NULL;
  }

  return conn;
}


struct
netconn *netconn_new(enum netconn_type t)
{
  return netconn_new_with_proto_and_callback(t,0,NULL);
}

struct
netconn *netconn_new_with_callback(enum netconn_type t,
                                   void (*callback)(struct netconn *, enum netconn_evt, u16_t len))
{
  return netconn_new_with_proto_and_callback(t,0,callback);
}


err_t
netconn_delete(struct netconn *conn)
{
  struct api_msg *msg;
  void *mem;
  
  if (conn == NULL) {
    return ERR_OK;
  }
  
  if ((msg = memp_malloc(MEMP_API_MSG)) == NULL) {
    return ERR_MEM;
  }
  
  msg->type = API_MSG_DELCONN;
  msg->msg.conn = conn;
  api_msg_post(msg);  
  sys_mbox_fetch(conn->mbox, NULL);
  memp_free(MEMP_API_MSG, msg);

  /* Drain the recvmbox. */
  if (conn->recvmbox != SYS_MBOX_NULL) {
    while (sys_arch_mbox_fetch(conn->recvmbox, &mem, 1) != SYS_ARCH_TIMEOUT) {
      if (conn->type == NETCONN_TCP) {
        if(mem != NULL)
          pbuf_free((struct pbuf *)mem);
      } else {
        netbuf_delete((struct netbuf *)mem);
      }
    }
    sys_mbox_free(conn->recvmbox);
    conn->recvmbox = SYS_MBOX_NULL;
  }
 

  /* Drain the acceptmbox. */
  if (conn->acceptmbox != SYS_MBOX_NULL) {
    while (sys_arch_mbox_fetch(conn->acceptmbox, &mem, 1) != SYS_ARCH_TIMEOUT) {
      netconn_delete((struct netconn *)mem);
    }
    
    sys_mbox_free(conn->acceptmbox);
    conn->acceptmbox = SYS_MBOX_NULL;
  }

  sys_mbox_free(conn->mbox);
  conn->mbox = SYS_MBOX_NULL;
  if (conn->sem != SYS_SEM_NULL) {
    sys_sem_free(conn->sem);
  }
  /*  conn->sem = SYS_SEM_NULL;*/
  memp_free(MEMP_NETCONN, conn);
  return ERR_OK;
}

enum netconn_type
netconn_type(struct netconn *conn)
{
  return conn->type;
}

err_t
netconn_peer(struct netconn *conn, struct ip_addr *addr,
       u16_t *port)
{
  switch (conn->type) {
  case NETCONN_RAW:
    /* return an error as connecting is only a helper for upper layers */
    return ERR_CONN;
  case NETCONN_UDPLITE:
  case NETCONN_UDPNOCHKSUM:
  case NETCONN_UDP:
    if (conn->pcb.udp == NULL ||
  ((conn->pcb.udp->flags & UDP_FLAGS_CONNECTED) == 0))
     return ERR_CONN;
    *addr = (conn->pcb.udp->remote_ip);
    *port = conn->pcb.udp->remote_port;
    break;
  case NETCONN_TCP:
    if (conn->pcb.tcp == NULL)
      return ERR_CONN;
    *addr = (conn->pcb.tcp->remote_ip);
    *port = conn->pcb.tcp->remote_port;
    break;
  }
  return (conn->err = ERR_OK);
}

err_t
netconn_addr(struct netconn *conn, struct ip_addr **addr,
       u16_t *port)
{
  switch (conn->type) {
  case NETCONN_RAW:
    *addr = &(conn->pcb.raw->local_ip);
    *port = conn->pcb.raw->protocol;
    break;
  case NETCONN_UDPLITE:
  case NETCONN_UDPNOCHKSUM:
  case NETCONN_UDP:
    *addr = &(conn->pcb.udp->local_ip);
    *port = conn->pcb.udp->local_port;
    break;
  case NETCONN_TCP:
    *addr = &(conn->pcb.tcp->local_ip);
    *port = conn->pcb.tcp->local_port;
    break;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品一区二区三区不卡| 琪琪久久久久日韩精品| 久久国产精品72免费观看| 欧美手机在线视频| 中文字幕av在线一区二区三区| 无吗不卡中文字幕| 欧日韩精品视频| 亚洲妇熟xx妇色黄| 欧美亚洲一区三区| 国产高清在线观看免费不卡| 久久噜噜亚洲综合| 国产一区二区看久久| 久久综合色鬼综合色| 国产一区二区三区在线观看免费| 一区二区三区中文字幕| 色欧美片视频在线观看在线视频| 亚洲三级电影全部在线观看高清| 成人黄色电影在线| 欧美激情一区二区三区在线| 欧美久久久久久蜜桃| 亚洲午夜av在线| 国产精品日韩成人| 欧美色图天堂网| 五月婷婷色综合| 亚洲人精品午夜| 91精品福利在线一区二区三区| 麻豆精品在线看| 国产精品全国免费观看高清 | 国产露脸91国语对白| 亚洲国产精品精华液ab| 亚洲精品一区二区三区香蕉| 成人sese在线| 国产成人午夜电影网| 国产综合久久久久久久久久久久| 亚洲天堂免费看| 国产精品盗摄一区二区三区| 6080日韩午夜伦伦午夜伦| 国产一区二区三区av电影| 蜜臀av性久久久久蜜臀aⅴ| 性久久久久久久久久久久| 久久久精品人体av艺术| 久久久久久久久久久久久夜| 日韩欧美中文字幕公布| 国产成人8x视频一区二区| 亚洲成av人影院| 天天av天天翘天天综合网| 精品国产乱码久久久久久1区2区| 日韩精品一区二区三区在线播放 | 51久久夜色精品国产麻豆| 欧美精品一卡两卡| 欧美一级日韩一级| 日韩免费看网站| 久久蜜桃香蕉精品一区二区三区| 国产无人区一区二区三区| 欧美伦理视频网站| 日韩亚洲欧美中文三级| 精品福利av导航| 中文字幕欧美日本乱码一线二线| 中文字幕在线播放不卡一区| 精品欧美久久久| 欧美精品一级二级| 欧美电视剧免费全集观看| 久久久久久夜精品精品免费| 国产三级一区二区| 亚洲色图视频网站| 亚洲一卡二卡三卡四卡无卡久久| ●精品国产综合乱码久久久久| 亚洲乱码中文字幕| 亚洲欧美另类久久久精品| 首页国产丝袜综合| 懂色av中文字幕一区二区三区| 91视视频在线观看入口直接观看www | 欧美午夜理伦三级在线观看| 欧美日韩午夜精品| 日韩欧美国产一区二区三区| 亚洲精品一区二区精华| 国产精品免费久久| 午夜影院在线观看欧美| 久久激情五月激情| 99久久婷婷国产综合精品| 成人美女视频在线观看18| 国产成人综合网| 欧美性猛交xxxxxx富婆| 久久亚洲精精品中文字幕早川悠里| 国产精品久久精品日日| 午夜视频久久久久久| 国产一二三精品| 在线观看欧美黄色| 久久综合色播五月| 亚洲午夜一区二区三区| 国产综合色在线| 欧美色综合天天久久综合精品| 久久一日本道色综合| 一卡二卡欧美日韩| 国产不卡高清在线观看视频| 欧美色综合网站| 最近日韩中文字幕| 极品少妇一区二区三区精品视频 | 国产一区二区视频在线播放| 欧美性大战xxxxx久久久| 久久久精品综合| 美国一区二区三区在线播放| 色综合中文综合网| 日本女优在线视频一区二区| 蜜臀久久久99精品久久久久久| thepron国产精品| 91国偷自产一区二区三区成为亚洲经典| 一本色道久久综合亚洲精品按摩| 精品国产乱码久久久久久1区2区 | 久久精品国产一区二区三| 91亚洲精品乱码久久久久久蜜桃| 日韩欧美区一区二| 亚洲成人免费影院| 91欧美一区二区| 国产精品久久久久久久久快鸭 | 亚洲一级二级在线| 97国产精品videossex| 国产亚洲污的网站| 激情综合色综合久久综合| 欧美男女性生活在线直播观看| 日韩欧美国产电影| 亚洲成人av资源| 欧美视频一区二区三区| 欧美国产精品v| 国产精品456| 久久久综合视频| 久久69国产一区二区蜜臀| 3d动漫精品啪啪| 日本欧美大码aⅴ在线播放| 欧美精品一级二级| 午夜一区二区三区视频| 欧美中文一区二区三区| 亚洲一区二区三区小说| 99re66热这里只有精品3直播| 国产免费成人在线视频| 亚洲国产精品影院| 欧美亚洲尤物久久| 亚洲成精国产精品女| 日本高清无吗v一区| 亚洲欧美日韩电影| 欧美在线啊v一区| 亚洲午夜精品网| 欧美精品免费视频| 日韩精品一级中文字幕精品视频免费观看 | 91麻豆成人久久精品二区三区| 中文av一区特黄| 91视频观看免费| 亚洲制服丝袜在线| 337p亚洲精品色噜噜噜| 欧美a一区二区| 久久久久久久综合日本| 大美女一区二区三区| 中文字幕五月欧美| 91成人免费电影| 五月婷婷色综合| 26uuu国产日韩综合| 国产iv一区二区三区| 亚洲视频在线一区观看| 欧美三级中文字| 国模冰冰炮一区二区| 中文一区一区三区高中清不卡| 一本在线高清不卡dvd| 亚洲一区二区三区三| 91精品免费观看| 国产精品99久久久久久久vr| 国产精品高潮呻吟| 欧美日韩国产成人在线免费| 加勒比av一区二区| 亚洲三级在线播放| 日韩一级片网站| 成人一级片在线观看| 亚洲黄色在线视频| 日韩免费观看高清完整版 | 色综合网色综合| 日韩av电影免费观看高清完整版 | 久久免费偷拍视频| 一本大道久久a久久精二百| 青青草伊人久久| 国产精品美女久久久久久久久久久| 99免费精品视频| 热久久久久久久| 国产精品国产三级国产aⅴ中文| 91福利小视频| 国产精品综合一区二区| 亚洲激情欧美激情| 久久蜜桃av一区精品变态类天堂| 色94色欧美sute亚洲线路一久 | 91免费视频观看| 麻豆成人av在线| 亚洲精品国产成人久久av盗摄| 精品福利一二区| 欧美精选一区二区| eeuss国产一区二区三区| 日韩成人av影视| 亚洲视频电影在线| 久久久久国产精品免费免费搜索| 欧美视频日韩视频在线观看| 国产成人免费在线观看不卡| 免费成人在线播放| 夜色激情一区二区|