驱动策略和效率的整理

驱动可控范畴内的:

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

相关推荐
QH1392923188019 分钟前
KEYSIGHT E5071C 端网络分析仪
网络·功能测试·嵌入式硬件·物联网·单元测试·集成测试·模块测试
I_Am_Zou1 小时前
STM32实战系列|智能摄像头巡检系统完整演示:第一讲
stm32·单片机·嵌入式硬件
发发就是发3 小时前
USB系统架构概述:从一次诡异的枚举失败说起
驱动开发·单片机·嵌入式硬件·算法·fpga开发
发发就是发3 小时前
TTY子系统与线路规程:那个让我深夜抓狂的串口“丢包”问题
linux·服务器·驱动开发·单片机·嵌入式硬件
RFCEO5 小时前
Rust编程基础课 第1课时:Rust简介与环境搭建 STM32 RUST嵌入式编程实战
stm32·嵌入式硬件·rust·probe-rs·rust工具链·rustup、cargo·stm32 rust适配
少年、潜行5 小时前
【代码开源】基于STM32的智能路灯控制系统设计
stm32·嵌入式硬件·开源·智能路灯
终将超越过去6 小时前
ASRPRO使用
单片机·物联网
wotaifuzao7 小时前
深度解析:NFC、UWB与BLE技术的演进、核心技术与“无感交互“融合应用展望
嵌入式硬件·交互·ble·uwb·nfc·数字钥匙
修勾勾L7 小时前
OneNet平台生成token注意事项
stm32·物联网
玩转单片机与嵌入式13 小时前
一个成熟的嵌入式AI系统,是长什么样子的?
人工智能·单片机·嵌入式硬件·嵌入式ai