ARM·中断控制器

发布者:rnm888最新更新时间:2015-11-17 来源: eefocus关键字:ARM  中断控制器 手机看文章 扫描二维码
随时随地手机看文章
【本章内容】
之前在基础篇里面看过中断概念的视频,不过因为介绍的十分繁琐,效果不是很好。今天看了高级开发篇,决定把中断的内容简化一些。
我觉得可以把这篇笔记分成2个区,寄存器区和代码区。寄存器区方便以后查看,代码区方便对中断控制的分析
 
【代码分析】
@******************************************************************************
@ File:head.S
@ 功能:初始化,设置中断模式、管理模式的栈,设置好中断处理函数
@******************************************************************************       
   
.extern     main @extern 声明引用main函数
.text 
.global _start 
_start:
@******************************************************************************       
@ 中断向量,本程序中,除Reset和HandleIRQ外,其它异常都没有使用
@******************************************************************************       
    b   Reset
 
@ 0x04: 未定义指令中止模式的向量地址
HandleUndef:
    b   HandleUndef 
 
@ 0x08: 管理模式的向量地址,通过SWI指令进入此模式
HandleSWI:
    b   HandleSWI
 
@ 0x0c: 指令预取终止导致的异常的向量地址
HandlePrefetchAbort:
    b   HandlePrefetchAbort
 
@ 0x10: 数据访问终止导致的异常的向量地址
HandleDataAbort:
    b   HandleDataAbort
 
@ 0x14: 保留
HandleNotUsed:
    b   HandleNotUsed
 
@ 0x18: 中断模式的向量地址
    b   HandleIRQ
 
@ 0x1c: 快中断模式的向量地址
HandleFIQ:
    b   HandleFIQ
 
Reset:                  
    ldr sp, =4096           @ 设置栈指针,以下都是C函数,调用前需要设好栈
    bl  disable_watch_dog   @ 关闭WATCHDOG,否则CPU会不断重启
    
    msr cpsr_c, #0xd2       @ 进入中断模式
    ldr sp, =3072           @ 设置中断模式栈指针
 
    msr cpsr_c, #0xd3       @ 进入管理模式
    ldr sp, =4096           @ 设置管理模式栈指针,
                            @ 其实复位之后,CPU就处于管理模式,
                            @ 前面的“ldr sp, =4096”完成同样的功能,此句可省略
 
    bl  init_led            @ 初始化LED的GPIO管脚
    bl  init_irq            @ 调用中断初始化函数,在init.c中
    msr cpsr_c, #0x5f       @ 设置I-bit=0,开IRQ中断
    
    ldr lr, =halt_loop      @ 设置返回地址
    ldr pc, =main           @ 调用main函数
halt_loop:
    b   halt_loop
 
HandleIRQ:
    sub lr, lr, #4                  @ 计算返回地址
    stmdb   sp!,    { r0-r12,lr }   @ 保存使用到的寄存器
                                    @ 注意,此时的sp是中断模式的sp
                                    @ 初始值是上面设置的3072
    
    ldr lr, =int_return             @ 设置调用ISR即EINT_Handle函数后的返回地址  
    ldr pc, =EINT_Handle            @ 调用中断服务函数,在interrupt.c中
int_return:
    ldmia   sp!,    { r0-r12,pc }^  @ 中断返回, ^表示将spsr的值复制到cpsr
注意:
(1)异常向量表(这里只用到了reset和IRQ异常)和各工作模式的CPRS
【???·ARM·中断控制器】【???·ARM·中断控制器】

(2)
    msr cpsr_c, #0xd2  (11010010)     @ 进入中断模式
    ldr sp, =3072           @ 设置中断模式栈指针
 
    msr cpsr_c, #0xd3(11010011)       @ 进入管理模式
    ldr sp, =4096           @ 设置管理模式栈指针,
                            @ 其实复位之后,CPU就处于管理模式,
                            @ 前面的“ldr sp, =4096”完成同样的功能,此句可省略
 
    bl  init_led            @ 初始化LED的GPIO管脚
    bl  init_irq            @ 调用中断初始化函数,在init.c中
    msr cpsr_c, #0x53 (01001110)      @ 设置I-bit=0,开IRQ中断
