ARM Architecture Overview

来源:http://www.cnblogs.com/archiexie/archive/2016/12/07/6126643.html
-Advertisement-
Play Games

ARM(Advanced RISC Machine)採用的是RISC精簡指令集,Load/Store架構,所有指令必須載入到寄存器才能進行運算。7種工作模式。31個通用寄存器,6個狀態寄存器。大小端可配置。 ...


ARM(Advanced RISC Machine)採用的是RISC精簡指令集,Load/Store架構,所有指令必須載入到寄存器才能進行運算。7種工作模式。31個通用寄存器,6個狀態寄存器。大小端可配置。


Processor Architecture = Instruction Set + Programmer’s model

ARM_Architecture_Overview.png

ARM Architecture profiles

ARM_Architecture_profiles.png


Programmer’s Model

Data Sizes and Instruction Sets

ARM_Data_Size_and_Instruction_Sets.png

Processor Modes

ARM_processor_mode.png

The ARM Register Set

ARM_register.png

Program Status Registers

program_status_reg.png

Data alignment

Data_align.png

Exception Handling

Exception_Handling


Instruction Sets

ARM Instruction Set

arm Instruction set

Thumb Instruction Set

Thumb Instruction set

Thumb-2 Instruction Set

Thumb-2 Instruction set

Thumb 2 Performance / Density
Thumb-2 Performance / Density


ARM926EJ-S Processor

arm926ejs

ARM Cortex-M3 Processor

cotex-m3


ARM NAMING CONVENTIONS

ARM processors have had a relatively consistent naming convention since their start, but thenaming convention can be a little confusing. You must understand the difference between aprocessor and an architecture.

An architecture is a design.
A processor is a device.

An architecture has several processors, all of them using the same basic features, but each processorhas a slightly different configuration.

How to Tell What Processor You Are Dealing With

Classic ARMcores have the name ARM{x}{labels}, with later variants adopting a name of the form ARM{x}{y}{z}{labels}. Since 2004, all ARM cores have been released under the Cortex brand and have names inthe form Cortex-{x}{y}.
The first cores, known as classic processors, use the naming conventions listed in Table 1-1. The firstnumber (x) corresponds to the core version. The second and third numbers (y and z) correspond tothe cache/MMU/MPU information and cache size, respectively.
TABLE 1-1: ARM Processor Numbering
ARM Processor Numbering

The letters after a processor name are called the label and indicate what optional extensions areavailable on the processor, as shown in Table 1-2.
TABLE 1-2: ARM Label Attributes
ARM Label Attributes

For newer cores, known as Cortex, the naming convention is different, and easier to follow. Thereare three Cortex families: Cortex-A, Cortex-R, and Cortex-M.

Which architecture is my processor?

processor -- architecture


References

1. ARM Architecture Overview
2. Professional-Embedded-ARM-Development


Copyright (C) 2016 archiexie@cnblogs. All Rights Reserved.



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

-Advertisement-
Play Games
更多相關文章
  • Linux設備驅動中必須解決的一個問題是多個進程對共用資源的併發訪問,併發的訪問會導致競態。中斷屏蔽、原子操作、自旋鎖和信號量都是解決併發問題的機制。中斷屏蔽很少單獨被使用,原子操作只能針對整數進行,因此自旋鎖和信號量應用最為廣泛。自旋鎖會導致死迴圈,鎖定期間不允許阻塞,因此要求鎖定的臨界區小。信號... ...
  • CentOS 6.5 x86_64系統下安裝Apache-2.4.10,並且根據生產環境需要做了一定的安全配置。 ...
  • 設備驅動充當了硬體和應用軟體之間的紐帶,它使得應用軟體只需要調用系統軟體的應用編程介面(API)就可讓硬體去完成要求的工作。本文主要講解了Linux設備驅動與硬體的關係,Linux設備驅動的開發模式以及內核中相關的重要基礎數據結構。 ...
  • CentOS 6.5 x86_64系統下安裝Nginx-1.6.2,並且根據生產環境需要做了一定的安全配置。 ...
  • MII(media-independent interface)提供了MAC(media access control)與PHY(Ethernet physical layer)之間的互聯技術,該介面支持10Mb/s與100Mb/s的數據傳輸速率,數據傳輸的位寬為4位。MDIO(Management... ...
  • SDRAM(Synchronous Dynamic Random Access Memory,同步動態隨機存儲器)也就是通常所說的記憶體。同步是指其時鐘頻率與CPU前端匯流排的系統時鐘頻率相同;動態是指存儲陣列需要不斷的刷新來保證數據不丟失;隨機是指數據不是線性依次存儲的。 ...
  • CentOS 6.5 x86_64系統下安裝MySQL-5.6.10,並且根據生產環境需要做了一定的安全配置。 ...
  • ARM彙編語言(Assembly Language)是ARM CPU所能接受的最底層唯一語言(所有的高級語言最終都要轉換成彙編語言然後彙編成processor instruction codes)。ARM彙編的核心是ARM指令集。理解ARM彙編有助於理解底層processor內部的工作原理,有助於對... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...