99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

3天內不再提示

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

黃工的嵌入式技術圈 ? 來源:黃工的嵌入式技術圈 ? 作者:黃工的嵌入式技術 ? 2020-02-28 17:13 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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位產生。

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)和內核復位

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

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

1.NVIC_CoreReset內核復位

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

這種復位的作用范圍覆蓋了整個CM3處理器中,除了調試邏輯之外的所有角落,但是它不會影響到 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}

內核主要注意:

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ā)生片內復位時,各外設和功能模塊都會回到什么樣的初始狀態(tài),或者有哪些功能模塊不受影響(比如, STM32系列的芯片有后備存儲區(qū),該區(qū)就被特殊對待)。

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

這里有一個要注意的問題:從 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}

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

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

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

    關注

    2293

    文章

    11031

    瀏覽量

    364573
  • 引腳
    +關注

    關注

    16

    文章

    1714

    瀏覽量

    52829
  • 電復位
    +關注

    關注

    0

    文章

    5

    瀏覽量

    6141
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    GraniStudio零代碼平臺軸復位算子支持多少個軸同時復位,有哪些回零模式?

    GraniStudio平臺在軸復位的功能上未對同時復位的軸數(shù)進行硬性限制,理論上支持任意數(shù)量軸同步復位,需要考慮的是在做多軸同步復位時要評估機械安全風險,建議提前確認機械在多軸同時
    的頭像 發(fā)表于 07-07 18:02 ?171次閱讀
    GraniStudio零代碼平臺軸<b class='flag-5'>復位</b>算子支持多少個軸同時<b class='flag-5'>復位</b>,有哪些回零模式?

    復位電路的核心功能和主要類型

    復位電路(Reset Circuit) 是數(shù)字系統(tǒng)中的關鍵功能模塊,用于確保設備在上電、電壓波動或異常狀態(tài)下可靠復位至初始狀態(tài)。其設計直接影響系統(tǒng)的穩(wěn)定性和抗干擾能力。
    的頭像 發(fā)表于 06-30 14:24 ?161次閱讀
    <b class='flag-5'>復位</b>電路的核心功能和主要類型

    復位電路的作用、控制方式和類型

    復位電路也是數(shù)字邏輯設計中常用的電路,不管是 FPGA 還是 ASIC 設計,都會涉及到復位,一般 FPGA或者 ASIC 的復位需要我們自己設計復位方案。
    的頭像 發(fā)表于 03-12 13:54 ?2301次閱讀
    <b class='flag-5'>復位</b>電路的作用、控制方式和類型

    FPGA復位的8種技巧

    在 FPGA 設計中,復位起到的是同步信號的作用,能夠將所有的存儲元件設置成已知狀態(tài)。在數(shù)字電路設計中,設計人員一般把全局復位作為一個外部引腳來實現(xiàn),在加電的時候初始化設計。全局復位引腳與任何
    的頭像 發(fā)表于 11-16 10:18 ?1166次閱讀
    FPGA<b class='flag-5'>復位</b>的8種技巧

    復位電路的設計問題

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

    復位電路的三種方式 復位電路的原理和作用

    復位電路是一種電子電路,用于將微控制器或其他電子設備重置到其初始狀態(tài)。這種電路通常在設備啟動時或在需要清除當前狀態(tài)以避免錯誤時使用。 1. 上電復位(Power-On Reset, POR
    的頭像 發(fā)表于 10-21 10:28 ?5029次閱讀

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

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

    復位電路是如何工作的

    復位電路的基本功能 復位電路的基本功能是在系統(tǒng)啟動時或在需要時將微控制器或其他邏輯電路的輸出和狀態(tài)寄存器設置為初始狀態(tài)。這通常涉及到將所有的輸出引腳設置為低電平,所有的輸入引腳設置為高電平,
    的頭像 發(fā)表于 10-21 10:22 ?1023次閱讀

    復位電路靜電整改案例分享(一)——交換機復位電路

    ? ?復位電路靜電整改案例分享(一)——交換機復位電路 一、摘要 復位電路可確保電路在啟動時處于可控的狀態(tài),避免上電造成的未知問題。復位電路通常由一個
    的頭像 發(fā)表于 10-19 14:56 ?951次閱讀
    <b class='flag-5'>復位</b>電路靜電整改案例分享(一)——交換機<b class='flag-5'>復位</b>電路

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

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

    單片機復位電路電阻電容如何取值

    在單片機系統(tǒng)中,復位電路是非常重要的組成部分,它確保了單片機在啟動時能夠可靠地進入初始狀態(tài),以及在異常情況下能夠進行復位操作。復位電路通常由
    的頭像 發(fā)表于 08-06 10:28 ?2292次閱讀

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

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

    雙管正激勵磁復位電路的作用

    雙管正激勵磁復位電路是一種廣泛應用于電子設備中的電路,它具有多種功能和優(yōu)點。 一、雙管正激勵磁復位電路的作用 雙管正激勵磁復位電路是一種特殊的電路,它具有以下主要作用: 提供穩(wěn)定的電源:雙管正激勵磁
    的頭像 發(fā)表于 08-02 15:41 ?1030次閱讀

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

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

    FPGA同步復位和異步復位

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