0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

STM32復位來源 以及系統(tǒng)和內(nèi)核復位區(qū)別

黃工的嵌入式技術(shù)圈 ? 來源:黃工的嵌入式技術(shù)圈 ? 作者:黃工的嵌入式技術(shù) ? 2020-02-28 17:13 ? 次閱讀

最近有朋友問了些關于STM32復位的問題,今天結(jié)合前面文章再次總結(jié)一下復位相關知識。

1STM32的復位和時鐘控制

RCC:Reset and Clock Control

每一塊STM32中都有這么一個RCC復位和時鐘控制模塊。

STM32的復位為三類:系統(tǒng)復位、電源復位和后備域復位。

系統(tǒng)復位:

1. NRST引腳上的低電平(外部復位)

2. 窗口看門狗計數(shù)終止(WWDG復位)

3. 獨立看門狗計數(shù)終止(IWDG復位)

4. 軟件復位(SW復位)

5. 低功耗管理復位

電源復位:

1. 上電/掉電復位(POR/PDR復位)

2. 從待機模式中返回

備份區(qū)域復位:

1. 軟件復位,備份區(qū)域復位可由設置備份域控制寄存器(RCC_BDCR)中的BDRST位產(chǎn)生。

2. 在VDD和VBAT兩者掉電的前提下, VDD或VBAT上電將引發(fā)備份區(qū)域復位。

2STM32的復位來源

在很多應用中,都會判斷是什么引起的復位。

比如:判斷為看門狗引起的復位,我們進行xxx操作。軟件引起的復位,我們又執(zhí)行xxx操作。

在STM32RCC模塊中,有這么一個寄存器:控制/狀態(tài)寄存器 (RCC_CSR):

這個寄存器就會記錄各種復位的狀態(tài),我們直接讀取這個寄存器(庫函數(shù)有讀寄存器接口)就能知道是什么引起的復位。

3STM32的復位來源例程

之前我提供了一個簡單Demo,STM32F103ZE(Keil)_復位來源(寄存器版):

http://pan.baidu.com/s/1hskScba

4STM32系統(tǒng)和內(nèi)核復位

內(nèi)核復位:它會使STM32內(nèi)核(Cortex-M)進行復位,而不會影響其外設,如GPIO、TIM、USART、SPI等這些寄存器的復位。

系統(tǒng)復位:這個復位會使整個芯片的所有電路都進行復位,系統(tǒng)默認的函數(shù)接口NVIC_SystemReset就是系統(tǒng)復位(位于core_cm*.h)。

1.NVIC_CoreReset內(nèi)核復位

CM3 允許由軟件觸發(fā)復位序列,用于特殊的調(diào)試或維護目的。在CM3中,有兩種方法可以執(zhí)行自我復位。第一種方法,是通過置位 NVIC 中應用程序中斷與復位控制寄存器(AIRCR)的VECTRESET 位(位偏移:0)。

這種復位的作用范圍覆蓋了整個CM3處理器中,除了調(diào)試邏輯之外的所有角落,但是它不會影響到 CM3 處理器外部的任何電路,所以單片機上的各片上外設和其它電路都不受影響。

C語言版函數(shù):

