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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

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

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

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

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

1STM32的復(fù)位和時(shí)鐘控制

RCC:Reset and Clock Control

每一塊STM32中都有這么一個(gè)RCC復(fù)位和時(shí)鐘控制模塊。

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

系統(tǒng)復(fù)位:

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

2. 窗口看門(mén)狗計(jì)數(shù)終止(WWDG復(fù)位)

3. 獨(dú)立看門(mén)狗計(jì)數(shù)終止(IWDG復(fù)位)

4. 軟件復(fù)位(SW復(fù)位)

5. 低功耗管理復(fù)位

電源復(fù)位:

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

2. 從待機(jī)模式中返回

備份區(qū)域復(fù)位:

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

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

2STM32的復(fù)位來(lái)源

在很多應(yīng)用中,都會(huì)判斷是什么引起的復(fù)位。

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

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

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

3STM32的復(fù)位來(lái)源例程

之前我提供了一個(gè)簡(jiǎn)單Demo,STM32F103ZE(Keil)_復(fù)位來(lái)源(寄存器版):

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

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

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

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

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

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

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

C語(yǔ)言版函數(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)復(fù)位唯一的區(qū)別。

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

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

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

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


C語(yǔ)言版函數(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)核復(fù)位與系統(tǒng)源代碼和相近,差異在于SYSRESETREQ和SYSRESETREQ這兩位。

關(guān)于復(fù)位的知識(shí),在實(shí)際項(xiàng)目中應(yīng)用的比較多。

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

    關(guān)注

    2257

    文章

    10828

    瀏覽量

    352444
  • 引腳
    +關(guān)注

    關(guān)注

    16

    文章

    1130

    瀏覽量

    49739
  • 電復(fù)位
    +關(guān)注

    關(guān)注

    0

    文章

    5

    瀏覽量

    6047
收藏 人收藏

    評(píng)論

    相關(guān)推薦

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

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

    FPGA同步復(fù)位和異步復(fù)位

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

    STM32如何用HAL庫(kù)進(jìn)行內(nèi)核復(fù)位?

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

    如何排查GD32 MCU復(fù)位是由哪個(gè)復(fù)位源導(dǎo)致的?

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

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

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

    stm32復(fù)位電容容值

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

    stm32復(fù)位電路電阻和電容怎么搭配

    電路的作用和基本原理 STM32復(fù)位電路是一種用于重新啟動(dòng)系統(tǒng)的電路,當(dāng)系統(tǒng)出現(xiàn)錯(cuò)誤或故障時(shí),通過(guò)產(chǎn)生一個(gè)短暫的復(fù)位脈沖信號(hào)來(lái)重新初始化
    的頭像 發(fā)表于 12-07 16:24 ?2514次閱讀

    Cortex-M內(nèi)核的軟件復(fù)位方式

    這里只討論內(nèi)核的軟件復(fù)位方式。像STM32的備份域復(fù)位里面也有軟件復(fù)位,則不在本文討論范圍。額外提一句,上電
    的頭像 發(fā)表于 12-06 16:18 ?1745次閱讀
    Cortex-M<b class='flag-5'>內(nèi)核</b>的軟件<b class='flag-5'>復(fù)位</b>方式

    復(fù)位那些小事—系統(tǒng)復(fù)位的特殊處理

    復(fù)位就是復(fù)位撤離,系統(tǒng)復(fù)位就是復(fù)位結(jié)束了系統(tǒng)準(zhǔn)備開(kāi)始工作。
    的頭像 發(fā)表于 12-04 15:25 ?1225次閱讀
    <b class='flag-5'>復(fù)位</b>那些小事—<b class='flag-5'>系統(tǒng)</b>解<b class='flag-5'>復(fù)位</b>的特殊處理

    系統(tǒng)復(fù)位的特殊處理

    復(fù)位就是復(fù)位撤離,系統(tǒng)復(fù)位就是復(fù)位結(jié)束了系統(tǒng)準(zhǔn)備開(kāi)始工作。
    的頭像 發(fā)表于 11-28 12:20 ?757次閱讀
    <b class='flag-5'>系統(tǒng)</b>解<b class='flag-5'>復(fù)位</b>的特殊處理

    RC復(fù)位電路中R如何影響芯片復(fù)位

    控制電荷釋放速度的作用。因此,不同的RC參數(shù)會(huì)影響芯片的復(fù)位時(shí)間、復(fù)位電平以及復(fù)位過(guò)程的穩(wěn)定性等方面的特性。 在RC復(fù)位電路中,電容元件的大
    的頭像 發(fā)表于 10-25 11:07 ?1067次閱讀

    單片機(jī)上位復(fù)位電路與按鍵與上電復(fù)位區(qū)別

    單片機(jī)上位復(fù)位電路與按鍵與上電復(fù)位區(qū)別? 單片機(jī)的復(fù)位電路常用于保證單片機(jī)在復(fù)位狀態(tài)下正常工作,以便單片機(jī)能夠在正確的起始狀態(tài)下啟動(dòng)。常見(jiàn)
    的頭像 發(fā)表于 10-17 18:17 ?2422次閱讀

    STM32失能時(shí)鐘和復(fù)位外設(shè)的區(qū)別

    STM32失能時(shí)鐘和復(fù)位外設(shè)的區(qū)別
    的頭像 發(fā)表于 10-17 11:48 ?753次閱讀
    <b class='flag-5'>STM32</b>失能時(shí)鐘和<b class='flag-5'>復(fù)位</b>外設(shè)的<b class='flag-5'>區(qū)別</b>

    中穎M0+內(nèi)核芯片軟件模擬內(nèi)核復(fù)位的方法

    中穎M0+內(nèi)核芯片軟件模擬內(nèi)核復(fù)位的方法
    的頭像 發(fā)表于 09-27 15:27 ?1048次閱讀
    中穎M0+<b class='flag-5'>內(nèi)核</b>芯片軟件模擬<b class='flag-5'>內(nèi)核</b><b class='flag-5'>復(fù)位</b>的方法

    STM32 Bootloader異常復(fù)位案例

    電子發(fā)燒友網(wǎng)站提供《STM32 Bootloader異常復(fù)位案例.pdf》資料免費(fèi)下載
    發(fā)表于 09-25 09:17 ?3次下載
    <b class='flag-5'>STM32</b> Bootloader異常<b class='flag-5'>復(fù)位</b>案例