一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

詳解中斷使能、清除或掛起等實現(xiàn)方式

安芯教育科技 ? 來源:極術(shù)社區(qū) ? 作者:靈動MM32 MCU ? 2022-04-14 09:54 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在前幾天有客戶問了一個問題:如果外部中斷來的頻率足夠快,上一個中斷沒有處理完成,新來的中斷該如何處理?

在研究了arm的官方手冊后,了解中斷有使能、清除或掛起等實現(xiàn)方式,今天分享給大家。

中斷一般是由硬件(例如外設(shè)、外部引腳)產(chǎn)生,當某種內(nèi)部或外部事件發(fā)生時,MCU的中斷系統(tǒng)將迫使 CPU 暫停正在執(zhí)行的程序,轉(zhuǎn)而去進行中斷事件的處理,中斷處理完畢后,又返回被中斷的程序處,繼續(xù)執(zhí)行下去,所有的Cortex-M 內(nèi)核系統(tǒng)都有一個用于中斷處理的組件NVIC,主要負責處理中斷,還處理其他需要服務(wù)的事件。嵌套向量式中斷控制器(NVIC: Nested Vectored Interrupt Controller)集成在Cortex-M0處理器里,它與處理器內(nèi)核緊密相連,并且提供了中斷控制功能以及對系統(tǒng)異常的支持。

處理器中的NVIC能夠處理多個可屏蔽中斷通道和可編程優(yōu)先級,中斷輸入請求可以是電平觸發(fā),也可以是最小的一個時鐘周期的脈沖信號。每一個外部中斷線都可以獨立的使能、清除或掛起,并且掛起狀態(tài)也可以手動地設(shè)置和清除。

主程序正在執(zhí)行,當遇到中斷請求(Interrupt Request)時,暫停主程序的執(zhí)行轉(zhuǎn)而去執(zhí)行中斷服務(wù)例程(Interrupt Service Routine,ISR),稱為響應,中斷服務(wù)例程執(zhí)行完畢后返回到主程序斷點處并繼續(xù)執(zhí)行主程序。多個中斷是可以進行嵌套的。正在執(zhí)行的較低優(yōu)先級中斷可以被較高優(yōu)先級的中斷所打斷,在執(zhí)行完高級中斷后返回到低級中斷里繼續(xù)執(zhí)行,采用“咬尾中斷”機制。

詳解中斷使能、清除或掛起等實現(xiàn)方式

內(nèi)核中斷(異常管理和休眠模式等),其中斷優(yōu)先級則由SCB寄存器來管理,IRQ的中斷優(yōu)先級是由NVIC來管理。

NVIC的寄存器經(jīng)過了存儲器映射,其寄存器的起始地址為0xE000E100,對其訪問必須是每次32bit。

SCB寄存器的起始地址:0xE000ED00,也是每次32bit訪問,SCB寄存器主要包含SysTick操作、異常管理和休眠模式控制。

NVIC具有以下特性:

  • 靈活的中斷管理:使能清除、優(yōu)先級配置
  • 硬件嵌套中斷支持
  • 向量化的異常入口
  • 中斷屏蔽
1. 中斷使能和清除使能

arm將處理器的中斷使能設(shè)置和清除設(shè)置寄存器分在兩個不同的地址,這種設(shè)計主要有如下優(yōu)勢:一方面這種方式減少了使能中斷所需要的步驟,使能一個中斷NVIC只需要訪問一次,同時也減少了程序代碼并且降低了執(zhí)行時間,另一方面當多個應用程序進程同時訪問寄存器或者在讀寫操作寄存器時有操作其他的中斷使能位,這樣就有可能導致寄存器丟失,設(shè)置和清除分成兩個寄存器能夠有效防止控制信號丟失。
詳解中斷使能、清除或掛起等實現(xiàn)方式

因此我可以獨立的操作每一個中斷的使能和清除設(shè)置。
1.1 C代碼

	*(volatileunsignedlong)(0xE000E100)=0x4;//使能#2中斷 *(volatileunsignedlong)(0xE000E180)=0x4;//清除#2中斷
	
