0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

riscv中的plic中断处理与eclic详解

嵌入式IoT 来源:嵌入式IoT 作者:嵌入式IoT 2021-04-15 13:50 次阅读

浅析riscv中的plic与eclic

1.PLIC中断处理

2.sifive中断的编程模型

3.关于eclic

4.关于jalmnxti

1.PLIC中断处理

在RISC V体系架构中,对中断有着一些定义,下面来分析一下这种定义的实现策略。

2c6be102-9d0e-11eb-8b86-12bb97331649.png

在riscv中一共定义了三种状态中断,对于hart层面,hart包含local中断源和global中断源。而local中断只有Timer和Software中断两种,而global中断则称为external interrupts。只有global中断源可以被PLIC core响应,通常为I/O device。

一般来说,timer和software是通过CLINT(CORE LOCAL INTERRUPT),而外部中断通过PLIC处理。

2d5a77b8-9d0e-11eb-8b86-12bb97331649.png

可以看一下蜂鸟处理器的处理流程,另外sifive的E31的中断也有如下的处理。

2d6d55cc-9d0e-11eb-8b86-12bb97331649.png

2.sifive中断的编程模型

中断处理过程有如下的流程

首先mstatus的MIE域被拷贝到mstatus的MPIE,然后mstatus的MIE域被清除。此时全局中断disable。

程序当前的pc值被拷贝到mepc寄存器中,然后pc值会根据mtvec的值设置其值。如果向量中断被使能,pc值会变成mtvec.BASE+4xexception处的代码。

从mstatus.MPP中取出特权模式的状态

接下来就是处理中断具体的函数实现

将特权模式的状态设置到mstatus.MPP

将mstatus.MPIE的数据拷贝到mstatus.MIE中

从mepc中取值放到pc中

最后执行eret恢复到程序正常运行的状态。

对于CLINT来说,有Software Interrupt和Timer Interrupt,可以直接在寄存器中控制。

而PLIC实际上可以理解为arm的中断控制器,存在其map地址。

2d8017ca-9d0e-11eb-8b86-12bb97331649.png

由于PLIC的使用是针对外部中断的,所以可以单独设置每个中断。可以设置如下的值:

中断的优先级priotity

中断挂起位pending

中断使能enables

中断阈值priority Thresholds

由于PLIC的实现是独立于hart的IP设计,所以其设计和布局也不一定完全一致。

3.关于eclic

eclic的设计是芯来科技设计的一种中断处理方式。

2dbc5852-9d0e-11eb-8b86-12bb97331649.png

eclic目前也是众多芯来科技core采用的中断控制器,也包括gd32vf103系列的芯片

3号中断是内核TIMER单元生成的软件中断。

7号中断是内核TIMER单元生成的计时器中断。

而从19~4095中断号都是外部中断,其中断的编号与中断的优先级其实没有关系。

2dcb96f0-9d0e-11eb-8b86-12bb97331649.png

而对于ECLIC的寄存器布局,可见上图。

cliccfg是中断全局配置寄存器,可以结合clicintctl[i]配置

clicinfo也是全局寄存器中的数据,对于使用上来说,是只读的

mth中断的阈值级别寄存器

clicintip[i]是中断等待寄存器,也相当于pending寄存器

clicintie[i]为中断使能寄存器

clicintattr[i]为中断的属性,可以设置中断的上升沿触发或者下降沿触发,同时也可以设置中断从处理是向量中断还是非向量中断。

clicintctl[i] 设置中断优先级级别和优先级,需要配合cliccfg设置阈。

4.关于jalmnxti

这个也是eclic为了减少中断延时,加速中断咬尾的自定义指令。

该指令是配合eclic处理机制设计的,其指令功能比较多

开启中断使能,处理下一个中断

返回下一个中断入口地址

跳转至中断handler

中断处理后返回

由于csrrw ra, CSR_JALMNXTI, ra一条指令可以达到JAL(Jump and Link)的效果,同时硬件上更新Link寄存器作为该指令的PC作为函数调用的返回值,因此从中断服务程序返回后,又会重新回到csrrw ra, CSR_JALMNXTI, ra指令再次执行,可以重新判断是否有中断pending,如果有则跳转到中断处理函数,从而实现中断的咬尾处理,如果没有中断等待,则jalmnxti实际上并不会做任何事情。