void NVIC_CoreReset(void){__DSB(); //置位VECTRESET SCB->AIRCR = ((0x5FA << SCB_AIRCR_VECTKEY_Pos) | (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) |SCB_AIRCR_VECTRESET_Msk); __DSB(); while(1);}

匯編版函數(shù):

__asm void NVIC_CoreReset_a(void){ LDR R0, =0xE000ED0C LDR R1, =0x05FA0001 //置位VECTRESET STR R1, [R0] deadloop_Core B deadloop_Core}

內(nèi)核主要注意:

SCB_AIRCR_VECTRESET_Msk

LDR R1, =0x05FA0001

它是和系統(tǒng)復位唯一的區(qū)別。

2.NVIC_SysReset系統(tǒng)復位

系統(tǒng)復位是置位同一個寄存器中的 SYSRESETREQ 位。這種復位則會波及整個芯片上的電路:它會使 CM3 處理器把送往系統(tǒng)復位發(fā)生器的請求線置為有效。但是系統(tǒng)復位發(fā)生器不是CM3的一部分,而是由芯片廠商實現(xiàn),因此不同的芯片對此復位的響應也不同。因此,讀者需要認真參閱該芯片規(guī)格書,明白當發(fā)生片內(nèi)復位時,各外設和功能模塊都會回到什么樣的初始狀態(tài),或者有哪些功能模塊不受影響(比如, STM32系列的芯片有后備存儲區(qū),該區(qū)就被特殊對待)。

大多數(shù)情況下,復位發(fā)生器在響應 SYSRESETREQ 時,它也會同時把 CM3 處理器的系統(tǒng)復位信號(SYSRESETn)置為有效。通常, SYSRESETREQ 不應復位調(diào)試邏輯。

這里有一個要注意的問題:從 SYSRESETREQ 被置為有效,到復位發(fā)生器執(zhí)行復位命令,往往會有一個延時。在此延時期間,處理器仍然可以響應中斷請求。但我們的本意往往是要讓此次執(zhí)行到此為止,不要再做任何其它事情了。所以,最好在發(fā)出復位請求前,先把FAULTMASK置位。因此,我在提供源代碼中有這么一句:__set_FAULTMASK(1);,也就是置位FAULTMASK。


C語言版函數(shù):

voidNVIC_SysReset(void){ __DSB(); SCB->AIRCR = ((0x5FA << SCB_AIRCR_VECTKEY_Pos) | (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | SCB_AIRCR_SYSRESETREQ_Msk); __DSB(); while(1);}

匯編版函數(shù):

__asm void NVIC_SysReset_a(void){ LDR R0, =0xE000ED0C LDR R1, =0x05FA0004 STR R1, [R0] deadloop_Sys B deadloop_Sys}

內(nèi)核復位與系統(tǒng)源代碼和相近,差異在于SYSRESETREQ和SYSRESETREQ這兩位。

關于復位的知識,在實際項目中應用的比較多。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • STM32
    +關注

    關注

    2270

    文章

    10900

    瀏覽量

    356090
  • 引腳
    +關注

    關注

    16

    文章

    1196

    瀏覽量

    50498
  • 電復位
    +關注

    關注

    0

    文章

    5

    瀏覽量

    6066
收藏 人收藏

    評論

    相關推薦

    復位電路的設計問題

    前言 最近看advanced fpga 以及fpga設計實戰(zhàn)演練中有講到復位電路的設計,才知道復位電路有這么多的門道,而不是簡單的外界信號輸入系統(tǒng)
    的頭像 發(fā)表于 11-15 11:13 ?166次閱讀
    <b class='flag-5'>復位</b>電路的設計問題

    復位電路的電容多大的 復位電路設計類型有哪幾種

    復位電路是電子系統(tǒng)中的一個關鍵部分,它確保系統(tǒng)在啟動或發(fā)生故障時能夠正確地初始化。復位電路的設計取決于多種因素,包括系統(tǒng)的復雜性、所需的
    的頭像 發(fā)表于 10-21 10:24 ?330次閱讀

    復位電路介紹 復位電路的原理及作用

    復位電路(Reset Circuit)是現(xiàn)代電子設備中常見的一種關鍵電路,它用于確保在正確的時間和條件下將系統(tǒng)恢復到初始狀態(tài)。復位電路的設計和應用對于保障電子系統(tǒng)的穩(wěn)定性和可靠性至關重
    的頭像 發(fā)表于 10-18 16:44 ?1879次閱讀

    STM32復位電路用復位芯片和阻容復位電路區(qū)別

    STM32是一款廣泛使用的微控制器,其復位電路設計對于系統(tǒng)的穩(wěn)定性和可靠性至關重要。本文將詳細介紹STM32復位電路中使用
    的頭像 發(fā)表于 08-06 10:26 ?1499次閱讀

    JK觸發(fā)器的置位和復位有什么區(qū)別

    JK觸發(fā)器的置位(Set)和復位(Reset)是其在數(shù)字電路中的兩種基本狀態(tài)控制功能,它們在操作原理、輸入條件以及觸發(fā)器輸出狀態(tài)的變化上有所區(qū)別。以下是對JK觸發(fā)器置位和復位的詳細分析
    的頭像 發(fā)表于 07-27 14:50 ?2342次閱讀

    FPGA同步復位和異步復位

    FPGA(Field-Programmable Gate Array,現(xiàn)場可編程門陣列)中的復位操作是設計過程中不可或缺的一環(huán),它負責將電路恢復到初始狀態(tài),以確保系統(tǒng)的正確啟動和穩(wěn)定運行。在FPGA設計中,復位方式主要分為同步
    的頭像 發(fā)表于 07-17 11:12 ?1574次閱讀

    PDR_ON復位和NRST引腳復位,對STM32F407IG的影響有什么區(qū)別呢?

    新手請問大家在實際做工程的時候,有沒有用PDR_ON引腳做芯片復位呢? PDR_ON復位和 NRST引腳復位,對芯片的影響有什么區(qū)別呢? 謝謝大家。 PS:我用的是
    發(fā)表于 05-16 07:21

    STM32如何用HAL庫進行內(nèi)核復位

    STM32如何用HAL庫進行內(nèi)核復位 普通的系統(tǒng)復位函數(shù)如下: / ** 簡短的系統(tǒng)重置 詳細
    發(fā)表于 04-11 06:49

    MCU復位RAM會保持嗎,如何實現(xiàn)復位時變量數(shù)據(jù)保持

    在使用MCU時,通常大家默認MCU復位時RAM會被復位清零,那實際MCU復位時RAM是什么狀態(tài)?如何讓mcu復位時RAM保持不變呢?
    的頭像 發(fā)表于 03-01 09:32 ?2505次閱讀
    MCU<b class='flag-5'>復位</b>RAM會保持嗎,如何實現(xiàn)<b class='flag-5'>復位</b>時變量數(shù)據(jù)保持

    如何排查GD32 MCU復位是由哪個復位源導致的?

    上期為大家講解了GD32 MCU復位包括電源復位系統(tǒng)復位,其中系統(tǒng)復位還包括獨立看門狗
    的頭像 發(fā)表于 02-03 09:46 ?1742次閱讀
    如何排查GD32 MCU<b class='flag-5'>復位</b>是由哪個<b class='flag-5'>復位</b>源導致的?

    GD32 MCU電源復位系統(tǒng)復位有什么區(qū)別

    GD32 MCU的復位分為電源復位系統(tǒng)復位,電源復位又稱為冷復位,相較于
    的頭像 發(fā)表于 02-02 09:37 ?1510次閱讀
    GD32 MCU電源<b class='flag-5'>復位</b>和<b class='flag-5'>系統(tǒng)</b><b class='flag-5'>復位</b>有什么<b class='flag-5'>區(qū)別</b>

    同步復位和異步復位到底孰優(yōu)孰劣呢?

    同步復位和異步復位到底孰優(yōu)孰劣呢? 同步復位和異步復位是兩種不同的復位方式,它們各自有優(yōu)勢和劣勢,下面將詳細介紹這兩種
    的頭像 發(fā)表于 01-16 16:25 ?1768次閱讀

    復位電路的復位條件和復位過程

    電源監(jiān)測芯片復位電路:這是最常見的復位電路類型,使用專用的電源監(jiān)測芯片來監(jiān)測電源電壓,并在電壓低于或高于預設閾值時觸發(fā)復位信號。
    的頭像 發(fā)表于 01-16 16:04 ?1253次閱讀

    stm32復位電容容值

    STM32是意法半導體(STMicroelectronics)推出的一系列32位微控制器,具有低功耗、高性能和豐富的外設功能。在STM32微控制器中,復位電容是電路中的一個重要組成部分,用于保持
    的頭像 發(fā)表于 01-05 17:39 ?1807次閱讀

    ht7044a復位原理

    HT7044A 是一種復位電路芯片,常用于電子設備中實現(xiàn)對系統(tǒng)復位功能。復位是一項重要的功能,用于將整個系統(tǒng)恢復到初始狀態(tài),以確保
    的頭像 發(fā)表于 01-04 11:24 ?1643次閱讀