打印
[其他]

带硬件FIFO的串口驱动程序设计思路

[复制链接]
679|6
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
renzheshengui|  楼主 | 2023-12-21 09:35 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
串口具有硬件FIFO可以降低中断频率,对于需要高波特率数据传输,MCU本身速度比较慢,或有更高级优先级中断需要及时处理的场合就显得比较重要。通常,即便串口本身带硬件FIFO,在编写串口驱动程序时,仍然需要在上层在加一层软件FIFO(或RingBuffer),本文在串口中断的基础上介绍带硬件FIFO的串口驱动程序设计。

1.串口发送

串口发送有上层应用主动发起,设计起来相对简单。

中断开启:开启硬件FIFO空中断或发送完成(TXC)中断(初始化时关闭,在发送函数中打开)。

1)发送接口

函数原型:

uint32_t UART_SendBuf(uint8_t *pData, uint32_t nLength);
思路:

a)首次数据传输,将数据丢入软件FIFO中,从软件FIFO中取最大为硬件FIFO深度的的数据丢入硬件FIFO,置位数据传输标志,开启串口传输完成中断(TXC),返回。

b)正在数据传输中(ISR TXC已开启),将数据丢入软件FIFO中,返回。

2)发送ISR

a)从软件FIFO中取最大为硬件FIFO深度的数据丢入硬件FIFO,返回。

b)若从软件FIFO中取数据为空,关闭串口传输完成中断,返回。

2.串口接收

串口接受由外部数据传入,因此由ISR驱动。

中断开启:开启硬件FIFO Level中断,Timeout中断。

1)接收接口

函数原型:

uint32_t UART_RecvBuf(uint8_t *pData, uint32_t nLength);
思路:

软件FIFO不空,读取指定长度数据,返回。

2)接收ISR(硬件FIFO达到Level中断)

a)检查硬件Level中断标志位,读取硬件FIFO中所有数据,丢入软件FIFO中,返回。

b)检查硬件Timeout中断标志位,读取硬件FIFO中所有数据,丢入软件FIFO中,返回。这一步主要是考虑到接收数据未达到Level时的情况。
————————————————
版权声明:本文为CSDN博主「propor」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/propor/article/details/131239937

使用特权

评论回复
沙发
tpgf| | 2024-1-3 16:50 | 只看该作者
硬件fifo是一个独立的空间 并不占用原来的flash以及ram吗

使用特权

评论回复
板凳
qcliu| | 2024-1-3 21:59 | 只看该作者
一般来说这个硬件fifo的大小是多少呢

使用特权

评论回复
地板
drer| | 2024-1-4 10:31 | 只看该作者
硬件fifo的存储速度是不是应该更快啊

使用特权

评论回复
5
coshi| | 2024-1-4 11:45 | 只看该作者
可以通过软件手段单独开辟一个独立的fifo空间吗

使用特权

评论回复
6
wiba| | 2024-1-4 23:20 | 只看该作者
数据传输使用硬件fifo会不会增加数据的吞吐量啊

使用特权

评论回复
7
kxsi| | 2024-1-4 23:54 | 只看该作者
硬件fifo是不是就像是我们常说的adc啊  定时器啊之类的模块啊

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

78

主题

3888

帖子

2

粉丝