驱动可控范畴内的:
走轮询/中断/DMA
1. 轮询模式(Polling)
-
工作原理:CPU 主动检查串口硬件发送缓冲区的状态。如果缓冲区空,就填入一个字节;如果缓冲区满,CPU 就忙等(死循环)直到硬件发送完该字节。
-
特点:
-
阻塞 :函数在返回前,必须等待所有数据发送完毕。如果发送长字符串,调用线程会被挂起很长时间(毫秒级)。
-
CPU 占用:在等待期间 CPU 无法做任何其他工作(除非被更高优先级任务抢占)。
-
多任务影响 :如果不加锁,多个任务同时调用会导致输出严重交错,因为一个任务可能在等待间隙被抢占,另一个任务开始打印。
-
2. 中断模式(Interrupt-driven)
-
工作原理 :驱动维护一个发送缓冲区(FIFO)。应用程序调用
printf时,仅将数据拷贝到缓冲区,然后立即返回。硬件在发送完一个字节后触发中断,中断服务程序从缓冲区取出下一个字节发送。 -
特点:
-
非阻塞:函数通常很快返回(仅受内存拷贝速度影响),发送过程在后台进行。
-
CPU 占用:发送本身不占用 CPU 算力,但每次中断(每个字节一次)会有短暂的中断开销。
-
多任务影响 :如果多个任务同时向同一个缓冲区写入数据,且没有互斥保护,缓冲区数据会被破坏,同样会导致输出乱码或混乱。但相比轮询,单个任务不会因为打印而长时间阻塞。
-
3. DMA 模式(Direct Memory Access)
-
工作原理:CPU 配置 DMA 控制器,指定数据源、长度和串口外设,然后 DMA 硬件自动将数据从内存搬运到串口发送寄存器,整个过程无需 CPU 干预。发送完成后触发中断通知 CPU。
-
特点:
-
极低 CPU 占用:传输大量数据时,CPU 几乎不参与,适合高速大数据量传输。
-
非阻塞:函数通常将数据交给 DMA 后立即返回。
-
多任务影响:如果多个任务同时发起 DMA 传输,必须由驱动进行排队或互斥,否则硬件资源冲突
-
-
==================================================================
-
速度问题:
-
吞吐量 (最终能发多快):由硬件波特率决定,与驱动策略无关。115200 bps 的波特率下,无论如何优化,每秒最多传输约 11.5KB 数据。
-
响应延迟(从调用到返回的时间):
-
轮询:延迟 = 发送时间(如 100 字节约 8.7 毫秒 @115200)。
-
中断/DMA:延迟 = 内存拷贝时间(微秒级)。
-
(
-
无论采用哪种策略,只要多个任务并发调用 且驱动未做互斥保护,都会出现输出交错:
-
轮询:任务 A 发送到一半,被任务 B 抢占,B 开始发送,导致两段内容混杂。
-
中断/DMA:任务 A 将数据写入共享缓冲区后返回,任务 B 随后也写入,若没有锁保护,缓冲区内容可能被覆盖或混合,导致最终输出的数据是 A 和 B 的混合。)
-