当前位置: 首页 > news >正文

ARM系列 -- 虚拟化(四)

今天来看看虚拟中断。

在一个非虚拟化的系统中,操作系统可以直接访问GIC的寄存器,并且处理GIC的物理中断接口(physical interrupt interface)。

但是在一个虚拟化的系统中,不是这样。Guest OS并不知道它运行在虚拟系统中,其接收的中断来自GIC的虚拟中断接口(virtual interrupt interface),但是OS本身并不知道;实际上是hypervisor接管了GIC的寄存器访问和物理中断接口,且hypervisor要负责产生虚拟中断给Guest OS。

还有另外一种方式产生虚拟中断,就是通过配置HCR_EL2,由内部CPU核产生。在HCR_EL2里面有三个bit用来产生虚拟中断:

  • VI:设置该bit产生一个vIRQ
  • VF:设置该bit产生一个vFIQ
  • VSE:设置该bit产生一个vSerror

设置这些bit位就相当于中断控制器向vCPU发送中断信号。生成的虚拟中断受PSTATE掩蔽的影响,就像常规中断一样。这种机制使用起来很简单,但缺点是hypervisor需要模拟中断控制器的操作。换言之,软件中的trap和emulate操作的开销比较大,影响性能。

通过GIC就能避免上面的问题。GIC的物理CPU接口和虚拟CPU接口是等同的,区别只是一个发送物理中断信号,另一个发送虚拟中断信号。

来看一个例子:

  • 外部中断到达GIC;
  • GIC产生一个物理IRQ给CPU;
  • CPU转换到EL2,hypervisor通过物理CPU接口读取中断;
  • Hypervisor写GIC的List寄存器产生虚拟中断;
  • GIC通过vIRQ发送中断给CPU;
  • CPU从EL2返回到EL1或者EL0;
  • Guest OS读取中断,CPU执行中断处理程序。

在GICv4中,增加了对虚拟机直接注入虚拟中断的支持。支持GICv4的IP是GIC-700.目前的虚拟中断直接注入支持产生LPI,也就是说系统中要有ITS组件。

  • Hypervisor会事先通过ITS命令配置ITS,重新映射虚拟core和物理core,虚拟中断和物理中断。
  • 当ITS接到消息中断后,先要查表得到虚拟的INTID和虚拟PE,然后发给相应的redistributor。
  • Redistributor会去检查内部的寄存器,查看vPE是否在自己这边注册过。
  • 如果注册过,发虚拟中断给vPE;
  • 如果没有,发中断给hypervisor。

GIC-700也支持软件通过将vPE和SGI-INTID写入GITS_SGIR寄存器的方式来直接注入SGI。对于PPI和SPI的直接注入,目前尚不支持。

作者:老秦谈芯

相关文章:

ARM系列 -- 虚拟化(四)

今天来看看虚拟中断。 在一个非虚拟化的系统中,操作系统可以直接访问GIC的寄存器,并且处理GIC的物理中断接口(physical interrupt interface)。 但是在一个虚拟化的系统中,不是这样。Guest OS并不知道它运行在虚拟系…...

QT GUI编程常用控件学习

1 GUI编程应该学什么 2 QT常用模块结构 QtCore: 包含了核心的非GUI的功能。主要和时间、文件与文件夹、各种数据、流、URLs、mime类文件、进程与线程一起使用 QtGui: 包含了窗口系统、事件处理、2D图像、基本绘画、字体和文字类 QtWidgets: 包含了一些列创建桌面应用的UI元素…...

【Python从入门到进阶】49、当当网Scrapy项目实战(二)

接上篇《48、当当网Scrapy项目实战(一)》 上一篇我们正式开启了一个Scrapy爬虫项目的实战,对当当网进行剖析和抓取。本篇我们继续编写该当当网的项目,讲解刚刚编写的Spider与item之间的关系,以及如何使用item&#xff…...

flutter build ipa 打包比 xcode archive 打出的ipa包大

为什么 flutter build ipa 打包比 xcode archive 打出的ipa包大? 如果你用Flutter构建的.ipa文件比通过Xcode Archive构建的.ipa文件要大,这可能是因为Flutter构建了一个包含了多平台的二进制文件的通用包。这意味着在Flutter构建的.ipa中包含了所有的C…...

B端系统:巧妙地容错和防错设置,减少用户操作错误

Hi,大家好,我是大美B端工场,从事8年前端开发的老司机。很多B端系统体验不好,让用户非常茫然或者容易出错,大大降低了操作体验,本文着重分析B端系统的容错机制该如何设计,欢迎老铁们关注、评论、…...

BIO实战、NIO编程与直接内存、零拷贝深入辨析

BIO实战、NIO编程与直接内存、零拷贝深入辨析 长连接、短连接 长连接 socket连接后不管是否使用都会保持连接状态多用于操作频繁,点对点的通讯,避免频繁socket创建造成资源浪费,比如TCP 短连接 socket连接后发送完数据后就断开早期的http服…...

PDF文件转换为图片

