Cortex-M4外设

关于Cortex-M4外设

专用外设总线(PPB)的地址映射为:

软件可以读取MPU类型寄存器0xE000ED90,以测试是否存在内存保护单元(MPU)。

  • Privileged:只有特权软件才能访问寄存器。
  • Unprivileged:非特权软件和特权软件都可以访问寄存器

嵌套向量中断控制器

本节描述NVIC及其使用的寄存器。NVIC支持:

  • 实现定义的中断数,范围为1~240个中断。
  • 每个中断的可编程优先级为0~255.较高的级别对应较低的优先级值,因此级别0是最高的中断优先级。
  • 电平和脉冲检测中断信号。
  • 中断的动态重优先级。
  • 将优先级值分组为组优先级和子优先级。
  • 中断尾链。
  • 外部不可屏蔽中断(NMI)。
  • 可选WIC,提供超低功耗睡眠模式支持。

处理器在异常入口时自动堆叠其状态,在异常出口时自动解除堆叠,没有指令开销。这提供了低延迟异常处理。NVIC寄存器的硬件实现如下:

使用CMSIS访问Cortex-M4 NVIC寄存器

CMSIS功能使不同的Cortex-M配置文件处理器之间的软件可移植性。

要在使用CMSIS时访问NVIC寄存器,请使用以下函数:

c 复制代码
/* 使能中断或异常 */
void NVIC_EnbaleIRQ(IRQn_Type IRQn);

/* 将中断或异常的挂起状态设置为1 */
void NVIC_SetPendingIRQ(IRQn_Type IRQn);

/* 读取中断或异常的挂起状态。如果挂起状态设置为1,则此函数返回非零值 */
uint32_t NVIC_GetPengdingIRQ(IRQn_Type IRQn);

void NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority);

中断设置-使能寄存器

NVIC_ISER0~NVIC_ISER7寄存器使能中断,并显示哪些中断是使能的。

位赋值为:

31:0\]:中断设置使能位。 写:0=没影响;1=中断使能; 读:0=中断失能;1=中断使能。 如果一个挂起的中断被启用,NVIC会根据它的优先级激活这个中断。 如果中断未启用,断言其中断信号将中断状态更改为挂起,但NVIC永远不会激活中断,无论其优先级如何。

相关推荐
SundayBear6 小时前
零基础入门MQTT协议
c语言·单片机
嗯嗯=6 小时前
STM32单片机学习篇9
stm32·单片机·学习
小范馆11 小时前
ESP各模组的引脚图-小智接线图
stm32
松涛和鸣11 小时前
DAY63 IMX6ULL ADC Driver Development
linux·运维·arm开发·单片机·嵌入式硬件·ubuntu
想放学的刺客14 小时前
单片机嵌入式试题(第23期)嵌入式系统电源管理策略设计、嵌入式系统通信协议栈实现要点两个全新主题。
c语言·stm32·单片机·嵌入式硬件·物联网
猫猫的小茶馆14 小时前
【Linux 驱动开发】五. 设备树
linux·arm开发·驱动开发·stm32·嵌入式硬件·mcu·硬件工程
YouEmbedded15 小时前
解码内部集成电路(IIC)与OLED屏
stm32·0.96寸oled·硬件iic·软件模拟iic·图片取模·汉字取模
jghhh0116 小时前
基于上海钜泉科技HT7017单相计量芯片的参考例程实现
科技·单片机·嵌入式硬件
恶魔泡泡糖16 小时前
51单片机外部中断
c语言·单片机·嵌入式硬件·51单片机
意法半导体STM3216 小时前
【官方原创】如何基于DevelopPackage开启安全启动(MP15x) LAT6036
javascript·stm32·单片机·嵌入式硬件·mcu·安全·stm32开发