我有一个串行设备,我想在通信过程中控制RTS和DTR信号。基本上,整个通信基于这两个信号。有没有办法在linux下使用boost :: asio :: serial_port实现这样做。有没有办法让底层结构用于控制两个信号?
我在boost / asio / impl / serial_port_basis.ipp
下找到了boost::system::error_code serial_port_base::flow_control::load(
const BOOST_ASIO_OPTION_STORAGE& storage, boost::system::error_code& ec)
{
#if defined(BOOST_ASIO_WINDOWS) || defined(__CYGWIN__)
...
#else
if (storage.c_iflag & (IXOFF | IXON))
{
value_ = software;
}
# if defined(_BSD_SOURCE)
else if (storage.c_cflag & CRTSCTS)
{
value_ = hardware;
}
# elif defined(__QNXNTO__)
else if (storage.c_cflag & IHFLOW && storage.c_cflag & OHFLOW)
{
value_ = hardware;
}
# endif
else
{
value_ = none;
}
#endif
ec = boost::system::error_code();
return ec;
}
boost还定义了#define BOOST_ASIO_OPTION_STORAGE termios
答案 0 :(得分:2)
很容易对native_handle诚实。 这就是我如何解决它。
#include <sys/ioctl.h>
....
:::Constructor:::
{
//config for my device
serialPort.open(port);
serialPort.set_option(serial_port::baud_rate(9600));
serialPort.set_option(serial_port::parity(serial_port::parity::even));
serialPort.set_option(serial_port::character_size(serial_port::character_size(8)));
serialPort.set_option(serial_port::stop_bits(serial_port::stop_bits::one));
serialPort.set_option(serial_port::flow_control(serial_port::flow_control::none));
fd = serialPort.native_handle(); // fd is of typ int
}
void setRTS(bool enabled
//int fd = serialPort.native_handle();
int data = TIOCM_RTS;
if (!enabled)
ioctl(fd, TIOCMBIC, &data);
else
ioctl(fd, TIOCMBIS, &data);
}
void setDTR(bool enabled)
{
//int fd = serialPort.native_handle();
int data = TIOCM_DTR;
if (!enabled)
ioctl(fd, TIOCMBIC, &data); // Clears the DTR pin
else
ioctl(fd, TIOCMBIS, &data); // Sets the DTR pin
}
答案 1 :(得分:0)
没有flow_control有帮助吗? 您可以使用serial_port :: native_handle()并使用本机OS函数