第六篇 GD32VF103C START EXTI中断
[复制链接]
本帖最后由 常见泽1 于 2019-12-28 16:20 编辑
RISC-V: EXTI(中断/事件控制器)包括19个相互独立的边沿检测电路并且能够向处理器内核产生中断请求或唤醒事件。 EXTI有三种触发类型:上升沿触发、下降沿触发和任意沿触发。 EXTI中的每一个边沿检测电路都可以独立配置和屏蔽
STM32:EXTI(External interrupt/event controller)—外部中断/事件控制器,管理了控制器的 20个中断/事件线。每个中断/事件线都对应有一个边沿检测器,可以实现输入信号的上升沿检测和下降沿的检测。EXTI 可以实现对每个中断/事件线进行单独配置,可以单独配置为中断或者事件,以及触发事件的属性。
看一下RISC-V EXTI框图
Cortex EXTI图
上图就可以看出不一样了,STM32是通过NVIC有个,而RISC采用了ECLIC
RISC-V集成了改进型内核中断控制器(ECLIC)来实现高效的异常和中断处理。 ECLIC旨在为RISC-V系统提供低延迟、矢量化、 抢占式的中断。 当ECLIC被激活后, 它将包含并替换现有的RISC-V处理器局部中断控制器。 CLIC设计有一个基本设计,需要最少的硬件,但它支持额外的扩展来提供硬件加速。 ECLIC设计的目标是为各种软件ABI和中断模型提供支持, 而不需要复杂的硬件影响高性能处理器的实现。它与处理器核心紧密耦合。
RSIC-V
Cortex图
Cortex配置的步骤
通过下面的过程来配置20个线路做为中断源:
● 配置20个中断线的屏蔽位(EXTI_IMR)
● 配置所选中断线的触发选择位(EXTI_RTSR和EXTI_FTSR);
● 配置对应到外部中断控制器(EXTI)的NVIC中断通道的使能和屏蔽位,使得20个中断线中的请求可以被正确地响应
RISC-V 中断配置
Cortex 中断配置
下面就和RISC不一样了,RISC中断等级等等都在ECLIC,而CORTEX还得配置下NVIC
中断函数
RISC-V
Cortex-M3
这个没啥说的 基本都一样句柄
|