1.在管理模式允许中断,在中断模式屏蔽中断,防止中断嵌套;且在管理模式用来Thumb,可以对表查看,做了解。
2.在每一中异常下都必须设置堆栈指针,便于调用C函数,因为pc在每种状态下都是独立的。
3.中断初始化的同时,也顺便将硬件GPIO管脚初始化,把中断函数初始化 ;
【关于中断寄存器,也就是这章的重点,也就都在中断函数初始化 bl  init_irq            @ 调用中断初始化函数,在init.c中中】
 
 
#include "s3c24xx.h"
 
#define GPF4_out (1<<(4*2))
#define GPF5_out (1<<(5*2))
#define GPF6_out (1<<(6*2))
 
#define GPF4_msk (3<<(4*2))
#define GPF5_msk (3<<(5*2))
#define GPF6_msk (3<<(6*2))
 
#define GPF0_eint     (0x2<<(0*2))
#define GPF2_eint     (0x2<<(2*2))
#define GPG3_eint     (0x2<<(3*2))
 
#define GPF0_msk    (3<<(0*2))
#define GPF2_msk    (3<<(2*2))
#define GPG3_msk    (3<<(3*2))
 
void disable_watch_dog(void)
{
    WTCON = 0;  // 关闭WATCHDOG很简单,往这个寄存器写0即可
}
 
void init_led(void)
{
    // LED1,LED2,LED4对应的3根引脚设为输出
    GPFCON &= ~(GPF4_msk | GPF5_msk | GPF6_msk);
    GPFCON |= GPF4_out | GPF5_out | GPF6_out;
}
 
 
void init_irq( )
{
    // S2,S3对应的2根引脚设为中断引脚 EINT0,ENT2
    GPFCON &= ~(GPF0_msk | GPF2_msk);
    GPFCON |= GPF0_eint | GPF2_eint;
 
    // S4对应的引脚设为中断引脚EINT11
    GPGCON &= ~GPG3_msk;
    GPGCON |= GPG3_eint;
    
    // 对于EINT11,需要在EINTMASK寄存器中使能它
    EINTMASK &= ~(1<<11);
        
   
    PRIORITY = (PRIORITY & ((~0x01) | (0x3<<7))) | (0x0 << 7) ;
 
    // EINT0、EINT2、EINT8_23使能
    INTMSK   &= (~(1<<0)) & (~(1<<2)) & (~(1<<5));
}
 
红色部分,便是我们这章的重点内容,也就是对中断寄存器的配置,init的初始化 。
 
   【???·ARM·中断控制器】 
这张图,前后反复提到,可以作为重点的参考图,结合下面这张s3c2440的中断源的表[page]
 
【???·ARM·中断控制器】
 
 
 
【实例分析】
           (1)轮流按下K1-K4,可以看见LED1-LED4被轮流点亮 ;
   (2)同时按下K3-K4,只有LED4被点亮;
   (3)同时按下K1-K2,LED1,LED2被点亮;
   (4)同时按下所有按键,只有LED4被点亮;
 
 
CPU与外设之间的数据传送控制方式,通常有以下三种:
*查询方式
*中断方式
*DMA方式(Direct Memory Access)
直接内存存取是数字信号处理器DSP用于快速数据交换的重要技术
独立于CPU后台批量数据传输能力
【中断】
*中断请求
*中断仲裁
*中断响应
*中断处理
*中断返回
 
中断处理流程:
(1)中断控制器捕获当前外设发出的中断信号,通知soc
(2)soc保存当前程序的运行环境,然后调用中断服务程序来处理中断
(3)ISR中通过读取中断控制寄存器、外设的相关寄存器来是哪一个中断触发,获取硬件中断号IRQ,跳转到相应的地方完成中断 
(4)清楚中断:通过读写相关中断控制寄存器和外设相关的寄存器来实现
(5)最后恢复被中断程序的环境,继续执行
 
【S3C2440A的中断源】(太多)
【???·ARM·中断控制器】
 
 
这里关于一级中断和二级中断源的一个处理
(EINT8_23,ENT4_7)
 
【???·ARM·中断控制器】
 
【中断相关的控制寄存器】
当一个中断响应,我们可以通过相应地控制寄存器对中断进行定性的控制,也就是操作这些寄存器 ;
 
