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

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

?? api_lib.c

?? 介紹:uC/OS-II & lwIP ports for TI C6000 DSP。非常好用!
?? 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;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性xxxxxxxx| 26uuu色噜噜精品一区| 免费在线观看精品| 夜夜嗨av一区二区三区| 中日韩av电影| 中文一区二区完整视频在线观看| 久久久噜噜噜久噜久久综合| 日韩美女视频一区二区在线观看| 717成人午夜免费福利电影| 欧美优质美女网站| 欧美日韩中文另类| 欧美一级理论性理论a| 日韩一区二区在线免费观看| 日韩三级视频在线观看| 日韩午夜在线播放| 日韩精品一区二区三区中文不卡 | 日韩一区二区三免费高清| 欧美丝袜丝交足nylons图片| 在线观看亚洲精品视频| 欧美日韩不卡视频| 日韩一级大片在线观看| 久久亚洲精品国产精品紫薇| 国产欧美日韩三级| 国产精品国产a级| 亚洲国产成人av好男人在线观看| 亚洲电影在线播放| 六月婷婷色综合| 盗摄精品av一区二区三区| 99国产一区二区三精品乱码| 欧美午夜精品一区| 日韩美女天天操| 国产精品理论在线观看| 五月激情丁香一区二区三区| 免费观看一级特黄欧美大片| 国产福利91精品一区| 99视频一区二区三区| 欧美日韩精品三区| 久久久久久97三级| 亚洲综合小说图片| 国产在线精品一区二区不卡了| 99久久免费精品| 欧美一区二区免费视频| 国产精品电影院| 人禽交欧美网站| 99国内精品久久| 精品捆绑美女sm三区| 亚洲欧美另类图片小说| 久久国产生活片100| 欧美做爰猛烈大尺度电影无法无天| 精品久久一区二区三区| 亚洲精品视频一区二区| 国产一区二区三区av电影| 欧美在线免费播放| 中文字幕免费不卡| 看国产成人h片视频| 在线观看视频欧美| 国产精品久久久久一区二区三区| 五月婷婷综合在线| 色综合欧美在线视频区| 国产欧美一区视频| 麻豆精品视频在线| 欧美福利视频一区| 一区二区在线观看视频在线观看| 国产精品一线二线三线精华| 欧美日韩高清一区| 一区二区三区小说| av在线不卡观看免费观看| 久久久久国产精品人| 久久国产视频网| 日韩欧美一级精品久久| 午夜一区二区三区在线观看| 欧洲国内综合视频| 亚洲精品久久嫩草网站秘色| 成人久久18免费网站麻豆| 久久综合色综合88| 国产在线精品免费av| 精品久久人人做人人爰| 免费在线看成人av| 日韩欧美国产综合一区| 蜜臀久久久99精品久久久久久| 欧美日韩一级视频| 午夜久久久久久| 欧美日韩国产综合一区二区三区| 亚洲亚洲人成综合网络| 欧美日韩免费高清一区色橹橹| 亚洲综合在线免费观看| 欧美亚洲禁片免费| 日韩和欧美一区二区| 欧美一级日韩不卡播放免费| 久久国产精品露脸对白| 亚洲精品一区二区精华| 国产精品一区不卡| 中文字幕日韩一区| 91日韩在线专区| 亚洲国产成人av网| 日韩欧美123| 国产91丝袜在线18| 亚洲区小说区图片区qvod| 欧美少妇一区二区| 麻豆精品视频在线观看免费| 久久综合国产精品| 色中色一区二区| 日本欧美一区二区三区乱码| wwwwww.欧美系列| 91首页免费视频| 日韩av一区二区在线影视| 国产午夜精品理论片a级大结局 | a4yy欧美一区二区三区| 亚洲自拍偷拍av| 日韩午夜在线播放| av一本久道久久综合久久鬼色| 亚洲一区免费在线观看| 精品久久国产97色综合| 国产成人精品aa毛片| 亚洲影视在线观看| 久久久久亚洲蜜桃| 欧美性猛交一区二区三区精品| 日本欧美一区二区三区| 中文字幕一区二区三区在线观看| 在线观看视频一区| 国产毛片精品视频| 亚洲午夜电影网| 亚洲国产岛国毛片在线| 7777精品伊人久久久大香线蕉 | gogo大胆日本视频一区| 日本大胆欧美人术艺术动态 | 91在线porny国产在线看| 奇米亚洲午夜久久精品| 亚洲免费三区一区二区| 精品精品欲导航| 欧美图区在线视频| 97久久精品人人爽人人爽蜜臀| 免费人成网站在线观看欧美高清| 亚洲免费观看高清完整| 久久久亚洲精品石原莉奈| 欧美日韩你懂得| 91久久精品国产91性色tv| 国产激情精品久久久第一区二区 | 欧美剧情片在线观看| 99国产精品久| 成人在线一区二区三区| 久久电影国产免费久久电影| 亚洲成人1区2区| 一区二区三区在线视频观看58| 久久精品在线观看| 久久嫩草精品久久久精品一| 91精品国产91久久久久久一区二区 | 亚洲精品网站在线观看| 国产精品国产三级国产普通话蜜臀 | 国内精品伊人久久久久av影院 | 久久精品综合网| 精品国产亚洲一区二区三区在线观看 | 美女视频一区在线观看| 亚洲妇熟xx妇色黄| 亚洲一级二级三级在线免费观看| 亚洲男人电影天堂| 亚洲精选在线视频| 一区二区成人在线| 夜夜亚洲天天久久| 亚洲成a人在线观看| 亚洲丶国产丶欧美一区二区三区| 一区二区三区在线视频免费| 亚洲精品乱码久久久久久黑人| 亚洲免费在线看| 亚洲主播在线播放| 亚洲一二三区在线观看| 丝袜美腿亚洲色图| 全国精品久久少妇| 国产在线国偷精品产拍免费yy| 国产乱码精品一区二区三区忘忧草| 精品一区二区三区免费视频| 国产精品小仙女| 91麻豆国产在线观看| 欧美视频一区二区三区四区| 欧美一区二区在线播放| 久久综合久久综合久久| 中文字幕av资源一区| 亚洲欧美电影院| 亚洲成a人v欧美综合天堂| 精品一区二区免费在线观看| 懂色av一区二区三区免费观看| 91麻豆免费观看| 91麻豆精品国产91久久久使用方法 | 91国产免费观看| 91精品国产综合久久国产大片| 精品理论电影在线观看| 国产精品久久一卡二卡| 亚洲二区在线观看| 国产精品一区二区无线| 在线欧美一区二区| 2020国产精品| 亚洲一区在线观看免费| 国产乱理伦片在线观看夜一区| 91欧美激情一区二区三区成人| 欧美色涩在线第一页| 久久久国产精华| 亚洲韩国精品一区| 国产jizzjizz一区二区| 欧美一区国产二区| 亚洲乱码国产乱码精品精小说|