- 1、本文档共42页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四章 S3C2410的中断系统 主要内容: 4.1 S3C2410的中断源 4.2 S3C2410的中断处理 4.3 中断控制 4.4 子中断源的中断控制 4.5 中断向量设置 4.6 其它常用寄存器 4.7 中断程序编写中需注意问题 4.8 中断实验和中断程序编写 4.1 S3C2410的中断源 S3C2410有56个中断源。在56个中断源中,有32个中断源提供中断控制器,其中,外部中断EINT4~EINT7通过“或”的形式提供一个中断源送至中断控制器,EINT8~EINT23也通过“或”的形式提供一个中断源送至中断控制器。 通过表4-1可以看到这些中断源之间的逻辑关系。 4.2 S3C2410的中断处理 S3C2410的中断控制逻辑如图4-1所示,S3C2410的中断控制可以处理56个中断源的中断请求。这些中断源可以是来自片内的中断,比如DMA、UART和I2C等;也可以来自处理器外部中断输入引脚。在这些中断源中,有如下11个中断源通过分支中断控制器来申请使用中断(与其它中断共用一个中断向量)。 INT_ADC A/D转换中断; INT_TC 触摸屏中断; INT_ERR2 UART2收发错误中断; INT_TXD2 UART2发送中断; INT_RXD2 UART2接受中断; INT_ERR1 UART1收发错误中断; INT_TXD1 UART1发送中断; INT_RXD1 UART1接受中断; INT_ERR0 UART0收发错误中断; INT_TXD0 UART0发送中断; INT_RXD0 UART0接受中断。 中断控制逻辑(interrupt controller logic)的任务是在片内和外部中断源组成的多重中断发生时,选择其中一个中断,通过FIQ (快速中断请求)或IRQ(通用中断请求)向CPU内核发出中断请求。 图4-1中,中断源是指给出中断向量的那些中断,子中断源是指与其它中断共用一个中断向量的中断。例如UART0是一个中断源,而TXD0和RXD0就是子中断源。子中断源向CPU申请中断,子中断源挂起寄存器中相应位要置1,如果该子中断没被屏蔽,则该子中断源所归属的总中断源挂起寄存器中相应位也要置1。 4.3 中断控制 4.3.1 中断模式(INTMOD)寄存器 ARM920T提供了两种中断模式,即FIQ模式(快速模式)和IRQ模式(通用模式)。所有的中断源在中断请求时都要确定使用那一种中断模式。中断模式控制寄存器设置如表4-2所示,因为复位时各位等于0,如果我们采用通用中断,中断模式寄存器可以不用设置。 4.3.2 中断挂起寄存器和中断源挂起寄存器 S3C2410有两个中断挂起寄存器:中断挂起寄存器(INTPND)见表4-3;中断源挂起寄存器(SRCPND)见表4-4。当中断源向CPU申请中断时,SRCPND寄存器的相应位被置1,表明哪一个中断源向CPU申请了中断;如果当前没有优先级与此中断源相等或高于的中断服务在执行,并该中断没被屏蔽,此中断会被响应,INTPND相应位会被置1 4.3.3 中断屏蔽寄存器(INTMSK) 当INTMSK寄存器的屏蔽位为1时,对应的中断被禁止;当INTMSK寄存器的屏蔽位为0时,则相应的中断正常执行,INTMSK定义见表4-5。如果一个中断的屏蔽位为1,则该中断请求不被受理 4.3.4 中断优先级寄存器 (PRIORITY) 上面已介绍过,S3C2410共有56个中断源,有32个中断控制器,外部中断EXTIN8~23共用一个中断控制器,外部中断EXTIN4~7共用一个中断控制器,9个UART中断分成3组,共用3个中断控制器,ADC和触摸屏共用一个中断控制器。系统对中断优先级实行由中断优先寄存器 (PRIORITY) 和7个中断仲裁器组组成的两级控制,这7个中断仲裁器组由6个子中断仲裁器组(ARBITER0~ ARBITER5)和一个主中断仲裁器组(ARBITER6)组成, 每个中断仲裁器下面有4~6个中断源,这些中断源对应着REQ0~REQ5这6个优先级。仲裁器具体分组见图4-2。中断优先寄存器 (PRIORITY)的定义见表4-6。 当一个中断源向CPU申请中断时,它首先要在自己所在的子中断仲裁器组进行仲裁比较,如果此中断仲裁器组中没有和它同级别或高于它的中断源向CPU申请中断,则它进入主中断仲裁器组和其他组的优先中断源进行仲裁比较,决定能否向CPU申请中断。 表4-6 优先级寄存器设定 由表4-6可以看到,中断优先寄存器 (PRIORITY)的[20:19]位控制中断仲裁器组ARB-SEL6的优先级。[20:19]=00,优先级REQ0-1-2-3-4-5;[20:19]=01,优先级R
您可能关注的文档
- 嵌入式Linux系统开发教程 教学课件 作者 978 7 302 22520 1 第十章.ppt
- 嵌入式Linux系统开发教程 教学课件 作者 978 7 302 22520 1 第四章.ppt
- 嵌入式Linux系统开发教程 教学课件 作者 978 7 302 22520 1 第五章.ppt
- 嵌入式Linux系统开发教程 教学课件 作者 978 7 302 22520 1 第一章.ppt
- 嵌入式Linux系统开发教程 教学课件 作者 978 7 302 22520 1 嵌入式Linux系统开发教程参考答案20100625.doc
- 嵌入式Linux系统开发与应用 教学课件 作者 康维新 第1章 嵌入式系统概述.ppt
- 嵌入式Linux系统开发与应用 教学课件 作者 康维新 第2章 嵌入式Linux开发基础.ppt
- 嵌入式Linux系统开发与应用 教学课件 作者 康维新 第3章 开发环境的建立.ppt
- 嵌入式Linux系统开发与应用 教学课件 作者 康维新 第4章 嵌入式Linux网络编程.ppt
- 嵌入式Linux系统开发与应用 教学课件 作者 康维新 第5章 嵌入式设备驱动.ppt
- 小学科学:ESP8266智能插座电路原理与动手实践研究教学研究课题报告.docx
- 《金融开放浪潮下我国多层次监管体系构建与创新研究》教学研究课题报告.docx
- 区域教育质量监测中人工智能应用的数据质量分析与优化策略教学研究课题报告.docx
- 《金融科技监管中的数据治理与合规性要求》教学研究课题报告.docx
- 《3D打印技术在航空航天领域中的多材料制造与复合材料应用》教学研究课题报告.docx
- 《绿色金融发展中的政府职能与市场机制研究》教学研究课题报告.docx
- 《植物工厂多层立体栽培光环境调控技术对植物生长发育节律的调控机制探讨》教学研究课题报告.docx
- 销售团队年度业绩总结.docx
- 银行风险管理与金融危机防范.docx
- 银行网络攻击预警与快速响应机制.docx
文档评论(0)