我根本无法获得poll()函数来响应通过UART1 / / dev / ttyO1发送的数据。代码如下,也许有人可以发现我的愚蠢错误?

#include <stdio.h>
#include <termios.h>
#include <fcntl.h>
#include <string.h>
#include <sys/types.h>
#include <sys/poll.h>
#include <time.h>
#include <errno.h>
#include <unistd.h>

int openPort()
{
    struct termios oldtio, newtio;

    int fd = open("/dev/ttyO1",O_RDWR|O_NOCTTY|O_NONBLOCK|O_NDELAY);
    if (fd == -1)
    {
        printf( "could not open tty" );
        return -1;
    }

    if ( tcgetattr( fd, &oldtio ) == -1 )
    {
        printf( "error getting tcattr\n" );
        close( fd );
        return -1;
    }

    cfmakeraw( &newtio );
    cfsetispeed( &newtio, B9600 );
    cfsetospeed( &newtio, B9600 );
    newtio.c_cflag = (newtio.c_cflag & ~CSIZE) | CS8 | B9600;
    newtio.c_cflag |= (CLOCAL | CREAD);
    newtio.c_cflag &= ~(PARENB | PARODD);
    newtio.c_cflag &= ~CRTSCTS;
    newtio.c_cflag &= ~CSTOPB;
    newtio.c_iflag = 0;//IGNPAR;
    //newtio.c_iflag &= ~(IXON | IXOFF | IXANY);
    newtio.c_lflag = 0;
    newtio.c_oflag = 0;
    newtio.c_cc[VTIME] = 0;
    newtio.c_cc[VMIN] = 1;
    tcflush( fd, TCIOFLUSH );
    if ( tcsetattr( fd, TCSANOW, &newtio ) == -1 )
    {
        close( fd );
        printf( "error setting attrs\n" );
        return -1;
    }

    return fd;
}

void selectLoop( int fd )
{
    struct pollfd fds[1];
    fds[0].fd = fd;
    fds[0].events = POLLIN;

    int rc = poll( fds, 1, 100000 );
    if (rc < 0)
    {
        perror( "poll" );
    }
    else if (rc > 0)
    {
        char buffer[32] = {0};
        int r = read( fd, buffer, sizeof(buffer) );
        if (r == -1)
        {
            printf( "error: %s\n", strerror( errno ) );
        }
        else
        {
            printf( buffer );
        }
    }
    else
    {
        printf( "No data\n" );
    }
    //close( fd );
    sleep( 1 );
}

int main( int c, char ** v )
{
    int fd = openPort();
    if (fd >= 0)
    {
        while(1)
        {
            selectLoop(fd);
        }
    }

    return 0;
}


使用select()得到相同的结果。但是,如果我将一个信号附加到“接收到的数据”上,则会触发该信号,尽管在这种情况下,由于NetBeans调试环境造成了严重破坏,因此我试图避免这种情况。

仅供参考:板修订为B6,UART1仅通过TX / RX连接。 “ screen”程序成功地从UART接收和发送了字符,因此我知道它从根本上可以工作。

最佳答案

将此替换为明智的:

        printf( buffer );


也许:

for (int i = 0; i < r; ++i)
   putchar(buffer[i]);
fflush(stdout);


如果缓冲区已满,则刷新并且不会冒输出比读取更多的字符的风险。

关于c++ - 串行端口轮询在Beaglebone Black上不起作用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/26012459/

10-11 22:25