请教lwip问题,tcp
发布网友
发布时间:2022-05-07 12:24
我来回答
共1个回答
热心网友
时间:2023-10-30 18:25
你的问题不是很详细
如果是不知道位置:在LWIP的tcp_active_pcbs==tcp_active_pcbs->next
如果是非阻塞的方式运行:
现在的用法,还是用sys_thread_new创建的,在tcpclient中这样处理的,但连接如果是server主动断掉可以检测到,但如果是其他原因,如网络错误之类的就检测不到了。
int fd;
FD_ZERO(&fdR);
FD_SET(sock, &fdR);
switch (select(sock + 1, &fdR, NULL,NULL, &timeout))
{
case -1:
{
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
case 0:
break;
default:
{
if(FD_ISSET(fd,&fdR))
{
int nread;
ioctlsocket(fd,FIONREAD,&nread);
if(nread == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
bytes_received = recv(sock, recv_data, 1024, 0);
if(bytes_received == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
recv_data[bytes_received] = '\0';
//*****数据解析*******
if(Check_frame(recv_data) == 1)
{
link((u8_t *)recv_data,sock);
}
}
}
}
break;
}
}
热心网友
时间:2023-10-30 18:25
你的问题不是很详细
如果是不知道位置:在LWIP的tcp_active_pcbs==tcp_active_pcbs->next
如果是非阻塞的方式运行:
现在的用法,还是用sys_thread_new创建的,在tcpclient中这样处理的,但连接如果是server主动断掉可以检测到,但如果是其他原因,如网络错误之类的就检测不到了。
int fd;
FD_ZERO(&fdR);
FD_SET(sock, &fdR);
switch (select(sock + 1, &fdR, NULL,NULL, &timeout))
{
case -1:
{
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
case 0:
break;
default:
{
if(FD_ISSET(fd,&fdR))
{
int nread;
ioctlsocket(fd,FIONREAD,&nread);
if(nread == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
bytes_received = recv(sock, recv_data, 1024, 0);
if(bytes_received == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
recv_data[bytes_received] = '\0';
//*****数据解析*******
if(Check_frame(recv_data) == 1)
{
link((u8_t *)recv_data,sock);
}
}
}
}
break;
}
}
热心网友
时间:2023-10-30 18:25
你的问题不是很详细
如果是不知道位置:在LWIP的tcp_active_pcbs==tcp_active_pcbs->next
如果是非阻塞的方式运行:
现在的用法,还是用sys_thread_new创建的,在tcpclient中这样处理的,但连接如果是server主动断掉可以检测到,但如果是其他原因,如网络错误之类的就检测不到了。
int fd;
FD_ZERO(&fdR);
FD_SET(sock, &fdR);
switch (select(sock + 1, &fdR, NULL,NULL, &timeout))
{
case -1:
{
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
case 0:
break;
default:
{
if(FD_ISSET(fd,&fdR))
{
int nread;
ioctlsocket(fd,FIONREAD,&nread);
if(nread == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
bytes_received = recv(sock, recv_data, 1024, 0);
if(bytes_received == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
recv_data[bytes_received] = '\0';
//*****数据解析*******
if(Check_frame(recv_data) == 1)
{
link((u8_t *)recv_data,sock);
}
}
}
}
break;
}
}
热心网友
时间:2023-10-30 18:25
你的问题不是很详细
如果是不知道位置:在LWIP的tcp_active_pcbs==tcp_active_pcbs->next
如果是非阻塞的方式运行:
现在的用法,还是用sys_thread_new创建的,在tcpclient中这样处理的,但连接如果是server主动断掉可以检测到,但如果是其他原因,如网络错误之类的就检测不到了。
int fd;
FD_ZERO(&fdR);
FD_SET(sock, &fdR);
switch (select(sock + 1, &fdR, NULL,NULL, &timeout))
{
case -1:
{
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
case 0:
break;
default:
{
if(FD_ISSET(fd,&fdR))
{
int nread;
ioctlsocket(fd,FIONREAD,&nread);
if(nread == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
bytes_received = recv(sock, recv_data, 1024, 0);
if(bytes_received == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
recv_data[bytes_received] = '\0';
//*****数据解析*******
if(Check_frame(recv_data) == 1)
{
link((u8_t *)recv_data,sock);
}
}
}
}
break;
}
}
热心网友
时间:2023-10-30 18:25
你的问题不是很详细
如果是不知道位置:在LWIP的tcp_active_pcbs==tcp_active_pcbs->next
如果是非阻塞的方式运行:
现在的用法,还是用sys_thread_new创建的,在tcpclient中这样处理的,但连接如果是server主动断掉可以检测到,但如果是其他原因,如网络错误之类的就检测不到了。
int fd;
FD_ZERO(&fdR);
FD_SET(sock, &fdR);
switch (select(sock + 1, &fdR, NULL,NULL, &timeout))
{
case -1:
{
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
case 0:
break;
default:
{
if(FD_ISSET(fd,&fdR))
{
int nread;
ioctlsocket(fd,FIONREAD,&nread);
if(nread == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
bytes_received = recv(sock, recv_data, 1024, 0);
if(bytes_received == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
recv_data[bytes_received] = '\0';
//*****数据解析*******
if(Check_frame(recv_data) == 1)
{
link((u8_t *)recv_data,sock);
}
}
}
}
break;
}
}
热心网友
时间:2023-10-30 18:25
你的问题不是很详细
如果是不知道位置:在LWIP的tcp_active_pcbs==tcp_active_pcbs->next
如果是非阻塞的方式运行:
现在的用法,还是用sys_thread_new创建的,在tcpclient中这样处理的,但连接如果是server主动断掉可以检测到,但如果是其他原因,如网络错误之类的就检测不到了。
int fd;
FD_ZERO(&fdR);
FD_SET(sock, &fdR);
switch (select(sock + 1, &fdR, NULL,NULL, &timeout))
{
case -1:
{
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
case 0:
break;
default:
{
if(FD_ISSET(fd,&fdR))
{
int nread;
ioctlsocket(fd,FIONREAD,&nread);
if(nread == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
bytes_received = recv(sock, recv_data, 1024, 0);
if(bytes_received == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
recv_data[bytes_received] = '\0';
//*****数据解析*******
if(Check_frame(recv_data) == 1)
{
link((u8_t *)recv_data,sock);
}
}
}
}
break;
}
}
热心网友
时间:2023-10-30 18:25
你的问题不是很详细
如果是不知道位置:在LWIP的tcp_active_pcbs==tcp_active_pcbs->next
如果是非阻塞的方式运行:
现在的用法,还是用sys_thread_new创建的,在tcpclient中这样处理的,但连接如果是server主动断掉可以检测到,但如果是其他原因,如网络错误之类的就检测不到了。
int fd;
FD_ZERO(&fdR);
FD_SET(sock, &fdR);
switch (select(sock + 1, &fdR, NULL,NULL, &timeout))
{
case -1:
{
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
case 0:
break;
default:
{
if(FD_ISSET(fd,&fdR))
{
int nread;
ioctlsocket(fd,FIONREAD,&nread);
if(nread == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
bytes_received = recv(sock, recv_data, 1024, 0);
if(bytes_received == 0)
{
//close
lwip_close(sock);
rt_free(recv_data);
recv_data = RT_NULL;
GPIOB->BSRR = GPIO_Pin_5;//灭灯
return 0;
}
else
{
recv_data[bytes_received] = '\0';
//*****数据解析*******
if(Check_frame(recv_data) == 1)
{
link((u8_t *)recv_data,sock);
}
}
}
}
break;
}
}