有STM32開發(fā)者用到STM32F429芯片開發(fā)產(chǎn)品,并用到其中的CAN外設。在CAN應用過程中有個專門針對收發(fā)出錯情況進行次數(shù)統(tǒng)計的兩個計數(shù)器,其值通過錯誤狀態(tài)寄存器CAN_ESR中的REC[7:0]和TEC[7:0]兩個字段來體現(xiàn),CAN硬件會根據(jù)錯誤數(shù)據(jù)大小做適當響應或處理。
根據(jù)寄存器描述得知,TEC[7:0]和REC[7:0]的值在這個寄存器里面是只讀的。而此時的STM32用戶有個強烈的需求,就是期望能適時地對這兩個出錯記錄字段做清零。他自己也嘗試編寫一些代碼想讓二者清零,均以失敗告終,便郵件咨詢有無解決辦法。
我們在閱讀CAN_ESR寄存器內(nèi)容時倒有個發(fā)現(xiàn),即該寄存器的復位值是0x00000000。
也就是說,芯片每次復位后其值一定是0,自然那兩個出錯計數(shù)器的值也是0。可客戶明確表明,不接受通過對芯片級復位的方式來實現(xiàn)對二者清零。
那怎么辦呢?對整個芯片復位不接受,直接寫又不起作用。還有別的辦法嗎?
其實,STM32芯片除了各種芯片級的復位外,還有專門針對各個外設模塊的復位。也就是說,既然這樣我們可以考慮僅針對CAN外設做復位而達到目的??蛻粢步邮苓@個做法。
以STM32F4芯片為例,下面寄存器就是負責對部分APB1外設進行復位操作的控制寄存器。
其中,CAN1/CAN2外設就是被其中的兩個控制位所管控。
我們對相應控制位置1或清零達到對外設模塊強制復位或做復位釋放的操作。我們不妨以這里的CAN1為例,相應的Cube庫函數(shù)代碼如下:
__HAL_RCC_CAN1_FORCE_RESET(); //對CAN1外設實施強制復位
__HAL_RCC_CAN1_RELEASE_RESET();//釋放對CAN1外設的強制復位
這里提醒并強調(diào)下,針對外設的強制復位和復位釋放指令原則上要成對使用。如果做了強制復位而不釋放的話,后面的配置不保證有效。
后來,客戶按照上面推薦的方法操作后,可靠有效,符合心意。我在這里將該案例分享出來,說不定哪天你能派上用場。畢竟書到用時方恨少嘛。
審核編輯:湯梓紅
-
mcu
+關(guān)注
關(guān)注
146文章
17983瀏覽量
366877 -
寄存器
+關(guān)注
關(guān)注
31文章
5434瀏覽量
124481 -
CAN
+關(guān)注
關(guān)注
57文章
2920瀏覽量
467797 -
STM32
+關(guān)注
關(guān)注
2293文章
11032瀏覽量
364914 -
STM32F429
+關(guān)注
關(guān)注
0文章
40瀏覽量
11353
原文標題:巧用外設復位修改只讀寄存器
文章出處:【微信號:stmcu832,微信公眾號:茶話MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
無法向外設寄存器寫入數(shù)值是怎么回事?
數(shù)據(jù)寄存器,數(shù)據(jù)寄存器是什么意思
ARM寄存器詳解
FPGA 調(diào)試 – 外設寄存器視圖

51單片機復位電路及復位后寄存器的狀態(tài)
配置STM32寄存器控制GPIO點亮LED

修改寄存器默認值的方法
修改寄存器默認值的方法有哪些

如何用外設復位修改只讀寄存器

干貨滿滿:ARM的內(nèi)核寄存器講解

評論