我想将Linux的串行端口设置为115200波特的“原始”模式。 如果我运行以下程序
#include
#include
#include
#include
#include
#include
#include
int main(int argc, char **argv)
{
int fd= open( "/dev/ttyS0", O_RDWR );
if ( fd < 0 )
{
perror(0);
int err = errno;
fprintf( stderr, "can't open /dev/ttyS0 got err %d\n",err );
return err;
}
printf("got fd %d\n", fd );
struct termios old;
tcgetattr(fd,&old);
struct termios news;
// enable raw comms
cfmakeraw( &news);
// set port to 115200 baud
cfsetispeed(&news, B115200);
tcsetattr( fd, TCSANOW,&news);
printf("set raw 115200\n");
usleep(5000000);
printf( "slept\n");
tcsetattr( fd, TCSANOW,&old);
printf( "restored\n");
close(fd);
printf("closed\n");
}
并在Ctrl-C睡眠期间中断它,然后再次运行它,第二次没有输出-程序在open()调用期间挂起。 即使以root身份运行也无济于事。
没有迹象表明第一个进程仍在使用该端口或该端口已被锁定,在/ var / lock /或ps aux |中没有明显的迹象。 grep tty
现在,我最好的选择是确保每当使用tty的进程终止时,它都会正确关闭端口。 但是,为什么这个问题会出现呢? 中止的进程不应该释放端口吗?