【ARMv8/v9 GIC 系列 5 -- GIC GICD_CTRL 使用详细介绍】

文章目录

  • GICD_CTRL
    • GICD_CTLR 寄存器结构
      • RWP(Register Write Pending)
      • E1NWF(Enable 1 of N Wakeup Functionality)
      • DS(Disable Security)
    • 亲和性路由(Affinity Routing)
      • ARE_NS
      • ARE_S
    • 中断组使能
      • EnableGrp1S
      • EnableGrp1NS)
      • EnableGrp0

GICD_CTRL

GICv3(通用中断控制器版本3)是ARM架构下用于管理和处理中断的关键组件之一。它包含了多个寄存器,用于配置和控制中断的行为。其中,GICD_CTLR(Distributor Control Register)是一个非常重要的寄存器,它用于启用中断和亲和性路由设置。
在这里插入图片描述

下面是对GICD_CTLR寄存器中一些关键位的详细介绍:

GICD_CTLR 寄存器结构

GICD_CTLR的格式取决于访问的安全状态以及系统支持的安全状态数量,这由GICD_CTLR.DS指定。当访问为安全状态,在支持两种安全状态的系统中,其结构如下:

RWP(Register Write Pending)

仅读。指示是否有寄存器写入操作正在进行。

  • 0b0:没有寄存器写入操作正在进行。之前对受影响寄存器字段的写入操作的效果对GIC架构的所有逻辑组件(包括CPU接口)都是可见的。
  • 0b1:寄存器写入操作正在进行。之前对受影响寄存器字段的写入操作的效果不能保证对所有GIC架构的逻辑组件(包括CPU接口)都是可见的,因为更改的效果仍在传播中。

RWP字段跟踪以下内容的写操作:

  • GICD_CTLR[2:0](组启用位,仅限从10的转变)
  • GICD_CTLR[7:4]ARE位,E1NWF位和DS位)
  • GICD_ICENABLER<n>

E1NWF(Enable 1 of N Wakeup Functionality)

如果硬件实现该bit,它将有以下行为:

  • 0b0:处于睡眠状态的PE(处理元素)不能被选为 1 of N中断。
  • 0b1:处于睡眠状态的PE可以根据实现定义的控制被选为 1 of N中断。

DS(Disable Security)

禁用安全性。

  • 0b0:不允许非安全访问访问和修改控制组0中断的寄存器。
  • 0b1:允许非安全访问访问和修改控制组0中断的寄存器。


如果当GICD_CTLR.ARE_S == 1时将DS从0写为1,则对于单一安全状态的GICD_CTLR.ARE是RAO/WI。
如果分配器只支持单一安全状态,此位是RAO/WI。
如果分配器支持两种安全状态,此位是否可编程或实现为RAZ/WI是由实现定义的。设置此字段为1时,所有对GICD_CTLR的访问都访问单一安全状态视图,且所有位都是可访问的。

设置为1后,只能通过硬件重置清除此字段。

如果在以下任何情况为真时将此位从0写为1,则行为是不可预测的:

  • GICD_CTLR.ENABLEGRP0==1
  • GICD_CTLR.ENABLEGRP1S==1
  • GICD_CTLR.ENABLEGRP1NS==1
  • 一个或多个INTID处于激活或激活和挂起状态。

亲和性路由(Affinity Routing)

亲和性路由(Affinity Routing)允许中断被路由到特定的处理器上,从而提高系统的性能和效率。ARE_NSARE_S位分别控制非安全和安全状态下的亲和性路由功能。在修改这些设置之前,需要确保系统处于正确的状态,否则可能会导致不可预测的行为。

以下是对这两个位的详细介绍:

ARE_NS

  • 0b0:非安全状态下禁用亲和性路由。
  • 0b1:非安全状态下启用亲和性路由。

安全状态下的亲和性路由被启用时,这个字段是只读/写入忽略(RAO/WI)。从0变为1的ARE_NS设置变化是不可预测的,除非GICD_CTLR.ENABLEGRP1_NON-SECURE == 0。从1变为0的ARE_NS设置变化也是不可预测的。如果没有实现针对非安全状态的GICv2向后兼容性,那么这个字段是只读/写入忽略(RAO/WI)。

ARE_S

  • 0b0:安全状态下禁用亲和性路由。
  • 0b1:安全状态下启用亲和性路由。

从0变为1的ARE_S设置变化是不可预测的,除非全部满足以下条件:

  • GICD_CTLR.ENABLEGRP0 == 0
  • GICD_CTLR.ENABLEGRP1S == 0
  • GICD_CTLR.ENABLEGRP1NS == 0

