• ARM GIC 和NVIC的区别


    ARM GIC(Generic Interrupt Controller)和NVIC(Nested Vectored Interrupt Controller)是两种不同的中断控制器,它们在ARM架构中扮演着重要的角色,但各自有不同的设计和应用场景。

    ARM GIC

    1. GIC是ARM架构中的一部分,用于处理来自多个源的中断请求,并将其分发到多个处理器核心。
    2. GIC设计用于多核处理器系统,能够支持多个中断源和多个处理器核心之间的中断管理。
    3. GIC分为不同的版本,如GICv1(已弃用)、GICv2、GICv3和GICv4,每个版本都支持不同的中断处理特性和系统规模。
    4. GICv3引入了属性层次(affinity hierarchies),以支持更多的核心,并且增加了redistributor组件和LPI(Locality-Partitioned Interrupts)来处理消息中断。
    5. GIC通常集成在系统级芯片(SoC)中,与CPU核心紧密集成,提供高效的中断处理。

    NVIC

    1. NVIC是Cortex-M系列微控制器中的中断控制器,专为单核或简单的多核系统设计。
    2. NVIC提供了中断优先级设置,支持抢占式和子优先级,允许中断嵌套。
    3. NVIC通常与Cortex-M内核紧密集成,提供快速的中断响应和处理。
    4. NVIC支持有限数量的中断源,适合中低端的微控制器应用,而不是为大型多核系统设计的。
    5. NVIC的设计相对简单,易于在微控制器中实现,通常用于嵌入式系统和简单的控制应用。

    GIC和NVIC的主要区别在于它们的设计目的、应用场景和支持的系统规模。GIC适用于需要处理大量中断和多核处理器的复杂系统,而NVIC则适用于中断源较少、对中断处理要求不是特别高的单核或简单多核微控制器系统。

  • 相关阅读:
    第四章 特定功能单元 第八节 其他不重要内容 (SpringMVC)
    虚拟化之内存(Memory)
    关于我对axios的源码理解
    MySQL 安装详细步骤
    c语言入门---文件操作
    JavaScript的基本知识点解析
    vue3+ts+element-plus实际开发之统一掉用弹窗封装
    线段树
    Linux 简单命令
    视频转二维码简单技巧,适用多种视频格式
  • 原文地址:https://blog.csdn.net/ygyglg/article/details/139280675