
01、概述6 |( ]7 l4 }- F" v. [) k 在定时器框图中,有个小细节,有些寄存器下有个阴影 ) S6 J$ h8 M$ Q2 F7 e, q$ T ![]() 4 y2 S8 r: f6 }, ~ 有这些阴影的表示这些寄存器存在影子寄存器。 在图例中也有对影子寄存器的说明: 6 C9 B! M' v9 G( A6 c ![]() 根据控制位,在发生U事件后,预装载寄存器内容转移到有效寄存器。这也就是对影子寄存器的说明。% W# n& O. [6 D5 o$ S) G1 Y5 _ , s& q6 n0 g% A: Q! q& j7 [# o 有阴影的寄存器(AutoReloadRegister),表示在物理上这个寄存器对应2个寄存器,一个是程序员可以写入或读出的寄存器,称为preloadregister(预装载寄存器),另一个是程序员看不见的、但在操作中真正起作用的寄存器,称为shadowregister(影子寄存器)。( g. Y5 @, [% j; l S3 o3 O; M/ U. L 这里有3个寄存器名称 AutoReloadRegister。/ L% Q9 t& g- P j) ^9 B " H Z r, ~- h% ]2 U! z% { preloadregister。 shadowregister。! ^- F) v- t: W( @4 x' ~# w( S& [ - ] G- o0 s% f, b7 c 在这里我的理解是,AutoReloadRegister自动重装载寄存器是一个概念寄存器,可以在寄存器表中找到每一位的定义,它是由preloadregister预装载寄存器和shadowregister影子寄存器组成。我们用户能接触到,能修改或读取的都是预装载寄存器,ST只是把它们开放出来(影子寄存器并没有开放给用户),其实就是ARR寄存器。 8 G4 X9 ]7 {. Y2 T6 U8 P8 q* H 设计preloadregister和shadowregister的好处是: 0 _# ^5 C& u- v% d6 L 所有真正需要起作用的寄存器(shadowregister)可以在同一个时间(发生更新事件时)被更新为所对应的preloadregister的内容,这样可以保证多个通道的操作能够准确地同步。如果没有shadowregister,或者preloadregister和shadowregister是直通的,即软件更新preloadregister时,同时更新了shadowregister,因为软件不可能在一个相同的时刻同时更新多个寄存器,结果造成多个通道的时序不能同步,如果再加上其它因素(例如中断),多个通道的时序关系有可能是不可预知的。 6 G8 @0 K9 `( U+ ^ 看到有阴影寄存器共三种: L9 H& D, C: y& j) A 0 u7 e- \( k! e5 T: m 1、PSC(Prescaler) 2 _ G* F1 X7 i; ]9 S! c# J 2、ARR(AutoReloadRegister)& b ~7 s. W/ } r8 u7 {+ ^& I 1 R' A* E3 @* x9 e& I* c @ 3、CCR(Capture/Comparex Register)( l5 |6 r! ^! w* Q; \ 4、REPRegister 02、PSC(Prescaler) 在预分频器的描述中:) n& A0 e0 d/ |7 y0 h7 D" p 8 _& c6 l% [( s5 f, ?% S$ K2 B It is based on a 16-bit counter controlled through a 16-bit register(in the TIMx_PSC register).It can be changed on the fly as thiscontrol register is buffered. The new prescaler ratio is taken intoaccount at the next update event.+ z" v* S% [8 ^7 {- F& l ( R/ w8 c9 F' t, c 节选自STM32F207 Reference manual手册 由于该控制寄存器具有缓冲功能,因此可对预分频器进行实时更改。而新的预分频比将在下一更新事件发生时被采用。 预分频器分频由1 变为2 时的计数器时序图2 U+ ~; t' V/ a$ f | 3 ^! o8 j- f- N+ @! |$ B. A ![]() ! Y7 ~! ^8 T, |2 s" z1 v 在这里看到预分频器寄存器存在影子寄存器,但是没有控制位控制它,它的预装载寄存器和影子寄存器是相连的。 0 x8 E: p3 c- B7 I 工作模式如下图:( V$ H# G% w; K* u9 H( g 9 |% Z2 Q1 Z8 ]5 d ![]() 注意:6 ]! F; Q: V7 K4 w7 H* u" O : Q! B' T8 u) _2 ~$ W8 G 在ST的手册中,影子寄存器被描述成缓冲,在对预分频器的影子寄存器描述成寄存器具有缓冲功能。其中 7 N- F7 U1 g; S( j8 ? ![]() 在这里又被描述成TIMx_ARR寄存器不进行缓冲。" l( q# Y7 t5 n# H9 b $ I* O* r4 A+ u 03、ARR(AutoReloadRegister) 控制位:+ {! G' v/ q& m" u0 \7 U6 P 3 e. ?5 y6 H% p+ ?: U2 x 在时基单位中有说明如下 The content of the preload register are transferred into theshadowregister permanently or at each update event (UEV), depending on theauto-reloadpreload enable bit (ARPE) in TIMx_CR1 register. 1 u4 e, f8 x) `/ a 节选自STM32F207 Reference manual手册 预装载寄存器的内容既可以直接传送到影子寄存器,也可以在每次发生更新事件(UEV)时传送到影子寄存器,这取决于TIMx_CR1 寄存器中的自动重载预装载使能位(ARPE)。- s* R2 w) ^ z; P ! k* z0 p% R) w 也就是TIMx_CR1的ARPE位决定了预装寄存器数据传入影子寄存器的时间先后顺序。$ a! L1 _3 n9 q. N. X+ c 计数器时序图,ARPE=0 时更新事件(TIMx_ARR 未预装载)。 ![]() 从上面两图看出,向上计数,还没有到达0x36,就把自动重载寄存器修改为0x36,就会在计数到0x36时产生动作。2 x( B. T( {% {3 ?) z 计数器时序图,ARPE=1 时更新事件(TIMx_ARR 预装载)。. j1 V" X$ C, d, b6 o* I # U7 @# T% D e ![]() 6 F% [ a1 k& y6 c8 b 从上面两图看出,向上计数,还没有到达0x36,就把自动重载预装载寄存器修改为0x36,就不会在计数到0x36时产生动作,会在这个时将自动重载预装载寄存器值赋给自动重载影子寄存器。5 s' h! z6 g6 C/ F" q8 P& b' E; w " S$ D, F. b' F4 S; } 从预装载寄存器ARR传送到影子寄存器,有两种方式,一种是立刻更新,一种是等触发事件之后更新;这两种方式主要取决于寄存器TIMx->CR1中的“ARPE”位; 4 ?* J7 X9 i: d ARPE=0,当ARR值被修改时,同时马上更新影子寄存器的值;+ k; X9 M, @ J/ s ARPE=1,当ARR值被修改时,必须在下一次事件UEV发生后才能更新影子寄存器的值; w9 S- ?6 S; o) u" d$ x( C 怎么样马上立刻更改影子寄存器的值,而不是下一个事件;方法如下 1、将ARPE=0。
2、在ARPE=1。 4 h! Z6 T1 H: P/ N$ h
我们更改完预装载寄存器后,立刻设置UEV事件,即更改EGR寄存的UG位,如下3 ^$ ?2 _: _* l! Y3 C6 b# D& [ # V9 o, p/ @6 [6 P2 x
工作模式如下图:0 `9 D: \' f3 Q9 I- {+ z, P, { : G- Q5 N$ t( h' O5 S! |1 Z, L- U8 o ![]() 04、CCR(Capture/Comparex Register)3 d4 t/ |9 _. H 还有计数器模式中有文字说明:5 `& j- S/ B& Y9 a C! f. Z7 j The UEV event can be disabled by software by setting the UDIS bit inthe TIMx_CR1 register. This is to avoid updating the shadow registerswhile writing new values in the preload registers。) x8 p: _2 v9 |5 f# y) c1 ~4 h - ~6 \: w6 U, D* g6 {- k( A' T8 m 节选自STM32F207 Reference manual手册0 T! x) n5 Z+ p5 F 通过软件将TIMx_CR1寄存器中的UDIS位置1可禁止更新事件UEV事件。这可避免向预装载寄存器写入新值时更新影子寄存器。 也就是TIMx_CR1寄存器中UDIS位间接决定了预装寄存器数据是否传入影子寄存器。 ! M5 C0 T: j+ a ! @* a; G9 L: b% i, b |
实战经验 | Keil工程使用NEAI库的异常问题
STM32 ISP IQTune:真正零门槛的免费ISP调整软件
【经验分享】STM32 新建基于STM32F40x 固件库的MDK5 工程
意法半导体MCU双供应链策略,打消中国客户后顾之忧
【经验分享】基于STM32使用HAL库实现USB组合设备CDC+MSC
2024意法半导体工业峰会:赋能智能电源和智能工业,构筑可持续未来
ST推出灵活、面向未来的智能电表通信解决方案,助力能源转型
意法半导体 x Qu-Bit Electronix:推动新一轮的数字声音合成革命
从STM32 MPU产品看嵌入式系统中微处理器的新变化
【Hot!】STM32全系列开发板都支持Arduino开发,你知道吗?