在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

介紹Cortex-M0中斷控制知識(shí)

安芯教育科技 ? 來源:靈動(dòng)MM32MCU ? 2023-03-16 13:39 ? 次閱讀

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

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

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

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

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

b2d89b92-c3bb-11ed-bfe3-dac502259ad0.png

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

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

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

NVIC具有以下特性:

靈活的中斷管理:使能清除、優(yōu)先級(jí)配置

硬件嵌套中斷支持

向量化的異常入口

中斷屏蔽

一、中斷使能和清除中斷

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

b2fa2a32-c3bb-11ed-bfe3-dac502259ad0.png

因此我可以獨(dú)立的操作每一個(gè)中斷的使能和清除設(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標(biāo)準(zhǔn)設(shè)備驅(qū)動(dòng)函數(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<

二、中斷掛起和清除掛起

如果一個(gè)中斷發(fā)生了,卻無法立即處理,這個(gè)中斷請(qǐng)求將會(huì)被掛起。掛起狀態(tài)保存在一個(gè)寄存器中,如果處理器的當(dāng)前優(yōu)先級(jí)還沒有降低到可以處理掛起的請(qǐng)求,并且沒有手動(dòng)清除掛起狀態(tài),該狀態(tài)將會(huì)一直保持。

可以通過操作中斷設(shè)置掛起和中斷清除掛起兩個(gè)獨(dú)立的寄存器來訪問或者修改中斷掛起狀態(tài),中斷掛起寄存器也是通過兩個(gè)地址來實(shí)現(xiàn)設(shè)置和清除相關(guān)位。這使得每一個(gè)位都可以獨(dú)立修改,并且無需擔(dān)心在兩個(gè)應(yīng)用程序進(jìn)程競爭訪問時(shí)出現(xiàn)的數(shù)據(jù)丟失。

b31139f2-c3bb-11ed-bfe3-dac502259ad0.png

中斷掛起狀態(tài)寄存器允許使用軟件來觸發(fā)中斷。如果中斷已經(jīng)使能并且沒有被屏蔽掉,當(dāng)前還沒有更高優(yōu)先級(jí)的中斷在運(yùn)行,這時(shí)中斷的服務(wù)程序就會(huì)立即得以執(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標(biāo)準(zhǔn)設(shè)備驅(qū)動(dòng)函數(shù)

//設(shè)置一個(gè)中斷掛起
__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芯片的用戶手冊(cè)中只有簡單的提及,沒有重點(diǎn)講述,需要深入了解相關(guān)寄存器和功能需要參考《Cortex-M0技術(shù)參考手冊(cè)》。





審核編輯:劉清

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

    關(guān)注

    68

    文章

    19740

    瀏覽量

    232873
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17718

    瀏覽量

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

    關(guān)注

    4

    文章

    125

    瀏覽量

    39212
  • 中斷控制
    +關(guān)注

    關(guān)注

    0

    文章

    26

    瀏覽量

    8954

原文標(biāo)題:Cortex-M0中斷控制和系統(tǒng)控制(一)

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    ARM Cortex-M0權(quán)威指南(英文版)

    嵌入式系統(tǒng)課程(ARM Cortex-M0)的高年級(jí)本科生及研究生等。Joseph Yiu是英國ARM公司微控制器系統(tǒng)級(jí)設(shè)計(jì)專家,是ARM Cortex-M3和Cortex-M0設(shè)計(jì)者
    發(fā)表于 10-08 16:46

    靈動(dòng)微課堂 (第176講) | Cortex-M0中斷控制和系統(tǒng)控制(二)

    每一個(gè)外部中斷都有一個(gè)對(duì)應(yīng)的優(yōu)先級(jí)寄存器,Cortex-M0NVIC-IPR共有8個(gè)寄存器,而每個(gè)寄存器管理4個(gè)IRQ中斷,所以M0的IR
    發(fā)表于 07-29 18:49

    基于Cortex-M0中斷系統(tǒng)的IP集成與中斷服務(wù)函數(shù)設(shè)計(jì)

    為極術(shù)線上技術(shù)分享干貨匯總(含PPT下載及視頻回放及線下活動(dòng)資料下載,持續(xù)更新,歡迎收藏~整理:極術(shù)社區(qū)集創(chuàng)賽Arm杯彭吉安-(集創(chuàng)賽)基于Cortex-M0中斷系統(tǒng)的IP集成與中斷服務(wù)函數(shù)設(shè)計(jì)彭吉安-(集創(chuàng)賽)AHB-Lite
    發(fā)表于 12-14 07:15

    Cortex-M0的指令集

    Cortex-M0的指令集,有需要的下來看看。
    發(fā)表于 01-13 17:17 ?29次下載

    ARM Cortex-M0 LPC1114基礎(chǔ)手冊(cè),知識(shí)全面

    ARM Cortex-M0 LPC1114基礎(chǔ)手冊(cè),知識(shí)全面
    發(fā)表于 09-22 11:03 ?13次下載
    ARM <b class='flag-5'>Cortex-M0</b> LPC1114基礎(chǔ)手冊(cè),<b class='flag-5'>知識(shí)</b>全面

    cortex-m0加密

    cortex-m0加密
    發(fā)表于 10-13 15:08 ?5次下載
    <b class='flag-5'>cortex-m0</b>加密

    基于ARM Cortex-M0核的MCU設(shè)計(jì)及應(yīng)用

    知網(wǎng)鏈接:基于ARM Cortex-M0核的MCU設(shè)計(jì)及應(yīng)用
    發(fā)表于 11-05 15:35 ?18次下載
    基于ARM <b class='flag-5'>Cortex-M0</b>核的MCU設(shè)計(jì)及應(yīng)用

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

    每一個(gè)外部中斷都有一個(gè)對(duì)應(yīng)的優(yōu)先級(jí)寄存器,Cortex-M0NVIC-IPR共有8個(gè)寄存器,而每個(gè)寄存器管理4個(gè)IRQ中斷,所以M0的IR
    發(fā)表于 02-08 15:48 ?3次下載
    <b class='flag-5'>Cortex-M0</b><b class='flag-5'>中斷</b><b class='flag-5'>控制</b>和系統(tǒng)<b class='flag-5'>控制</b>(二)

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

    Cortex-M0采用Armv6-M架構(gòu),優(yōu)先級(jí)寄存器配置位有8位,但是有效位只有最高2位,這個(gè)地方很多人使用了Cortex-M3后一直也認(rèn)為Cortex-M0也是最高3或4位有效位
    的頭像 發(fā)表于 04-24 11:20 ?3373次閱讀

    全球最強(qiáng)性能Cortex-M0 MCU誕生!

    Arm傳統(tǒng)的、為MCU打造的Cortex-M系列CPU主要有:Cortex-M0, Cortex-M3, Cortex-M4。其中Cortex-M0
    的頭像 發(fā)表于 12-20 11:15 ?1438次閱讀

    Cortex-M0中斷控制和系統(tǒng)控制知識(shí)點(diǎn)

    每一個(gè)外部中斷都有一個(gè)對(duì)應(yīng)的優(yōu)先級(jí)寄存器,Cortex-M0NVIC-IPR共有8個(gè)寄存器,而每個(gè)寄存器管理4個(gè)IRQ中斷,所以M0的IR
    的頭像 發(fā)表于 03-20 09:28 ?3691次閱讀

    Cortex-M3中斷優(yōu)先級(jí)的相關(guān)知識(shí)

    本文詳細(xì)介紹Cortex-M3中斷優(yōu)先級(jí)相關(guān)知識(shí)
    的頭像 發(fā)表于 03-23 11:45 ?3148次閱讀
    <b class='flag-5'>Cortex-M</b>3<b class='flag-5'>中斷</b>優(yōu)先級(jí)的相關(guān)<b class='flag-5'>知識(shí)</b>

    Cortex-M0系統(tǒng)控制塊(SCB)介紹

    Cortex-M0系統(tǒng)控制塊(SCB)是內(nèi)核外設(shè)的主要模塊之一,提供系統(tǒng)控制以及系統(tǒng)執(zhí)行信息,包括配置,控制,上報(bào)系統(tǒng)異常等。
    的頭像 發(fā)表于 03-25 15:14 ?6556次閱讀

    敏矽微電子Cortex-M0學(xué)習(xí)筆記05——端口外部中斷實(shí)例

    敏矽微電子Cortex-M0學(xué)習(xí)筆記05——端口外部中斷實(shí)例
    的頭像 發(fā)表于 09-26 17:10 ?1007次閱讀
    敏矽微電子<b class='flag-5'>Cortex-M0</b>學(xué)習(xí)筆記05——端口外部<b class='flag-5'>中斷</b>實(shí)例

    敏矽微電子Cortex-M0學(xué)習(xí)筆記02——Cortex-M0開發(fā)環(huán)境的建立及調(diào)試

    敏矽微電子Cortex-M0學(xué)習(xí)筆記02——Cortex-M0開發(fā)環(huán)境的建立及調(diào)試
    的頭像 發(fā)表于 09-26 17:05 ?1822次閱讀
    敏矽微電子<b class='flag-5'>Cortex-M0</b>學(xué)習(xí)筆記02——<b class='flag-5'>Cortex-M0</b>開發(fā)環(huán)境的建立及調(diào)試
    主站蜘蛛池模板: 激情婷婷综合久久久久 | 亚洲免费视频在线观看 | 天天操精品 | 大尺度在线播放 | 国产一级特黄aaaa大片野外 | 国产高清在线 | 中文字幕在线天堂 | 婷婷在线影院 | 色视频在线观看免费 | 成人免费一区二区三区 | 天天做天天爱天天综合网 | 精品亚洲午夜久久久久 | 日本小视频免费 | аⅴ资源天堂8在线 | 天堂日韩| 午夜影院视频 | 35qao强力打造免费上线高清 | 明星三级国产免费播放 | 午夜在线影视 | 日韩一级欧美一级一级国产 | 美女免费观看一区二区三区 | 在线aa| 亚洲系列中文字幕一区二区 | 天天射天天草 | 2020国产v亚洲v天堂高清 | 欧美午夜精品一区二区三区 | 国产福利萌白酱喷水视频铁牛 | 亚洲毛片免费在线观看 | 天天综合网天天做天天受 | 欧美亚洲另类在线观看 | 97色在线视频 | 伊人久久大香线蕉综合高清 | 中文字幕一二三区乱码老 | 夜夜夜夜曰天天天天拍国产 | 日韩欧美亚洲综合一区二区 | 717影院理论午夜伦八戒 | 丁香花五月天婷婷 | 一区二区高清在线 | 成人免费午间影院在线观看 | 日本大片免费一级 | 色天天综合色天天天天看大 |