部署DeepSeek模型,进群交流最in玩法!
立即加群
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >关于ARM2440中断源个数的一点想法[通俗易懂]

关于ARM2440中断源个数的一点想法[通俗易懂]

作者头像
全栈程序员站长
发布于 2022-08-04 01:29:50
发布于 2022-08-04 01:29:50
2450
举报

大家好,又见面了,我是你们的朋友全栈君。

S3c2440支持多达36个内部中断源和24个外部中断源,分别使用内部终端屏蔽寄存器INTMSK和外部中断寄存器MSK进行屏蔽控制。其中,外部中断源通过GPIO以复用的方式成为内部中断源的一部分。

但是我们清楚,INTMSK是一个32位的寄存器,最多只能支持32中断,它是如何对应这么多中断的呢?

首先我们先看INTMSK对应的位。 INTERRUPT MASK (INTMSK) REGISTER (Continued) INT_ADC [31] 0 = Service available, 1 = Masked 1 INT_RTC [30] 0 = Service available, 1 = Masked 1 INT_SPI1 [29] 0 = Service available, 1 = Masked 1 INT_UART0 [28] 0 = Service available, 1 = Masked 1 INT_IIC [27] 0 = Service available, 1 = Masked 1 INT_USBH [26] 0 = Service available, 1 = Masked 1 INT_USBD [25] 0 = Service available, 1 = Masked 1 INT_NFCON [24] 0 = Service available, 1 = Masked 1 INT_UART1 [23] 0 = Service available, 1 = Masked 1 INT_SPI0 [22] 0 = Service available, 1 = Masked 1 INT_SDI [21] 0 = Service available, 1 = Masked 1 INT_DMA3 [20] 0 = Service available, 1 = Masked 1 INT_DMA2 [19] 0 = Service available, 1 = Masked 1 INT_DMA1 [18] 0 = Service available, 1 = Masked 1 INT_DMA0 [17] 0 = Service available, 1 = Masked 1 INT_LCD [16] 0 = Service available, 1 = Masked 1 INT_UART2 [15] 0 = Service available, 1 = Masked 1 INT_TIMER4 [14] 0 = Service available, 1 = Masked 1 INT_TIMER3 [13] 0 = Service available, 1 = Masked 1 INT_TIMER2 [12] 0 = Service available, 1 = Masked 1 INT_TIMER1 [11] 0 = Service available, 1 = Masked 1 INT_TIMER0 [10] 0 = Service available, 1 = Masked 1 INT_WDT_AC97 [9] 0 = Service available, 1 = Masked 1 INT_TICK [8] 0 = Service available, 1 = Masked 1 nBATT_FLT [7] 0 = Service available, 1 = Masked 1 INT_CAM [6] 0 = Service available, 1 = Masked 1 EINT8_23 [5] 0 = Service available, 1 = Masked 1 EINT4_7 [4] 0 = Service available, 1 = Masked 1 EINT3 [3] 0 = Service available, 1 = Masked 1 EINT2 [2] 0 = Service available, 1 = Masked 1 EINT1 [1] 0 = Service available, 1 = Masked 1 EINT0 [0] 0 = Service available, 1 = Masked 1

我们发现INTMSK的第5,6位对应了EINT4_7, EINT8_23,20个外部中断,也就是所,这20个GPIO引脚只能触发这两个中断。 但是当中断到来时,我们如果判断是由哪一个GPIO引脚触发的呢?这个时候我们可以通过查询EINTMASK来判断中断源。 EINTMASK Bit Description EINT23 [23] 0 = enable interrupt 1= masked EINT22 [22] 0 = enable interrupt 1= masked EINT21 [21] 0 = enable interrupt 1= masked EINT20 [20] 0 = enable interrupt 1= masked EINT19 [19] 0 = enable interrupt 1= masked EINT18 [18] 0 = enable interrupt 1= masked EINT17 [17] 0 = enable interrupt 1= masked EINT16 [16] 0 = enable interrupt 1= masked EINT15 [15] 0 = enable interrupt 1= masked EINT14 [14] 0 = enable interrupt 1= masked EINT13 [13] 0 = enable interrupt 1= masked EINT12 [12] 0 = enable interrupt 1= masked EINT11 [11] 0 = enable interrupt 1= masked EINT10 [10] 0 = enable interrupt 1= masked EINT9 [9] 0 = enable interrupt 1= masked EINT8 [8] 0 = enable interrupt 1= masked EINT7 [7] 0 = enable interrupt 1= masked EINT6 [6] 0 = enable interrupt 1= masked EINT5 [5] 0 = enable interrupt 1= masked EINT4 [4] 0 = enable interrupt 1= masked Reserved [3:0] Reserved 但是还有一个疑问,不是说60个中断源吗?除去24个外部中断源应该还有60-24 -(32-6)=10个内部中断源啊。他们在哪呢?

