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永远不会激活中断,无论其优先级如何。

相关推荐
ting_zh1 小时前
定时器输出PWM信号同步控制传感器开关与 ADC 采样
stm32·tim·pwm·adc
比奇堡派星星2 小时前
MCU 裸机时间片调度系统
单片机·嵌入式硬件
安科瑞刘鸿鹏173 小时前
工业自动化系统中抗晃电保护的协同控制研究
运维·网络·嵌入式硬件·物联网
深圳市方中禾科技5 小时前
LED驱动芯片FZH02,应用开发相关数据技术手册
单片机·嵌入式硬件·led
第二层皮-合肥5 小时前
光耦瞬态响应特性:上升时间与下降时间的测试方法与误差分析
嵌入式硬件
yuanmenghao5 小时前
CAN系列 — (6) CAN FD 带宽、CPU、中断:工程上是如何一起算的?
网络·驱动开发·单片机·mcu·自动驾驶·信息与通信
锻炼²8 小时前
USB 设备/配置/接口/端点/描述符 和 HID类请求详解
stm32·usb·hid·全速传输·sof包·中断传输
Arciab8 小时前
51单片机_蜂鸣器
单片机·嵌入式硬件·51单片机
SmartRadio8 小时前
在CH585M代码中如何精细化配置PMU(电源管理单元)和RAM保留
linux·c语言·开发语言·人工智能·单片机·嵌入式硬件·lora
qq_411262429 小时前
纯图像传感器(只出像素),还是 Himax WiseEye/WE1/WE-I Plus 这类带处理器、能在端侧跑模型并输出“metadata”的模块
人工智能·嵌入式硬件·esp32·四博智联