当前位置:网站首页>关于ARM2440中断源个数的一点想法[通俗易懂]
关于ARM2440中断源个数的一点想法[通俗易懂]
2022-08-04 09:44:00 【全栈程序员站长】
大家好,又见面了,我是你们的朋友全栈君。
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
边栏推荐
- MindSpore:【mindinsight】【Profiler】用execution_time推导出来的训练耗时远小于真实的耗时
- 【C补充】指针相关知识点收集01
- 各位大佬,请问mysql数据的cdc,能指定存量数据同步的zone为utc 吗
- leetcode单调栈经典例题——最大矩形
- 被Win11安全中心误删除的文件怎么恢复?
- 无线Mesh自组网方案,CV5200无线模组应用,支持高清数据远距离传输
- 请问下Flink SQL如何写hologres分区表?我想要每天一个分区
- ps如何换背景颜色,自学ps软件photoshop2022,3种不同的方式笔记记录
- Anton Paar Anton Paar Density Meter Hydrometer Repair DMA35 Performance Parameters
- The difference between Mysql application log time and system time is eight hours
猜你喜欢
DOM简述
cannot import name 'import_string' from 'werkzeug' [bug solution]
【C补充】指向指针或函数的指针
OAK-FFC-4P全网首次测试
MindSpore:【mindinsight】【Profiler】用execution_time推导出来的训练耗时远小于真实的耗时
[Cloud Residency Co-Creation] HCSD Celebrity Live Streaming – Employment Guide
leetcode单调栈经典例题——最大矩形
菲沃泰科创板上市:市值123亿 宗坚赵静艳夫妇身价76亿
Acwing 3208. Z字形扫描 偏移量+扩展图
Win10电脑经常发出叮咚声音怎么关闭
随机推荐
LeetCode581+621+207
VRRP+MSTP配置详解【华为eNSP实验】
Detailed explanation of telnet remote login aaa mode [Huawei eNSP]
Detailed explanation of NAT/NAPT address translation (internal and external network communication) technology [Huawei eNSP]
密码字典生成工具pydictor/john
TiCDC迁移-TiDB到MySQL测试
【COS 加码福利】COS 用户实践有奖征文,等你来投稿!
GBsae 8 c database using an error, how to do?
双重for循环案例以及while循环和do while循环案例
路由/三层交换机DHCP下发地址详解【华为eNSP】
MindSpore:图算融合报错
Cloud function to achieve automatic website check-in configuration details [Web function/Nodejs/cookie]
使用ClickHouse分析COS的清单和访问日志
TiFlash 源码阅读(五) DeltaTree 存储引擎设计及实现分析 - Part 2
Detailed Explanation of Addresses Delivered by DHCP on Routing/Layer 3 Switches [Huawei eNSP]
HTB-Nibbles
usb设备复合g_webcam摄像头码流传输功能以及g_serial串口功能
I am 37 this year, and I was rushed by a big factory to...
leetcode动态规划经典例题——53.最大子数组和
外包干了四年,秋招终于上岸了