zoukankan      html  css  js  c++  java
  • ARM NVIC控制器(基于cortex-M4)【转】

    转自:https://www.cnblogs.com/wangyanwen/p/11448535.html

    中断控制寄存器映射

    中断寄存器的基地址为0xE000E000,所有中断控制/状态寄存器都只能在特权级下访问(除软件触发中断寄存器外),寄存器映射列表见表3-2。也可以参考cortex-m4使用手册,并推荐使用CMSIS函数来访问相关功能。

    表3-2  中断寄存器映射

    偏移量

    名称

    位宽

    类型

    复位值

    描述

    0x100-0x11C

    ISER0-ISER7

    32

    R/W

    0x00000000

    中断使能寄存器,寄存器0为(IRQ0~IRQ31),以此类推

    0x180-0x19C

    ICER0-ICER7

    32

    R/W

    0x00000000

    中断清除使能寄存器,寄存器0为(IRQ0~IRQ31),以此类推

    0x200-0x21C

    ISPR0-ISPR7

    32

    R/W

    0x00000000

    中断挂起寄存器,寄存器0为(IRQ0~IRQ31),以此类推

    0x280-0x29C

    ICPR0-ICPR7

    32

    R/W

    0x00000000

    中断挂起清除寄存器寄存器0为(IRQ0~IRQ31),以此类推

    0x300-0x31C

    IABR0-IABR7

    32

    RO

    0x00000000

    中断活动状态寄存器寄存器0为(IRQ0~IRQ31),以此类推

    0x400-0x4EF

    IPR0-IPR59

    32

    R/W

    0x00000000

    中断优先级寄存器0寄存器0为(IRQ0~IRQ3),以此类推

    0xD08

    VTOR

    32

    R/W

    0x00000000

    向量表偏移寄存器

    0xD0C

    AIRCR

    32

    R/W

    0x00000000

    应用中断控制寄存器

     

    上表中将同类寄存器放在同一行描述,每个寄存器按4字节偏移增加,用户可自行计算出所需的寄存器地址偏移量。例如:要获取IPR2的地址,则在IPR0的基地址偏移量上增加8个字节,偏移量为0x400 + 0x8 = 0x408,则其实际地址为0xE000E408,其余寄存器偏移量计算以此类推。

    中断使能寄存器(ISER)

    偏移量:0x100

    复位值:0x00000000

     

    位域

    名称

    复位值

    类型

    描述

    31:0

    SETENA

    0x00000000

    R/W

    中断使能控制:

    1:使能中断

    0:不影响

    中断清除使能寄存器(ICER)

    偏移量:0x180

    复位值:0x00000000

     

    位域

    名称

    复位值

    类型

    描述

    31:0

    CLRENA

    0x00000000

    R/W

    中断清除使能控制:

    1:禁止中断

    0:不影响

    中断挂起寄存器(ISPR)

    偏移量:0x200

    复位值:0x00000000

     

    位域

    名称

    复位值

    类型

    描述

    31:0

    SETPEND

    0x00000000

    R/W

    中断挂起控制:

    1:中断挂起

    0:中断未挂起

    中断挂起清除寄存器(ICPR)

    偏移量:0x280

    复位值:0x00000000

     

    位域

    名称

    复位值

    类型

    描述

    31:0

    CLRPEND

    0x00000000

    R/W

    中断挂起清除控制:

    1:清除挂起中断

    0:不清除挂起中断

    中断活动状态寄存器(IABR)

    偏移量:0x300

    复位值:0x00000000

     

    位域

    名称

    复位值

    类型

    描述

    31:0

    ACTIVE

    0x00000000

    RO

    中断挂起清除控制:

    1:ISR执行中或者被抢占或者压栈

    0:ISR未执行或者压栈

    中断优先级寄存器(IPR)

    偏移量:0x400~0x41C

    复位值:0x00000000

     

    位域

    名称

    复位值

    类型

    描述

    7:0

    PRI_n

    0x00

    R/W

    中断n的优先级控制,受AIRCR影响。

    向量表偏移寄存器(VTOR)

    偏移量:0xD08

    复位值:0x00000000

     

    位域

    名称

    复位值

    类型

    描述

    31:30

    Reserved

    0x0

    R/W

    保留

    29

    TBLBASE

    0

    R/W

    向量表映射域:

    0:Code

    1:RAM

    28:7

    TBLOFF

    0x000000

    R/W

    向量表偏移地址

    6:0

    Reserved

    0x00

    R/W

    保留

    应用中断控制寄存器(AIRCR)

    偏移量:0xD0C

    复位值:0x00000000

     

    位域

    名称

    复位值

    类型

    描述

    31:16

    VECTKEY

    0x0000

    R/W

    寄存器配置解锁控制。写该寄存器时,该段位域须为0x05FA,否则写操作被忽略。

    读该寄存器时,该段位域值为0xFA05

    15:2

    Reserved

    0x0000

    R/W

    保留

    1

    VECTCLR

    0

    R/W

    清除正在执行的中断:

    1:清除所有中断信息,包括NMI和fault

    0:不清除

    0

    VECTRESET

    0

    R/W

    系统复位位,复位整个系统(除调试系统):

    1:复位系统

    0:不复位系统

    在调试时,当core被挂起(halted)时才能写该位

    ------脱命散人[记]
  • 相关阅读:
    Mac下ssh连接远程服务器时自动断开问题
    解决php中json_decode的异常JSON_ERROR_CTRL_CHAR (json_last_error = 3)
    如何写.gitignore只包含指定的文件扩展名
    python操作mysql数据库
    php数组函数
    Python中字符串切片操作
    Python实现字符串反转的几种方法
    每个Android开发者都应该了解的资源列表
    Android Studio 入门指南
    一个优秀的Android应用从建项目开始
  • 原文地址:https://www.cnblogs.com/sky-heaven/p/12458468.html
Copyright © 2011-2022 走看看