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

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

?? sockets.c

?? 焦海波大蝦在uCOS_II上移植LwIP的源代碼。具體說明比較大
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* * 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> * * Improved by Marc Boucher <marc@mbsi.ca> and David Haas <dhaas@alum.rpi.edu> * */#include <string.h>//#include <errno.h>#include "lwip/opt.h"#include "lwip/api.h"#include "lwip/arch.h"#include "lwip/sys.h"#include "lwip/sockets.h"#define NUM_SOCKETS MEMP_NUM_NETCONNstruct lwip_socket {  struct netconn *conn;  struct netbuf *lastdata;  u16_t lastoffset;  u16_t rcvevent;  u16_t sendevent;  u16_t  flags;  int err;};struct lwip_select_cb{    struct lwip_select_cb *next;    fd_set *readset;    fd_set *writeset;    fd_set *exceptset;    int sem_signalled;    sys_sem_t sem;};static struct lwip_socket sockets[NUM_SOCKETS];static struct lwip_select_cb *select_cb_list = 0;static sys_sem_t socksem = 0;static sys_sem_t selectsem = 0;static voidevent_callback(struct netconn *conn, enum netconn_evt evt, u16_t len);static int err_to_errno_table[11] = {    0,      /* ERR_OK    0      No error, everything OK. */    ENOMEM,    /* ERR_MEM  -1      Out of memory error.     */    ENOBUFS,    /* ERR_BUF  -2      Buffer error.            */    ECONNABORTED,  /* ERR_ABRT -3      Connection aborted.      */    ECONNRESET,    /* ERR_RST  -4      Connection reset.        */    ESHUTDOWN,    /* ERR_CLSD -5      Connection closed.       */    ENOTCONN,    /* ERR_CONN -6      Not connected.           */    EINVAL,    /* ERR_VAL  -7      Illegal value.           */    EIO,    /* ERR_ARG  -8      Illegal argument.        */    EHOSTUNREACH,  /* ERR_RTE  -9      Routing problem.         */    EADDRINUSE    /* ERR_USE  -10     Address in use.          */};#define ERR_TO_ERRNO_TABLE_SIZE \  (sizeof(err_to_errno_table)/sizeof(err_to_errno_table[0]))#define err_to_errno(err) \  (-(err) >= 0 && -(err) < ERR_TO_ERRNO_TABLE_SIZE ? \    err_to_errno_table[-(err)] : EIO)#ifdef ERRNO#define set_errno(err) errno = (err)#else#define set_errno(err)#endif#define sock_set_errno(sk, e) do { \      sk->err = (e); \      set_errno(sk->err); \} while (0)static struct lwip_socket *get_socket(int s){  struct lwip_socket *sock;  if ((s < 0) || (s > NUM_SOCKETS)) {    LWIP_DEBUGF(SOCKETS_DEBUG, ("get_socket(%d): invalid\n", s));    set_errno(EBADF);    return NULL;  }  sock = &sockets[s];  if (!sock->conn) {    LWIP_DEBUGF(SOCKETS_DEBUG, ("get_socket(%d): not active\n", s));    set_errno(EBADF);    return NULL;  }  return sock;}static intalloc_socket(struct netconn *newconn){  int i;  if (!socksem)      socksem = sys_sem_new(1);  /* Protect socket array */  sys_sem_wait(socksem);  /* allocate a new socket identifier */  for(i = 0; i < NUM_SOCKETS; ++i) {    if (!sockets[i].conn) {      sockets[i].conn = newconn;      sockets[i].lastdata = NULL;      sockets[i].lastoffset = 0;      sockets[i].rcvevent = 0;      sockets[i].sendevent = 1; /* TCP send buf is empty */      sockets[i].flags = 0;      sockets[i].err = 0;      sys_sem_signal(socksem);      return i;    }  }  sys_sem_signal(socksem);  return -1;}intlwip_accept(int s, struct sockaddr *addr, socklen_t *addrlen){  struct lwip_socket *sock;  struct netconn *newconn;  struct ip_addr naddr;  u16_t port;  int newsock;  struct sockaddr_in sin;  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_accept(%d)...\n", s));  sock = get_socket(s);  if (!sock) {    set_errno(EBADF);    return -1;  }  newconn = netconn_accept(sock->conn);  /* get the IP address and port of the remote host */  netconn_peer(newconn, &naddr, &port);  memset(&sin, 0, sizeof(sin));  sin.sin_len = sizeof(sin);  sin.sin_family = AF_INET;  sin.sin_port = htons(port);  sin.sin_addr.s_addr = naddr.addr;  if (*addrlen > sizeof(sin))      *addrlen = sizeof(sin);  memcpy(addr, &sin, *addrlen);  newsock = alloc_socket(newconn);  if (newsock == -1) {    netconn_delete(newconn);  sock_set_errno(sock, ENOBUFS);  return -1;  }  newconn->callback = event_callback;  sock = get_socket(newsock);  sys_sem_wait(socksem);  sock->rcvevent += -1 - newconn->socket;  newconn->socket = newsock;  sys_sem_signal(socksem);  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_accept(%d) returning new sock=%d addr=", s, newsock));  ip_addr_debug_print(SOCKETS_DEBUG, &naddr);  LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%u\n", port));  sock_set_errno(sock, 0);  return newsock;}intlwip_bind(int s, struct sockaddr *name, socklen_t namelen){  struct lwip_socket *sock;  struct ip_addr local_addr;  u16_t local_port;  err_t err;  sock = get_socket(s);  if (!sock) {    set_errno(EBADF);    return -1;  }  local_addr.addr = ((struct sockaddr_in *)name)->sin_addr.s_addr;  local_port = ((struct sockaddr_in *)name)->sin_port;  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_bind(%d, addr=", s));  ip_addr_debug_print(SOCKETS_DEBUG, &local_addr);  LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%u)\n", ntohs(local_port)));  err = netconn_bind(sock->conn, &local_addr, ntohs(local_port));  if (err != ERR_OK) {    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_bind(%d) failed, err=%d\n", s, err));    sock_set_errno(sock, err_to_errno(err));    return -1;  }  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_bind(%d) succeeded\n", s));  sock_set_errno(sock, 0);  return 0;}intlwip_close(int s){  struct lwip_socket *sock;  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_close(%d)\n", s));  if (!socksem)      socksem = sys_sem_new(1);  /* We cannot allow multiple closes of the same socket. */  sys_sem_wait(socksem);  sock = get_socket(s);  if (!sock) {      sys_sem_signal(socksem);      set_errno(EBADF);      return -1;  }  netconn_delete(sock->conn);  if (sock->lastdata) {    netbuf_delete(sock->lastdata);  }  sock->lastdata = NULL;  sock->lastoffset = 0;  sock->conn = NULL;  sys_sem_signal(socksem);  sock_set_errno(sock, 0);  return 0;}intlwip_connect(int s, struct sockaddr *name, socklen_t namelen){  struct lwip_socket *sock;  err_t err;  sock = get_socket(s);  if (!sock) {    set_errno(EBADF);    return -1;  }  if (((struct sockaddr_in *)name)->sin_family == AF_UNSPEC) {    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d, AF_UNSPEC)\n", s));    err = netconn_disconnect(sock->conn);  } else {    struct ip_addr remote_addr;    u16_t remote_port;    remote_addr.addr = ((struct sockaddr_in *)name)->sin_addr.s_addr;    remote_port = ((struct sockaddr_in *)name)->sin_port;    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d, addr=", s));    ip_addr_debug_print(SOCKETS_DEBUG, &remote_addr);    LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%u)\n", ntohs(remote_port)));    err = netconn_connect(sock->conn, &remote_addr, ntohs(remote_port));   }  if (err != ERR_OK) {    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d) failed, err=%d\n", s, err));    sock_set_errno(sock, err_to_errno(err));    return -1;  }  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d) succeeded\n", s));  sock_set_errno(sock, 0);  return 0;}intlwip_listen(int s, int backlog){  struct lwip_socket *sock;  err_t err;  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_listen(%d, backlog=%d)\n", s, backlog));  sock = get_socket(s);  if (!sock) {    set_errno(EBADF);    return -1;  }  err = netconn_listen(sock->conn);  if (err != ERR_OK) {    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_listen(%d) failed, err=%d\n", s, err));    sock_set_errno(sock, err_to_errno(err));    return -1;  }  sock_set_errno(sock, 0);  return 0;}intlwip_recvfrom(int s, void *mem, int len, unsigned int flags,        struct sockaddr *from, socklen_t *fromlen){  struct lwip_socket *sock;  struct netbuf *buf;  u16_t buflen, copylen;  struct ip_addr *addr;  u16_t port;  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_recvfrom(%d, %p, %d, 0x%x, ..)\n", s, mem, len, flags));  sock = get_socket(s);  if (!sock) {    set_errno(EBADF);    return -1;  }  /* Check if there is data left from the last recv operation. */  if (sock->lastdata) {    buf = sock->lastdata;  } else {    /* If this is non-blocking call, then check first */    if (((flags & MSG_DONTWAIT) || (sock->flags & O_NONBLOCK))  && !sock->rcvevent)    {      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_recvfrom(%d): returning EWOULDBLOCK\n", s));      sock_set_errno(sock, EWOULDBLOCK);      return -1;    }    /* No data was left from the previous operation, so we try to get       some from the network. */    buf = netconn_recv(sock->conn);    if (!buf) {      /* We should really do some error checking here. */      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_recvfrom(%d): buf == NULL!\n", s));      sock_set_errno(sock, 0);      return 0;    }  }  buflen = netbuf_len(buf);  buflen -= sock->lastoffset;  if (len > buflen) {    copylen = buflen;  } else {    copylen = len;  }  /* copy the contents of the received buffer into     the supplied memory pointer mem */  netbuf_copy_partial(buf, mem, copylen, sock->lastoffset);  /* Check to see from where the data was. */  if (from && fromlen) {    struct sockaddr_in sin;    addr = netbuf_fromaddr(buf);    port = netbuf_fromport(buf);    memset(&sin, 0, sizeof(sin));    sin.sin_len = sizeof(sin);    sin.sin_family = AF_INET;    sin.sin_port = htons(port);    sin.sin_addr.s_addr = addr->addr;    if (*fromlen > sizeof(sin))      *fromlen = sizeof(sin);    memcpy(from, &sin, *fromlen);    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_recvfrom(%d): addr=", s));    ip_addr_debug_print(SOCKETS_DEBUG, addr);    LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%u len=%u\n", port, copylen));  } else {#if SOCKETS_DEBUG    addr = netbuf_fromaddr(buf);    port = netbuf_fromport(buf);    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_recvfrom(%d): addr=", s));    ip_addr_debug_print(SOCKETS_DEBUG, addr);    LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%u len=%u\n", port, copylen));#endif  }  /* If this is a TCP socket, check if there is data left in the     buffer. If so, it should be saved in the sock structure for next     time around. */  if (netconn_type(sock->conn) == NETCONN_TCP && buflen - copylen > 0) {    sock->lastdata = buf;    sock->lastoffset += copylen;  } else {    sock->lastdata = NULL;    sock->lastoffset = 0;    netbuf_delete(buf);  }  sock_set_errno(sock, 0);  return copylen;}intlwip_read(int s, void *mem, int len){  return lwip_recvfrom(s, mem, len, 0, NULL, NULL);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久久久果冻传媒 | 国产成人亚洲精品狼色在线 | 蜜臀av性久久久久av蜜臀妖精| 国产一区二区视频在线播放| 欧美日韩一区二区三区高清| 国产精品青草综合久久久久99| 日日欢夜夜爽一区| 制服丝袜亚洲色图| 一区二区三区四区蜜桃| kk眼镜猥琐国模调教系列一区二区| 久久久不卡网国产精品二区| 中文字幕一区二区三区四区不卡 | 91麻豆精品国产91久久久资源速度| 国产大陆亚洲精品国产| 亚洲成人www| 亚洲视频在线一区| 久久欧美一区二区| 欧美一区二区三区成人| 日本精品一级二级| 高清av一区二区| 精品在线播放午夜| 日本一区中文字幕| 亚洲一区二区在线免费观看视频| 国产精品视频九色porn| 欧美成人一级视频| 91精品国产综合久久久久久| 欧美综合亚洲图片综合区| 99视频精品在线| 懂色av一区二区在线播放| 久草这里只有精品视频| 日本欧美韩国一区三区| 亚洲国产精品久久久久秋霞影院| 一区二区三区中文在线观看| 国产精品久久久久婷婷| 国产视频一区二区三区在线观看| 久久综合久色欧美综合狠狠| 欧美xfplay| 欧美成人一区二区三区片免费| 日韩三区在线观看| 欧美一级精品在线| 欧美一区二区久久久| 日韩一级视频免费观看在线| 日韩精品一区二区三区三区免费 | 国产精品综合久久| 蜜臀a∨国产成人精品| 美女脱光内衣内裤视频久久网站| 日本成人在线不卡视频| 青青草国产成人av片免费| 免费成人av在线| 蜜芽一区二区三区| 久久99国产乱子伦精品免费| 亚洲欧洲韩国日本视频| 精品国产免费人成在线观看| 久久久www成人免费无遮挡大片| 欧美日韩中字一区| 91麻豆国产福利在线观看| 91亚洲国产成人精品一区二区三| 色婷婷亚洲婷婷| 久久99久久久久| 日韩高清一区在线| 图片区小说区国产精品视频| 韩国欧美一区二区| 国产成人av一区二区| 国产精品一级片在线观看| 国产91精品在线观看| 91色在线porny| 欧洲生活片亚洲生活在线观看| 欧美丝袜自拍制服另类| 日韩一区二区不卡| 久久嫩草精品久久久久| 国产精品久久福利| 亚洲在线视频免费观看| 蜜臀av亚洲一区中文字幕| 国产成人综合亚洲网站| 在线一区二区视频| 欧美一三区三区四区免费在线看| 欧美精品一区二区三| 亚洲少妇中出一区| 日韩精品成人一区二区在线| 国产一区二区美女| 一本一道综合狠狠老| 欧美一级黄色大片| 日本一二三四高清不卡| 婷婷综合五月天| 国产成人免费视频一区| 欧美性大战久久久| www国产成人免费观看视频 深夜成人网| 国产精品卡一卡二卡三| 琪琪一区二区三区| 波多野结衣一区二区三区| 欧美一区二区三区在线看| 国产精品精品国产色婷婷| 奇米一区二区三区| 99riav一区二区三区| 欧美成人三级电影在线| 亚洲欧美日韩国产一区二区三区| 麻豆高清免费国产一区| 日本伦理一区二区| 国产欧美一二三区| 免费久久精品视频| 色欧美88888久久久久久影院| 久久噜噜亚洲综合| 香蕉成人伊视频在线观看| 成人毛片老司机大片| 欧美大片日本大片免费观看| 亚洲一区二区三区四区中文字幕 | 成人丝袜高跟foot| 欧美乱妇一区二区三区不卡视频| 国产精品人人做人人爽人人添 | 国产超碰在线一区| 日本高清免费不卡视频| 精品国产一区二区三区久久久蜜月 | 国产精品国产自产拍在线| 美女脱光内衣内裤视频久久影院| 91精品国产综合久久久久久| 欧美v日韩v国产v| 日韩一区二区三区观看| 亚洲第一福利一区| av成人免费在线| 国产区在线观看成人精品| 日韩电影在线免费| 欧美体内she精视频| 亚洲你懂的在线视频| 成人性生交大片免费看视频在线| 欧美成人精品3d动漫h| 亚洲第一狼人社区| 在线国产电影不卡| 国产精品第五页| 成人精品gif动图一区| 久久精品视频在线看| 久久av资源站| 精品欧美一区二区久久| 老鸭窝一区二区久久精品| 欧美精品自拍偷拍动漫精品| 亚洲愉拍自拍另类高清精品| 91国产视频在线观看| 亚洲激情五月婷婷| 在线观看欧美精品| 一区二区三区电影在线播| 91网站视频在线观看| 亚洲精品免费看| 色系网站成人免费| 一区二区三区丝袜| 91精品福利视频| 亚洲一区二区美女| 欧美日韩国产综合一区二区| 视频一区二区欧美| 91精品午夜视频| 久久精品国产久精国产爱| 精品久久久久久无| 国产剧情一区二区三区| 国产精品区一区二区三| 91亚洲午夜精品久久久久久| 亚洲影院理伦片| 91麻豆精品国产自产在线| 精品一区二区免费视频| 久久久精品国产免费观看同学| 成人av午夜影院| 伊人色综合久久天天人手人婷| 欧美亚洲国产一区在线观看网站| 午夜精品福利在线| 欧美大片国产精品| 成人高清免费观看| 一区二区三区在线视频观看58| 欧美三级日本三级少妇99| 蜜臀国产一区二区三区在线播放 | 日韩激情视频网站| 久久亚洲综合色一区二区三区| 精品一区二区免费在线观看| 日本在线不卡视频一二三区| 精久久久久久久久久久| 欧美xingq一区二区| 日韩欧美亚洲一区二区| 欧美福利视频一区| 欧美日韩亚洲综合一区二区三区| 欧美日韩国产中文| 久久久久久亚洲综合| 91精品麻豆日日躁夜夜躁| 日本精品视频一区二区| 乱一区二区av| 日韩av中文字幕一区二区三区| 日韩国产精品大片| 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美精三区欧美精三区| 久久国产欧美日韩精品| 亚洲欧洲精品一区二区三区不卡 | 色噜噜夜夜夜综合网| 久久精品国产99国产| 国产精品高潮久久久久无| 91精品国产欧美日韩| 国产suv一区二区三区88区| 亚洲成人你懂的| 国产拍揄自揄精品视频麻豆| 欧美日产在线观看| 国产精品中文字幕一区二区三区| 亚洲福利视频一区| 国产精品另类一区| 日韩欧美一二三| 欧美性色aⅴ视频一区日韩精品| 国内偷窥港台综合视频在线播放|