短文标题: 硬件PWM:定时器自动翻转引脚,CPU不费心

你有没有想过一个问题:用软件延时翻转GPIO,CPU被占死,其他事做不了。用定时器中断翻转GPIO,中断频繁进出,CPU负载还是高。硬件PWM:配置好,它就自己在后台翻转引脚,CPU占用率≈0。硬件PWM的核心原理 通用定时器的PWM模式本质是比较输出。
- 计数器从0向上计数(或向下/中央对齐)
- 计数值 < CCR(捕获/比较寄存器)→ 输出高电平
- 计数值 ≥ CCR → 输出低电平
- 计数值 = ARR(自动重装载寄存器)→ 归零,重复
整个过程硬件完成,不需要软件干预。占空比和周期的配置

- 周期:ARR决定。PWM频率 = 定时器时钟 / (PSC+1) / (ARR+1)
- 占空比:CCR决定。占空比 = CCR / (ARR+1) × 100%
示例:ARR=999,CCR=500 → 占空比50%。CCR=200 → 20%。代码示例,CubeMX配置:
- 定时器时钟:72MHz
- 预分频器(PSC):71 → 计数时钟1MHz(周期1μs)
- ARR:999 → 周期1ms → PWM频率1kHz
- CCR:500 → 占空比50%
启动PWM:
HAL_TIM_PWM_Start(&htim2, TIM_CHANNEL_1);
运行时改变占空比:
__HAL_TIM_SET_COMPARE(&htim2, TIM_CHANNEL_1, 300); // 动态调为30%
关键:硬件自动更新输出,改CCR即可,无需重启定时器。
硬件PWM vs 软件模拟
硬件PWM是电机控制、LED调光、开关电源的首选方案。高级功能:互补输出与死区 高级定时器(TIM1/TIM8)支持互补PWM (CHx和CHxN),用于驱动H桥上下桥臂。通过死区时间配置,防止上下管同时导通。
// 设置死区时间(BDTR寄存器)
htim1.Init.BreakDeadTime = 100; // 100个时钟周期
刹车输入(BKIN):外部故障信号触发时,硬件自动关闭PWM输出,保护电路。多通道独立PWM,通用定时器(TIM2~TIM5)通常有4个独立的比较通道,可同时输出4路不同占空比的PWM(周期相同,占空比独立),适合RGB灯控、多轴电机驱动。
这个故事的启示, 硬件能做的事,别让软件做。定时器、PWM、DMA都是"硬件加速器"------配置好,启动,然后忘记。把CPU从"苦力"变成"指挥官"。
需要输出PWM?别再自己翻转GPIO了。翻开定时器章节,配好PWM模式。启动后,它就自己在后台干活,CPU去忙更重要的事。选硬件PWM,效率和性能都提高一截。

(本文灵感源于于振南《新概念ARM32单片机》教程第6.7节"通用定时器硬件PWM原理与其优势"。)
觉得有用?点赞、转发,让更多人看懂"硬件PWM"如何解放CPU