原文标题:浅析riscv中的plic与eclic

文章出处:【微信公众号:嵌入式IoT】欢迎添加关注!文章转载请注明出处。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 模型
    +关注

    关注

    1

    文章

    2222

    浏览量

    47225
收藏 人收藏

    评论

    相关推荐

    51单片机中断详解

    中断理解51单片机中断详解(上)51单片机中断详解)51单片机中断详解(下)单片机 串口编程之串口通信仿真实验单片机学习(三)定时器篇
    发表于 11-22 06:08

    PLIC在写入complete寄存器后立马会触发下一次中断的原因?如何解决?

    PLIC在写入complete寄存器后立马会触发下一次中断的原因?如何解决?
    发表于 12-28 07:30

    PLIC管理的中断的优先级和RISC-V本身的机器定时器以及软中断中断优先级问题

    PLIC管理的外设中断的优先级和RISC-V本身的机器定时器以及软中断谁的优先级会更高? 机器定时器
    发表于 06-25 19:05

    内部中断的非向量处理模式详解

    中断号。
    发表于 08-16 07:58

    外部中断的非向量处理模式介绍

    exti_key_interrupt应用程序为例,简单讲解外部中断的非向量处理模式。 系统环境 Windows 10-64bit 软件平台
    发表于 08-16 07:40

    深度剖析gd32vf103的中断行为

    中断编程模型的理解 对于cortex-m3等
    发表于 08-16 08:06

    GD32VF103CBT6使用C++编译无法设置中断是为什么?如何解决?

    ECLIC_GetVector(USART2_IRQn); // 获取中断向量表中断函数的地址 printf(\"vector=%x\\r\\n
    发表于 08-17 06:31

    51单片机中断编程实例详解

    中断编程实例详解.pdf
    发表于 12-16 15:42 17次下载

    中断系统详解、外部中断

    中断系统的主要功能:处理随机突发事件中断系统结构:什么是中断系统:数据的输入/输出传送方式:中断传送方式特点:51系统允许的5个中断源:51单片机中断系统内部结构
    发表于 11-22 12:51 13次下载
    <b>中断</b>系统<b>详解</b>、外部<b>中断</b>

    STM32的Cortex-M3中断异常处理

    处理器中有43个可屏蔽中断通道(不包含 16个 Cortex?-M3的中断线)。共设置了16个可编程的优先等级(使用了 4位中断优先级);它的嵌套向量中断控制器(NVIC)和处理器核
    发表于 11-16 15:35 7225次阅读
    STM32的Cortex-M3<b>中断</b>异常<b>处理</b>

    STM32中断过程详解

    中断事件都是通过一个 TIME2 的中断通道向 STM32 内核提出中断申请,那么 STM32 如何处理和控制 TIME2 和它众多的、不同的、中断申请呢?
    发表于 06-01 09:48 1.8w次阅读

    opensbi下的riscv64裸机编程:中断与异常

    riscv64裸机编程2(中断与异常) 1.本文说明 2.riscv特权模式下的异常 2.1 CSPs 2.2 异常开关的寄存器 2.3 与中断相关的指令 3.中断测试 3.1
    的头像 发表于 01-07 10:30 2131次阅读

    riscvgd32vf103的中断行为分析

    riscv底层原理分析gd32vf103的中断行为 1.概述 2.中断向量表初始化 3.详细分析一下irq_entry 4.关于gd32vf103中断编程模型的理解 1.概述在
    的头像 发表于 04-15 13:55 3762次阅读
    <b>riscv</b><b>中</b>gd32vf103的<b>中断</b>行为分析

    处理异常和中断解决

    处理器转而执行一块与该事件相关的代码(异常处理)。事件可以是外部输入,也可以是内部产生的,外部产生的事件通常被称作
    的头像 发表于 10-12 17:14 3577次阅读

    STM32中断系统详解

    处理中断:在处理,CPU正在执行某一段代码时遇到内部或者外部的紧急事件需要处理,暂停当前执行的代码、转而去处理紧急事件,处理完毕后继续执行之前的代码。
    的头像 发表于 04-20 11:43 479次阅读
    STM32<b>中断</b>系统<b>详解</b>