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

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

?? api_lib.c

?? freertosV4.40 是一種small的嵌入式系統(tǒng)。利于嵌入式開好者入門學(xué)習(xí)嵌入式操作系統(tǒng)。通過對(duì)于源碼的學(xué)習(xí)可以很好的掌握freertos的運(yùn)行機(jī)制。
?? C
?? 第 1 頁 / 共 2 頁
字號(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一区二区三区免费野_久草精品视频
18成人在线视频| 欧美午夜精品一区| 精品久久99ma| 丝袜国产日韩另类美女| 99精品国产热久久91蜜凸| 国产亚洲一区二区三区| 久久99九九99精品| 欧美精品久久99| 亚洲国产婷婷综合在线精品| 99精品视频一区二区三区| 国产女主播在线一区二区| 久久av中文字幕片| 2020国产精品| 国产精品18久久久久久久久久久久 | 亚洲一级电影视频| 色欧美日韩亚洲| 亚洲一区二区不卡免费| 欧美日韩久久久久久| 亚洲一区二区三区在线播放| 欧美巨大另类极品videosbest | 日本不卡高清视频| 日韩欧美电影一区| 成人av中文字幕| 亚洲一区二区免费视频| 日韩欧美亚洲一区二区| 九色|91porny| 国产精品国产自产拍高清av| 欧美日韩午夜在线| 精品午夜久久福利影院| 国产精品久久久久久久久免费樱桃| 91猫先生在线| 午夜国产不卡在线观看视频| 26uuu国产在线精品一区二区| 97se亚洲国产综合自在线观| 亚洲一区在线电影| 久久看人人爽人人| 在线视频一区二区三区| 亚洲国产视频一区| 久久久久9999亚洲精品| 精品视频999| 成人自拍视频在线观看| 三级精品在线观看| 国产精品乱人伦一区二区| 欧美一区二区成人6969| 欧美视频在线不卡| www.欧美亚洲| 狠狠色综合播放一区二区| 一区二区成人在线观看| 久久久不卡影院| 日韩午夜激情电影| 欧美精品 日韩| 97精品电影院| 欧美图片一区二区三区| 狠狠色丁香婷婷综合久久片| 亚洲在线免费播放| 亚洲男人的天堂网| 国产三级欧美三级日产三级99 | 99re8在线精品视频免费播放| 捆绑变态av一区二区三区| 性做久久久久久免费观看| 日韩美女啊v在线免费观看| 国产精品丝袜久久久久久app| 精品免费视频一区二区| 日韩免费在线观看| 26uuu成人网一区二区三区| 91精品国产综合久久久久久| 欧美色大人视频| 欧美在线短视频| 欧美日韩在线精品一区二区三区激情 | 久久精品国产**网站演员| 亚洲精品美国一| 亚洲色图视频免费播放| www欧美成人18+| 精品日韩一区二区| 日韩女优av电影| 日韩欧美国产不卡| 欧美一区二区播放| 日韩一区二区三区视频| 91精品国产一区二区三区香蕉| 欧美中文字幕久久| 色久优优欧美色久优优| 99视频在线观看一区三区| 99久久伊人网影院| 岛国av在线一区| 国产xxx精品视频大全| 国产精品中文字幕欧美| 激情文学综合网| 国产精品白丝av| aaa欧美日韩| 色综合咪咪久久| 欧美二区在线观看| 日韩欧美一二三区| 国产欧美日韩卡一| 亚洲成av人片一区二区三区 | 成人av电影免费观看| 色婷婷久久一区二区三区麻豆| 久久综合久久综合九色| 久久久久久99精品| 国产精品国产三级国产aⅴ中文| 一区二区三区自拍| 黑人巨大精品欧美黑白配亚洲| 大美女一区二区三区| 在线视频你懂得一区二区三区| 精品视频一区二区不卡| 日韩亚洲欧美高清| 亚洲国产成人自拍| 亚洲人精品午夜| 国产精品视频免费| 一区二区三区中文在线观看| 麻豆精品久久久| a亚洲天堂av| 日韩视频一区二区三区| 国产精品蜜臀在线观看| 日韩在线一区二区| 不卡av在线网| 精品电影一区二区| 一级精品视频在线观看宜春院| 乱一区二区av| 欧洲一区二区三区免费视频| 国产东北露脸精品视频| xf在线a精品一区二区视频网站| 亚洲欧美一区二区三区孕妇| 免费看精品久久片| 99久久99久久精品免费看蜜桃| 欧美精品国产精品| 日韩一区中文字幕| 老司机精品视频导航| 欧美日韩小视频| 香蕉加勒比综合久久| 99久久精品国产毛片| 综合精品久久久| 麻豆精品一区二区三区| 日韩你懂的电影在线观看| 日日欢夜夜爽一区| 欧美久久高跟鞋激| 日韩精品每日更新| 91精品国产品国语在线不卡| 日韩成人免费电影| 日韩女优av电影| 精品在线免费视频| 精品国产百合女同互慰| 韩国v欧美v亚洲v日本v| 久久久九九九九| 99这里只有精品| 午夜免费久久看| 欧美精品久久久久久久久老牛影院| 一区二区三区不卡在线观看| 在线精品国精品国产尤物884a| 亚洲成人精品一区| 久久视频一区二区| caoporn国产精品| 丝袜美腿亚洲一区二区图片| 精品视频在线免费观看| 韩国精品在线观看| 亚洲码国产岛国毛片在线| 欧美日韩aaaaa| 国产成人免费视频一区| 又紧又大又爽精品一区二区| 欧美高清一级片在线| 免费成人在线影院| 亚洲欧美另类小说| 日韩免费看的电影| 91香蕉视频在线| 国产一区二区美女诱惑| 亚洲一区二区3| 国产欧美精品区一区二区三区| 成人一区在线观看| 久久99最新地址| 亚洲一区二区高清| 国产亚洲va综合人人澡精品| 欧美日韩国产美女| 高潮精品一区videoshd| 亚洲一区二区视频在线| 国产精品天天看| 精品欧美一区二区三区精品久久| 欧洲中文字幕精品| 色94色欧美sute亚洲线路二| 国产精品原创巨作av| 免费高清在线视频一区·| 亚洲成人午夜电影| 夜夜精品视频一区二区| 亚洲欧美自拍偷拍| 久久婷婷国产综合国色天香| 久久色.com| 精品国产免费视频| 精品国产欧美一区二区| 日韩免费看的电影| 日韩一二三区视频| 欧美一区二区三区免费在线看 | 在线观看免费亚洲| 色老头久久综合| 欧美在线免费观看亚洲| 91麻豆精品一区二区三区| 91在线丨porny丨国产| 国产一区二区成人久久免费影院 | 九九**精品视频免费播放| 久久精品久久综合| 精品一区二区三区免费观看| 图片区小说区国产精品视频| 成人精品gif动图一区|