Чтение необработанных байтов из последовательного порта

Я пытаюсь прочитать необработанные байты из последовательного порта, отправленного симулятором протокола win32 IEC 870-5-101 с программой, написанной на C, запущенной на 32-битной ОС Linux.

Он отлично работает для байтовых значений, таких как 0x00 - 0x7F. Но для значений, начинающихся от 0x80 до 0xAF, старший бит неверен, например:

0x7F -> 0x7F //correct
0x18 -> 0x18 //correct
0x79 -> 0x79 //correct
0x80 -> 0x00 //wrong
0xAF -> 0x2F //wrong
0xFF -> 0x7F //wrong

После копания в течение двух дней, я понятия не имею, что вызывает это.

Это моя конфигурация последовательного порта:

    cfsetispeed(&config, B9600);
    cfsetospeed(&config, B9600);

    config.c_cflag |= (CLOCAL | CREAD);

    config.c_cflag &= ~CSIZE;                               /* Mask the character size bits */
    config.c_cflag |= (PARENB | CS8);                       /* Parity bit Select 8 data bits */

    config.c_cflag &= ~(PARODD | CSTOPB);                   /* even parity, 1 stop bit */


    config.c_cflag |= CRTSCTS;                              /*enable RTS/CTS flow control - linux only supports rts/cts*/


    config.c_iflag &= ~(IXON | IXOFF | IXANY);              /*disable software flow control*/ 

    config.c_oflag &= ~OPOST;                               /* enable raw output */
    config.c_lflag &= ~(ICANON | ECHO | ECHOE | ISIG);      /* enable raw input */

    config.c_iflag &= ~(INPCK | PARMRK);                    /* DANGEROUS no parity check*/
    config.c_iflag |= ISTRIP;                               /* strip parity bits */
    config.c_iflag |= IGNPAR;                               /* DANGEROUS ignore parity errors*/

    config.c_cc[VTIME] = 1;                                 /*timeout to read a character in tenth of a second*/

Я читаю из последовательного порта:

*bytesread = read((int) fd, in_buf, BytesToRead);

Сразу после этой операции "in_buf" содержит неправильный байт, поэтому я думаю, что что-то не так с моей конфигурацией, которая является портом из структуры DCB win32.

Спасибо за любые идеи!

Ответ 1

Основываясь на ваших примерах, только 8-й бит (высокий бит) ошибочен, и он ошибочен, всегда будучи 0. Вы устанавливаете ISTRIP в своей линейной дисциплине на стороне Linux, и это приведет к этому. ISTRIP не делает, как утверждает комментарий в коде C, разбивает биты четности. Он разделяет 8-й бит данных.

Если установлен ISTRIP, допустимые входные байты сначала должны быть разделены на семь бит; в противном случае все восемь бит должны обрабатываться. IEEE Std 1003.1, выпуск 2004, глава 11, Общий интерфейс терминалов