4. NVIC中断向量配置—基于CT117E开发板的STM32库函数编程

在 MDK 内,与NVIC 相关的寄存器,MDK 为其定义了如下的结构体:typedef struct{vu32 ISER[2];u32 RESERVED0[30];vu32 ICER[2];u32 RSERVED1[30];vu32 ISPR[2];u32 RESERVED2[30];vu32 ICPR[2];u32 RESERVED3[30];vu32 IABR[2];u32 RESE
摘要由CSDN通过智能技术生成
在 MDK 内,与NVIC 相关的寄存器,MDK 为其定义了如下的结构体:
  
  
  
  1. typedef struct
  2. {
  3. vu32 ISER[2];
  4. u32 RESERVED0[30];
  5. vu32 ICER[2];
  6. u32 RSERVED1[30];
  7. vu32 ISPR[2];
  8. u32 RESERVED2[30];
  9. vu32 ICPR[2];
  10. u32 RESERVED3[30];
  11. vu32 IABR[2];
  12. u32 RESERVED4[62];
  13. vu32 IPR[15];
  14. } NVIC_TypeDef;
STM32 的中断在这些寄存器的控制下有序的执行的。只有了解这些中断寄存器,才能了解STM32 的中断。下面简要介绍这几个寄存器:
ISER[2]:ISER 全称是:Interrupt Set-Enable Registers,这是一个中断使能寄存器组。上面说了 STM32F103 的可屏蔽中断只有 60 个,这里用了 2 个 32 位的寄存器,总共可以表示 64 个中断。 而 STM32F103 只用了其中的前 60 位。 ISER[0]的 bit0~bit31 分别对应中断 0~31。 ISER[1]的 bit0~27 对应中断 32~59;这样总共 60 个中断就分别对应上了。你要使能某个中断,必须设置相应的 ISER 位为 1,使该中断被使能(这里仅仅是使能,还要配合中断分组、屏蔽、IO 口映射等设置才算是一个完整的中断设置)。具体每一位对应哪个中断,请参考 stm32f10x_nvic..h 里面的第 36 行处。
 
ICER[2]:全称是:Interrupt Clear-Enable Registers,是一个中断除能寄存器组。该寄存器组与 ISER 的作用恰好相反,是用来清除某个中断的使能的。其对应位的功能&#x
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值