*源挂起寄存器 SRCPND (与SUBSRCPND相似)
*中断模式寄存器 INTMOD   (选择中断模式,设置为0:IRQ中断;设置为1:FIQ中断)
*中断屏蔽寄存器 INTMASK  (用来配置SRCPND的中断是否被屏蔽)(只能屏蔽IRQ)
*中断优先级寄存器 PRIOPITY
*中断挂起寄存器 INTPND   (选择优先级最高的一个中断,置1)
*确认中断源寄存器 INTOFFSET  (对应INTPND)
*子中断源源挂起寄存器 SUBSRCPND(清中断时往SUBSRCPND寄存器中的对应位写入1)
*子中断屏蔽寄存器 INTSUBMASK(设置为1:对应子中断被屏蔽 ;设置为0:表示子中断允许)
 
(关于 挂起:有人说的很好,挂起是被翻译过来的,英文是Pending,另一个意思更加准确:等待被执行)
(多个中断一起响应的时候,优先级更高的中断先执行,其他被挂起)
 
【S3C2440A的外部中断寄存器】
*外部中断控制寄存器EXTINTx
*外部中断屏蔽寄存器EINTMASK
*外部中断挂起寄存器EINTPEND
 
(1)EXTINTx
【???·ARM·中断控制器】
 
【???·ARM·中断控制器】
 
设置可以控制低电平触发,高电平触发,下降沿触发,上升沿触发,边沿触发
 
(2)外部中断屏蔽寄存器
【???·ARM·中断控制器】
 
(3)外部中断挂起寄存器
 
【???·ARM·中断控制器】
 
 
 
关键字:ARM  中断控制器 引用地址:ARM·中断控制器

上一篇:ARM·UART初始化程序
下一篇:ARM·存储器配置

推荐阅读最新更新时间:2024-03-16 14:39

