新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > STM32定時(shí)器的預(yù)裝載寄存器與影子寄存器之間的關(guān)系

STM32定時(shí)器的預(yù)裝載寄存器與影子寄存器之間的關(guān)系

作者: 時(shí)間:2016-11-09 來(lái)源:網(wǎng)絡(luò) 收藏
STM32參考手冊(cè)的第13、14章中,都有一張定時(shí)器框圖,下面是第14章中定時(shí)器框圖的局部,圖中黃色框所示的是auto-reload register,在下面的第14.3.2節(jié)"Counter Modes"就解釋了auto-reload register的用法。

本文引用地址:http://m.butianyuan.cn/article/201611/318032.htm

在圖中可以看到auto-reload register這個(gè)框有一個(gè)陰影,有些其它寄存器也有用陰影表示,如我用藍(lán)色標(biāo)出的Capture/Compare寄存器;有陰影的寄存器,表示在物理上這個(gè)寄存器對(duì)應(yīng)2個(gè)寄存器,一個(gè)是程序員可以寫(xiě)入或讀出的寄存器,稱為preload register(預(yù)裝載寄存器),另一個(gè)是程序員看不見(jiàn)的、但在操作中真正起作用的寄存器,稱為shadow register(影子寄存器);正如手冊(cè)上的14.3.1節(jié)所說(shuō),根據(jù)TIMx_CR1寄存器中APRE位的設(shè)置,preload register的內(nèi)容可以隨時(shí)傳送到shadow register,即兩者是連通的(permanently),或者在每一次更新事件(UEV)時(shí)才把preload register的內(nèi)容傳送到shadow register。

在圖中用紅線圈起的一個(gè)大寫(xiě)的U和一個(gè)向下的箭頭,表示對(duì)應(yīng)寄存器的影子寄存器可以在發(fā)生更新事件時(shí),被更新為它的preload register的內(nèi)容;而圖中用綠線圈起的部分,表示對(duì)應(yīng)的Autoreload register可以產(chǎn)生一個(gè)更新事件(U)或更新事件中斷(UI)。

設(shè)計(jì)preload register和shadow register的好處是,所有真正需要起作用的寄存器(shadow register)可以在同一個(gè)時(shí)間(發(fā)生更新事件時(shí))被更新為所對(duì)應(yīng)的preload register的內(nèi)容,這樣可以保證多個(gè)通道的操作能夠準(zhǔn)確地同步。如果沒(méi)有shadow register,或者preload register和shadow register是直通的,即軟件更新preload register時(shí),同時(shí)更新了shadow register,因?yàn)檐浖豢赡茉谝粋€(gè)相同的時(shí)刻同時(shí)更新多個(gè)寄存器,結(jié)果造成多個(gè)通道的時(shí)序不能同步,如果再加上其它因素(例如中斷),多個(gè)通道的時(shí)序關(guān)系有可能是不可預(yù)知的。



評(píng)論


技術(shù)專區(qū)

關(guān)閉