ARMV8體繫結構簡介

来源:https://www.cnblogs.com/linhaostudy/archive/2019/04/02/10643443.html
-Advertisement-
Play Games

armv8 1.前言 本文的主要內容來源於ARMV8白皮書v5,對ARMV8做一個概述。包含如下的內容: 首先從背景談起,講述ARM的發展歷程; 之後介紹ARMV8體繫結構的基本特征; 介紹A64指令集 介紹異常級別 介紹記憶體管理單元 介紹編程寄存器 介紹DEBUG相關 ARMV8生態系統的演化 2 ...


armv8

1.前言

本文的主要內容來源於ARMV8白皮書v5,對ARMV8做一個概述。包含如下的內容:

  • 首先從背景談起,講述ARM的發展歷程;
  • 之後介紹ARMV8體繫結構的基本特征;
  • 介紹A64指令集
  • 介紹異常級別
  • 介紹記憶體管理單元
  • 介紹編程寄存器
  • 介紹DEBUG相關
  • ARMV8生態系統的演化

2. 背景

圖 ARMV7之前體繫結構與手機發展歷程

  • 從1995年,ARMV4(主要對應ARM7 family)開始到現在ARM RISC體繫結構到現在已經演化了20多年。從設計一開始ARM就關註到了低功耗
  • 到2011年,所有的ARM-Cotex family都被設計成使用ARMV7架構。

ARM7:採用ARMV4架構

ARM9:ARMV4的變體

ARM11:ARMV4的變體

Cotex-A8:為了匹配不同的市場,ARMV7從Cotex-A8開始被劃分為三種屬性:Application-Profile、RealTime-Profile、Microcontroller-Profile

Cotex-A9:引入了多核

Cotex-A5:引入低功耗、低成本的網路互聯

Cotex-A7:引入了出色的能效管理,可以延長手機的續航時間

Cotex-A15:引入了很多可選的擴展,如LPAE、虛擬化、

  • 為何要引入ARMV8?

(1)考慮到ARMV7被市場廣泛接受,以及形成的成熟的生態,因此後續的體繫結構升級需要做到向後相容;

(2)另外要讓廠商能夠願意將軟體系統遷移到新的體繫結構,新的體繫結構一定要有原體繫結構不具有的優勢

(3)為瞭解決舊有架構遺留的問題,提供一種更加清晰的架構,同時考慮到將來的發展趨勢,採用一種全新的架構來實現

3. ARMV8架構基本特性

image

  • ARMV8目前只定義了Application profile
  • ARMV8定義了48bit符號虛擬地址和達到48bit物理地址
  • ARMV8採用了新的指令集A64
  • ARMV8相容ARMV7的指令
  • A32和A64的轉換隻能發生在異常級別轉換時

4. A64指令集

  • A64下的每條指令被定義為固定32bit
  • A32和A64分別解碼,這樣可以簡化解碼表,單獨的解碼表可以允許更多更先進的分支預測技術
  • 通用目的寄存器增加到31個
  • A64刪除了LDM/STM指令,因為LDM/STM實現比較複雜
  • 更少的條件指令,因為實現複雜,並且沒有明顯的好處
  • 浮點單元硬體支持
  • SIMD支持,針對A64做了專門修訂,引入了雙精度浮點支持

5.異常級別

image

  • A32和A64之間的轉換有一個嚴格的規則集合
  • 異常級別增加,可以保持A32或升級到A64
  • A64引入了專門的寄存器ELR,用於記錄異常返回地址,在所有的異常入口會進行設置
  • 在異常入口,中斷mask會自動置位
  • 每個異常級別都有自己的向量基址寄存器,每個向量被按照類型區分:synchronous,IRQ,FIQ或Error
  • 關於異常的詳細細節在syndrome register

6. 記憶體管理單元

image

  • 支持48bit虛擬地址和物理地址,這樣可以簡化硬體,可以只支持到4級頁表;
  • 支持4K和64K頁
  • 提供了兩種基地址,分別是內核空間和用戶空間
  • 用戶空間虛擬地址到物理地址的轉換需要經過兩個階段,分別是VA->IPA,IPA->PA

7.程式寄存器

image

  • 30個通用寄存器(X0-X30),每個寄存器使64bits,其中X30是LR寄存器
  • 只有一個SP寄存器和ELR寄存器
  • SPSR
  • Pstate

8. DEBUG

  • 可以通過debugger調試器直接發送指令,處理器可以提取
  • 兩種類型的debug:self-host和halt mode debug

9.生態系統演變


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • vi編輯器是Linux和Unix上最基本的文本編輯器,工作在字元模式下。由於不需要圖形界面,vi是效率很高的文本編輯器。儘管在Linux上也有很多圖形界面的編輯器可用,但vi在系統和伺服器管理中的功能是那些圖形編輯器所無法比擬的。 ...
  • 今天,朋友買了一個新的聯想電腦,自帶出廠系統。進入PE後發現居然有聯想官方的OEM分區,於是直接拷貝過來,然後裝在另一個電腦里可以正常使用,這裡給大家分享一下。 工程下載: 鏈接:https://pan.baidu.com/s/1p2nM3n1ZuzZeBPGN2DcCaQ 提取碼:pbtw 1.下 ...
  • 安裝mysql 檢查安裝是否成功 登錄mysql 啟動關閉mysql 配置遠程連接 1. 檢查是否有防火牆限制 2. 檢查mysql是否有訪問許可權 3. 修改 /etc/mysql/mysql.conf.d/mysqld.cnf,註釋bind address 4. 開啟阿裡雲安全組埠策略,開放33 ...
  • 相對來講嵌入式相關的人群總體來說比較少,那麼有沒有一個聚集地呢? ...
  • 自己在Ubuntu下練習C程式時,用到了庫函數math.h,雖然在源程式中已添加頭文件“math.h”,但仍提示所用函數未定義,原本以為是程式出錯了,找了好久,這是怎麼回事呢?後來上網查了下,發現是Linux系統的原因,在Linux下,若要調用C中的math庫里的函數,必須在編譯時加上“-lm”,表 ...
  • PuTTY自帶的pscp非常好用。 使用方式和Linux中的scp命令很像,格式如下: pscp 文件 用戶名@LinuxIP:目錄 例如: pscp d:/a.iso [email protected]:/home/ 按提示輸入密碼即可。 ...
  • iDEA啟動後報Error:Abnormal build process terminatio 報錯的原因如下:Error:Abnormal build process termination: "C:\Program Files\Java\jdk1.8.0_121\bin\java" -Xmx70 ...
  • 瞭解IO多路復用,瞭解poll和select存在的問題,深入瞭解epoll如何高效,最後使用epoll實現一個聊天室鞏固學習 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...