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

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

?? sockets.c

?? 最新版FreeRTOS, 包擴(kuò)多種開(kāi)發(fā)平臺(tái)的移植
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
intlwip_recv(int s, void *mem, int len, unsigned int flags){  return lwip_recvfrom(s, mem, len, flags, NULL, NULL);}intlwip_send(int s, void *data, int size, unsigned int flags){  struct lwip_socket *sock;  struct netbuf *buf;  err_t err;  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_send(%d, data=%p, size=%d, flags=0x%x)\n", s, data, size, flags));  sock = get_socket(s);  if (!sock) {    set_errno(EBADF);    return -1;  }  switch (netconn_type(sock->conn)) {  case NETCONN_RAW:  case NETCONN_UDP:  case NETCONN_UDPLITE:  case NETCONN_UDPNOCHKSUM:    /* create a buffer */    buf = netbuf_new();    if (!buf) {      LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_send(%d) ENOBUFS\n", s));      sock_set_errno(sock, ENOBUFS);      return -1;    }    /* make the buffer point to the data that should       be sent */    netbuf_ref(buf, data, size);    /* send the data */    err = netconn_send(sock->conn, buf);    /* deallocated the buffer */    netbuf_delete(buf);    break;  case NETCONN_TCP:    err = netconn_write(sock->conn, data, size, NETCONN_COPY);    break;  default:    err = ERR_ARG;    break;  }  if (err != ERR_OK) {    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_send(%d) err=%d\n", s, err));    sock_set_errno(sock, err_to_errno(err));    return -1;  }  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_send(%d) ok size=%d\n", s, size));  sock_set_errno(sock, 0);  return size;}intlwip_sendto(int s, void *data, int size, unsigned int flags,       struct sockaddr *to, socklen_t tolen){  struct lwip_socket *sock;  struct ip_addr remote_addr, addr;  u16_t remote_port, port;  int ret,connected;  sock = get_socket(s);  if (!sock) {    set_errno(EBADF);    return -1;  }  /* get the peer if currently connected */  connected = (netconn_peer(sock->conn, &addr, &port) == ERR_OK);  remote_addr.addr = ((struct sockaddr_in *)to)->sin_addr.s_addr;  remote_port = ((struct sockaddr_in *)to)->sin_port;  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_sendto(%d, data=%p, size=%d, flags=0x%x to=", s, data, size, flags));  ip_addr_debug_print(SOCKETS_DEBUG, &remote_addr);  LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%u\n", ntohs(remote_port)));  netconn_connect(sock->conn, &remote_addr, ntohs(remote_port));  ret = lwip_send(s, data, size, flags);  /* reset the remote address and port number     of the connection */  if (connected)    netconn_connect(sock->conn, &addr, port);  else  netconn_disconnect(sock->conn);  return ret;}intlwip_socket(int domain, int type, int protocol){  struct netconn *conn;  int i;  /* create a netconn */  switch (type) {  case SOCK_RAW:    conn = netconn_new_with_proto_and_callback(NETCONN_RAW, protocol, event_callback);    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_socket(%s, SOCK_RAW, %d) = ", domain == PF_INET ? "PF_INET" : "UNKNOWN", protocol));    break;  case SOCK_DGRAM:    conn = netconn_new_with_callback(NETCONN_UDP, event_callback);    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_socket(%s, SOCK_DGRAM, %d) = ", domain == PF_INET ? "PF_INET" : "UNKNOWN", protocol));    break;  case SOCK_STREAM:    conn = netconn_new_with_callback(NETCONN_TCP, event_callback);    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_socket(%s, SOCK_STREAM, %d) = ", domain == PF_INET ? "PF_INET" : "UNKNOWN", protocol));    break;  default:    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_socket(%d, %d/UNKNOWN, %d) = -1\n", domain, type, protocol));    set_errno(EINVAL);    return -1;  }  if (!conn) {    LWIP_DEBUGF(SOCKETS_DEBUG, ("-1 / ENOBUFS (could not create netconn)\n"));    set_errno(ENOBUFS);    return -1;  }  i = alloc_socket(conn);  if (i == -1) {    netconn_delete(conn);  set_errno(ENOBUFS);  return -1;  }  conn->socket = i;  LWIP_DEBUGF(SOCKETS_DEBUG, ("%d\n", i));  set_errno(0);  return i;}intlwip_write(int s, void *data, int size){   return lwip_send(s, data, size, 0);}static intlwip_selscan(int maxfdp1, fd_set *readset, fd_set *writeset, fd_set *exceptset){    int i, nready = 0;    fd_set lreadset, lwriteset, lexceptset;    struct lwip_socket *p_sock;    FD_ZERO(&lreadset);    FD_ZERO(&lwriteset);    FD_ZERO(&lexceptset);    /* Go through each socket in each list to count number of sockets which       currently match */    for(i = 0; i < maxfdp1; i++)    {        if (FD_ISSET(i, readset))        {            /* See if netconn of this socket is ready for read */            p_sock = get_socket(i);            if (p_sock && (p_sock->lastdata || p_sock->rcvevent))            {                FD_SET(i, &lreadset);		LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_selscan: fd=%d ready for reading\n", i));                nready++;            }        }        if (FD_ISSET(i, writeset))        {            /* See if netconn of this socket is ready for write */            p_sock = get_socket(i);            if (p_sock && p_sock->sendevent)            {                FD_SET(i, &lwriteset);		LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_selscan: fd=%d ready for writing\n", i));                nready++;            }        }    }    *readset = lreadset;    *writeset = lwriteset;    FD_ZERO(exceptset);    return nready;}intlwip_select(int maxfdp1, fd_set *readset, fd_set *writeset, fd_set *exceptset,               struct timeval *timeout){    int i;    int nready;    fd_set lreadset, lwriteset, lexceptset;    u32_t msectimeout;    struct lwip_select_cb select_cb;    struct lwip_select_cb *p_selcb;    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_select(%d, %p, %p, %p, tvsec=%ld tvusec=%ld)\n", maxfdp1, (void *)readset, (void *) writeset, (void *) exceptset, timeout ? timeout->tv_sec : -1L, timeout ? timeout->tv_usec : -1L));    select_cb.next = 0;    select_cb.readset = readset;    select_cb.writeset = writeset;    select_cb.exceptset = exceptset;    select_cb.sem_signalled = 0;    /* Protect ourselves searching through the list */    if (!selectsem)        selectsem = sys_sem_new(1);    sys_sem_wait(selectsem);    if (readset)        lreadset = *readset;    else        FD_ZERO(&lreadset);    if (writeset)        lwriteset = *writeset;    else        FD_ZERO(&lwriteset);    if (exceptset)        lexceptset = *exceptset;    else        FD_ZERO(&lexceptset);    /* Go through each socket in each list to count number of sockets which       currently match */    nready = lwip_selscan(maxfdp1, &lreadset, &lwriteset, &lexceptset);    /* If we don't have any current events, then suspend if we are supposed to */    if (!nready)    {        if (timeout && timeout->tv_sec == 0 && timeout->tv_usec == 0)        {            sys_sem_signal(selectsem);            if (readset)                FD_ZERO(readset);            if (writeset)                FD_ZERO(writeset);            if (exceptset)                FD_ZERO(exceptset);	    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_select: no timeout, returning 0\n"));	    set_errno(0);            return 0;        }        /* add our semaphore to list */        /* We don't actually need any dynamic memory. Our entry on the         * list is only valid while we are in this function, so it's ok         * to use local variables */        select_cb.sem = sys_sem_new(0);        /* Note that we are still protected */        /* Put this select_cb on top of list */        select_cb.next = select_cb_list;        select_cb_list = &select_cb;        /* Now we can safely unprotect */        sys_sem_signal(selectsem);        /* Now just wait to be woken */        if (timeout == 0)            /* Wait forever */            msectimeout = 0;        else            msectimeout =  ((timeout->tv_sec * 1000) + ((timeout->tv_usec + 500)/1000));        i = sys_sem_wait_timeout(select_cb.sem, msectimeout);        /* Take us off the list */        sys_sem_wait(selectsem);        if (select_cb_list == &select_cb)            select_cb_list = select_cb.next;        else            for (p_selcb = select_cb_list; p_selcb; p_selcb = p_selcb->next)                if (p_selcb->next == &select_cb)                {                    p_selcb->next = select_cb.next;                    break;                }        sys_sem_signal(selectsem);        sys_sem_free(select_cb.sem);        if (i == 0)             /* Timeout */        {            if (readset)                FD_ZERO(readset);            if (writeset)                FD_ZERO(writeset);            if (exceptset)                FD_ZERO(exceptset);	    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_select: timeout expired\n"));	    set_errno(0);            return 0;        }        if (readset)            lreadset = *readset;        else            FD_ZERO(&lreadset);        if (writeset)            lwriteset = *writeset;        else            FD_ZERO(&lwriteset);        if (exceptset)            lexceptset = *exceptset;        else            FD_ZERO(&lexceptset);        /* See what's set */        nready = lwip_selscan(maxfdp1, &lreadset, &lwriteset, &lexceptset);    }    else        sys_sem_signal(selectsem);    if (readset)        *readset = lreadset;    if (writeset)        *writeset = lwriteset;    if (exceptset)        *exceptset = lexceptset;    LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_select: nready=%d\n", nready));    set_errno(0);    return nready;}static voidevent_callback(struct netconn *conn, enum netconn_evt evt, u16_t len){    int s;    struct lwip_socket *sock;    struct lwip_select_cb *scb;    /* Get socket */    if (conn)    {        s = conn->socket;        if (s < 0)        {            /* Data comes in right away after an accept, even though             * the server task might not have created a new socket yet.             * Just count down (or up) if that's the case and we             * will use the data later. Note that only receive events             * can happen before the new socket is set up. */            if (evt == NETCONN_EVT_RCVPLUS)                conn->socket--;            return;        }        sock = get_socket(s);        if (!sock)            return;    }    else        return;    if (!selectsem)        selectsem = sys_sem_new(1);    sys_sem_wait(selectsem);    /* Set event as required */    switch (evt)    {      case NETCONN_EVT_RCVPLUS:        sock->rcvevent++;        break;      case NETCONN_EVT_RCVMINUS:        sock->rcvevent--;        break;      case NETCONN_EVT_SENDPLUS:        sock->sendevent = 1;        break;      case NETCONN_EVT_SENDMINUS:        sock->sendevent = 0;        break;    }    sys_sem_signal(selectsem);    /* Now decide if anyone is waiting for this socket */    /* NOTE: This code is written this way to protect the select link list       but to avoid a deadlock situation by releasing socksem before       signalling for the select. This means we need to go through the list       multiple times ONLY IF a select was actually waiting. We go through       the list the number of waiting select calls + 1. This list is       expected to be small. */    while (1)    {        sys_sem_wait(selectsem);        for (scb = select_cb_list; scb; scb = scb->next)        {            if (scb->sem_signalled == 0)            {                /* Test this select call for our socket */                if (scb->readset && FD_ISSET(s, scb->readset))                    if (sock->rcvevent)                        break;                if (scb->writeset && FD_ISSET(s, scb->writeset))                    if (sock->sendevent)                        break;            }        }        if (scb)        {            scb->sem_signalled = 1;            sys_sem_signal(selectsem);            sys_sem_signal(scb->sem);        } else {            sys_sem_signal(selectsem);            break;        }    }}int lwip_shutdown(int s, int how){  LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_shutdown(%d, how=%d)\n", s, how));  return lwip_close(s); /* XXX temporary hack until proper implementation */}int lwip_getpeername (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;  }

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人猛片aaaaaaa| 亚洲激情第一区| 日韩美女主播在线视频一区二区三区| 色哟哟一区二区| 99久久国产免费看| 波多野结衣中文字幕一区 | 美女尤物国产一区| 亚洲3atv精品一区二区三区| 亚洲中国最大av网站| 一级日本不卡的影视| 亚洲一区二区三区在线播放| 一区二区欧美在线观看| 午夜精品一区二区三区电影天堂 | 久久久电影一区二区三区| 久久久久国产成人精品亚洲午夜| 久久伊99综合婷婷久久伊| 国产日韩欧美在线一区| 国产精品国产三级国产普通话蜜臀| 国产精品情趣视频| 亚洲日本欧美天堂| 亚洲一二三区不卡| 美女免费视频一区二区| 国产精品伊人色| 成人黄色在线网站| 色香蕉久久蜜桃| 9191国产精品| 久久欧美中文字幕| 国产精品二三区| 亚洲一区二区三区小说| 免费看欧美女人艹b| 国产精品亚洲а∨天堂免在线| 粉嫩在线一区二区三区视频| 91麻豆swag| 911精品国产一区二区在线| 久久女同性恋中文字幕| 亚洲视频在线一区观看| 日本不卡中文字幕| 国产精品一区一区三区| 91在线码无精品| 欧美一区三区二区| 国产偷国产偷精品高清尤物| 亚洲精品国产品国语在线app| 午夜视频一区二区| 国产成人综合网站| 欧美午夜精品久久久久久超碰 | 欧美一区二区黄色| 国产目拍亚洲精品99久久精品| 亚洲欧美日韩成人高清在线一区| 日韩中文字幕一区二区三区| 国产精一区二区三区| 欧美三级电影在线观看| 久久综合成人精品亚洲另类欧美| 亚洲精品水蜜桃| 激情伊人五月天久久综合| 99久久精品99国产精品| 日韩精品自拍偷拍| 一区二区三区鲁丝不卡| 激情欧美日韩一区二区| 欧美在线观看视频在线| 国产欧美日韩卡一| 日韩中文欧美在线| 99久久99久久精品免费观看| 日韩欧美一级精品久久| 亚洲精品日韩综合观看成人91| 久久精品国产在热久久| 日本韩国一区二区| 久久久精品天堂| 日本亚洲天堂网| 91久久精品一区二区三| 中文字幕第一区二区| 奇米色777欧美一区二区| 一本色道久久综合亚洲91| www激情久久| 天堂影院一区二区| 91农村精品一区二区在线| 2022国产精品视频| 日韩和的一区二区| 日本电影欧美片| 国产精品国产三级国产aⅴ原创 | 九九精品一区二区| 欧美日韩日日摸| 亚洲欧美偷拍卡通变态| 国产成人h网站| 2023国产精品视频| 免费三级欧美电影| 欧美日韩专区在线| 夜夜操天天操亚洲| 91性感美女视频| 中文字幕一区二区三区色视频| 麻豆成人久久精品二区三区红 | 亚洲精品视频一区| 成人av网在线| 一区精品在线播放| www.欧美日韩国产在线| 国产农村妇女精品| 成人精品一区二区三区四区| 久久久99精品免费观看| 国产一区二区三区久久久| 欧美α欧美αv大片| 久久99精品一区二区三区三区| 91精品国产综合久久精品app| 亚洲国产成人av网| 欧美日韩一区 二区 三区 久久精品| 亚洲美腿欧美偷拍| 欧美性感一区二区三区| 亚洲丰满少妇videoshd| 在线成人免费视频| 人禽交欧美网站| 日韩一级黄色大片| 久久国内精品视频| 色综合久久久网| 中文字幕免费观看一区| 粉嫩av一区二区三区粉嫩| 成人不卡免费av| 久久蜜桃av一区精品变态类天堂| 裸体一区二区三区| 欧美一区二区三区啪啪| 亚洲国产日韩在线一区模特| 欧美性生活影院| 亚洲在线观看免费视频| 欧美午夜精品理论片a级按摩| 一区二区三区精品视频| 色综合中文字幕| 一区二区激情小说| 欧美视频完全免费看| 欧美国产日韩在线观看| 91老师国产黑色丝袜在线| 综合激情网...| 色婷婷一区二区三区四区| 亚洲乱码一区二区三区在线观看| 国产福利91精品一区| 亚洲精品久久7777| 欧美日韩精品一区视频| 视频一区在线播放| 日韩亚洲国产中文字幕欧美| 久久不见久久见中文字幕免费| 欧美激情在线观看视频免费| 国产成a人无v码亚洲福利| 国产精品日日摸夜夜摸av| 99精品在线观看视频| 亚洲综合一区二区| 欧美日本不卡视频| 欧美大片在线观看一区二区| 777xxx欧美| 成人aa视频在线观看| 国产精品色哟哟网站| 色婷婷综合久色| 激情五月婷婷综合网| 国产精品天美传媒| 欧美在线影院一区二区| 亚洲h在线观看| 欧美精品一区二区三区久久久| 91视频精品在这里| 日本不卡的三区四区五区| 久久久综合视频| 99久久综合99久久综合网站| 亚洲午夜久久久久中文字幕久| 精品福利一二区| 色偷偷88欧美精品久久久| 日本视频中文字幕一区二区三区| 久久久久亚洲蜜桃| 91麻豆国产精品久久| 韩国精品在线观看| 亚洲欧美日韩系列| 日韩欧美国产1| 99精品桃花视频在线观看| 日本人妖一区二区| 中文字幕一区二区三| 欧美一区二区三区四区高清| 福利视频网站一区二区三区| 亚洲国产精品精华液ab| 51精品久久久久久久蜜臀| 国产成人综合在线播放| 亚洲不卡在线观看| 中文字幕欧美区| 精品动漫一区二区三区在线观看| 91在线免费看| 狠狠久久亚洲欧美| 亚洲精品免费在线| 精品国内二区三区| 欧美一区二区免费观在线| 97久久久精品综合88久久| 九九**精品视频免费播放| 亚洲一区二区在线免费看| 亚洲私人黄色宅男| 久久免费视频色| 欧美男人的天堂一二区| 成人免费黄色大片| 久久狠狠亚洲综合| 亚洲二区在线视频| 自拍偷在线精品自拍偷无码专区| 精品少妇一区二区三区视频免付费| 91麻豆国产福利在线观看| 99久久夜色精品国产网站| 精品一区二区三区欧美| 亚洲国产一区二区在线播放| 国产精品妹子av| 精品国产三级a在线观看| 欧美日韩一区二区不卡| 日本道色综合久久|