1.2 匯編代碼

	__asmvoidInterrupt_Enable() { LDRR0,=0xE000E100;//ISER寄存器的地址 MOVSR1,#04;//設(shè)置#2中斷 STRR1,[R0];//使能中斷#2 } __asmvoidInterrupt_Disable() { LDRR0,=0xE000E180;//ICER寄存器的地址 MOVSR1,#04;//設(shè)置#2中斷 STRR1,[R0];//使能中斷#2 }
	
1.3 CMSIS標準設(shè)備驅(qū)動函數(shù)

	//使能中斷#IRQn __STATIC_INLINEvoid__NVIC_EnableIRQ(IRQn_TypeIRQn) { if((int32_t)(IRQn)>=0){ NVIC->ISER[0U]=(uint32_t)(1UL<=0){ NVIC->ICER[0U]=(uint32_t)(1UL<=0){ return((uint32_t)(((NVIC->ISER[0U]&(1UL<
	
2. 中斷掛起和清除掛起

如果一個中斷發(fā)生了,卻無法立即處理,這個中斷請求將會被掛起。掛起狀態(tài)保存在一個寄存器中,如果處理器的當前優(yōu)先級還沒有降低到可以處理掛起的請求,并且沒有手動清除掛起狀態(tài),該狀態(tài)將會一直保持。可以通過操作中斷設(shè)置掛起和中斷清除掛起兩個獨立的寄存器來訪問或者修改中斷掛起狀態(tài),中斷掛起寄存器也是通過兩個地址來實現(xiàn)設(shè)置和清除相關(guān)位。這使得每一個位都可以獨立修改,并且無需擔心在兩個應用程序進程競爭訪問時出現(xiàn)的數(shù)據(jù)丟失。詳解中斷使能、清除或掛起等實現(xiàn)方式

中斷掛起狀態(tài)寄存器允許使用軟件來觸發(fā)中斷。如果中斷已經(jīng)使能并且沒有被屏蔽掉,當前還沒有更高優(yōu)先級的中斷在運行,這時中斷的服務(wù)程序就會立即得以執(zhí)行。
2.1 C代碼

	*(volatileunsignedlong)(0xE000E100)=0x4;//使能中斷#2 *(volatileunsignedlong)(0xE000E200)=0x4;//掛起中斷#2 *(volatileunsignedlong)(0xE000E280)=0x4;//清除中斷#2的掛起狀態(tài)
	
2.2 匯編代碼

	__asmvoidInterrupt_Set_Pending() { LDRR0,=0xE000E100;//設(shè)置使能中斷寄存器地址 MOVSR1,#0x4;//中斷#2 STRR1,[R0];//使能#2中斷 LDRR0,=0xE000E200;//設(shè)置掛起中斷寄存器地址 MOVSR1,#0x4;//中斷#2 STRR1,[R0];//掛起#2中斷 } __asmvoidInterrupt_Clear_Pending() { LDRR0,=0xE000E100;//設(shè)置使能中斷寄存器地址 MOVSR1,#0x4;//中斷#2 STRR1,[R0];//使能#2中斷 LDRR0,=0xE000E280;//設(shè)置清除中斷掛起寄存器地址 MOVSR1,#0x4;//中斷#2 STRR1,[R0];//清除#2的掛起狀態(tài) }
	
2.3 CMSIS標準設(shè)備驅(qū)動函數(shù)

	//設(shè)置一個中斷掛起 __STATIC_INLINEvoid__NVIC_SetPendingIRQ(IRQn_TypeIRQn) { if((int32_t)(IRQn)>=0){ NVIC->ISPR[0U]=(uint32_t)(1UL<=0){ NVIC->ICPR[0U]=(uint32_t)(1UL<=0){ return((uint32_t)(((NVIC->ISPR[0U]&(1UL<

NVIC屬于處理器內(nèi)核部分,因此在MM32 MCU芯片的用戶手冊中只有簡單的提及,沒有重點講述,需要深入了解相關(guān)寄存器和功能需要參考《Cortex-M0技術(shù)參考手冊》。在下一章節(jié)中,我們將和大家一起學習中斷優(yōu)先級的實現(xiàn)方式

原文標題:技術(shù)分享 | Cortex-M0中斷控制和系統(tǒng)控制(一)

文章出處:【微信公眾號:安芯教育科技】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

    關(guān)注

    114

    文章

    17098

    瀏覽量

    184201
  • 中斷系統(tǒng)
    +關(guān)注

    關(guān)注

    1

    文章

    96

    瀏覽量

    61400
  • Cortex-M0
    +關(guān)注

    關(guān)注

    4

    文章

    126

    瀏覽量

    39509
  • MM32
    +關(guān)注

    關(guān)注

    1

    文章

    108

    瀏覽量

    1093

原文標題:技術(shù)分享 | Cortex-M0中斷控制和系統(tǒng)控制(一)

文章出處:【微信號:Ithingedu,微信公眾號:安芯教育科技】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    FreeRTOS任務(wù)掛起恢復與使用中斷遇到的坑

    任務(wù)掛起簡單點理解就是現(xiàn)在不需要執(zhí)行這個任務(wù),讓它先暫停,就是掛起?;謴途褪菑膭偛?b class='flag-5'>掛起的狀態(tài)下繼續(xù)運行。
    的頭像 發(fā)表于 09-26 09:01 ?7122次閱讀
    FreeRTOS任務(wù)<b class='flag-5'>掛起</b>恢復與使用<b class='flag-5'>中斷</b>遇到的坑

    靈動微課堂 (第175講) | Cortex-M0中斷控制和系統(tǒng)控制(一)

    在前幾天有客戶問了一個問題:如果外部中斷來的頻率足夠快,上一個中斷沒有處理完成,新來的中斷該如何處理?在研究了arm的官方手冊后,了解中斷有使
    發(fā)表于 07-29 17:14

    STM32F10X外部中斷(EXTI)的學習

    寄存器ICER//中斷清除寄存器ISPR//中斷使掛起寄存器ICPR//
    發(fā)表于 01-14 09:21

    ARM接口編程之中斷控制器GIC介紹

    掛起寄存器ICDICPR1_CPU0 [25] 當該位為1時,中斷掛起了,寫1到對應的位,清除對應中斷7、配置CPU接口層:1)ICCIC
    發(fā)表于 04-25 10:20

    N32G4FR系列低功耗應用筆記資料下載

    N32G45x 將在事件發(fā)生時立即退出 SLEEP 模式。喚醒事件可以通過以下方式生成:? 在外設(shè)控制寄存器中使一個中斷,而不是在 NVIC 中使, 同時
    發(fā)表于 11-02 06:38

    CW32L083系列MCU中斷系統(tǒng)介紹

    FAULT 中斷。中斷寄存器的相關(guān)配置1.中斷使掛起
    發(fā)表于 12-01 10:30

    清除SQL掛起工具

    在裝SQL時都會經(jīng)常出現(xiàn)SQL未掛起的問題。這時只要用工具就可以解決這個問題了。
    發(fā)表于 11-24 14:01 ?0次下載

    STM32單片機實現(xiàn)外部中斷的步驟及方法

    和配置NVIC一樣,這也是EXTI配置的一般步驟:清除相應中斷線標志位(這個很重要,剛開始一直沒找到這個問題),聯(lián)結(jié)端口與中斷線(也可以在GPIO初始化時配置),選擇中斷線,設(shè)置
    發(fā)表于 11-20 15:46 ?2.5w次閱讀
    STM32單片機<b class='flag-5'>實現(xiàn)</b>外部<b class='flag-5'>中斷</b>的步驟及方法

    STM32F10X的外部中斷(EXTI)前篇

    寄存器 ICER //中斷清除寄存器 ISPR //中斷使
    發(fā)表于 01-14 15:22 ?3次下載
    STM32F10X的外部<b class='flag-5'>中斷</b>(EXTI)前篇

    單片機中斷程序新來的中斷該如何處理?

    處理器中的NVIC能夠處理多個可屏蔽中斷通道和可編程優(yōu)先級,中斷輸入請求可以是電平觸發(fā),也可以是最小的一個時鐘周期的脈沖信號。每一個外部中斷線都可以獨立的使
    的頭像 發(fā)表于 05-10 10:02 ?4256次閱讀

    Cortex-M0中斷控制和系統(tǒng)控制(一)

    處理器中的NVIC能夠處理多個可屏蔽中斷通道和可編程優(yōu)先級,中斷輸入請求可以是電平觸發(fā),也可以是最小的一個時鐘周期的脈沖信號。每一個外部中斷線都可以獨立的使
    的頭像 發(fā)表于 03-16 13:38 ?1435次閱讀

    單片機中斷程序是如何處理器新來的中斷?

     如果一個中斷發(fā)生了,卻無法立即處理,這個中斷請求將會被掛起。掛起狀態(tài)保存在一個寄存器中,如果處理器的當前優(yōu)先級還沒有降低到可以處理掛起的請
    發(fā)表于 05-13 12:24 ?558次閱讀
    單片機<b class='flag-5'>中斷</b>程序是如何處理器新來的<b class='flag-5'>中斷</b>?

    LIC內(nèi)核中斷掛起位和中斷使

    中斷源 0 的字 0 的位 0 硬接線為零。 PLIC 內(nèi)核中的掛起位可以通過設(shè)置相關(guān)的啟用位然后執(zhí)行第 9.8 節(jié)中描述的聲明來清除 中斷使
    的頭像 發(fā)表于 10-07 17:57 ?1193次閱讀
    LIC內(nèi)核<b class='flag-5'>中斷</b><b class='flag-5'>掛起</b>位和<b class='flag-5'>中斷</b><b class='flag-5'>使</b><b class='flag-5'>能</b>

    如何在特權(quán)模式下用arm匯編指令使和禁止irq中斷?

    如何在特權(quán)模式下用arm匯編指令使和禁止irq中斷? 在 ARM 系統(tǒng)中,中斷是非常常見的一種事件。在特權(quán)模式下,可以使用 ARM 匯編指令來使
    的頭像 發(fā)表于 10-19 16:42 ?1850次閱讀

    串口中斷需要清除標志位嗎,串口中斷標志位會自動清除

    在電子通信領(lǐng)域,串口中斷作為一種重要的通信機制,廣泛應用于各種嵌入式系統(tǒng)和計算機設(shè)備中。串口中斷標志位的管理,尤其是是否需要手動清除以及是否會自動清除,是理解和
    的頭像 發(fā)表于 01-29 14:59 ?1866次閱讀