
STM32G474 中包含了针对数字电源应用的高精度定时器(HRTIMER),客户在应用该定时器产生 PWM 时,发现 PWM 的输出出现了“丢波”现象,本文对该问题进行分析并给出解决方案。* k8 B- [( g J, H$ x. M - l" e# B6 U5 V/ O" p4 m' F; u 2.问题描述3 g1 e& v! K4 d " }( F @0 ^6 b$ v% f, d0 g 客户使用高精度定时器产生 PWM, 其 PWM 产生的配置如下,Master Timer 的 period event与 compare 1 event 分别作为 Timer A 与 Timer B 的复位源,Timer A 与 Timer B 产生的 180 度移相的 PWM 输出,EEV4 作为外部事件来触发 PWM reset, 并且使用 blanking 功能过滤发生在PWM set 点附近的 EEV4 事件,Timer compare 3 event 用来限制 PWM 的最大占空比,当 PWM周期内没有 EEV4 发生或是发生的时间点晚于 compare 3 事件时,Timer compare 3 event 将触发PWM reset。 + W }/ T8 B7 @& x Master Timer: 8 |) i& {$ I5 q4 w& f4 \) w- } Interleaved Mode:Half mode 9 y9 Y1 f8 B G( E# p' C. D" c5 Y % g+ V9 F* _# B( E: T6 Z Timer A : Up-Down Mode : Up-counting ; }% j9 {5 T9 @/ @7 m Timer counter reset trigger source : Master timer period event PWM set source : Master timer period event " V) X3 d5 ]& F k% U PWM reset source : Timer compare 3 event + EEV4 9 c, g- m; b0 R* E+ e( F& q Timer B : Up-Down Mode : Up-counting Timer counter reset trigger source : Master timer compare 1 event 1 E. `. |% B6 ~: |5 i, [ PWM set source : Master timer compare 1 event/ i2 v7 f T2 |* s# t$ l" y, y PWM reset source : Timer compare 3 event + EEV4 EEV4 : Source:EE source 2 – COMP1 Sensitivity:Falling edge Fast Mode:re-sync mode& b8 W) s( t3 n `5 }. B Filtering : Blanking from counter reset/roll-over to compare 1 Latch : Ignored if happens during a blank ! ^; ]. ~* n3 V1 q9 k& ^4 a* k4 \ 3 P/ y4 V; I! Z! D$ A 使用以上的配置,正常情况下产生的 PWM 如下所示,C1/C2 分别为 TA1 与 TB1,C3 为EEV4,下降沿触发事件,使 PWM reset。 1 J c( v& N- D- z4 P( E ![]() " M5 _) g& }# I: r$ h 但是当外部事件发生的点接近于 PWM 周期值时,就会出现 “丢波”,如下图所示。5 ^0 t; W" j4 s# g ![]() 展开其中的部分波形观察如下 3 G, D4 e! R$ s0 ], h ![]() 6 v+ \% Q8 v: Q 3.原因分析 对 PWM 丢失的波形进行分析,当该情况发生时,EEV4 发生的时间点已经晚于 CMP3 事件,正常波形的占空比也与设定的最大允许占空比一致。丢波情形节点:在 EEV4 事件发生的时间点靠近 TA1 或 TB1 波形的 set 点处才会出现。 , l; P& v2 i5 v2 {6 c ![]() 3 i! p# \2 [0 H* _ 为什么会出现“丢波”?从波形上分析,唯一可能的原因就是 C1/C2 的 set 事件被“忽略”了 ,导致整个周期一直处于低电平状态。在高精度定时器中,若多个事件同时发生的时候就会出现事件被“忽略”的情况,且 reset 事件具备最高优先级(除了多个事件都来源于同一定时器的CMP、PER 事件),导致 set 事件被“忽略”,可阅读 RM 的 26.3.7 Set / reset events priorities and narrow pulses management 了解更多详细的规则。 ; D2 S0 y( F) Q( _& y8 |+ G, Z 从客户实际的配置中可确认在“丢波”情况出现时,EEV4 不会跨周期,且实际的波形也验证了该点,C3 的下降沿先于 C1/C2 的上升沿出现的,那么一般就会理解 EEV4 导致的 reset 事件不会与 PWM 的 set 事件 Master timer period/ compare 1 event 同时出现,且客户的配置中对EEV4 添加了消隐功能, blanking 区间为 counter reset/roll-over to compare 1,即使 EEV4 与Master timer period/ compare 1 event 同时出现,也应该被过滤掉,set 事件不应该被忽略。总结如下:+ m, v4 _/ w5 G • EEV4 不会与 Master timer period/ compare 1 event 同时出现;1 P# m) P3 j, U) f6 A • 即使同时出现,EEV4 也应该被消隐过滤掉。但是 EEV4 作为外部事件作用于高精度定时器(复位 counter 或是 set/reset PWM 输出),其从事件发生到生效是存在一定的内部延时(26.3.8 External events global conditioning),如下图所示。在 re-sync 模式下,这个延时一般会在 60ns 左右。 ![]() 在高精度定时器中对多个事件同时出现的处理都是以事件的实际生效点为准,所以当 EEV4的下降沿发生点靠近 PWM set 事件的情况下,经过内部延时后,就可能会与 set 事件同时出现了。# k7 ~, `4 h; ]. h6 A4 s! h6 f+ L 关于消隐功能的 blanking 区间,比如本文中的 counter reset/roll-over to compare 1,一般的理解是从起点到终点全部过滤,但是实际情况是在设定的起点处 blanking 不会生效(经 division确认),即 blanking 区间不是闭区间。另外需要注意的是消隐功能作用的也是事件的实际生效点,而非发生点。 " O" E; y- @; P! u6 @ / d6 w/ [8 l# b! E1 t. m 对以上的分析总结如下:9 `4 X7 ~. p# v5 h8 t9 B •多个事件同时出现的处理过程中,以事件的实际生效点为准,而非发生点; • 消隐功能在 blanking 区间的起始点无效,且消隐对象为实际生效点在区间内的事件。 , B+ S" ^6 r5 ~4 x ]% u1 c0 L4 p 客户的配置中,blanking 区间的起始点与 PWM 的 set 点为同一个点,若是 reset 事件 EEV4通过内部延时后刚好也落在这个点上,那么消隐不生效,reset 相对 set 优先级高,结果就是 set事件被忽略,PWM 输出继续保持低电平,也是我们观察到的 PWM“丢波”。基于上述分析,对客户描述现象进行复现,很容易捕捉到“丢波”现象,本文中提供的“丢波”时的波形就是基于以上的分析与实验获取的。, M! o$ [) G8 @ [8 ~ E+ x) }, L$ }: g# w9 ?: t* p . P& g$ T) b2 ? |