嵌入式 Linux C ARM ARMv8-AC语言&嵌入式

1. Fundamentals of ARMv8-A

2019-02-02  本文已影响1人  Loyen

在ARMv8-A中,程序在4个Exception Level中的某一个Level执行。在64-bit的执行状态中,Exception Level决定了执行时的特权级别,这个特权级别与ARMv7-A中定义的特权级别类似。

Exception Level是ARMv8-A体系结构中的基础概念。所有的操作都在一个特定的Exception Level中执行,并且一个寄存器能存在多个Exception Level中。在一个Exception Level中改变寄存器中的值,在另一个Exception Level会产生影响。

Exception Level为软件的执行特权提供了逻辑隔离,这个适用于ARMv8-A体系结构中的所有操作状态。系统软件决定Exception Level,从而也就决定了软件执行的特权级别。Exception Level有点类似于计算机科学中的分层保护域的概念。

4个Exception Level如下:

通常来说,应用程序,操作系统内核,或者Hypervisor,分别占用一个Exception Level。内核Hypervisor是一个例外,比如KVM,它同时运行在EL2和EL1中。

ARMv8-A中还提供了两个安全状态,分别用Secure和Non-Secure来指代。一般Non-secure通常指Normal world,Non-Secure并不是指存在安全漏洞,而是指正常的操作。操作系统运行在Normal world中,与之对应的是trusted OS运行在Secure world中。ARM的TrustZone技术可以将系统划分成Normal world和Secure world。这个可以在遇到软件攻击或硬件攻击时提供保护。Secure Monitor可以在Normal world和Secure world之间移动时充当通道的作用。在ARMv8-A体系架构中,Secure Monitor运行在一个比其他软件都要高的Exception Level中。下图将很好的描述这个关系:


ARMv8-A提供了虚拟化的硬件支持。在Normal world中,虚拟化可以使多个操作系统能并存在同一个系统中,这意味着Hypervisor或者Virtual Machine Manager(VMM)可以在系统上运行,并承载多个客户机操作系统。

Normal world有以下组成部分:

Secure world有以下组成部分:

上一篇 下一篇

猜你喜欢

热点阅读