以串口中断为例,给你个介绍。
在启动文件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,进而执行中断服务函数中的应用。
|