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

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

?? sockets.c

?? 最新版FreeRTOS, 包擴(kuò)多種開(kāi)發(fā)平臺(tái)的移植
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
  memset(&sin, 0, sizeof(sin));  sin.sin_len = sizeof(sin);  sin.sin_family = AF_INET;  /* get the IP address and port of the remote host */  netconn_peer(sock->conn, &naddr, &sin.sin_port);  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getpeername(%d, addr=", s));  ip_addr_debug_print(SOCKETS_DEBUG, &naddr);  LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%d)\n", sin.sin_port));  sin.sin_port = htons(sin.sin_port);  sin.sin_addr.s_addr = naddr.addr;  if (*namelen > sizeof(sin))      *namelen = sizeof(sin);  memcpy(name, &sin, *namelen);  sock_set_errno(sock, 0);  return 0;}int lwip_getsockname (int s, struct sockaddr *name, socklen_t *namelen){  struct lwip_socket *sock;  struct sockaddr_in sin;  struct ip_addr *naddr;  sock = get_socket(s);  if (!sock) {    set_errno(EBADF);    return -1;  }  memset(&sin, 0, sizeof(sin));  sin.sin_len = sizeof(sin);  sin.sin_family = AF_INET;  /* get the IP address and port of the remote host */  netconn_addr(sock->conn, &naddr, &sin.sin_port);  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockname(%d, addr=", s));  ip_addr_debug_print(SOCKETS_DEBUG, naddr);  LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%d)\n", sin.sin_port));  sin.sin_port = htons(sin.sin_port);  sin.sin_addr.s_addr = naddr->addr;  if (*namelen > sizeof(sin))      *namelen = sizeof(sin);  memcpy(name, &sin, *namelen);  sock_set_errno(sock, 0);  return 0;}int lwip_getsockopt (int s, int level, int optname, void *optval, socklen_t *optlen){  int err = 0;  struct lwip_socket *sock = get_socket(s);  if(!sock) {   	set_errno(EBADF);    return -1;  }  if( NULL == optval || NULL == optlen ) {    sock_set_errno( sock, EFAULT );    return -1;  }  /* Do length and type checks for the various options first, to keep it readable. */  switch( level ) {   /* Level: SOL_SOCKET */  case SOL_SOCKET:      switch(optname) {               case SO_ACCEPTCONN:      case SO_BROADCAST:      /* UNIMPL case SO_DEBUG: */      /* UNIMPL case SO_DONTROUTE: */      case SO_ERROR:      case SO_KEEPALIVE:      /* UNIMPL case SO_OOBINLINE: */      /* UNIMPL case SO_RCVBUF: */      /* UNIMPL case SO_SNDBUF: */      /* UNIMPL case SO_RCVLOWAT: */      /* UNIMPL case SO_SNDLOWAT: */#if SO_REUSE      case SO_REUSEADDR:      case SO_REUSEPORT:#endif /* SO_REUSE */      case SO_TYPE:      /* UNIMPL case SO_USELOOPBACK: */        if( *optlen < sizeof(int) ) {          err = EINVAL;        }          break;      default:        LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, SOL_SOCKET, UNIMPL: optname=0x%x, ..)\n", s, optname));        err = ENOPROTOOPT;      }  /* switch */      break;                     /* Level: IPPROTO_IP */  case IPPROTO_IP:      switch(optname) {      /* UNIMPL case IP_HDRINCL: */      /* UNIMPL case IP_RCVDSTADDR: */      /* UNIMPL case IP_RCVIF: */      case IP_TTL:      case IP_TOS:        if( *optlen < sizeof(int) ) {          err = EINVAL;        }        break;      default:        LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, IPPROTO_IP, UNIMPL: optname=0x%x, ..)\n", s, optname));        err = ENOPROTOOPT;      }  /* switch */      break;         /* Level: IPPROTO_TCP */  case IPPROTO_TCP:      if( *optlen < sizeof(int) ) {        err = EINVAL;        break;    }            /* If this is no TCP socket, ignore any options. */      if ( sock->conn->type != NETCONN_TCP ) return 0;      switch( optname ) {      case TCP_NODELAY:      case TCP_KEEPALIVE:        break;               default:        LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, IPPROTO_TCP, UNIMPL: optname=0x%x, ..)\n", s, optname));        err = ENOPROTOOPT;      }  /* switch */      break;/* UNDEFINED LEVEL */  default:      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, level=0x%x, UNIMPL: optname=0x%x, ..)\n", s, level, optname));      err = ENOPROTOOPT;  }  /* switch */     if( 0 != err ) {    sock_set_errno(sock, err);    return -1;  }     /* Now do the actual option processing */  switch(level) {   /* Level: SOL_SOCKET */  case SOL_SOCKET:    switch( optname ) {    /* The option flags */    case SO_ACCEPTCONN:    case SO_BROADCAST:    /* UNIMPL case SO_DEBUG: */    /* UNIMPL case SO_DONTROUTE: */    case SO_KEEPALIVE:    /* UNIMPL case SO_OOBINCLUDE: */#if SO_REUSE    case SO_REUSEADDR:    case SO_REUSEPORT:#endif /* SO_REUSE */    /*case SO_USELOOPBACK: UNIMPL */      *(int*)optval = sock->conn->pcb.tcp->so_options & optname;      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, SOL_SOCKET, optname=0x%x, ..) = %s\n", s, optname, (*(int*)optval?"on":"off")));      break;    case SO_TYPE:      switch (sock->conn->type) {      case NETCONN_RAW:        *(int*)optval = SOCK_RAW;        break;      case NETCONN_TCP:        *(int*)optval = SOCK_STREAM;        break;      case NETCONN_UDP:      case NETCONN_UDPLITE:      case NETCONN_UDPNOCHKSUM:        *(int*)optval = SOCK_DGRAM;        break;      default: /* unrecognized socket type */        *(int*)optval = sock->conn->type;        LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, SOL_SOCKET, SO_TYPE): unrecognized socket type %d\n", s, *(int *)optval));      }  /* switch */      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, SOL_SOCKET, SO_TYPE) = %d\n", s, *(int *)optval));      break;    case SO_ERROR:      *(int *)optval = sock->err;      sock->err = 0;      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, SOL_SOCKET, SO_ERROR) = %d\n", s, *(int *)optval));      break;    }  /* switch */    break;/* Level: IPPROTO_IP */  case IPPROTO_IP:    switch( optname ) {    case IP_TTL:      *(int*)optval = sock->conn->pcb.tcp->ttl;      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, IPPROTO_IP, IP_TTL) = %d\n", s, *(int *)optval));      break;    case IP_TOS:      *(int*)optval = sock->conn->pcb.tcp->tos;      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, IPPROTO_IP, IP_TOS) = %d\n", s, *(int *)optval));      break;    }  /* switch */    break;/* Level: IPPROTO_TCP */  case IPPROTO_TCP:    switch( optname ) {    case TCP_NODELAY:      *(int*)optval = (sock->conn->pcb.tcp->flags & TF_NODELAY);      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, IPPROTO_TCP, TCP_NODELAY) = %s\n", s, (*(int*)optval)?"on":"off") );      break;    case TCP_KEEPALIVE:      *(int*)optval = (int)sock->conn->pcb.tcp->keepalive;      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_getsockopt(%d, IPPROTO_IP, TCP_KEEPALIVE) = %d\n", s, *(int *)optval));      break;    }  /* switch */    break;  }  sock_set_errno(sock, err);  return err ? -1 : 0;}int lwip_setsockopt (int s, int level, int optname, const void *optval, socklen_t optlen){  struct lwip_socket *sock = get_socket(s);  int err = 0;  if(!sock) {   	set_errno(EBADF);    return -1;  }  if( NULL == optval ) {    sock_set_errno( sock, EFAULT );    return -1;  }  /* Do length and type checks for the various options first, to keep it readable. */  switch( level ) {/* Level: SOL_SOCKET */  case SOL_SOCKET:    switch(optname) {    case SO_BROADCAST:    /* UNIMPL case SO_DEBUG: */    /* UNIMPL case SO_DONTROUTE: */    case SO_KEEPALIVE:    /* UNIMPL case SO_OOBINLINE: */    /* UNIMPL case SO_RCVBUF: */    /* UNIMPL case SO_SNDBUF: */    /* UNIMPL case SO_RCVLOWAT: */    /* UNIMPL case SO_SNDLOWAT: */#if SO_REUSE    case SO_REUSEADDR:    case SO_REUSEPORT:#endif /* SO_REUSE */    /* UNIMPL case SO_USELOOPBACK: */      if( optlen < sizeof(int) ) {        err = EINVAL;      }      break;    default:      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, SOL_SOCKET, UNIMPL: optname=0x%x, ..)\n", s, optname));      err = ENOPROTOOPT;    }  /* switch */    break;/* Level: IPPROTO_IP */  case IPPROTO_IP:    switch(optname) {    /* UNIMPL case IP_HDRINCL: */    /* UNIMPL case IP_RCVDSTADDR: */    /* UNIMPL case IP_RCVIF: */    case IP_TTL:    case IP_TOS:      if( optlen < sizeof(int) ) {        err = EINVAL;      }        break;      default:      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, IPPROTO_IP, UNIMPL: optname=0x%x, ..)\n", s, optname));      err = ENOPROTOOPT;    }  /* switch */    break;/* Level: IPPROTO_TCP */  case IPPROTO_TCP:    if( optlen < sizeof(int) ) {      err = EINVAL;        break;    }    /* If this is no TCP socket, ignore any options. */    if ( sock->conn->type != NETCONN_TCP ) return 0;    switch( optname ) {    case TCP_NODELAY:    case TCP_KEEPALIVE:      break;    default:      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, IPPROTO_TCP, UNIMPL: optname=0x%x, ..)\n", s, optname));      err = ENOPROTOOPT;    }  /* switch */    break;/* UNDEFINED LEVEL */        default:    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, level=0x%x, UNIMPL: optname=0x%x, ..)\n", s, level, optname));    err = ENOPROTOOPT;  }  /* switch */  if( 0 != err ) {    sock_set_errno(sock, err);    return -1;  }  /* Now do the actual option processing */  switch(level) {/* Level: SOL_SOCKET */  case SOL_SOCKET:    switch(optname) {    /* The option flags */    case SO_BROADCAST:    /* UNIMPL case SO_DEBUG: */    /* UNIMPL case SO_DONTROUTE: */    case SO_KEEPALIVE:    /* UNIMPL case SO_OOBINCLUDE: */#if SO_REUSE    case SO_REUSEADDR:    case SO_REUSEPORT:#endif /* SO_REUSE */    /* UNIMPL case SO_USELOOPBACK: */      if ( *(int*)optval ) {        sock->conn->pcb.tcp->so_options |= optname;      } else {        sock->conn->pcb.tcp->so_options &= ~optname;      }      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, SOL_SOCKET, optname=0x%x, ..) -> %s\n", s, optname, (*(int*)optval?"on":"off")));      break;    }  /* switch */    break;/* Level: IPPROTO_IP */  case IPPROTO_IP:    switch( optname ) {    case IP_TTL:      sock->conn->pcb.tcp->ttl = (u8_t)(*(int*)optval);      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, IPPROTO_IP, IP_TTL, ..) -> %u\n", s, sock->conn->pcb.tcp->ttl));      break;    case IP_TOS:      sock->conn->pcb.tcp->tos = (u8_t)(*(int*)optval);      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, IPPROTO_IP, IP_TOS, ..)-> %u\n", s, sock->conn->pcb.tcp->tos));      break;    }  /* switch */    break;/* Level: IPPROTO_TCP */  case IPPROTO_TCP:    switch( optname ) {    case TCP_NODELAY:      if ( *(int*)optval ) {        sock->conn->pcb.tcp->flags |= TF_NODELAY;      } else {        sock->conn->pcb.tcp->flags &= ~TF_NODELAY;      }      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, IPPROTO_TCP, TCP_NODELAY) -> %s\n", s, (*(int *)optval)?"on":"off") );      break;    case TCP_KEEPALIVE:      sock->conn->pcb.tcp->keepalive = (u32_t)(*(int*)optval);      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_setsockopt(%d, IPPROTO_TCP, TCP_KEEPALIVE) -> %lu\n", s, sock->conn->pcb.tcp->keepalive));      break;    }  /* switch */    break;  }  /* switch */  sock_set_errno(sock, err);  return err ? -1 : 0;}int lwip_ioctl(int s, long cmd, void *argp){  struct lwip_socket *sock = get_socket(s);  if(!sock) {   	set_errno(EBADF);    return -1;  }  switch (cmd) {  case FIONREAD:    if (!argp) {      sock_set_errno(sock, EINVAL);      return -1;    }    *((u16_t*)argp) = sock->conn->recv_avail;    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_ioctl(%d, FIONREAD, %p) = %u\n", s, argp, *((u16_t*)argp)));    sock_set_errno(sock, 0);    return 0;  case FIONBIO:    if (argp && *(u32_t*)argp)      sock->flags |= O_NONBLOCK;    else      sock->flags &= ~O_NONBLOCK;    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_ioctl(%d, FIONBIO, %d)\n", s, !!(sock->flags & O_NONBLOCK)));    sock_set_errno(sock, 0);    return 0;  default:    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_ioctl(%d, UNIMPL: 0x%lx, %p)\n", s, cmd, argp));    sock_set_errno(sock, ENOSYS); /* not yet implemented */    return -1;  }}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区在线| 成人国产精品免费观看动漫| 久久综合久久综合亚洲| 成人av电影免费在线播放| 亚洲妇熟xx妇色黄| 中文字幕的久久| 91精品国产综合久久蜜臀| www.亚洲精品| 久久av中文字幕片| 亚洲制服丝袜av| 中文av字幕一区| 日韩精品在线一区二区| 99久久综合色| 国内精品国产三级国产a久久| 亚洲综合区在线| 国产精品久久久久桃色tv| 欧美一卡在线观看| 欧美在线一二三| www.在线欧美| 国产69精品一区二区亚洲孕妇 | 亚洲高清视频的网址| 日本一区二区电影| 2欧美一区二区三区在线观看视频| 欧洲精品一区二区三区在线观看| 国产成人午夜高潮毛片| 免费在线一区观看| 亚洲自拍偷拍网站| 日韩毛片一二三区| 18成人在线视频| 国产欧美一区二区在线| 精品日韩一区二区三区免费视频| 欧美系列亚洲系列| 91色乱码一区二区三区| 国产成人免费视频网站高清观看视频 | 日本不卡123| 亚洲高清免费观看| 亚洲小说欧美激情另类| 亚洲精品伦理在线| 亚洲免费观看高清完整版在线观看 | 中文字幕欧美一| 久久久精品中文字幕麻豆发布| 日韩欧美精品在线| 日韩天堂在线观看| 日韩精品中文字幕在线不卡尤物| 91麻豆精品国产91久久久| 欧美高清一级片在线| 欧美日韩在线直播| 欧美日本乱大交xxxxx| 欧美日韩激情在线| 欧美区一区二区三区| 欧美精品久久天天躁| 欧美日韩在线不卡| 欧美精品日韩一本| 欧美成人video| 亚洲精品在线免费播放| 欧美精品一区二区三区一线天视频 | 日韩国产精品91| 老汉av免费一区二区三区| 狂野欧美性猛交blacked| 蜜臀av国产精品久久久久 | 国产乱人伦精品一区二区在线观看| 男女男精品视频网| 捆绑调教美女网站视频一区| 激情综合色播激情啊| 国产98色在线|日韩| 成人午夜伦理影院| 一本大道av一区二区在线播放 | 91香蕉视频mp4| 欧美综合色免费| 日韩一级欧美一级| 久久美女艺术照精彩视频福利播放| 中文字幕av一区二区三区高| 亚洲人成人一区二区在线观看| 亚洲自拍偷拍欧美| 老司机精品视频一区二区三区| 国产**成人网毛片九色| 99国产精品久久久| 欧美区视频在线观看| 国产性色一区二区| 亚洲精品国产第一综合99久久 | 亚洲超碰精品一区二区| 乱一区二区av| 91丝袜美女网| 欧美一级黄色片| 中文字幕精品综合| 丝袜亚洲另类丝袜在线| 国产一区二区三区免费| 91福利在线免费观看| 日韩精品中午字幕| 日韩毛片一二三区| 精品伊人久久久久7777人| 99久久久精品| 欧美一级精品在线| 亚洲女厕所小便bbb| 青青草成人在线观看| 成人av在线播放网站| 欧美男生操女生| 中文字幕成人在线观看| 日本在线观看不卡视频| 成人午夜电影网站| 欧美精品色一区二区三区| 国产精品灌醉下药二区| 日韩电影一区二区三区四区| 成人在线视频一区| 91精品国产综合久久久久久漫画| 国产精品久久久久久久岛一牛影视| 午夜久久久影院| 成人av网在线| 精品美女被调教视频大全网站| 一区二区三区色| 国产成人精品一区二| 欧美一级精品大片| 亚洲电影一区二区三区| 成人精品视频.| 精品国产亚洲在线| 午夜久久电影网| 99国产精品99久久久久久| 久久综合九色综合欧美98| 日本中文在线一区| 欧美三级电影在线看| 亚洲视频小说图片| 大胆欧美人体老妇| 国产欧美精品一区| 美国三级日本三级久久99| 欧美日韩在线一区二区| 曰韩精品一区二区| 色综合欧美在线| 中文字幕亚洲一区二区va在线| 国产精品一级在线| 久久综合五月天婷婷伊人| 久久精品久久99精品久久| 欧美伊人精品成人久久综合97| 亚洲人成网站色在线观看| 国产成人综合自拍| 久久亚洲二区三区| 国产精品影音先锋| 2021国产精品久久精品| 男人的j进女人的j一区| 日韩精品一区二区三区视频在线观看 | 色噜噜偷拍精品综合在线| 一色桃子久久精品亚洲| 成人h动漫精品一区二区| 国产精品成人免费精品自在线观看 | 国产午夜亚洲精品午夜鲁丝片 | 国产精品免费久久| 成人综合婷婷国产精品久久蜜臀 | 国产成人精品免费网站| 欧美国产综合色视频| 成人高清伦理免费影院在线观看| 国产欧美日韩在线看| 不卡视频一二三| 尤物在线观看一区| 欧美无人高清视频在线观看| 午夜精品视频一区| 91精品国产色综合久久不卡蜜臀 | 午夜精品视频一区| 日韩午夜激情av| 国产一区二区三区免费播放| 国产欧美日本一区二区三区| 不卡电影免费在线播放一区| 亚洲精品免费看| 欧美丰满嫩嫩电影| 裸体健美xxxx欧美裸体表演| 精品日本一线二线三线不卡| 国产成人亚洲综合色影视| 中文字幕亚洲一区二区av在线| 色哟哟在线观看一区二区三区| 婷婷中文字幕一区三区| 精品1区2区在线观看| 99在线热播精品免费| 亚洲一区二区三区小说| 日韩视频永久免费| 不卡的av网站| 午夜在线电影亚洲一区| 精品国产百合女同互慰| 成人高清伦理免费影院在线观看| 艳妇臀荡乳欲伦亚洲一区| 欧美一区二区精品| 成人午夜私人影院| 亚洲在线视频免费观看| 日韩欧美国产精品| 成人伦理片在线| 无吗不卡中文字幕| 亚洲国产高清在线| 911精品国产一区二区在线| 国产99久久久国产精品潘金网站| 亚洲最新视频在线观看| 久久久久久久久久久久久久久99 | 国产精品乱人伦一区二区| 欧美日韩国产高清一区| 国产成人亚洲精品青草天美| 香蕉成人伊视频在线观看| 久久精品视频在线免费观看| 欧美在线观看视频在线| 国产精品一二三在| 午夜成人在线视频| 国产精品久久久久久久浪潮网站 | 91污片在线观看| 国产一区二区三区精品视频| 懂色av一区二区夜夜嗨|