串口端口轮询无法在Beaglebone Black上运行

时间:2014-09-24 08:48:18

标签: c++ linux serial-port beagleboneblack

我根本无法获得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连接。 “屏幕”程序成功接收并发送UART中的字符,因此我知道它从根本上起作用。

1 个答案:

答案 0 :(得分:0)

用明智的东西取而代之:

        printf( buffer );

也许:

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

如果缓冲区已满,则刷新并且不会冒印刷多于字符的风险。