ARM 架构与技术综述

news2024/11/14 11:59:58

目录

认识 ARM

ARM 发展历史

指令集

ARM 公司产品分类

ARM 体系结构

数据类型约定

处理器的 32 位和 64 位含义

指令集

ARM 处理器的工作模式

CPU (内核) 组成

寄存器

时钟


认识 ARM

  • ARM 可以指:

    1. 一家公司。
    2. 一种技术。
    3. 一系列处理器。
  • 架构:ARM 架构包括:

    • arm-v4
    • arm-v5
    • arm-v6
    • arm-v7 (32 位)
    • arm-v8 (64 位)

    这些架构定义了处理器所支持的指令集。

  • 内核

    • Cortex-A 系列(例如 A9, A53, A73, A77)
    • ARM 将其内核授权给芯片制造商,后者在此基础上添加额外的功能和外设,从而制造出 SoC(片上系统)。
  • SoC (System On Chip)

    • 示例包括 S5P6818、Snapdragon 855(Qualcomm)、Kirin 990(Hisilicon)等。
  • S5P6818

    • S5P6818 是一个具体的 SoC 示例,但具体细节需要查阅资料来确认。

ARM 发展历史
  • 1978年:CPU 公司(Cambridge Processing Unit,剑桥处理单元)成立。
  • 1979年:Acorn Computer 成立,从事个人计算机组装业务。
  • 1985年:开发出 32 位、8 MHz 的 RISC 架构处理器,该芯片被称为 ARM(Acorn RISC Machine)。
  • 1990年
    • 苹果公司出资 150 万英镑,VLSI 技术公司出资 25 万英镑。
    • 12 名工程师加上技术专利共同创立 ARM 公司(Advanced RISC Machines)。
    • ARM 公司本身不直接生产芯片,而是授权其技术并提供解决方案。
  • 2016年:日本软银集团收购 ARM。
指令集
  • 精简指令集 (RISC):选择了一些较为简单且使用频率高的指令。
    • 指令宽度固定,多为单周期指令。
    • 例如,如果有一个加法运算器,则没有乘法运算器,计算 3 * 3 就需要通过 3 + 3 + 3 来实现。
  • 复杂指令集 (CISC):注重指令的功能性,指令周期和宽度不固定。

eg精简:可以编译后,用反汇编查看代码指令。

编译源代码

arm-linux-gnueabi-gcc 1.c -o a.out

检查文件属性:

file a.out

反汇编 ELF 文件:

arm-linux-gnueabi-objdump -D a.out > a.dis
ARM 公司产品分类
  • Cortex-A:针对高端的基于虚拟内存的操作系统和应用程序设计。
    • 高通、联发科、海思、三星、飞思卡尔等公司的产品。
  • Cortex-R:针对实时系统的高性能解决方案。
    • 例如汽车电子、照相机等。
  • Cortex-M:针对成本和功耗敏感的 MCU 和终端应用。
    • 通常不运行操作系统,或者运行 RTOS 如 FreeRTOS、μC/OS-II、LiteOS 等。
    • 意法半导体 (ST) 的 STM32 系列等。
ARM 体系结构
  • ARM-v8 (A):Cortex-A53 (8 核) → S5P6818 → 主频 1.4 GHz
数据类型约定
  • ARM-v7 架构:32 位处理器
    • char:8 位
    • halfword:16 位
    • word:32 位
    • doubleword:64 位 (Cortex-A)
  • ARM-v8 架构:64 位处理器
    • 向下兼容 32 位
    • char:8 位
    • halfword:16 位
    • word:32 位
    • doubleword:64 位 (Cortex-A)
    • quadword:128 位 (ARM-v8)

处理器的 32 位和 64 位含义
  • 32 位:一条指令可以处理 32 位的数据。
  • 64 位:一条指令可以处理 64 位的数据。
指令集
  • ARM-v7 架构
    • ARM 指令集 (32 位)
    • Thumb 指令集 (16 位)
  • ARM-v8 架构
    • 向下兼容 ARM-v7 架构
    • ARM 指令集:A64, A32
    • Thumb 指令集:T32, T16
    • 不论是 A64 还是 A32,每条指令都占用 32 位空间。
    • 不论是 T32 还是 T16,每条指令都占用 16 位空间。
ARM 处理器的工作模式
  • ARM7 至 ARM11 有七种基本工作模式:

    • User:非特权模式,大多数任务在此模式下执行。
    • FIQ:当发生高优先级中断时进入该模式。
    • IRQ:当发生低优先级中断时进入该模式。

FIQ和IRQ打断当前正在做的事去做其他的事情,做了再回来继续做自己的事情。鼠标键盘等都是这样实现的。(Linux内核会有中断,驱动写中断驱动代码)

    • Supervisor (SVC):当复位或软中断指令执行时进入该模式。

