arm gic 中断控制器工作原理概述

2023-11-30 12:58

本文主要是介绍arm gic 中断控制器工作原理概述,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

linux pinctrl 里面有个gpio抽象的中断控制器与系统的gic中断控制器级联cascade

阅读arm generic interrupter controller architecture specification,总结下

支持的中断类型

平常工作接触到的是ppi,sgi和spi,ppi和sgi是对某一个核的,spi是对所有核的,sgi一般是用来核间通信

gic 的hw 分为简单两部分distributor和cpu interface(实际上还有int service 和 redistributor),下图以是gic工作原理的简化图,distributor是只有一个,cpu interface 每个核有一个,每个核可以通过一个private bus去访问gic的寄存器

distributor 的功能包括(针对不同类型中断可能支持的功能不同,如下只描述spi):

.中断的优先级控制(group0  group1)

.中断的security 配置(secure  non-secure)

.中断的affinity配置(亲核性 )

.中断的level-edge sensitive

.对中断active或者pending(state machine)

cpu interface的功能包括:

.中断的ACK

.中断的priority drop

.中断在对应的security状态执行(secure  non-secure)

.中断的deavtive

gic state machine

一般的中断处理流程: 中断的初始状态是inactive,device assert 中断后状态变为pending如果这个时候priority security 条件都满足的话cpu interface会ack to this interrupter,中断的状态变为active,系统读取中断号然后执行中断,如果之后该device没有再assert中断的话,中断的状态就变为了inactive

device assert 中断对于level-edge sensitive(配置在distributor)的中断是不一样的,这次想翻看gic文档的目的是想知道level sensitive的中断gic会不会有device已经关掉中断,gic还记录着该中断是pending的状态,答案是不会

这篇关于arm gic 中断控制器工作原理概述的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/437112

相关文章

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Java Stream的distinct去重原理分析

《JavaStream的distinct去重原理分析》Javastream中的distinct方法用于去除流中的重复元素,它返回一个包含过滤后唯一元素的新流,该方法会根据元素的hashcode和eq... 目录一、distinct 的基础用法与核心特性二、distinct 的底层实现原理1. 顺序流中的去重

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手