从1变为0的ARE_S设置变化也是不可预测的。

中断组使能

GICD_CTLR(Distributor Control Register)寄存器中,有几个位专门用来控制不同安全状态下的中断组的使能状态。这些位包括EnableGrp1SEnableGrp1NSEnableGrp0,它们分别控制安全组1非安全组1组0中断的使能状态。

以下是这些控制位的详细介绍:

EnableGrp1S

Enable Secure Group 1 Interrupts

  • 0b0:安全组1中断被禁用。
  • 0b1:安全组1中断被启用。

这个位允许控制器启用或禁用安全组1的中断。
当设置为1时,安全组1中的中断可以被发送到处理器;
当设置为0时,这些中断被阻止。

EnableGrp1NS)

Enable Non-Secure Group 1 Interrupts

  • 0b0:非安全组1中断被禁用。
  • 0b1:非安全组1中断被启用。

这个位的功能与EnableGrp1S相似,但它专门控制非安全状态下的组1中断。启用这些中断允许非安全环境的中断传递给处理器。

EnableGrp0

Enable Group 0 Interrupts

  • 0b0:组0中断被禁用。
  • 0b1:组0中断被启用。

组0中断通常被用于处理安全相关的中断。通过设置这个位,可以控制这类中断是否能够被分发和处理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/40035.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【java计算机毕设】服装生产管理系统java MySQL springboot vue html maven项目设计源代码+万字文档

目录 1项目功能 2项目介绍 3项目地址 1项目功能 【java计算机毕设】服装生产管理系统java MySQL springboot vue html maven项目代码文档 2项目介绍 系统功能&#xff1a; 服装生产管理系统包括管理员、用户两种角色。 管理员功能包括个人中心模块用于修改个人信息和密码&a…

【UE5.3】笔记6-创建可自由控制Pawn类

搭建场景 搭建一个场景&#xff1a;包含地板、围墙。可以根据喜好加一些自发光的效果。 增加食物 创建食物蓝图类&#xff0c;在场景里放置一些食物以供我们player去吃掉获取分值。 创建可控制的layer 我们先右键创建一个蓝图继承自pawn类&#xff0c;起名BP_Player&#xf…

2024年在WordPress中创建销售活动的专家级优惠券方法

2024年在WordPress中创建销售活动的专家级优惠券方法 今天我想和大家分享一些关于如何在WordPress网站上使用专家级优惠券工具来创建销售活动的经验。对于已经在电商领域有一定经验的店主&#xff0c;利用专家级优惠券不仅能吸引顾客&#xff0c;还能显著增加销量。在这篇文章…

【Linux】线程封装与互斥(万字)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 文章目录 前言 C多线程的用法 对原生线程进行一次封装 理解pthread线程 Linux线程互斥 进程线程间的互斥相关背景概念 互斥量mutex 操作共享变量会有问题的售票…

[go-zero] goctl 生成api和rpc

文章目录 1.goctl 概述2.go-zero 需要安装的组件3.生成 api4.生成 rpc 1.goctl 概述 goctl支持多种rpc&#xff0c;较为流行的是google开源的grpc&#xff0c;这里主要介绍goctl rpc protoc的代码生成与使用。protoc是grpc的命令&#xff0c;作用是将proto buffer文件转化为相…

探讨命令模式及其应用

目录 命令模式命令模式结构命令模式适用场景命令模式优缺点练手题目题目描述输入描述输出描述题解 命令模式 命令模式是一种行为设计模式&#xff0c; 它可将请求转换为一个包含与请求相关的所有信息的独立对象。 该转换让你能根据不同的请求将方法参数化、 延迟请求执行或将其…

《亚马逊搬运亚马逊产品》配合跟卖采集爬取跟卖店铺高质量

亚马逊高质量产品如何搬运&#xff1f;亚马逊采集亚马逊。 哈喽大家好&#xff0c;大家讲一下做亚马逊是发货、铺货这块的功能。目前这款软件做跟卖大家都知道&#xff0c;同时也支持做铺货。铺货可以采集国内的1688、淘宝、京东都可以采&#xff0c;采完之后也可以采速卖通&a…

周周星分享7.3—基于气象大数据的自动站实况联合预测

赛题 2024中国高校计算机大赛 — 大数据挑战赛 经验分享 大家好&#xff0c;我是扫地僧团队的队长&#xff0c;以前参加这样打榜的比赛比较少&#xff0c;了解的打榜技巧不是太多&#xff0c;所以想从科研的角度给大家一点分享。 这次比赛主要从以下五个步骤进行&#xff1a…