(任务的切换会切入这个模式,权限最高的模式,刚启动的时候在这个模式下,权限高,可以做一些核心的操作。进行系统调用的时候会切换这个模式。)

    • Abort:当指令存取异常时进入该模式。
    • Undef:当执行未定义指令时进入该模式。
    • System:具有与 User 模式相同寄存器集的特权模式。

保证不同任务每次调用同一个函数都是从头开始。

  • Cortex-A 系列特有的模式:

    • Monitor:为了安全性而扩展出来的用于执行安全监控代码的模式;也是一种特权模式。

特定的模式拥有特定的权限,执行特定的代码,完成特定的功能

CPU (内核) 组成
  • 运算器:执行加法等运算。
  • 控制器:控制指令执行流程。
  • 寄存器:存储机器码,由 ARM 公司集成到 CPU 内部。
    • A32:每个寄存器可以存储一个 32 位数据。
    • A64:每个寄存器可以存储一个 64 位数据。

寄存器
  • ARM7, ARM9, ARM11 有 37 个 32 位寄存器:

    • 1 个作为 PC (program counter)。
    • 1 个作为 CPSR (current program status register)。
    • 5 个作为 SPSR (saved program status registers)。
    • 30 个通用寄存器。
  • Cortex-A 系列 多出 3 个寄存器,共有 40 个 32 位寄存器:

    • Monitor 模式的 r13_mon, r14_mon, spsr_mon。
  • R0-R15, CPSR, SPSR:由 ARM 公司提供的寄存器,每个都是 32 位宽。

    • 这些寄存器没有物理地址,只有唯一的编号,通过编号可以访问相应的地址空间。
  • R13:栈指针寄存器 (stack pointer, sp):存放栈顶地址。

  • R14:链接寄存器 (link register, lr):函数调用时保存返回地址。

  • R15:程序计数寄存器 (program counter, pc):存放当前取指指令的地址。

  • CPSR:当前程序状态寄存器 (current program status register, cpsr):存储当前程序运行状态。

  • SPSR:保存程序状态的寄存器 (saved program status register, spsr):用于保存 CPSR。

时钟
  • 负责发出 CPU 开始计时的时钟信号。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1975110.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

定时任务框架 xxl-job

🍓 简介:java系列技术分享(👉持续更新中…🔥) 🍓 初衷:一起学习、一起进步、坚持不懈 🍓 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正🙏 🍓 希望这篇文章对你有所帮助,欢…

算法通关:015:最小栈

文章目录 题目思路主要代码问题总结有时候提交不了可能是方法名的问题 题目 leetcode152 思路 主要代码 同一个思路,法一是用栈实现,法二是用数组实现 /*** Author: ggdpzhk* CreateTime: 2024-08-03* 最小栈 155*/ import java.util.Stack;public…

fonttools - 操作字体

文章目录 一、关于 fonttools二、安装贡献测试可选依赖 三、如何制作新版本四、工具五、库 一、关于 fonttools fontTools是一个用于操作字体的库,用Python编写。这 项目包括TTX工具,可以转换TrueType和OpenType XML文本格式之间的字体,也称…

cesium加载wms与arcgis服务

1、加载geoserver的wms服务 2、加载arcgis服务

idea使用free流程,2024idea、2023idea都可以安装免费使用

1.先到官网下载,这里选择win系统的,点击下图的.exe https://www.jetbrains.com/idea/download/?sectionwindows 2.下载好后基本上就是一直点击“下一步”到直到安装好,安装好后先打开软件后关闭退出 3.下载配配套资料 链接: https://pan.ba…

C++计算二维坐标欧式距离

1.何为欧式距离 在欧几里得空间中&#xff0c;点x (x1,…,xn)和 y (y1,…,yn)之间的欧氏距离为 2.C实现计算两点欧氏距离 point1(x1, y1): (1,3) point2(x2, y2): (2,6) #include <iostream> #include <cmath>using namespace std;int main() {struct point {…

【Android驱动08】Sensor传感器框架以及驱动移植和调试方法(Kernel层部分)

接续上一节&#xff0c;本文主要介绍驱动部分的客制化 1&#xff0c; hardware层 通过系统调用open,read,write对sys/class/sensor/m_acc_misc读写操作 路径&#xff1a;vendor/mediatek/proprietary/hardware/sensor/sensors-1.0/Acceleration.cpp 直接操作/sys/class/sensor…

pytorch基础模块:Tensorboard、Dataset、Transforms、Dataloader

Tensorboard、Dataset、Transforms、Dataloader 该文档主要参考【土堆】的视频教程&#xff1a;pytorch入门教程–土堆 一、Tensorboard 安装tensorboard&#xff1a;pip install tensorboard 使用步骤&#xff1a; 引入相关库&#xff1a;from torch.utils.tensorboard i…

