新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > STM32定時器的預裝載寄存器與影子寄存器之間的關系

        STM32定時器的預裝載寄存器與影子寄存器之間的關系

        作者: 時間:2016-11-09 來源:網絡 收藏
        STM32參考手冊的第13、14章中,都有一張定時器框圖,下面是第14章中定時器框圖的局部,圖中黃色框所示的是auto-reload register,在下面的第14.3.2節"Counter Modes"就解釋了auto-reload register的用法。

        本文引用地址:http://www.104case.com/article/201611/318032.htm

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

        在圖中用紅線圈起的一個大寫的U和一個向下的箭頭,表示對應寄存器的影子寄存器可以在發生更新事件時,被更新為它的preload register的內容;而圖中用綠線圈起的部分,表示對應的Autoreload register可以產生一個更新事件(U)或更新事件中斷(UI)。

        設計preload register和shadow register的好處是,所有真正需要起作用的寄存器(shadow register)可以在同一個時間(發生更新事件時)被更新為所對應的preload register的內容,這樣可以保證多個通道的操作能夠準確地同步。如果沒有shadow register,或者preload register和shadow register是直通的,即軟件更新preload register時,同時更新了shadow register,因為軟件不可能在一個相同的時刻同時更新多個寄存器,結果造成多個通道的時序不能同步,如果再加上其它因素(例如中斷),多個通道的時序關系有可能是不可預知的。



        評論


        技術專區

        關閉
        主站蜘蛛池模板: 阜宁县| 新邵县| 丹巴县| 大港区| 高邑县| 百色市| 衡水市| 青神县| 探索| 神池县| 昭平县| 马山县| 永川市| 武安市| 余干县| 东至县| 江源县| 嘉兴市| 兴隆县| 维西| 九龙坡区| 仁寿县| 铜山县| 兰州市| 西平县| 黄浦区| 鸡东县| 资阳市| 铜山县| 温泉县| 临泽县| 吉林省| 罗山县| 嵩明县| 兰西县| 太康县| 西昌市| 宜兰县| 康保县| 新巴尔虎左旗| 壶关县|