STM32 中断向量表

STM32 F4系列中断向量表

External Interrupts
DCD     WWDG_IRQHandler                   ; Window WatchDog                                        
DCD     PVD_IRQHandler                    ; PVD through EXTI Line detection                        
DCD     TAMP_STAMP_IRQHandler             ; Tamper and TimeStamps through the EXTI line            
DCD     RTC_WKUP_IRQHandler               ; RTC Wakeup through the EXTI line                       
DCD     FLASH_IRQHandler                  ; FLASH                                           
DCD     RCC_IRQHandler                    ; RCC                                             
DCD     EXTI0_IRQHandler                  ; EXTI Line0                                             
DCD     EXTI1_IRQHandler                  ; EXTI Line1                                             
DCD     EXTI2_IRQHandler                  ; EXTI Line2                                             
DCD     EXTI3_IRQHandler                  ; EXTI Line3                                             
DCD     EXTI4_IRQHandler                  ; EXTI Line4                                             
DCD     DMA1_Stream0_IRQHandler           ; DMA1 Stream 0                                   
DCD     DMA1_Stream1_IRQHandler           ; DMA1 Stream 1                                   
DCD     DMA1_Stream2_IRQHandler           ; DMA1 Stream 2                                   
DCD     DMA1_Stream3_IRQHandler           ; DMA1 Stream 3                                   
DCD     DMA1_Stream4_IRQHandler           ; DMA1 Stream 4                                   
DCD     DMA1_Stream5_IRQHandler           ; DMA1 Stream 5                                   
DCD     DMA1_Stream6_IRQHandler           ; DMA1 Stream 6                                   
DCD     ADC_IRQHandler                    ; ADC1, ADC2 and ADC3s                            
DCD     CAN1_TX_IRQHandler                ; CAN1 TX                                                
DCD     CAN1_RX0_IRQHandler               ; CAN1 RX0                                               
DCD     CAN1_RX1_IRQHandler               ; CAN1 RX1                                               
DCD     CAN1_SCE_IRQHandler               ; CAN1 SCE                                               
DCD     EXTI9_5_IRQHandler                ; External Line[9:5]s                                    
DCD     TIM1_BRK_TIM9_IRQHandler          ; TIM1 Break and TIM9                   
DCD     TIM1_UP_TIM10_IRQHandler          ; TIM1 Update and TIM10                 
DCD     TIM1_TRG_COM_TIM11_IRQHandler     ; TIM1 Trigger and Commutation and TIM11
DCD     TIM1_CC_IRQHandler                ; TIM1 Capture Compare                                   
DCD     TIM2_IRQHandler                   ; TIM2                                            
DCD     TIM3_IRQHandler                   ; TIM3                                            
DCD     TIM4_IRQHandler                   ; TIM4                                            
DCD     I2C1_EV_IRQHandler                ; I2C1 Event                                             
DCD     I2C1_ER_IRQHandler                ; I2C1 Error                                             
DCD     I2C2_EV_IRQHandler                ; I2C2 Event                                             
DCD     I2C2_ER_IRQHandler                ; I2C2 Error                                               
DCD     SPI1_IRQHandler                   ; SPI1                                            
DCD     SPI2_IRQHandler                   ; SPI2                                            
DCD     USART1_IRQHandler                 ; USART1                                          
DCD     USART2_IRQHandler                 ; USART2                                          
DCD     USART3_IRQHandler                 ; USART3                                          
DCD     EXTI15_10_IRQHandler              ; External Line[15:10]s                                  
DCD     RTC_Alarm_IRQHandler              ; RTC Alarm (A and B) through EXTI Line                  
DCD     OTG_FS_WKUP_IRQHandler            ; USB OTG FS Wakeup through EXTI line                        
DCD     TIM8_BRK_TIM12_IRQHandler         ; TIM8 Break and TIM12                  
DCD     TIM8_UP_TIM13_IRQHandler          ; TIM8 Update and TIM13                 
DCD     TIM8_TRG_COM_TIM14_IRQHandler     ; TIM8 Trigger and Commutation and TIM14
DCD     TIM8_CC_IRQHandler                ; TIM8 Capture Compare                                   
DCD     DMA1_Stream7_IRQHandler           ; DMA1 Stream7                                           
DCD     FSMC_IRQHandler                   ; FSMC                                            
DCD     SDIO_IRQHandler                   ; SDIO                                            
DCD     TIM5_IRQHandler                   ; TIM5                                            
DCD     SPI3_IRQHandler                   ; SPI3                                            
DCD     UART4_IRQHandler                  ; UART4                                           
DCD     UART5_IRQHandler                  ; UART5                                           
DCD     TIM6_DAC_IRQHandler               ; TIM6 and DAC1&2 underrun errors                   
DCD     TIM7_IRQHandler                   ; TIM7                   
DCD     DMA2_Stream0_IRQHandler           ; DMA2 Stream 0                                   
DCD     DMA2_Stream1_IRQHandler           ; DMA2 Stream 1                                   
DCD     DMA2_Stream2_IRQHandler           ; DMA2 Stream 2                                   
DCD     DMA2_Stream3_IRQHandler           ; DMA2 Stream 3                                   
DCD     DMA2_Stream4_IRQHandler           ; DMA2 Stream 4                                   
DCD     ETH_IRQHandler                    ; Ethernet                                        
DCD     ETH_WKUP_IRQHandler               ; Ethernet Wakeup through EXTI line                      
DCD     CAN2_TX_IRQHandler                ; CAN2 TX                                                
DCD     CAN2_RX0_IRQHandler               ; CAN2 RX0                                               
DCD     CAN2_RX1_IRQHandler               ; CAN2 RX1                                               
DCD     CAN2_SCE_IRQHandler               ; CAN2 SCE                                               
DCD     OTG_FS_IRQHandler                 ; USB OTG FS                                      
DCD     DMA2_Stream5_IRQHandler           ; DMA2 Stream 5                                   
DCD     DMA2_Stream6_IRQHandler           ; DMA2 Stream 6                                   
DCD     DMA2_Stream7_IRQHandler           ; DMA2 Stream 7                                   
DCD     USART6_IRQHandler                 ; USART6                                           
DCD     I2C3_EV_IRQHandler                ; I2C3 event                                             
DCD     I2C3_ER_IRQHandler                ; I2C3 error                                             
DCD     OTG_HS_EP1_OUT_IRQHandler         ; USB OTG HS End Point 1 Out                      
DCD     OTG_HS_EP1_IN_IRQHandler          ; USB OTG HS End Point 1 In                       
DCD     OTG_HS_WKUP_IRQHandler            ; USB OTG HS Wakeup through EXTI                         
DCD     OTG_HS_IRQHandler                 ; USB OTG HS                                      
DCD     DCMI_IRQHandler                   ; DCMI                                            
DCD     CRYP_IRQHandler                   ; CRYP crypto                                     
DCD     HASH_RNG_IRQHandler               ; Hash and Rng
DCD     FPU_IRQHandler                    ; FPU
### STM32中断向量表定义与使用 #### 中断向量表的位置和结构 在STM32微控制器中,中断向量表是一个非常重要的组成部分。该表格位于闪存或SRAM的起始位置,并由一系列指针组成,这些指针指向各个异常处理程序和服务例程[^1]。 对于大多数应用而言,开发者不需要手动调整这个表的内容;然而,在某些特殊情况下(比如实现动态重映射),则可能涉及到对它的修改操作[^3]。 #### 如何查看预设的中断向量表 文件`stm32f10x.s`内包含了预先设定好的多个中断响应函数原型——即所谓的“弱”定义版本。当用户创建自己的ISR时,则会覆盖掉默认设置。此文件中的标签`__Vectors`标志着实际物理地址处所存储的数据序列起点,也就是整个系统的入口点所在之处[^2]。 ```assembly .section .isr_vector,"a",%progbits .align 2 __Vectors: LDR PC, Reset_Handler /* ...其他条目... */ ``` 这段汇编代码片段展示了如何在一个典型的启动文件里指定并填充向量表项。注意这里采用的是ARM架构特有的LDR指令来加载PC寄存器值从而跳转到相应的处理器状态恢复过程之中去执行后续任务。 #### 动态更改中断向量表的方法 尽管不常见,但在特定应用场景下确实允许改变当前使用的中断向量表。这通常涉及调用库函数如NVIC_SetVector()来进行具体变更动作。不过需要注意的是,任何此类改动都应当谨慎行事以免引起系统不稳定甚至崩溃等问题发生。 为了确保安全性和可靠性,建议仅限于那些真正必要的场合才考虑实施这种高级特性。同时也要充分测试新配置下的行为表现以验证预期效果是否达成。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值