DDL、DML、DQL、DCL具体实例与关系

一、DDL、DCL、DML、DQL 通过二维表的形式&#xff0c;更加清晰直观的学习、对比其关系。 DDL DCL DML DQL 英文释义 Data Defination Language 数据库定义语言 Data Control Language 数据库控制语言 Data Manipulation Language 数据操作语言 Data Query Language 数…

PyMuPDF-Guide

本文翻译整理自&#xff1a; https://pymupdf.readthedocs.io/en/latest/how-to-open-a-file.html 文章目录 一、打开文件1、支持的文件类型2、如何打开文件打开一个错误的文件扩展名 3、打开远程文件从云服务打开文件 4、以文本形式打开文件例子打开一个C#文件打开一个XML文件…

按摩行业的革新者:从挑战到辉煌的转型之路

在时代浪潮的推动下&#xff0c;一个勇于创新的团队于2018年毅然踏入按摩服务市场&#xff0c;创立了一家颠覆传统的按摩店。面对行业内的激烈竞争与瞬息万变的市场环境&#xff0c;他们凭借独树一帜的经营模式和不懈的努力&#xff0c;不仅稳固了市场地位&#xff0c;更在去年…

使用Greenhills生成Lib并使用Lib的两种方法

文章目录 前言GHS工程生成libmake方式生成liblib的使用总结 前言 在软件交付过程&#xff0c;如果不交付源代码&#xff0c;可以将源码编译之后生成lib文件提供给客户。本文介绍GHS中生成lib的两种方法&#xff0c;一种基于GHS工程&#xff0c;一种基于make文件。生成完lib后的…

uniapp自定义网格布局用于选择金额、输入框焦点事件以及点击逻辑实战

样式 <view class="withdraw-section"><text class="section-title">提现金额</text><view class="amount-options"><view v-for="(item, index) in list" :key="index" class="amount-opt…

使用Leaflet进行船舶航行警告区域绘制实战

目录 前言 一、坐标格式转换 1、数据初认识 2、将区域分割成多个点 3、数据转换 4、数据转换调用 二、WebGIS展示空间位置信息 1、定义底图 2、Polygon的可视化 3、实际效果 三、总结 前言 通常而言&#xff0c;海事部门如海事局&#xff0c;通常会在所述的管辖区域内…

Java从入门到精通(十五) ~ IO流

晚上好&#xff0c;愿这深深的夜色给你带来安宁&#xff0c;让温馨的夜晚抚平你一天的疲惫&#xff0c;美好的梦想在这个寂静的夜晚悄悄成长。 目录 前言 什么是IO流&#xff1f; IO流的作用&#xff1a; 一、基础流 1. 字节流 1.1 字节输入流 FileInputStream 1.2 字节…

找到第一个满足条件的格值

表格第1列是科目&#xff0c;之后几列是每次的考试成绩&#xff0c;顺序排列。 ABCDE1Art03.676.27.82History3.786.217.29.83Maths5.66.36.68.9 要求根据指定的科目和成绩&#xff0c;找到该科目中大于等于该成绩的第1个格值&#xff0c;比如参数是Maths、6.5时&#xff0c;…

element-ui简单入门1.0.0

第一篇&#xff1a;table标签速用 总结&#xff1a;建楼前&#xff0c;先打地基<el-table></el-table>&#xff0c;打完地基看高度&#xff0c;一层楼4米&#xff0c;80米20个<el-table-column></el-table-column>&#xff0c;每次楼的名字是label 第…

[翻译] Asset Administration Shells

关于资产管理外壳 (AAS) 资产管理外壳 (AAS) 是工业4.0中的关键概念&#xff0c;为产品、资源&#xff08;如设备&#xff09;和过程提供信息隐藏和更高层次的抽象。AAS 是技术和设备无关的机器可读描述&#xff0c;提供访问资产属性和功能的统一接口。与现有解决方案不同&…

C# 下的限定符运算详解(全部,任意,包含)与示例

文章目录 1.限定符概述2. 全部限定符运算&#xff08;All&#xff09;3. 任意限定符运算&#xff08;Any&#xff09;4. 包含限定符运算&#xff08;Contains&#xff09;总结 当我们在C#编程中需要进行条件判断或集合操作时&#xff0c;限定符&#xff08;qualifiers&#xff…

Vue项目启动ESLint报错no-unused-vars解决办法

目录 原因分析解决方法 Vue项目启动时报错如下 ✘ http://eslint.org/docs/rules/no-unused-vars index is assigned a value but never usedsrc\views\friend\list.vue:206:17const index this.tableList.indexOf(v)^原因分析 ESLint是一个在JavaScript代码中识别和报告问…