选择ARM处理器,ARM7还是Cortex-M3
要使用低成本的 32位处理器,开发人员面临两种选择,基于Cortex-M3内核或者ARM7TDMI内核的处理器。如何做出选择?选择标准又是什么?本文主要介绍了ARM Cortex-M3内核微控制器区别于ARM7的一些特点,帮助您快速选择。 1.ARM实现方法 ARM Cortex-M3是一种基于ARM7v架构的最新ARM嵌入式内核,它采用哈佛结构,使用分离的指令和数据总线(冯诺伊曼结构下,数据和指令共用一条总线)。从本质上来说,哈佛结构在物理上更为复杂,但是处理速度明显加快。根据摩尔定理,复杂性并不是一件非常重要的事,而吞吐量的增加却极具价值。 ARM公司对Cortex-M3的定位是:向专业嵌入式市场提供低成本、低功耗的芯片。在
[单片机]
arm linux 下中断流程简要分析中断处理流程
三 响应中断 首先在分析源码之前,让我们了解一些原理性的东西, 我们都知道在处理中断要保存当前现场状态,然后才能处理中断,处理完之后还要把现场状态恢复过来才能返回到被中断的地方继续执行,这里要说明的是在指令跳转到中断向量的地方开始执行之前,CPU帮我们做了哪些事情: R14_irq = 要执行的下条指令地址 + 4 //这里的下条指令是相对于被中断指令的下条。即返回地址 SPSR_irq = CPSR //保存的现场状态,r0到r12要由我们软件来保存(如果需要的话)。 CPSR = 0b10010 //进入中断模式 CPSR = 0 //在ARM模式下执行(不是Thumb下) CPSR
[单片机]
<font color='red'>arm</font> linux 下中断流程简要分析中断处理流程
基于ARM的CAN总线智能节点的设计
摘要:CAN总线是一种应用广泛的实时性现场总线,提出了基于具有ARM7TDMI内核的32位微控制器的CAN总线智能节点设计方案。详细介绍了ARM控制(LPC2294)的特点、智能节点的结构以及系统软件设计,同时结合现场实际使用给出了硬件抗干扰措施。 关键词:CAN总线 ARM 嵌入式控制器 CAN(Controller Area Network)即控制器局域网,CAN总线是国际上应用最广泛的现场总线之一。它最早是由德国Bosch公司推出的,CAN通信协议是一种用于汽车内部测量与执行部件之间的数据通信协议。 作为一种技术先进、可靠性高、功能完善、成本合理的远程网络通讯控制方式,CAN总线已被广泛应用于各个自动化控制系统中。例如
[嵌入式]
基于ARM的11种嵌入式操作系统大盘点
1、Android    Android 是一个包括操作系统,中间件以及一些重要应用程序的专门针对移动设备的层次结构的软件集。Android 作为一个完全开源的操作系统,是由操作系统Linux、中间件以及核心应用程序组成的软件栈。通过 android SDK 提供的 API 以及相应的开发工具, 程序员可以很方便的开发android平台上的应用程序。其整个系统由应用程序,应用程序框架,应用程序库,Android运行库,Linux内核(Linux Kernel)五个部分组成。Android操作系统内置了一部分应用程序, 包括电子邮件客户端、SMS程序、日历、地图、浏览器、通讯录以及其他的程序,值得一提的是这些所有的程序都是用java
[单片机]
三星准备丢开ARM,开发RISC-V架构自主CPU内核
今年三星的半导体部门已经开始尝试一些大的飞跃,其运用于Galaxy S7旗舰的Exynos 8890处理器,首次采用了自主定制的CPU内核M1。现在来看,三星正计划扩大芯片定制开发的实力,因为日前根据业内人士透露的消息了解,三星设备解决方案(Device Solution)事业部正在为研发32位的MCU微控制器定制一种CPU内核,并且似乎是以可穿戴设备或物联网市场为目标。 据称,三星研发中的这个CPU内核基于开源的RISC-V指令集架构,而不是我们常见的ARM架构(例如三星旗舰机长期所用的ARMv6-M最新的ARMv8-M架构)。这就意味着,三星不必支付ARM授权许可费。更进一步来说,三星的CPU战略目标正在发生转变,从之前获
[单片机]
汽车MCU缺货与保供 芯旺微如何布局车规级MCU
汽车MCU大缺货引发了一个思考,如何保证国产汽车芯片供应链的自主可控。特别是随着汽车向电子化和智能化方向发展,车用MCU作为汽车电子系统内部运算和处理的核心,遍布悬挂、气囊、门控和音响等几十种次系统中,地位愈发重要。以往,该市场多由恩智浦、瑞萨电子、Microchip、英飞凌、ST等国外厂商所占据,国内厂商份额寥寥。 不过,这种局面正在发生改变,国内车用MCU在逐步崛起。其中,就包括芯旺微电子,其凭借十余年的车规芯片研发设计和市场交付经验,已经成功打开了国产MCU上车之门。在2021上海慕尼黑电子展现场,芯旺微电子展台人气爆棚,火爆程度可见一斑。 自主内核 长期以来,MCU领域的国内多数厂商均采用ARM授权的内
[汽车电子]
汽车MCU缺货与保供 芯旺微如何布局车规级MCU
ARM Linux中断机制之中断的初始化
一,认识几个重要结构体: 1.中断描述符 对于每一条中断线都由一个irq_desc结构来描述。 //在include/linux/irq.h中 struct irq_desc { unsigned int irq;//中断号 struct timer_rand_state *timer_rand_state; unsigned int *kstat_irqs; #ifdef CONFIG_INTR_REMAP struct irq_2_iommu *irq_2_iommu; #endif /* 在kernel/irq/chip.c中实现了5个函数:handle_simple_irq(),handle_
[单片机]
<font color='red'>ARM</font> Linux中断机制之中断的初始化
基于ARM的嵌入式TCP/IP协议的实现
摘要:介绍嵌入式TCP/IP协议在低速处理器中的一种简化实现方案,并成功应用于某分布式监控系统中。 关键词:TCP/IP协议 嵌入式 ARM 在网络应用日益普遍的今天,越来越多的嵌入式设备实现Internet网络化。TCP/IP协议是一种目前被广泛采用的网络协议。嵌入式Internet的技术核心是在嵌入式系统中部分或完整地实现TCP/IP协议。由于TCP/IP协议比较复杂,而目前嵌入式系统中大量应用低速处理器,受内存和速度限制,有必要将TCP/IP协议简化。 图1 协议处理 1 TCP/IP协议的实现 嵌入式TCP/IP协议一般实现:ARP/RARP、IP、ICMP、TCP、UDP、HTTP、SMTP、FTP、TELNE
[嵌入式]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved