在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

剖析Armv8-A的AArch64寄存器

jf_78858299 ? 來源:老秦談芯 ? 作者: 老秦談芯 ? 2023-01-30 16:45 ? 次閱讀

今天來簡單研究一下Armv8-A的AArch64寄存器

根據指令使用數據的方式, 指令系統可分為堆棧型、累加器型和寄存器型。寄存器型又可以進一步分為寄存器-寄存器型和寄存器-存儲器型。

  • 堆棧型。堆棧型指令又稱零地址指令, 其操作數都在棧頂, 在運算指令中不需要指定操作數, 默認對棧頂數據進行運算并將結果壓回棧頂。
  • 累加器型。累加器型指令又稱單地址指令, 包含一個隱含操作數——累加器, 另一個操作數在指令中指定, 結果寫回累加器中。
  • 寄存器-存儲器型。在這種類型的指令系統中, 每個操作數都由指令顯式指定, 操作數為寄存器和內存單元。
  • 寄存器-寄存器型。在這種類型的指令系統中, 每個操作數也由指令顯式指定, 但除了訪存指令外的其他指令的操作數都只能是寄存器。

寄存器-寄存器型指令系統中,運算指令的操作數只能來自寄存器, 不能來自存儲器, 所有的訪存都必須顯式的通過load和store指令來完成, 所以寄存器-寄存器型又被稱為load-store型。使用寄存器的優勢在于, 寄存器的訪問速度快, 便于編譯器的調度優化, 并可以充分利用局部性原理, 大量的操作可以在寄存器中完成。此外, 寄存器-寄存器型的另一個優勢是寄存器之間的相關性容易判斷, 容易實現流水線、多發射和亂序執行等方法。當今的指令系統主要是寄存器-寄存器型。(以上內容摘自《計算機體系結構基礎》)

說了這么多,就是想強調一下在Armv8-A中寄存器的重要性。

在AArch64應用級角度,一個PE(Process Element)具有下列寄存器:

31個通用寄存器, R0 - R30,其中64-bit的寄存器命名為X0 – X30,而32位的寄存器命名為W0 -W30。

零寄存器XZR(64-bit)和WZR(32-bit)。

一個64-bit的堆棧指針(Stack Pointer)寄存器,堆棧指針的最低有效32位可以使用寄存器WSP訪問。

一個64-bit的程序計數器(Program Counter),用于保存當前指令地址。軟件無法直接寫入PC。

32個SIMD(Single Instruction Multiple Data)&FP(Float Point)寄存器,V0 – V31。其中,128-bit的寄存器命名為Q0 -Q31;64-bit的命名為D0 – D31;32-bit的命名為S0 – S31;16-bit的命名為H0 -H31;8-bit的命名為B0 – B31。

一個64-bit的SIMD&FP控制寄存器FPCR。

一個64-bit的SIMD&FP狀態寄存器FPSR。

三十二個可擴展向量寄存器(Scalable Vector registers),Z0 – Z31,寄存器寬度取決于具體實現,在128-1024 bit之間。

十六個可擴展斷言寄存器(Scalable Predicate registers),P0 - P15。

一個專用SVE第一故障寄存器FFR(First Fault Register)。

一個處理器狀態寄存器PSTATE,它是處理器狀態信息的集合,包括條件標記寄存器NZCV,異常屏蔽寄存器DAIF,SP選擇寄存器SPSEL、異常等級寄存器CurrentEL等。下圖是PSTATE的字段定義。

在AArch64下,PSTATE字段使用以下專用(Special-Purpose)寄存器訪問,通過MRS指令直接讀取,通過MSR指令直接寫入。

NZCV寄存器比較簡單,如下圖。N是負數條件標志位,如果最后一個標志設置指令的結果為負,則N=1;Z是0條件標志位,如果最后一個標志設置指令的結果為零,則Z=1,否則Z=0;C是進位條件標志位,如果最后一個標志設置指令導致進位情況發生,則C=1;V是溢出條件標志位,如果最后一個標志設置指令導致溢出情況發生,則V=1。其它位是保留位。

D是處理器狀態調試屏蔽位;A是系統錯誤(SError)中斷屏蔽位;I是IRQ屏蔽位;F是FIQ屏蔽位。其它位是保留位。

CurrentEL是當前異常等級寄存器,

SPSel(Stack Pointer Select)是堆棧指針選擇寄存器,如下圖,只有一個有效位。0b0表示在所有異常級別使用SP_EL0;0b1表示在異常級別ELx使用SP_ELx。

PAN(Privileged Access Never)是特權訪問禁止寄存器。0b0表示特權讀寫不被此機制禁用;0b1表示禁用對EL0級別可訪問地址的特權讀寫訪問。

UAO(User Access Override)是用戶訪問覆蓋寄存器。

DIT(Data Independent Timing)是數據獨立時序寄存器。0b0表示該架構沒有說明任何指令的時序屬性。

SSBS是Speculative Store Bypass Safe(翻譯不出來了)。0b0表示不允許硬件進行推測性load/store。

TCO(Tag Check Override)是標記檢查覆蓋寄存器。改為表示是否允許全局禁用內存標記檢查。0b0表示load/store不受影響;0b1表示load/store不被檢查。

ALLINT(All Interrupt Mask Bit)是全部中斷屏蔽寄存器。

AArch64的專用寄存器除了上述,還有很多其它的。

此外,AArch64中還有大量的系統寄存器(System Registers)。系統寄存器為執行控制、狀態和一般系統配置提供支持。大多數系統寄存器在EL0異常等級時不可訪問。然而,一些系統寄存器可以配置為允許執行在EL0等級的軟件進行訪問。可以從EL0訪問的寄存器包括:

  • Cache ID registers
  • Debug registers
  • Performance Monitors registers
  • Activity Monitors registers
  • Thread ID registers
  • Timer registers

前面講GIC的時候提到過,ARM把一些中斷相關的寄存器從GIC中剝離出來,放到了CPU interface中。在GICv2時,這些寄存器可以設計成系統寄存器,也可以設計成尋址訪問的寄存器,但是到了GICv3,要求這些寄存器必須是系統寄存器。

對于系統寄存器的訪問,也是通過MSR和MRS指令。

本次介紹的寄存器只是AArch64中全部寄存器的冰山一角,實際的寄存器遠遠多于今天提到的這些。ARM專門提供了一篇描述Armv8-A寄存器的文檔,有四千多頁。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 存儲器
    +關注

    關注

    38

    文章

    7525

    瀏覽量

    164162
  • 數據
    +關注

    關注

    8

    文章

    7128

    瀏覽量

    89365
  • 累加器
    +關注

    關注

    0

    文章

    50

    瀏覽量

    9475
收藏 人收藏

    評論

    相關推薦

    ARMv8-A AArch32主要特性

    Cortex-A32產品介紹ARMv8-A AArch32主要特性ARMv7-M與AArch32的不同之處軟件從
    發表于 02-19 06:20

    ARMv8架構資料分享

    (異常級別為 EL0 - EL3)  · ARMv8 寄存器組(和先前完全不同的 64寄存器)  · A64 指令集(新的
    發表于 03-21 14:50

    ARMv8aarch64aarch32是怎樣進行切換的

    ARMv8中,aarch64aarch32是通過異常進行切換的。而A32和T32是通過bx指令進行切換的。如下圖:以下A64
    發表于 04-01 15:09

    一文讀懂ARM AArch64 state的寄存器

    AArch64 state的寄存器寄存器分為一般寄存器和特殊寄存器,另外一些寄存器在特權執行模式
    發表于 05-09 09:37

    請問Armv8-A到底是什么東西呢

    兼容,在Armv8-A中實際應用較少,后面內容基本都是介紹AArch64的相關內容。AArch64中擴展了一些寄存器,包括以下:31個通用的64
    發表于 08-22 15:39

    簡單研究一下Armv8-AAArch64寄存器

    的指令系統主要是寄存器-寄存器型。說了這么多,就是想強調一下在Armv8-A寄存器的重要性。在AArch64應用級角度,一個PE(Proc
    發表于 09-20 14:54

    AArch64異常模型指南

    AArch64異常模型指南介紹了Armv8-A中的異常和特權模型Armv9-A。它涵蓋了Arm體系結構中不同類型的異常,以及處理與異常的關系。 這些內容面向底層代碼的開發人員,例如引
    發表于 08-02 06:03

    AArch64外部調試詳解

    Armv8-A體系結構支持自托管調試和外部調試。本指南提供了外部調試的概述,并描述了 體系結構支持。該指南解釋了外部調試功能,以及啟用這些功能的步驟功能。 當調試托管在處理元素(PE)上時,將使
    發表于 08-02 06:37

    ARM通用中斷控制體系結構規范GIC體系結構版本3和版本4

    本手冊中的體系結構描述使用了與Armv8體系結構相同的術語。有關該術語的更多信息,請參閱Armv8-A架構配置文件Armv8 Arm?架構參考手冊A部分的介紹。此外,在適當的情況下使用
    發表于 08-11 07:45

    ARM Cortex-A系列ARMv8-A程序員指南

    ARMv8-A是針對應用配置文件的最新一代ARM架構。 在本書中,名稱ARMv8用于描述整個體系結構,它現在包括32位執行狀態和64位執行狀態。 ARMv8引入了使用
    發表于 08-22 07:22

    ARM公司64ARMv8-A技術授權新里程

    2014年9月4日——ARM近日宣布完成第50份64ARMv8-A的技術授權協議。隨著業界在更廣泛應用中對于更高性能計算實現的需求提升,截至目前,共有27家企業取得了ARMv8-A技術授權。
    發表于 09-04 16:46 ?2114次閱讀

    ARM64與ARM32 的Linux程序區別在哪里

    arm64或ARM64。我在示例中使用了AArch64寄存器,但我所描述的許多問題也發生在ARMv8-A 32位執行狀態。
    的頭像 發表于 08-09 09:51 ?2.7w次閱讀
    ARM<b class='flag-5'>64</b>與ARM32 的Linux程序區別在哪里

    AArch64寄存器介紹

    作為 RISC 架構,AArch64 提供了大量的通用寄存器。除通用寄存器之外,本節還會介紹特殊寄存器、系統控制寄存器、處理
    的頭像 發表于 08-24 09:57 ?6228次閱讀

    Armv8架構及虛擬化介紹

    ARMv8基本概念 (1)執行狀態(execution state):處理運行時的環境,包括寄存器的位寬、支持的指令集、異常模型、內存管理及編程模型等。ARMv8體系結構定義了
    的頭像 發表于 04-16 10:45 ?6593次閱讀

    最新的Linux aarch64 LSA驅動程序

    電子發燒友網站提供《最新的Linux aarch64 LSA驅動程序.zip》資料免費下載
    發表于 08-23 15:46 ?2次下載
    最新的Linux <b class='flag-5'>aarch64</b> LSA驅動程序
    主站蜘蛛池模板: 精品黄色录像| 国产五月婷婷| 四虎影音在线观看| 天堂视频免费| 色拍拍拍| 免费的三级网站| 韩国理论三级在线观看视频| www婷婷| 天天爽天天干天天操| 久久免| 激情综合色五月丁香六月亚洲| 亚洲一区二区三区网站| 综合色亚洲| 色综合天天综合给合国产| 欧美色国| 国产精品主播在线| 午夜视频在线免费播放| 国产亚洲高清视频| 亚洲视频第一页| 五月婷久久| 免费人成网555www| 97影院理论午夜论不卡| 免费又爽又黄1000禁片| 国产女人小便视频| 在线亚洲成人| 欧美一级一一特黄| 成年人黄色片视频| 欧美午夜精品久久久久久黑人| 欧美成人区| 亚洲人成人网毛片在线播放| 欧美a性| 午夜精品久久久| 欧美系列在线| 亚洲人成综合网站在线| 美女黄页网站免费进入| 午夜在线观看免费观看大全| www.午夜剧场| 一级中文字幕乱码免费| 免费四影虎ww4hu10| 午夜免费福利在线观看| 男人午夜视频在线观看|