简述:使用TIM2捕获pwm* A/ H. ]' M) {$ E. v2 z5 Q
IDE: KEILv5.27! C' ?; {8 K* l
Firmware Package:STM32Cube FW_H7 V1.8.0
% p8 a$ V, @, \3 J芯片:STM32H750VBT6
e4 }4 |' Y4 f9 t9 s2 u) A4 D" n, x0 i' V% }2 J& I F, z9 G7 g
( X/ g# ?: t9 r1 F4 ~, b$ [: K7 z, e( k+ z/ z5 i
开启tim2输入捕获
$ T' l5 N. U- p6 F; Y8 y) @
/ U; V ~ f" a1 Q4 ^8 B; V. {: b% g6 q. R# X0 o! L; a
配置PSC为200-1,这里主要是方便计算,计时器加一正好是1微妙。我配置的H750的主频为400M,APB1时钟为200M,并且我是用来测量50Hz的矩形波。所以PSC为200-1已经足够。ARR就取最大值即可。
; E% X- o A2 L/ U7 C$ y- r
7 s( u0 p1 U) b- R2 C
8 R7 {% I: `. B; V& m* s
. a: {7 P* C6 X: w0 {通道一和二都配置成捕获上升沿。
- a% m8 a0 Y2 h" C7 Y% N8 `- z' R( E6 N! L9 J$ W0 c. t
# F% J) c( H$ g6 E5 g6 Q% Q
/ {) k* O* [1 z管脚配置成上拉或者下拉。在无信号输入的时候,保持稳定的电平。4 c, _* m( _7 }# D+ Q( [
% O x2 p0 F8 F
- HAL_TIM_IC_Start_IT(&htim2,TIM_CHANNEL_1); 3 L8 D2 T! J+ }: L& R* s
- HAL_TIM_IC_Start_IT(&htim2,TIM_CHANNEL_2);
) g! ]+ H" \! e+ x1 y% w0 \ - //开启tim2两通道的输入捕获
复制代码- void HAL_TIM_IC_CaptureCallback(TIM_HandleTypeDef *htim)
0 S7 d1 `1 J) ?, p8 A8 k - {//hal库输入捕获回调函数、2 Z; ~% p8 m8 @4 X6 G4 t0 J
- if(htim->Instance == TIM2)# p3 x" ^4 \) b. U% x
- {//判断是否为TIM2* s; s- ]+ P: m0 t
- if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_1)//判断是否为TIM2的通道一 `" G9 W9 o/ Q9 h) G+ E
- TIM2_CaptureChannel1_Callback();/ `) Z7 Y- z8 U8 d* b+ ~8 o! z
- if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_2)
4 ]# i5 b" m+ K' B - TIM2_CaptureChannel2_Callback();
, d3 _9 v8 t7 P/ H - }. [5 e# ^0 f& i# }8 q7 G3 L
- if(htim->Instance == TIM4)' J5 G2 ?1 b( M" }2 o) v
- {
; y* G( N$ s: v& B' O) ? - if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_1)2 n; B$ F' L/ h* P1 P/ E
- TIM4_CaptureChannel1_Callback();
: D* d" l7 _& u - if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_2)
2 e% `& W p+ R# Q! j) Z. D - TIM4_CaptureChannel2_Callback();
' G4 ? b2 B; c, V8 R% H - }8 h9 I/ d6 s ]( F# }
- }& s- U2 u6 O' g( G5 ]7 F( N
. q4 g9 v: G6 b4 l% r2 A5 w
2 c I; g- y% F2 q* |: C) H
0 T s9 G# Q+ A0 J- void TIM2_CaptureChannel1_Callback(void)
4 D3 C% {0 {' S* b# S/ y+ e - {
' {* H, a# M/ e4 H; d Q; k - switch(tim2_ch1.capture_edge); {5 ~3 m4 W; q$ n
- {
9 H0 w' a; b0 ]; E' h - case RASING:6 d8 }' A3 x7 }: O, w8 _* l/ _
- __HAL_TIM_SET_CAPTUREPOLARITY(&htim2,TIM_CHANNEL_1,TIM_ICPOLARITY_FALLING);
9 b$ T% J: ~! C6 [6 `8 V - tim2_ch1.capture_edge = FALLING;
6 T w! U( y% |5 m1 H% S - . L3 |2 B& w7 }0 A# A
- tim2_ch1.capture_period = __HAL_TIM_GetCounter(&htim2);. `7 j% \# p1 a1 e( \) F( U
- __HAL_TIM_SET_COUNTER(&htim2,0);3 y8 O {3 k! ]$ e( P
- break;
5 U" g3 N1 z2 f6 \2 l L - case FALLING:/ M7 l. p: s- P) U
- __HAL_TIM_SET_CAPTUREPOLARITY(&htim2,TIM_CHANNEL_1,TIM_ICPOLARITY_RISING);( h: z+ l1 R$ ?: m( Q
- tim2_ch1.capture_edge = RASING;
- I8 b; w. b: K4 X$ c$ H - tim2_ch1.capture_half_period = __HAL_TIM_GetCounter(&htim2); 2 |/ O9 G& _4 B- A& \! M# f. y
- }
# v: K4 S1 r, |1 W% O - ' p* N6 F' N& F& g7 ^( @" E- b
- }
复制代码- #define __HAL_TIM_SET_CAPTUREPOLARITY(__HANDLE__, __CHANNEL__, __POLARITY__) \5 [% d# c; v1 u3 R
- do{ \
2 {6 n0 {/ s0 o- Z - TIM_RESET_CAPTUREPOLARITY((__HANDLE__), (__CHANNEL__)); \
1 o( L$ i+ q3 |4 |9 K; ~3 v - TIM_SET_CAPTUREPOLARITY((__HANDLE__), (__CHANNEL__), (__POLARITY__)); \) {0 l+ e" K d8 D, s
- }while(0)
复制代码 3 M& N, z2 W, i, K( l+ q
这一句话__HAL_TIM_SET_CAPTUREPOLARITY中就包含了清除原来通道的极性和设置型通道的极性。所以直接使用即可。# J' C5 A7 k0 q" I1 \
; P. L! s) j8 [4 m3 q, @- __HAL_TIM_GetCounter(&htim2)
v- s- R: W/ E+ f6 i4 E [ - __HAL_TIM_GetCompare(&htim2,TIM_CHANNEL_1)
复制代码 这两句话 第一句是用来获得计数器的值,一个是用来获得CCR1的值。CCR1是通道一的捕获/比较寄存器。CCR1包含了由上一次输入捕获事件传输的计数器值。所以在此中断里两句话的作用差不多。如果不在中断内调用,获得CCR1的值即可。由于我要在TIM4的中断中取获得TIM2的计数值,所以都使用了__HAL_TIM_GetCounter。
% T! \6 A/ H7 J' F1 g0 N" J实验结果:50HZ方波捕获到的周期为20000us基本不变。+ e* F0 t. f# j/ g( L/ k
) Y% o8 s" f3 Y9 Z% k U7 Q
, ~ l* X8 e' o; T: y. e, W% F" S. E* B* p
|