找回密码
 立即注册
首页 资源区 代码 Serial函数库setTimeout导致FTDI USB转串口失去响应 ...

Serial函数库setTimeout导致FTDI USB转串口失去响应

靛尊 2025-6-3 09:51:46
之前在客户那里调试设备,控制器上用的FTDI的USB转串口芯片。上位机需要和控制器进行指令交互,然后不同的指令的超时时间不同,因此需要在打开串口后修改超时时间。但是调试下来发现,串口通信变得很不稳定,非常容易收不到数据。
困扰了一段时间后,果断抓包看USB转串口的数据包,一看吓一跳setTimeout发送之后,系统再不停地重新配置USB转串口的各项参数,包括波特率,数据位等等。明明我只需要配置超时,却相当于重新开关了一遍串口。
1.png
  1. void Serial::SerialImpl::setTimeout (serial::Timeout &timeout)
  2. {
  3.   timeout_ = timeout;
  4.   if (is_open_) {
  5.     reconfigurePort ();
  6.   }
  7. }
复制代码
查看serial库的源码发现,这货真的牛啊,直接调用了reconfigurePort来配置超时,所以抓包setTimeout时的数据有一堆配置波特率的东西。
2.png

我们只需要修改超时时间,因此修改这个函数就可以解决问题,只单纯的改变超时的等待时间
  1. void Serial::SerialImpl::setTimeout (serial::Timeout &timeout)
  2. {
  3.   timeout_ = timeout;
  4.   if (is_open_) {
  5.     //reconfigurePort ();
  6.     // Setup timeouts
  7.     COMMTIMEOUTS timeouts = { 0 };
  8.     timeouts.ReadIntervalTimeout = timeout_.inter_byte_timeout;
  9.     timeouts.ReadTotalTimeoutConstant = timeout_.read_timeout_constant;
  10.     timeouts.ReadTotalTimeoutMultiplier = timeout_.read_timeout_multiplier;
  11.     timeouts.WriteTotalTimeoutConstant = timeout_.write_timeout_constant;
  12.     timeouts.WriteTotalTimeoutMultiplier = timeout_.write_timeout_multiplier;
  13.     if (!SetCommTimeouts(fd_, &timeouts)) {
  14.         THROW(IOException, "Error setting timeouts.");
  15.     }
  16.   }
  17. }
复制代码
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册