串口驱动读取时遇到的问题
最近在做串口驱动时,在用read函数读取数据时,从串口收到的数据上层没法收到,但对方却能收到我将数据原样返回了
跟踪运行发现,read操作时,我的start_tx函数被调用了。
继续看,发现应该是serial_core中的uart_flush_chars函数调用的。
但uart_flush_chars是学习驱动时一直被告知用来将数据发送到硬件的,为什么会调用呢
继续深入,找到flush_to_ldisc函数调用的receive_buf函数即n_tty_receive_buf中有这样一段
if (tty->ops->flush_chars)
tty->ops->flush_chars(tty);
于是乎,我彻底疑惑了,接收数据的时候为什么要调用发送的操作呢。
做驱动开发没多久,还有很多需要学习,还希望各位大哥大姐指点迷津,谢谢啦!
[解决办法]
可能是你配置串口的时候没有关闭回显功能
[解决办法]
下面的内容是初始化串口时用到的,没有回显。你可以copy过去
//设置字符大小
//激活本地连接和接收使能
newtio.c_cflag
[解决办法]
= CLOCAL; //
newtio.c_cflag
[解决办法]
= CREAD; //
/*
在用write发送数据时没有键入回车??
信息就将发送不出去的情况,
这主要是因为我们在输出输入时是按照 规范模式接受到回车或者换行才发送,
而很多情况我们是不需要回车和换行的,
这时,应当切换到行方式输入,
设置options.c_lflag &= ~(ICANON
[解决办法]
ECHO
[解决办法]
ECHOE
[解决办法]
ISIG);
不经处理直接发送。
*/
newtio.c_lflag &= ~(ICANON
[解决办法]
ECHO
[解决办法]
ECHOE
[解决办法]
ISIG);
/*
在我们发送字符0x0d的时候,
往往接受端得到的字符是0x0a 这是怎么回事,
原因是在串口设置中c_iflag和c_oflag中存在从NL-CR 和CR-NL的映射,
也就是说,串口可以把回车和换行看成一个字符,所以,
此时我们应该屏蔽掉这些,
用options.c_oflag &=~(INLCR
[解决办法]
IGNCR
[解决办法]
ICRNL
[解决办法]
);
和options.c_oflag &=~(ONLCR
[解决办法]
OCRNL);
进行设置
*/
newtio.c_oflag &= ~(INLCR
[解决办法]
IGNCR
[解决办法]
ICRNL);
newtio.c_oflag &= ~(ONLCR
[解决办法]
OCRNL);