现在确实有很多线上的工具可以把pdf文件转为图片,比如smallpdf等等,都很好用。但我们有时会碰到一些敏感数据,或者要批量去转,那么需要自己写脚本来实现,以下脚本可以提供这个功能~ def pdf2img(pdf_dir, result_path…...

【Java程序设计】【C00317】基于Springboot的智慧社区居家养老健康管理系统(有论文)

基于Springboot的智慧社区居家养老健康管理系统(有论文) 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的智慧社区居家养老健康管理系统设计与实现,本系统有管理员、社区工作人员、医生以及家属四种角色权限 管…...

Vue3前端实现一个本地消息队列(MQ), 让消息延迟消费或者做缓存

MQ功能实现的具体代码(TsMQ.ts): import { v4 as uuidx } from uuid;import emitter from /utils/mitt// 消息类 class Message {// 过期时间,0表示马上就消费exp: number;// 消费标识,避免重复消费tag : string;// 消息体body : any;constr…...

普中51单片机学习(8*8LED点阵)

8*8LED点阵 实验代码 #include "reg52.h" #include "intrins.h"typedef unsigned int u16; typedef unsigned char u8; u8 lednum0x80;sbit SHCPP3^6; sbit SERP3^4; sbit STCPP3^5;void HC595SENDBYTE(u8 dat) {u8 a;SHCP1;STCP1;for(a0;a<8;a){SERd…...

Python 实现Excel自动化办公(上)

在Python 中你要针对某个对象进行操作&#xff0c;是需要安装与其对应的第三方库的&#xff0c;这里对于Excel 也不例外&#xff0c;它也有对应的第三方库&#xff0c;即xlrd 库。 什么是xlrd库 Python 操作Excel 主要用到xlrd和xlwt这两个库&#xff0c;即xlrd是读Excel &am…...

DayDreamInGIS 之 ArcGIS Pro二次开发 图层属性中换行符等特殊字符替换

具体参考ArcMap中类似的问题&#xff0c;本帖开发一个ArcGISPro版的工具 1.基础库部分 插件开发&#xff0c;经常需要处理图层与界面的交互。基础库把常用的交互部分做了封装&#xff0c;方便之后的重复使用。 &#xff08;1&#xff09;下述类定义了数据存储结构&#xff0…...

RK3568平台 RTC时间框架

一.RTC时间框架概述 RTC&#xff08;Real Time Clock&#xff09;是一种用于计时的模块&#xff0c;可以是再soc内部&#xff0c;也可以是外部模块。对于soc内部的RTC&#xff0c;只需要读取寄存器即可&#xff0c;对于外部模块的RTC&#xff0c;一般需要使用到I2C接口进行读取…...

番外篇 | YOLOv5+DeepSort实现行人目标跟踪检测

前言:Hello大家好,我是小哥谈。DeepSort是一种用于目标跟踪的深度学习算法。它结合了目标检测和目标跟踪的技术,能够在视频中准确地跟踪多个目标,并为每个目标分配一个唯一的ID。DeepSort的核心思想是将目标检测和目标跟踪两个任务进行联合训练,以提高跟踪的准确性和稳定性…...

认识Sass

sass中文文档&#xff1a; Sass: Sass 文档 1. sass的安装步骤 1. 卸载冲突的Node.js (1) winR输入control,找到电脑上的卸载软件&#xff0c;找到Node.js&#xff0c;右键”卸载” (2) winR输入cmd,输入命令:node -v查看结果。 如果提示: node 不…...

YOLOv9-Openvino和ONNXRuntime推理【CPU】

1 环境&#xff1a; CPU&#xff1a;i5-12500 Python&#xff1a;3.8.18 2 安装Openvino和ONNXRuntime 2.1 Openvino简介 Openvino是由Intel开发的专门用于优化和部署人工智能推理的半开源的工具包&#xff0c;主要用于对深度推理做优化。 Openvino内部集成了Opencv、Tens…...

AIGC 架构:RAG (retrieval augumented generation) 应用可以使用 PostgreSQL 作为向量数据库组件吗?

是的&#xff0c;RAG&#xff08;检索增强生成&#xff09;应用程序可以绝对地使用 PostgreSQL 作为向量数据库&#xff01;事实上&#xff0c;它是一个流行的选择&#xff0c;因为有以下几个优点&#xff1a; 使用 PostgreSQL 和 pgvector 的优点&#xff1a; 集成解决方案&…...

leetcode:134.加油站

解题思路&#xff1a;需要注意开始时的编号&#xff0c;有的可以走一圈&#xff0c;有的走不了 模拟过程&#xff1a;for循环主要是用来模拟线性的过程&#xff0c;而在这里它是环状的&#xff1b; 可以用暴力解法&#xff0c;但是在这里我用贪心来解决。 常见疑惑&#xff1…...

uniapp的微信小程序授权头像昵称(最新版)

前面我出过两期博客关于小程序授权登录,利用php实现一个简单的小程序授权登录并存储授权用户信息到数据库的完整流程。无奈&#xff0c;小程序官方又整幺蛾子了。wx.getUserInfo接口收回&#xff0c;wx.getUserProfile接口也不让用。导致我的个人小程序&#xff1a;梦缘 的授权…...

Spring Boot到底是如何进行自动配置的?

【1】从 spring.factories 配置文件中加载 EnableAutoConfiguration 自动配置类&#xff09;,获取的自动配 置类如图所示。 【2】若 EnableAutoConfiguration 等注解标有要 exclude 的自动配置类&#xff0c;那么再将这个自动配置类 排除掉&#xff1b; 【3】排除掉要 exclude …...

【Spring Boot 4.0 Agent-Ready 架构终极指南】:20年架构师亲授生产级字节码增强实战秘技

第一章&#xff1a;Spring Boot 4.0 Agent-Ready 架构全景认知Spring Boot 4.0 首次将 JVM Agent 集成能力深度融入核心启动生命周期&#xff0c;标志着可观测性、安全增强与运行时治理从“可选插件”跃迁为“原生契约”。Agent-Ready 并非仅指支持 Java Agent 加载&#xff0c…...

用EasyX图形库给你的C语言课设加满分:从贪吃蛇到飞机大战的实战思路

用EasyX图形库为C语言课设注入视觉活力&#xff1a;从数据可视化到小游戏开发 每到期末&#xff0c;计算机专业的同学们总会面临一个共同的挑战&#xff1a;如何让C语言课设脱颖而出&#xff1f;当大多数同学还在使用控制台菜单交互时&#xff0c;掌握EasyX图形库就能让你的项目…...

快速体验CAM++:上传两段语音,秒级判断是否同一说话人

快速体验CAM&#xff1a;上传两段语音&#xff0c;秒级判断是否同一说话人 1. 引言&#xff1a;从“听声辨人”到一键验证 你有没有想过&#xff0c;只凭一段语音&#xff0c;就能在茫茫人海中确认一个人的身份&#xff1f;这听起来像是科幻电影里的情节&#xff0c;但今天&a…...

【紧急通告】C# 14原生AOT已成Dify企业版合同SLA新增条款!未启用AOT部署的客户将于2025 Q3起暂停远程模型热更新支持——立即获取迁移检查表与ROI测算器

第一章&#xff1a;C# 14原生AOT部署Dify客户端的企业级战略定位在AI工程化落地加速的背景下&#xff0c;企业对轻量、安全、可审计的LLM客户端提出更高要求。C# 14引入的原生AOT&#xff08;Ahead-of-Time&#xff09;编译能力&#xff0c;使Dify客户端可脱离.NET运行时独立部…...

C语言结构体完全指南:从基础到底层内存布局

引言在C语言中&#xff0c;数组让我们能够存储一组相同类型的数据。但现实世界中的实体往往包含不同类型的信息——比如一个学生有姓名&#xff08;字符串&#xff09;、年龄&#xff08;整数&#xff09;、学号&#xff08;长整数&#xff09;、成绩&#xff08;浮点数&#x…...

SketchUp动态组件实战:用onClick函数制作一个能自动开关的门(附完整公式)

SketchUp动态组件实战&#xff1a;用onClick函数制作自动开关门 在建筑可视化与室内设计领域&#xff0c;交互式组件能显著提升方案展示的专业度与趣味性。想象一下&#xff0c;当客户点击你模型中的门扇时&#xff0c;它能像真实物体一样旋转开合——这种动态演示效果远比静态…...

中兴光猫工厂模式解锁:zteOnu工具完整指南

中兴光猫工厂模式解锁&#xff1a;zteOnu工具完整指南 【免费下载链接】zteOnu A tool that can open ZTE onu device factory mode 项目地址: https://gitcode.com/gh_mirrors/zt/zteOnu 中兴光猫工厂模式解锁利器zteOnu是一款专为网络管理员和技术爱好者设计的开源工具…...

大数据开发中常见的排序算法

大数据处理中&#xff0c;排序算法需兼顾效率与可扩展性。 主流方案包括&#xff1a; 1)Timsort作为混合排序算法&#xff0c;适应Spark等分布式场景&#xff1b; 2)外部排序通过分片归并解决内存限制&#xff1b; 3)基数排序适合固定长度数据&#xff1b; 4)BitonicSort专为并…...

SAP 清账凭证 底层完整生成逻辑(无冗余、纯原理 + 分录规则 + 边界场景)

SAP 清账凭证 底层完整生成逻辑&#xff08;无冗余、纯原理 分录规则 边界场景&#xff09;一、基础前置定义&#xff08;决定能不能生成清账凭证&#xff09;仅勾选【未清项管理】 的总账科目才可执行清账&#xff1a;应收账款、应付账款、GR/IR 暂估、其他往来、暂估科目等…...

从冷战到海湾战争:聊聊‘长曲棍球’雷达卫星如何用合成孔径雷达(SAR)穿透云层和烟雾

透视战场的“天眼”&#xff1a;合成孔径雷达如何突破气象屏障重塑军事侦察 1988年12月2日&#xff0c;美国佛罗里达州肯尼迪航天中心的发射架上&#xff0c;亚特兰蒂斯号航天飞机搭载着一个特殊载荷升空——这个代号“长曲棍球”的绝密项目&#xff0c;标志着合成孔径雷达(SAR…...