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

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

?? sockets.c

?? atmel at91sam9260 LWIP移植工程
?? C
?? 第 1 頁 / 共 3 頁
字號:
  }  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;  }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区免费看| 国产精品99久久久久久有的能看 | 久久国产综合精品| 不卡一区中文字幕| 777色狠狠一区二区三区| 国产日韩精品一区二区三区| 亚洲成人动漫在线观看| 国产成人av电影在线观看| 欧美日韩亚洲国产综合| 国产精品久久一级| 韩国v欧美v亚洲v日本v| 欧美在线观看你懂的| 中文字幕欧美激情一区| 九九精品视频在线看| 欧美日韩一级二级三级| 中文字幕一区二区三区在线不卡| 久久国产精品72免费观看| 欧美午夜精品一区二区三区| 国产精品三级av在线播放| 精品一区二区三区免费播放 | 亚洲欧美成人一区二区三区| 国产一区高清在线| 日韩午夜中文字幕| 亚洲1区2区3区4区| 欧美性猛片aaaaaaa做受| 自拍偷拍亚洲综合| 成a人片国产精品| 国产日韩欧美一区二区三区乱码 | 国产精品久久久久久亚洲伦| 韩日欧美一区二区三区| 欧美精品久久99久久在免费线 | 久久中文娱乐网| 久久精品国产久精国产爱| 日韩欧美国产三级电影视频| 蜜臀av性久久久久蜜臀aⅴ四虎 | 粉嫩绯色av一区二区在线观看| 日韩久久免费av| 蜜臀国产一区二区三区在线播放| 678五月天丁香亚洲综合网| 亚洲va天堂va国产va久| 欧美日韩日日摸| 午夜精品久久久久久久蜜桃app| 久久精品视频免费观看| 色哟哟一区二区| 欧美视频一区二区三区四区| 日韩一区欧美小说| 国产成人精品免费一区二区| 欧美精品一区男女天堂| 国产福利一区二区三区| 国产精品美女一区二区| 9i看片成人免费高清| 亚洲精品视频观看| 欧美婷婷六月丁香综合色| 亚洲不卡一区二区三区| 日韩一区二区三区精品视频| 激情av综合网| 国产精品午夜久久| 91福利视频网站| 日韩av一区二区在线影视| 欧美成人aa大片| 美女网站色91| 久久久久久久综合日本| 欧美无乱码久久久免费午夜一区| 一卡二卡欧美日韩| 欧美精品久久99| 国产在线不卡一卡二卡三卡四卡| 国产性做久久久久久| 色94色欧美sute亚洲线路二| 日韩av不卡一区二区| 国产欧美一区二区三区鸳鸯浴| 色哟哟精品一区| 青青草原综合久久大伊人精品| 国产亚洲一二三区| 91福利国产精品| 狠狠网亚洲精品| 亚洲久草在线视频| 精品国内二区三区| 一本久久a久久免费精品不卡| 日本不卡在线视频| 国产精品久久久久久久久快鸭 | 欧美一区二区三区四区五区| 国产精品99久久久久久久女警| 亚洲欧美国产77777| 精品国产不卡一区二区三区| 91网站黄www| 国产麻豆精品久久一二三| 一区二区成人在线视频| 久久久久97国产精华液好用吗| 日本高清成人免费播放| 国产毛片精品视频| 日日噜噜夜夜狠狠视频欧美人| 欧美激情在线免费观看| 欧美一区二区人人喊爽| 色婷婷综合久久久久中文 | 91精品婷婷国产综合久久性色| 成人性色生活片| 精品一区二区三区影院在线午夜| 亚洲综合无码一区二区| 亚洲国产精品黑人久久久| 日韩欧美专区在线| 欧美日韩一本到| 日本黄色一区二区| 成人黄色网址在线观看| 国产乱码精品1区2区3区| 日本欧美加勒比视频| 亚洲国产日韩精品| 亚洲精品一二三| 亚洲欧洲一区二区三区| 国产日韩欧美制服另类| 国产亚洲一本大道中文在线| 日韩欧美中文字幕精品| 91麻豆精品国产91久久久资源速度 | 天天影视网天天综合色在线播放| 国产喂奶挤奶一区二区三区| 日韩小视频在线观看专区| 91久久精品午夜一区二区| 色综合天天综合网国产成人综合天 | 久久久国产午夜精品| 精品三级在线看| 欧美成人一区二区| 欧美mv日韩mv国产网站| 欧美大片拔萝卜| 精品精品国产高清a毛片牛牛| 日韩一级片在线播放| 日韩欧美三级在线| 日韩午夜精品电影| 日韩欧美国产不卡| 2021中文字幕一区亚洲| 精品国产一二三| 久久精品日产第一区二区三区高清版 | 欧美国产一区视频在线观看| 欧美国产成人精品| 国产精品三级视频| 一区二区三区中文在线观看| 一区二区三区在线高清| 性感美女极品91精品| 日本成人在线电影网| 极品少妇一区二区| 成人视屏免费看| 精品处破学生在线二十三| 亚洲a一区二区| 中文字幕一区免费在线观看| 1024亚洲合集| 性做久久久久久久久| 久久精品国产亚洲aⅴ| 欧美日韩成人综合天天影院| 制服丝袜在线91| 久久久亚洲精品石原莉奈| 国产精品私人影院| 亚洲国产成人精品视频| 青青草91视频| 成人午夜大片免费观看| 91农村精品一区二区在线| 欧美精品久久久久久久多人混战| 久久新电视剧免费观看| 亚洲免费电影在线| 久久国产精品99久久久久久老狼| 成人av网站大全| 4438成人网| 欧美激情一区在线| 舔着乳尖日韩一区| 成人丝袜高跟foot| 欧美一区二区三区色| 国产精品久久久久永久免费观看| 亚洲一二三区不卡| 粉嫩一区二区三区性色av| 欧美老年两性高潮| 国产欧美日韩三区| 香蕉成人啪国产精品视频综合网| 国产精品影视天天线| 欧美高清视频在线高清观看mv色露露十八 | 中文字幕在线免费不卡| 青青草一区二区三区| 97久久精品人人澡人人爽| 欧美一级生活片| 亚洲精品第一国产综合野| 国产精品一二三区| 4438x成人网最大色成网站| 中文字幕一区免费在线观看| 国产乱码精品一区二区三区av| 欧美视频在线一区| 中文字幕一区二区三区在线播放| 久久狠狠亚洲综合| 欧美性色欧美a在线播放| 国产精品国产三级国产普通话三级| 毛片av一区二区三区| 欧美日精品一区视频| 国产精品国产三级国产普通话99| 狠狠色丁香婷综合久久| 欧美精品在欧美一区二区少妇| 1024精品合集| 成人性生交大片免费| 国产视频一区不卡| 国产米奇在线777精品观看| 日韩亚洲欧美成人一区| 日韩综合在线视频| 欧美嫩在线观看| 亚洲成人综合网站| 欧美午夜不卡视频| 亚洲动漫第一页|