Linux Doxygen快速生成文档

此前写过一篇编写Doxygen格式的注释以用于生成文档,点击以查阅, Doxygen常用语法与字段记录,但是当时用的windows桌面版的doxygen,最近使用ubuntu编写代码想直接使用doxygen生成,故写下此博客 Doxygen Doxygen是一个用于生成软件文档的工具&#xff0c;它可以从代码中提取注释…

Android高级面试_6_性能优化

Android 高级面试-7&#xff1a;网络相关的三方库和网络协议等 1、网络框架 问题&#xff1a;HttpUrlConnection, HttpClient, Volley 和 OkHttp 的区别&#xff1f; HttpUrlConnection 的基本使用方式如下&#xff1a; URL url new URL("http://www.baidu.com")…

SwanLinkOS首批实现与HarmonyOS NEXT互联互通,软通动力子公司鸿湖万联助力鸿蒙生态统一互联

在刚刚落下帷幕的华为开发者大会2024上&#xff0c;伴随全场景智能操作系统HarmonyOS Next的盛大发布&#xff0c;作为基于OpenHarmony的同根同源系统生态&#xff0c;软通动力子公司鸿湖万联全域智能操作系统SwanLinkOS首批实现与HarmonyOS NEXT互联互通&#xff0c;率先攻克基…

大模型与机器人精彩碰撞-7月5日晚上八点不见不散!

在瞬息万变的科技时代&#xff0c;新兴人工智能和机器人技术的结合正在引领新一轮的创新浪潮。你是否想成为未来科技的领航者&#xff1f;你是否想了解最前沿的AI与机器人技术&#xff1f;行麦科技重磅推出的“AIGC时代的生存法则”AI系列课&#xff0c;将为你揭开大模型与机器…

创建kset

1、kset介绍 2、相关结构体和api介绍 2.1 struct kset 2.2 kset_create_and_add kset_create_and_addkset_createkset_registerkobject_add_internalkobject_add_internal2.3 kset_unregister kset_unregisterkobject_delkobject_put3、实验操作 #include<linux/module.…

【leetcode64-69二分查找、70-74栈、75-77堆】

二分查找[64-69] 时间复杂度O(log n)&#xff0c;要想到二分排序 35.搜索插入位置 class Solution:def searchInsert(self, nums: List[int], target: int) -> int:left 0right len(nums)-1while left < right: #左闭右闭mid (leftright)//2if nums[mid] < target…

【算法训练记录——Day39】

Day39——动态规划Ⅱ 1.leetcode_62不同路径2.leetcode_63不同路径Ⅱ3.leetcode_343整数拆分4.leetcode_96不同的二叉树搜索 1.leetcode_62不同路径 思路&#xff1a;经典的动态规划问题&#xff1a; dp[i][j]表示到达&#xff08;i&#xff0c;j&#xff09;位置时的不同路径…

运维锅总浅析云原生DevOps工具

本文从Tekton与Kubevela、Jenkins、GitLab CI的区别与联系对常见的云原生DevOps工具进行对比分析&#xff0c;最后给出DevOps工具选型思路。希望对您有所帮助&#xff01; 一、DevOps简介 DevOps是一种结合了软件开发&#xff08;Development&#xff09;和IT运维&#xff08…

登录功能和校验

基础版 controller package com.web.management.controller;import com.web.management.pojo.Emp; import com.web.management.pojo.Result; import com.web.management.service.EmpService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.anno…

Ignis 应用: 社交 + 游戏 + 工业4.0,Ignis 构建Web3生态圈

引言 在数字经济快速发展的今天&#xff0c;Web3技术为我们带来了前所未有的变革。作为Ardor平台的主要子链&#xff0c;Ignis公链在推动Web3生态系统建设中扮演了重要角色。本文将通过介绍Vessel Chain、Mythical Beings和Bridge Champ等应用&#xff0c;探讨Ignis公链如何通…

html+css+js文章模板

图片 源代码在图片后面&#xff0c;点赞加关注&#xff0c;谢谢&#x1f604; 源代码 <!DOCTYPE html> <html lang"zh"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width,…

停车场车牌识别计费系统,用Python如何实现?

关注星标&#xff0c;每天学习Python新技能 前段时间练习过的一个小项目&#xff0c;今天再看看&#xff0c;记录一下~ 项目结构 说明&#xff1a; datefile文件夹&#xff1a;保存车辆信息表的xlsx文件 file文件夹&#xff1a;保存图片文件夹。ic_launcher.jpg是窗体的右上角…