其实这里涉及到了子中断源的概念。 Sub Sources Descriptions Source INT_AC97 AC97 interrupt INT_WDT_AC97 INT_WDT Watchdoc interrupt INT_WDT_AC97 INT_CAM_P P-port capture interrupt in camera interface INT_CAM INT_CAM_C C-port capture interrupt in camera interface INT_CAM INT_ADC_S ADC interrupt INT_ADC INT_TC Touch screen interrupt (pen up/down) INT_ADC INT_ERR2 UART2 error interrupt INT_UART2 INT_TXD2 UART2 transmit interrupt INT_UART2 INT_RXD2 UART2 receive interrupt INT_UART2 INT_ERR1 UART1 error interrupt INT_UART1 INT_TXD1 UART1 transmit interrupt I NT_UART1 INT_RXD1 UART1 receive interrupt INT_UART1 INT_ERR0 UART0 error interrupt INT_UART0 INT_TXD0 UART0 transmit interrupt INT_UART0 INT_RXD0 UART0 receive interrupt NT_UART0

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/107101.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年4月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
嵌入式:ARM中断系统设计全解
ARM920T能处理有8个异常,他们分别是:Reset,Undefined instruction,Software Interrupt,Abort (prefetch),Abort (data),Reserved,IRQ,FIQ ,它们的矢量表是:
timerring
2023/01/04
1K0
嵌入式:ARM中断系统设计全解
c6000 中断小结
1. 中断相关概念 中断过程———————————–你在下象棋,突然电话响了,你回屋接电话,然 后回来继续下象棋,这个过程就叫做中断响应过程。 CPU执行正常任务———————下象棋 保护现场———————————-你已经想好要“将军”,先在脑海中记下来。 中断发生———————————-电话响- 中断服务程序—————————-接电话 恢复现场———————————-回来后恢复刚才想法 中断返回———————————-你回来继续下象棋 中断屏蔽———————————-Boss 正在训话,要求所有电话关机,你不能接电话 了。 不可屏蔽中断——————————-你内急,即使是 Boss 在训话,你还是得到外面去 嘘嘘。
全栈程序员站长
2022/07/04
6320
s3c2440中断体系
用户模式(usr):ARM处理器正常的程序执行状态 快速中断模式(fiq):用于高速数据传输或通道处理 中断模式(irq):用于通用的中断处理 管理模式(svc):操作系统使用的保护模式 数据访问终止模式(abt):当数据或指令预取终止时进入该模式,可用于虚拟存储及存储保护 系统模式(sys):运行具有特权的操作系统任务 未定义指令中止模式(und):当未定义的指令执行时进入该模式,可用于支持硬件协处理器的软件仿真 除用户模式外,其他6种工作模式都属于特权模式,大多数程序运行于用户模式,进入特权模式是为了处理中断、异常,或者访问被保护的系统资源。
全栈程序员站长
2022/08/14
7360
s3c2440中断体系
ARM(十二).ADC with IRQ2
main.c 主 c 程序中定义了中断处理程序 #include "2440addr.h" //将"2440addr.h"包含进来,这里面放的是所有寄存器的地址宏 //中断方式ADC int flag = 0; //捕获ADC中断的中断标记 void UART0Init(void) //初始化UART0 { rGPHCON = (2<<6) | (2<<4); //设定GPH{2,3}为TXD[0]和RXD[0] rGPHUP = (1<<3) | (1<<2)
franket
2021/08/13
5370
ARM(十四).WatchDog with IRQ
ARM 处理器是英国 Acorn 有限公司设计的低功耗低成本的一款 RISC 微处理器
franket
2021/08/12
1K0
第014课 Jz2400_ARM异常与中断体系详解
2 发生了各种声音,如何处理这些声音 :: 有远处的猫叫(听而不闻,忽略) :: 门铃声有快递(开门收快递) :: 小孩哭声(打开房门,照顾小孩) 3 母亲的处理 :: 只会处理门铃声和小孩哭声 :: a 现在书中放入书签,合上书(保存现场) :: b 去处理 (调用对应的中断服务程序) :: c 继续看书(恢复现场)
韦东山
2020/09/30
1.7K0
第014课 Jz2400_ARM异常与中断体系详解
ARM中断处理过程
以s3c2440  ARM9核为例: 一:s3c2440 ARM处理器特性:   1、S3C2440支持60个中断源,含子中断源;   2、ARM9采用五级流水线方式;    3、支持外部中断和内部中断; 二、s3c2440 支持的寄存器: 2.1 外部中断寄存器             24个外部中断占用GPF0-GPF7(EINT0-EINT7),GPG0-GPG15(EINT8-EINT23)。用这些脚做中断输入,则必须配置引脚为中断,并且不要上拉。具体可参考datesheet数据手册。 寄存器:  
233333
2018/03/07
1.7K0
ARM(十五).IIC with IRQ 3
2440addr.h 这个文件作为 c 的头文件,定义了各种寄存器的地址宏,和清中断的函数 //============================================================================= // File Name : 2440addr.h // Function : S3C2440 Define Address Register // History // 0.0 : Programming start (February 15,2002)
franket
2021/08/12
7670
ARM(十五).IIC with IRQ
ARM 处理器是英国 Acorn 有限公司设计的低功耗低成本的一款 RISC 微处理器
franket
2021/08/12
1K0
ARM(十三).WatchDog1
ARM 处理器是英国 Acorn 有限公司设计的低功耗低成本的一款 RISC 微处理器
franket
2021/08/13
7920
DshanMCU-R128s2芯片参数
韦东山
2023/12/22
2170
相关推荐
嵌入式:ARM中断系统设计全解
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档