STM32关于外部中断的问题

[复制链接]
1009|6
 楼主| ahhsyf 发表于 2016-9-21 17:42 | 显示全部楼层 |阅读模式
void EXTI0_IRQHandler(void)
{
EXTI_ClearITPendingBit(EXTI_Line0);  //清除EXTI0线路挂起位
}
这个外部中断函数 是怎么进入的?在哪调用这个函数呢

enginezhong 发表于 2016-9-22 16:30 | 显示全部楼层
楼主一看就是新手,建议看看51中断那部分的讲解先。
liutongda 发表于 2016-9-22 19:38 | 显示全部楼层
内核自动跳转到这里,不需要程序调用。
myidear 发表于 2016-9-22 20:51 | 显示全部楼层
中断是不需要额外调用的,只要满足触发条件,就自动进去中断了。
gaoxiansheng 发表于 2016-9-23 17:23 | 显示全部楼层
EXTI0_IRQHandler(void)这个函数名需要在启动文件的中断函数表中写进去,然后只要满足中断的触发条件,就OK了。
hello_galaxy 发表于 2016-9-23 21:04 | 显示全部楼层
中断初始化,打开中断,写好中断服务函数,然后开启中断,中断就能用了。
lt1231 发表于 2016-9-24 18:54 | 显示全部楼层
以串口中断为例,给你个介绍。
在启动文件startup_stm32f10x_md.s中有这样一段代码,汇编
DCD USART1_IRQHandler
其中DCD是一条数据定义伪指令,用于分配一片连续的字存储单元并用指定的数据初始化。
还有一些如PUBWEAK USART1_IRQHandler等,具体意思不是很清楚。
库里定义 #define USART1 ((USART_TypeDef *) USART1_BASE)
同时 #define USART1_BASE (APB2PERIPH_BASE + 0x3800)
我个人的理解是,当配置好USART1的控制寄存器中断使能时,当发生中断(异常)时,该异常被Cortex-M3内核接受,对应的异常Handler就会执行。而这个响应过程都是硬件来完成的,当然为了决定Handler的入口地址,Cortex-M3使用了“向量表查表机制”。startup_stm32f10x_md.s启动文件已经为USART1_IRQHandler赋予了该地址。所以在异常发生后,CPU进入异常模式,同时程序计数器PC自动指向异常入口地址,也就是USART1_IRQHandler,进而执行中断服务函数中的应用。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

16

主题

222

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部