驱动策略和效率的整理

驱动可控范畴内的:

走轮询/中断/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 的混合。)

相关推荐
jghhh0114 分钟前
STM32 上使用 SPI 总线驱动 OLED 的程序
stm32·单片机·嵌入式硬件
foundbug99925 分钟前
STM32 + uIP协议栈实现TCP/UDP功能指南
stm32·tcp/ip·udp
XINVRY-FPGA26 分钟前
XC7Z010-2CLG400I Xilinx Zynq-7000 FPGA
arm开发·嵌入式硬件·算法·fpga开发·硬件工程·dsp开发·fpga
WYH28739 分钟前
一、驱动基础
linux·嵌入式硬件
XINVRY-FPGA1 小时前
XCZU11EG-2FFVC1156I Xilinx Zynq UltraScale+ MPSoC EG FPGA
图像处理·嵌入式硬件·计算机视觉·fpga开发·硬件工程·dsp开发·fpga
山木嵌入式13 小时前
【STM32实战】轻量级任务调度器实现
stm32·单片机·rtos·任务调度器·裸机开发
guygg8813 小时前
基于霍尔传感器的BLDC控制源码
单片机·嵌入式硬件
ytttr87313 小时前
DSP 28335 CAN总线通信程序
开发语言·stm32·单片机
一枝小雨15 小时前
RISC-V架构sp寄存器 & RISC-V架构下FreeRTOS任务上下文保存与恢复
单片机·架构·嵌入式·risc-v·rtos·内核原理
BW.SU16 小时前
PackagingTool 嵌入式资源打包合并工具
单片机·二进制·嵌入式开发·资源合并软件·图片打包