3

我们在硬件中使用 FTDI 串行端口芯片。现在我们在 Linux 中有了工作代码,我们移到了 Windows 7。我们遇到了一些奇怪的问题。

问题:我们不能在不运行其他控制台应用程序的情况下将数据写入串行端口:

 serial.setPortName("COM3");
        if (serial.open(QIODevice::ReadWrite)) {
            bool success = serial.setBaudRate(QSerialPort::Baud9600) &
            serial.setStopBits(QSerialPort::OneStop) &
            serial.setDataBits(QSerialPort::Data8) &
            serial.setParity(QSerialPort::NoParity) &
            serial.setFlowControl(QSerialPort::NoFlowControl);
            qDebug() << "Connected to usb device: " << (success ? "OK" : "FAIL");

           while(true) {
                if(serial.waitForReadyRead(-1)) {
                    QByteArray out = serial.readAll();
                    for(int i=0; i< out.length(); i++) {
                        qDebug() << (int) out[i];
                    }
                }
            }
            serial.close();

所以它只是循环读取所有内容。硬件不发送任何东西,所以读取只是无限循环。关闭并运行我们的写入程序后,它可以正常运行。

char* input;
input = new char[size+3];
QByteArray bytearr;

for(int i=0;i<size+2;i++) {
    input[i] = (char) package[i];
    bytearr.append((unsigned char) package[i]);
}


QString serialPortName = "COM3";
QSerialPort serialPort;
serialPort.setPortName(serialPortName);
serialPort.open(QIODevice::ReadWrite);
serialPort.write(bytearr);
serialPort.flush();
serialPort.close();

运行 read 后一切正常,但没有 read all 就不行了。我们做错了什么?谢谢。

4

2 回答 2

2

我们在使用带有 FTDI 芯片的电路板的应用程序中遇到了类似的问题。我们尝试以 19200 波特/秒写入字节,但实际上大约为 1200 波特/秒(使用示波器查看)。问题是在写入一个字节后立即关闭串行端口。在关闭端口之前等待使用 QThread::msleep(5) 会有所帮助。看起来,设备在关闭操作期间得到了重置或其他东西,并且最新的字节以错误的波特率和其他参数发送。

于 2015-02-10T09:13:49.623 回答
1

我发现QT串口SW需要你处理QT事件才能工作。在读取之前将 qApp->processEvents() 放入循环中使其对我有用。

(Windows-7 上的 QT 4.8.5)

于 2014-04-15T11:02:41.867 回答