微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 无线和射频 > TI WIFI设计交流 > CC3200 sl_Select 使用不成功问题

CC3200 sl_Select 使用不成功问题

时间:10-02 整理:3721RD 点击:
TI工程师,你们好:

UDP客户端发送数据和接收数据中我使用了sl_Select去等待可发送和可接收事件,代码如下,但是出现的现象是写的sl_Select要等足8秒(我设置就为8秒)才返回,而读的sl_Select就一直都不返回,请问是我使用上存在问题还是其他什么原因呢?谢谢

  SlTimeval_t         sel_to;
  SlSockAddrIn_t      ipas_addr;
  SlFdSet_t           rfds, wfds;
  SlSockNonblocking_t enable_option;
  int                 i_addr_size, socket_fd = -1, ret;
  

  ipas_addr.sin_family      = SL_AF_INET;
  ipas_addr.sin_port        = sl_Htons(PORT);
  ipas_addr.sin_addr.s_addr = sl_Htonl(IP);
  i_addr_size = sizeof(SlSockAddrIn_t);

  socket_fd = sl_Socket(SL_AF_INET, SL_SOCK_DGRAM, 0);
  if(socket_fd < 0){
    DO_Printf("sl_Socket call Failure!\r\n");
    goto function_exit;
  }
  
  enable_option.NonblockingEnabled = 0x1;
  sl_SetSockOpt(socket_fd, SOL_SOCKET, SL_SO_NONBLOCKING, &enable_option, sizeof(enable_option));
  
  keep_on_send:
  sel_to.tv_sec  = 8;
  sel_to.tv_usec = 0;
  SL_FD_ZERO(&wfds);
  SL_FD_SET(socket_fd, &wfds);
  ret = sl_Select(socket_fd + 1, 0, &wfds, 0, &sel_to);
  if(ret < 0){
    DO_Printf("sl_Select1 call failure!\r\n");
    goto function_exit;
  }else{
    if(SL_FD_ISSET(socket_fd, &wfds)){
      ret = sl_SendTo(socket_fd, sp + already_len, willbe_len - already_len, 0, (SlSockAddr_t *)&ipas_addr, i_addr_size);
      if(ret < 0){
        DO_Printf("sl_SendTo call Failure!\r\n");
        goto function_exit;
      }else{
        already_len += ret;
        DO_Printf("Send Data Count:%d\r\n", already_len);
        if(already_len < willbe_len){
          goto keep_on_send;
        }
      }
    }else{
      DO_Printf("Send Data Timeout!\r\n");
      goto function_exit;
    }
  }
  
  DO_Printf("Test Send Finish\r\n");
  
  keep_on_recv:
  SL_FD_ZERO(&rfds);
  SL_FD_SET(socket_fd, &rfds);
  sel_to.tv_sec  = 8;
  sel_to.tv_usec = 0;
  ret = sl_Select(socket_fd + 1, &rfds, 0, 0, &sel_to);
  if(ret < 0){
    DO_Printf("sl_Select2 call failure!\r\n");
    goto function_exit;
  }else{
    if(SL_FD_ISSET(socket_fd, &rfds)){
      ret = sl_RecvFrom(socket_fd, sp + already_len, willbe_len - already_len, 0, (SlSockAddr_t *)(&ipas_addr), (SlSocklen_t*)(&i_addr_size));
      if(ret < 0){
        if(ret == SL_EAGAIN){
          goto keep_on_recv;
        }
        DO_Printf("sll_SendTo call Failure!\r\n");
        goto function_exit;
      }else{
        already_len += ret;
        if(already_len < willbe_len){
          goto keep_on_recv;
        }
      }
    }else{
      DO_Printf("Recv Data Timeout!\r\n");
      goto function_exit;
    }
  }
  .....
 

1. 你的读和写都是在一台cc31xx上吗,如果是的话能否合到一个select里面去查询

2. 你读写的fds的时候8秒之后它的返回值是多少呢?

8秒之后是能读到数据的,也就是fds是有被置位的,现象就是有数据时Select不能马上返回,一定要超时才能,超时返回的fds是正确的

不过这个问题我用其他办法解决了,后来想了下,其实没必要使用select。。。

请您帮我看看另外一个问题吧!就是如何获取CC3200 STA模式下的连接质量.

http://www.deyisupport.com/question_answer/wireless_connectivity/wifi/f/105/t/71209.aspx

能否分享一下select是遇到了什么问题,怎么解决的,也可以给其他童鞋一些分享。thanks.

关于链接质量的问题,我已经回你了,请参考。

哦,我的解决办法就是不使用select,因为是设置为异步socket,后来想了一下,使用select就是多此一举,直接法判断send和recv的返回值就好了,使用free-rtos的时间API去做超时判断。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top