C ++ libserial跳过0x09

时间:2015-05-20 13:05:37

标签: c++ libserial

我试图从Pixhawk飞行控制器读取串行数据,该控制器通过Mavlink协议进行通信。它发送17个字节,前三个是0xFE,0x09后跟一个计数器,每个消息递增一次。我已经用GtkTerm证实了这一点。

但是当我运行以下代码时,总是跳过0x09(第二个字节),因此只接收每个17字节消息的16个字节。

有什么想法吗? 谢谢,詹姆斯。

LibSerial::SerialStream pixhawkSerial;

pixhawkSerial.Open("/dev/ttyACM0");

pixhawkSerial.SetBaudRate( LibSerial::SerialStreamBuf::BAUD_57600 ) ;

pixhawkSerial.SetCharSize( LibSerial::SerialStreamBuf::CHAR_SIZE_8 );

pixhawkSerial.SetNumOfStopBits(1);

pixhawkSerial.SetParity( LibSerial::SerialStreamBuf::PARITY_NONE ) ;

pixhawkSerial.SetFlowControl( LibSerial::SerialStreamBuf::FLOW_CONTROL_NONE );

char next_byte [100];
int i = 0;
while (i<100){
    if( pixhawkSerial.rdbuf()->in_avail() > 0 ){
        pixhawkSerial >> next_byte[i];
        i++;
    }
    else cout << "No data" << endl;
}

1 个答案:

答案 0 :(得分:1)

无法使用libserial工作,但是我给了temios一个去,它没有问题。

附件是工作代码。

int fd;
struct termios oldAtt, newAtt;
fd = open("/dev/ttyACM0", O_RDWR  | O_NOCTTY | O_NDELAY);

tcgetattr(fd, &oldAtt);
memset(&newAtt, 0, sizeof(newAtt));
newAtt.c_cflag = CRTSCTS | CS8 | CLOCAL | CREAD;
newAtt.c_iflag = IGNPAR;
newAtt.c_ispeed = B57600;
newAtt.c_oflag = 0;
newAtt.c_ospeed = B57600;
newAtt.c_lflag = 0;

newAtt.c_cc[VTIME] = 0;
newAtt.c_cc[VMIN] = 1;

tcflush(fd, TCIOFLUSH);
tcsetattr(fd, TCSANOW, &newAtt);

char rBuffer;
char next_byte [100];
int i=0;
int dataReceived;

while (i<100) {
    dataReceived = read(fd,&rBuffer,1);
    if (dataReceived>0){
        next_byte[i] = rBuffer;
        i++;
    }
}

tcsetattr(fd,TCSANOW,&oldAtt);
close(fd);