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去做超时判断。