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

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

?? sockets.c

?? 包含lwip這個(gè)精簡(jiǎn)IP協(xié)議棧的ucos源代碼.
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
int
lwip_recv(int s, void *mem, int len, unsigned int flags)
{
  return lwip_recvfrom(s, mem, len, flags, NULL, NULL);
}

int
lwip_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;
}

int
lwip_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;
}

int
lwip_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;
}

int
lwip_write(int s, void *data, int size)
{
   return lwip_send(s, data, size, 0);
}


static int
lwip_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;
}



int
lwip_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 void
event_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一区二区三区免费野_久草精品视频
国产午夜亚洲精品不卡| 26uuu国产电影一区二区| 精品一区二区久久| 亚洲另类色综合网站| 久久亚洲精品小早川怜子| 欧美亚洲综合另类| 波多野结衣精品在线| 九色porny丨国产精品| 亚洲一区二区精品久久av| 欧美国产亚洲另类动漫| 91精品国产入口在线| 在线看日本不卡| 成人理论电影网| 国产精品99久久久久久似苏梦涵 | 国精品**一区二区三区在线蜜桃| 一区二区三区自拍| 久久精品视频一区二区| 精品欧美乱码久久久久久1区2区 | 7777精品伊人久久久大香线蕉超级流畅 | 日韩精品一区二区三区四区视频 | 91蝌蚪porny| 国产麻豆成人精品| 日本最新不卡在线| 性做久久久久久久免费看| 亚洲日本在线a| 中文字幕中文字幕一区| 欧美激情一二三区| 中文字幕 久热精品 视频在线| 日韩三级视频在线看| 欧美一区二区三区思思人| 欧美日本乱大交xxxxx| 精品视频在线免费观看| 在线免费观看一区| 欧美日韩一区高清| 欧美精品粉嫩高潮一区二区| 欧美丝袜第三区| 欧美三级资源在线| 欧美综合在线视频| 欧美日韩国产在线观看| 69堂精品视频| 欧美一二三区在线| 欧美成人aa大片| 亚洲精品在线电影| 国产人成亚洲第一网站在线播放| 久久人人爽人人爽| 欧美经典一区二区| 国产精品久久久久久久久搜平片 | 久久精品无码一区二区三区| 久久久国产一区二区三区四区小说| 26uuu国产在线精品一区二区| 久久久美女艺术照精彩视频福利播放| 亚洲精品在线一区二区| 亚洲国产经典视频| 中文字幕在线观看一区二区| 亚洲乱码中文字幕| 午夜精品久久久久久久蜜桃app | 成人福利视频网站| 91蜜桃网址入口| 欧美精品 国产精品| 欧美电影免费提供在线观看| 国产亚洲精品资源在线26u| 国产精品毛片高清在线完整版| 亚洲精品中文在线影院| 五月天国产精品| 国产九色sp调教91| 色天天综合色天天久久| 日韩三级av在线播放| 中文字幕欧美日韩一区| 亚洲一区二区三区三| 捆绑紧缚一区二区三区视频| 国产成人免费av在线| 欧洲一区二区三区在线| 欧美v日韩v国产v| ...xxx性欧美| 免费在线欧美视频| av不卡免费在线观看| 在线成人av网站| 中文字幕av不卡| 日本欧美大码aⅴ在线播放| 成人小视频免费观看| 91麻豆免费在线观看| 日韩精品一区二区三区老鸭窝 | 国产精品嫩草99a| 亚洲韩国一区二区三区| 国产一区二区精品在线观看| 色狠狠色噜噜噜综合网| 精品国产乱码久久久久久影片| |精品福利一区二区三区| 蜜桃视频在线观看一区| 99国内精品久久| 亚洲精品一区二区精华| 亚洲一区在线观看免费| 加勒比av一区二区| 欧美亚洲高清一区| 国产精品免费看片| 欧美a级理论片| 在线免费视频一区二区| 中文字幕精品一区| 久久草av在线| 欧美日本在线一区| 亚洲激情在线播放| 国产精品一线二线三线| 91麻豆精品国产91久久久使用方法| 1区2区3区欧美| 国产精品一线二线三线精华| 6080yy午夜一二三区久久| 国产精品毛片无遮挡高清| 极品少妇xxxx偷拍精品少妇| 欧美日韩精品一区二区三区 | 国产欧美一区二区三区鸳鸯浴| 偷拍一区二区三区| 91女人视频在线观看| 久久久久久久久久久久久女国产乱| 日韩精品一级中文字幕精品视频免费观看 | 亚洲一区二区偷拍精品| 成人免费视频国产在线观看| 精品欧美一区二区三区精品久久| 亚洲成人精品一区| 色婷婷国产精品| 亚洲欧洲国产专区| 国产.欧美.日韩| 久久亚洲影视婷婷| 免费看黄色91| 欧美一区二区免费视频| 性感美女极品91精品| 一本大道久久a久久综合婷婷| 中文欧美字幕免费| 国产高清无密码一区二区三区| 日韩美女视频在线| 青青草一区二区三区| 制服.丝袜.亚洲.中文.综合| 亚洲国产婷婷综合在线精品| 色呦呦网站一区| 亚洲免费在线播放| 色综合久久99| 伊人婷婷欧美激情| 在线视频国内一区二区| 一区二区三区四区亚洲| 欧洲精品视频在线观看| 亚洲一区精品在线| 欧美日韩国产系列| 日本三级亚洲精品| 精品少妇一区二区三区视频免付费 | 中文字幕欧美区| av一二三不卡影片| 亚洲激情图片qvod| 欧美影视一区在线| 日韩不卡一二三区| 久久影院午夜片一区| 丁香激情综合五月| 亚洲欧美一区二区三区国产精品| 色狠狠av一区二区三区| 日日夜夜一区二区| 欧美va亚洲va在线观看蝴蝶网| 久久99久久精品欧美| 日本一区二区三区四区 | 欧美videos大乳护士334| 国内精品伊人久久久久av影院| 久久久午夜电影| 色综合久久综合网| 秋霞av亚洲一区二区三| 久久美女艺术照精彩视频福利播放| 国产精品 欧美精品| 一区二区三区免费网站| 日韩一区二区视频在线观看| 国产一区二区三区黄视频| 中文字幕视频一区| 在线成人午夜影院| 粉嫩久久99精品久久久久久夜| 亚洲欧美另类在线| 欧美一区二区三区视频在线| 成人国产亚洲欧美成人综合网| 一区二区三区国产精华| 精品欧美乱码久久久久久1区2区| 日韩网站在线看片你懂的| 国产激情精品久久久第一区二区| 亚洲蜜臀av乱码久久精品| 欧美一区二区播放| 91亚洲精品乱码久久久久久蜜桃| 天堂成人免费av电影一区| 国产欧美日韩三级| 欧美日韩国产大片| 国产91精品精华液一区二区三区 | 成人免费观看av| 丝袜诱惑制服诱惑色一区在线观看| 久久久久久久国产精品影院| 在线一区二区三区四区| 狠狠网亚洲精品| 亚洲国产色一区| 国产欧美一二三区| 日韩一区二区中文字幕| 色诱视频网站一区| 国产成人免费在线视频| 日韩主播视频在线| 亚洲精品免费在线播放| 国产欧美日韩三级| 日韩欧美在线不卡| 欧美日韩精品一区二区天天拍小说 | 欧美一区二区三区四区视频| 91美女在线观看|