我根本无法获得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/