18video性欧美19sex,欧美高清videosddfsexhd,性少妇videosexfreexxx片中国,激情五月激情综合五月看花,亚洲人成网77777色在线播放

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
    +關注

    關注

    2301

    文章

    11092

    瀏覽量

    369912
  • 引腳
    +關注

    關注

    16

    文章

    2001

    瀏覽量

    54703
  • 電復位
    +關注

    關注

    0

    文章

    5

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    GraniStudio:軸復位例程

    功能說明 實現(xiàn)單軸復位、兩軸同時復位以及兩軸順序復位功能。 2.1通過初始化運控板卡算子連接格拉尼總線型運控卡,導入工程自動進行連接,此算子為使用運控控制板卡的第一項操作,后續(xù)運控算子
    的頭像 發(fā)表于 08-22 16:05 ?391次閱讀
    GraniStudio:軸<b class='flag-5'>復位</b>例程

    絕對值編碼器復位:工業(yè)自動化的精準重啟藝術

    在工業(yè)自動化領域,絕對值編碼器如同設備的“數(shù)字羅盤”,以機械位置為基準生成唯一二進制編碼,實現(xiàn)斷電后位置數(shù)據(jù)零丟失的精準定位。然而,當首次安裝、電池更換或系統(tǒng)故障觸發(fā)警報時,如何通過科學復位喚醒
    的頭像 發(fā)表于 07-24 08:41 ?460次閱讀
    絕對值編碼器<b class='flag-5'>復位</b>:工業(yè)自動化的精準重啟藝術

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

    GraniStudio平臺在軸復位的功能上未對同時復位的軸數(shù)進行硬性限制,理論上支持任意數(shù)量軸同步復位,需要考慮的是在做多軸同步復位時要評估機械安全風險,建議提前確認機械在多軸同時
    的頭像 發(fā)表于 07-07 18:02 ?404次閱讀
    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 ?640次閱讀
    <b class='flag-5'>復位</b>電路的核心功能和主要類型

    單片機各種復位電路原理

    使用哪種類型的單片機,總要涉及到單片機復位電路的設計。而單片機復位電路設計的好壞,直接影響到整個系統(tǒng)工作的可靠性。許多用戶在設計完單片機系統(tǒng),并在實驗室調試成功后,在現(xiàn)場卻出現(xiàn)了“死機
    發(fā)表于 05-30 16:53

    LM3724系列 低功率電壓監(jiān)控和復位IC,帶手動復位功能數(shù)據(jù)手冊

    LM3722/LM3723/LM3724 微處理器監(jiān)控電路可監(jiān)控電源 在微處理器和數(shù)字系統(tǒng)中。它們在上電期間為微處理器提供復位, 掉電、掉電條件和手動復位。 LM3722/LM3723
    的頭像 發(fā)表于 04-12 11:11 ?667次閱讀
    LM3724系列 低功率電壓監(jiān)控和<b class='flag-5'>復位</b>IC,帶手動<b class='flag-5'>復位</b>功能數(shù)據(jù)手冊

    TPS3840-Q1 具有手動復位和可編程復位時間延遲的汽車高輸入電壓監(jiān)控器數(shù)據(jù)手冊

    當 VDD 上的電壓降至負電壓閾值 (V 以下) 時,復位輸出信號被置位 ~它-~ ) 或當手動復位被拉至低邏輯 (V ~MR_L~ ).當 V 時 reset 信號被清除~DD 系列~上升到 V
    的頭像 發(fā)表于 04-10 11:20 ?546次閱讀
    TPS3840-Q1 具有手動<b class='flag-5'>復位</b>和可編程<b class='flag-5'>復位</b>時間延遲的汽車高輸入電壓監(jiān)控器數(shù)據(jù)手冊

    TPS3870-Q1 具有延時和手動復位功能的汽車級高精度過壓復位 IC數(shù)據(jù)手冊

    TPS3870-Q1 器件是一款集成過壓 (OV) 監(jiān)控器或復位 IC,采用業(yè)界最小的 6 引腳 DSE 封裝。這款高精度電壓監(jiān)控器非常適合在低電壓電源軌上工作且具有窄裕量電源容差的系統(tǒng)。低閾值遲滯
    的頭像 發(fā)表于 04-10 11:09 ?447次閱讀
    TPS3870-Q1 具有延時和手動<b class='flag-5'>復位</b>功能的汽車級高精度過壓<b class='flag-5'>復位</b> IC數(shù)據(jù)手冊

    TLV840系列 具有可調復位時間延遲和手動復位功能的低壓監(jiān)控器數(shù)據(jù)手冊

    TLV840 系列電壓監(jiān)控器或復位 IC 可在高電壓水平下工作,同時在整個 VDD 和溫度范圍內保持極低的靜態(tài)電流。TLV840 提供低功耗、高精度和低傳播延遲 (t p_HL = 30 μs
    的頭像 發(fā)表于 04-10 10:17 ?582次閱讀
    TLV840系列 具有可調<b class='flag-5'>復位</b>時間延遲和手動<b class='flag-5'>復位</b>功能的低壓監(jiān)控器數(shù)據(jù)手冊

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

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

    AN-686: 實現(xiàn)I2C復位

    電子發(fā)燒友網站提供《AN-686: 實現(xiàn)I2C復位.pdf》資料免費下載
    發(fā)表于 01-15 16:26 ?0次下載
    AN-686: 實現(xiàn)I2C<b class='flag-5'>復位</b>

    EE-64:設置復位時的模式引腳

    電子發(fā)燒友網站提供《EE-64:設置復位時的模式引腳.pdf》資料免費下載
    發(fā)表于 01-14 15:14 ?0次下載
    EE-64:設置<b class='flag-5'>復位</b>時的模式引腳

    C2000? MCU在有器件復位時的實時固件更新

    電子發(fā)燒友網站提供《C2000? MCU在有器件復位時的實時固件更新.pdf》資料免費下載
    發(fā)表于 11-25 14:16 ?0次下載
    C2000? MCU在有器件<b class='flag-5'>復位</b>時的實時固件更新

    FPGA復位的8種技巧

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

    復位電路的設計問題

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