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

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

?? api_lib.c

?? ARM7的一些試驗程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
 * 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) {
  ((char *)dataptr)[left] = ((char *)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
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡视频在线观看| 欧美日韩国产美| 午夜欧美在线一二页| 26uuu亚洲综合色欧美 | 国产成人在线免费| 午夜精品国产更新| 亚洲欧美自拍偷拍| 久久日韩粉嫩一区二区三区 | 337p粉嫩大胆色噜噜噜噜亚洲| 波多野结衣欧美| 久久99最新地址| 亚洲一二三区在线观看| 国产精品三级av| 欧美电影免费观看高清完整版| 在线精品视频免费播放| a4yy欧美一区二区三区| 国产一区二区三区四| 天堂一区二区在线免费观看| 亚洲黄色在线视频| 中文字幕一区二区三区不卡| 久久嫩草精品久久久精品一| 91精品国产91综合久久蜜臀| 日本乱人伦一区| 97精品超碰一区二区三区| 成人免费不卡视频| 国产一区激情在线| 国产一区二区在线观看免费| 毛片av一区二区| 日本视频一区二区三区| 亚洲成人免费观看| 一区二区成人在线| 亚洲精品乱码久久久久久黑人| 国产精品激情偷乱一区二区∴| 2021国产精品久久精品| 精品久久久久久久一区二区蜜臀| 欧美一级日韩不卡播放免费| 欧美久久高跟鞋激| 欧美日韩激情一区| 欧美久久久久久蜜桃| 555夜色666亚洲国产免| 欧美日韩国产成人在线91| 欧美亚洲综合在线| 欧美精品久久天天躁| 欧美日韩aaaaaa| 91精品国产91久久久久久一区二区 | 亚洲国产另类精品专区| 亚洲一区免费在线观看| 亚洲一区二区三区四区在线| 亚洲欧美另类久久久精品 | 中文字幕制服丝袜成人av| 国产精品美女久久久久高潮| 国产精品欧美极品| 亚洲免费观看视频| 性久久久久久久久久久久| 天天操天天干天天综合网| 青青国产91久久久久久| 国产在线一区观看| 99在线精品一区二区三区| 91久久久免费一区二区| 91精品欧美一区二区三区综合在| 精品国产一区二区在线观看| 国产欧美日韩久久| 夜夜精品视频一区二区 | 国产做a爰片久久毛片| 国产一区二区伦理| 97精品视频在线观看自产线路二| 日本道免费精品一区二区三区| 欧美裸体一区二区三区| 精品捆绑美女sm三区| 国产精品乱码一区二区三区软件| 亚洲免费大片在线观看| 天天操天天色综合| 国产成人免费视频一区| 欧美性受xxxx| 日韩欧美另类在线| 国产精品人人做人人爽人人添| 一区二区三区在线观看国产| 日日夜夜精品视频免费| 高清国产午夜精品久久久久久| 91免费精品国自产拍在线不卡| 欧美精品一级二级| 日本一区二区动态图| 亚洲chinese男男1069| 国产一区二区调教| 色综合久久88色综合天天| 日韩片之四级片| 自拍偷拍国产精品| 极品少妇xxxx精品少妇| 在线中文字幕一区二区| 精品国产凹凸成av人导航| 亚洲三级电影网站| 久久精品99国产精品| 色综合天天综合| 精品国产人成亚洲区| 亚洲一卡二卡三卡四卡| 国产成人亚洲综合色影视| 欧美午夜片在线观看| 欧美激情综合网| 老司机免费视频一区二区三区| 91原创在线视频| 久久女同精品一区二区| 天天综合日日夜夜精品| av在线免费不卡| www久久久久| 日韩av中文字幕一区二区三区| 91亚洲精品久久久蜜桃网站| 26uuu欧美日本| 奇米在线7777在线精品| 色88888久久久久久影院按摩| 久久综合色综合88| 免费高清成人在线| 精品视频全国免费看| 亚洲少妇最新在线视频| 国产91精品久久久久久久网曝门| 91精品福利在线一区二区三区| 一区二区视频在线| 99久久久无码国产精品| 久久久国产一区二区三区四区小说| 丝瓜av网站精品一区二区| 色哟哟精品一区| 亚洲欧洲日韩一区二区三区| 国产一区二区三区| 精品久久久久99| 久久精品国产成人一区二区三区| 8x8x8国产精品| 天堂在线亚洲视频| 欧美日韩国产综合视频在线观看| 亚洲欧美日韩小说| 91老师片黄在线观看| 日韩理论片在线| 99精品视频在线播放观看| 中文字幕中文在线不卡住| av成人老司机| 亚洲欧美aⅴ...| 色欧美88888久久久久久影院| 亚洲人快播电影网| 91猫先生在线| 亚洲一二三级电影| 欧美日韩国产大片| 美腿丝袜亚洲三区| 26uuu国产日韩综合| 国产九色sp调教91| 国产视频一区二区在线观看| 成人午夜视频福利| 亚洲同性同志一二三专区| 91亚洲国产成人精品一区二区三 | 麻豆精品在线观看| 日韩一区二区在线观看| 奇米精品一区二区三区在线观看一| 欧美日本在线观看| 久久草av在线| 国产视频亚洲色图| 不卡一区二区三区四区| 一区二区视频在线看| 欧美久久久久免费| 国产伦理精品不卡| 国产精品国产三级国产a| 91久久一区二区| 美女一区二区视频| 国产日韩一级二级三级| 99久久久无码国产精品| 香蕉加勒比综合久久| 日韩一区二区免费视频| 国产精品一区二区久久不卡 | 国精产品一区一区三区mba桃花 | 欧美aⅴ一区二区三区视频| 欧美电影免费观看高清完整版| 国产99久久久国产精品免费看| 综合欧美一区二区三区| 欧美日韩一区久久| 韩国一区二区视频| 中文字幕一区二区三区在线播放| 欧美日韩一区二区三区不卡| 激情小说欧美图片| 亚洲女爱视频在线| 日韩精品一区二区三区在线播放| 国产不卡免费视频| 亚洲无人区一区| 久久久不卡网国产精品二区| 欧美专区日韩专区| 国产综合色视频| 一卡二卡三卡日韩欧美| 久久久亚洲精华液精华液精华液 | 中国色在线观看另类| 欧美日韩在线观看一区二区| 国产精品亚洲第一| 亚洲成人先锋电影| 中文幕一区二区三区久久蜜桃| 精品视频一区三区九区| 国产99精品国产| 视频在线观看91| 亚洲欧洲无码一区二区三区| 日韩欧美一级二级三级久久久| 日本精品一区二区三区高清| 国产高清不卡一区二区| 丝袜诱惑制服诱惑色一区在线观看| 国产精品电影一区二区| 精品国一区二区三区| 欧美日韩日日摸| 91论坛在线播放|