- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在阅读this document来自 TrustZone 上的 ARM,有些事情我不清楚。
事实上,Hypervisor 提供了一种特殊的 CPU 模式,并且对于 TrustZone,处理器附带了一个额外的第 33 位:模式不也是一个特定的位设置吗?那么,额外的一点是如何在安全性方面产生如此大的差异的呢?我确实知道额外的位可以为两个单独的 32 位地址空间让路,但除此之外,我无法将两个和两个放在一起。有人可以清楚地解释为什么 TrustZone 比虚拟机管理程序更安全吗?
最佳答案
典型的管理程序仅限于CPU。它不能防止其他 DMA 主设备。请参阅维基百科 DMA Attack网页了解更多相关信息。其他攻击,例如Cold boot ,需要其他机制如zeroizable memory以防止剥削。也就是说,TrustZone 不是一个全部安全解决方案,而是其中的一个重要部分。由于ARM只是一个CPU,因此控制其他BUS Master的机制未指定。除了DMA Master之外,备用CPU也对内存分区构成威胁。为了解决这个问题,一些辅助 CPU 可以识别 TrustZone。即,他们总是使用 NS 位(33rd 位)来标记交易。
相比之下,虚拟机管理程序很少局限于两个世界。 管理程序托管任意数量的操作系统。 TrustZone 只有两个世界;安全且正常。尽管每个世界可以有一个控制监督者操作系统,具有许多独立的线程、任务或进程 在操作系统允许的情况下。
DMA 攻击解释:与硬件位相比,管理程序通常使用 CPU MMU 来限制软件访问。这不会阻止替代总线主控器访问内存。如果管理程序受限软件可以控制单独的总线主设备,那么它们就可以获取要保护的内存。 DMA 使用物理地址并绕过 MMU 和一般虚拟机管理程序保护。
DMA 攻击通过使用 CPU 外部的东西访问内存来规避 CPU 保护。通过TrustZone,保护不在 CPU 中,而是在总线 Controller 中。请参阅:NIC301举个例子 ARM TrustZone CPU 仅允许 CPU 支持四种模式; 安全主管、安全用户、普通主管和普通用户。普通的 ARM CPU 仅支持用户和管理程序分离,并且管理程序的所有托管操作系统都在用户模式下运行;通常,所有 DMA 外设都以管理程序特权运行,并且该值通常硬编码在 SOC 中。
<小时/>更新:原始问题不包括 IOMMU。
Hypervisor + IOMMU 可以完成一些针对 DMA 攻击的防护。然而,这意味着在“世界切换”上,IOMMU 表必须更新。这将防止针对该外设的 DMA 攻击。每个需要这种保护的外设都需要 IOMMU。
在某些情况下,“正常世界”设备可能会访问安全设备以执行“安全操作”。例如,请求在不访问 key 的情况下解密数据。
管理程序 + IOMMU 并不等同于信任区域。 Trustzone 受总线矩阵保护,包括所有外设和主设备。大师可以处于任一世界状态;即,在多CPU系统上,一个可以正常,另一个可以安全。意义计算可以在两者上进行。 HV+IOMMU方案相当于抢占式多任务。当系统进入该模式时,必须切换 IOMMU。
同样,TZ 的弱点是仅支持两个“世界”。 HV+IOMMU 可以支持多个“ guest ”。
关于security - TrustZone 与虚拟机管理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17485367/
我一直在尝试弄清VMware是如何工作的(特别是在安装Linux时),我有两个问题: 当VMware遇到push cs这样的命令时会发生什么?特别是cs,因为其特权级别为0,而VMware以1特权级别
我正在尝试将 vim 配置为我的主要编码程序。我已经想出了如何编译单个文件,但是当我从 vim 中执行程序时,我不断收到 127 错误代码。我的盒子上有 a 别名为 ./a.out,但是当我从 vim
我正在尝试将 vim 配置为我的主要编码程序。我已经想出了如何编译单个文件,但是当我从 vim 中执行程序时,我不断收到 127 错误代码。我的盒子上有 a 别名为 ./a.out,但是当我从 vim
想知道有没有什么javascript虚拟机是你用过的或者有什么想法的! 我不是在谈论用于 chrome 的 V8 等浏览器的 javascript 引擎,我想在 linux 服务器机器上执行 java
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。 10年前关闭。 Improve this qu
我正在查找 Azure 中存储帐户的用途。因为我有一个问题。 我的帐户仅限于 1 个存储帐户,显然我已经在使用它,但我不知道为什么,我认为我不需要它。 我有一台带有云服务和存储帐户的虚拟机。我想创建另
Error - JVM - BlackBerry 9800 Simulator --------------------------------------- JVM: could not open
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
这是我的情况 我需要配置linux系统,因为路由器和客户端也在虚拟机中.. 系统A eth0:从isp获取ip(在VM ware中配置为Bidge) eth1: DEVICE=eth1 BOOTPRO
我知道 BEA 正在开发不需要底层操作系统的 LiquidVM,但想知道开源社区中是否有人正在开发类似的东西。 理想情况下,我想找到一个实现,其中 VM 直接由操作系统引导加载程序加载。 最佳答案 与
Linux系统下安装Vmware教程 由于项目需要,要在Linux下虚拟一个Windows,经过查找些资料,发现可一用VMware来实现,当然还有其他一些虚拟机可以使用如Win4lin,bochs
我正在使用虚拟机进行开发,但是每次我需要一个新的 VM 时,我都会复制文件并创建一个新服务器,但是我需要一个新的服务器名称才能将其添加到我们的网络中。 重命名服务器后,Sharepoint 站点有很多
如果 Cassandra 和代码在同一台机器上,则以下代码有效: using System; using Cassandra; namespace CassandraInsertTest {
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 3年前关闭。 Improve this qu
我正在将我的 Web 应用程序 try catch 异常错误跟踪消息转储到 Web 服务器上的 C:\Temp 文件夹但是当我的 web 应用程序位于 azure 上时,我希望在 azure VM c
我们为客户提供桌面 ERP 软件。该软件安装在 Azure 虚拟机中。每个公司都有自己的数据库文件。我需要优化性能,但我有些怀疑无法找到回应。例如,对于 2 个公司: 1-购买 2 台小型 VM(2
我试图将 Azure 上的虚拟机的网络号地址更改为与 Azure 池上的另一个虚拟机位于同一网络中,一旦我单击网卡上的“保存”,它就会卡住并无法通过远程桌面或任何其他方式。 请帮忙。 最佳答案 切勿尝
是否可以在 Azure 上设置虚拟机并使该虚拟机的同一实例对多个用户可见? 我们是 ISV。我们的用户分散在全局。我们希望使用 Azure 虚拟机来指导用户设置我们的软件。理想情况下,我们的帮助台将在
我使用 Ubuntu 镜像创建了一个虚拟机,并从 Azure 库预加载了 Discourse。自动设置完成后,我可以看到虚拟机正在运行,但我无法连接到它以远程查看计算机。我没有看到任何设置可以为我解决
我是一名优秀的程序员,十分优秀!