ARM开发基础知识

这篇具有很好参考价值的文章主要介绍了ARM开发基础知识。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、ARM寄存器

概念:寄存器是处理器内部的存储器,没有地址

作用:一般用于暂时存储参与运算的数据和运算结果

分类:通用寄存器、专用寄存器、状态寄存器

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

注意:有标签(带三角光标)的是独有的寄存器

总结:

ARM7,9,11 有37个寄存器

30 个通用寄存器

1 个用作PC( program counter)

1个用作CPSR(current program status register) 当前程序状态的寄存器

5个用作SPSR(saved program status registers) 保存程序状态的寄存器

Cortex-A多出3个寄存器,即有40个寄存器

Monitor 模式r13_mon , r14_mon, spsr_mon

R0-R15, CPSR,SPSR 这些寄存器是由ARM公司提供,每个寄存器都是32位的。

这些寄存器没有地址,只有一个唯一的编号,通过这些编号,就可以访问对应的地址空间。

R0-R15,cpsr,spsr就是对应的编号,每个编号都对应的32位二进制

专用寄存器

R13(SP,Stack Pointer)

栈指针,用于存储当前模式下的栈顶地址

R14(LR,Link Register)

链接寄存器:函数调用时,保存返回地址

(保存调用函对应指令的下一条指令地址,返回的时候把LR值给PC,可以继续执行接下来的代码)

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

一般有以下两种用途:

> 执行跳转指令(BL/BLX)时,LR会自动保存跳转指令下一条指令的地址

程序需要返回时将LR的值赋值到PC即可实现

> 产生异常时,对应异常模式下的LR会自动保存被异常打断的指令的下

一条指令的地址,异常处理结束后将LR的值赋值给PC即可实现程序返回

 R15(PC,Program Counter)

程序计数器:用于存储当前取址指令的地址(下一条指令)

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

CPU从内存中一条一条的拿指令(取指)

CPSR寄存器

CPSR(Current Program Status Register),当前程序状态寄存器

存储当前程序运行状态

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

NZCV这几位叫条件位,后边八位叫控制位(C表示) 

CPSR寄存器分为四个域

[31:24]为条件域用F表示

[23:16]为状态域用S表示

[15:8]为预留域用X表示

[7:0]为控制域用C表示

Bit[4:0]

[10000]User [10001]FIQ [10010]IRQ [10011]SVC

[10111]Abort [11011]Undef [11111]System [10110]Monitor

Bit[5]

[0]ARM状态     [1]Thumb状态

Bit[6]

[0]开启FIQ     [1]禁止FIQ

Bit[7]

[0]开启IRQ     [1]禁止IRQ

Bit[28]

> 当运算器中进行加法运算且产生符号位进位时该位自动置1,否则为0

> 当运算器中进行减法运算且产生符号位借位时该位自动置0,否则为1

Bit[29]

> 当运算器中进行加法运算且产生进位时该位自动置1,否则为0

> 当运算器中进行减法运算且产生借位时该位自动置0,否则为1

Bit[30]

当运算器中产生了0的结果该位自动置1,否则为0

Bit[31]

当运算器中产生了负数的结果该位自动置1,否则为0

SPSR寄存器

SPSR:保存程序状态的寄存器(saved program status register)

用于保存CPSR(通用寄存器,在切换模式的时候用)

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

2、ARM的工作模式

ARM有8种工作模式

  1. User :非特权模式,一般在执行上层的应用程序时ARM处于该模式大部分任务执行在这种模式 (运行程序在这个模式)
  2. FIQ :当一个高优先级(fast) 中断产生时将会进入这种模式
  3. IRQ:当一个低优先级(normal) 中断产生时将会进入这种模式   

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

  1. SVC(Supervisor):当复位或软中断指令执行时将会进入这种模式

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

  1. Abort :当指令产生存取异常时ARM将会进入这种模式
  2. Undef :当执行未定义指令时ARM会进入这种模式
  3. System :使用和User模式相同寄存器集的特权模式

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

  1. Monitor : 是为了安全而扩展出的用于执行安全监控代码的模式。也是一种特权模式(Cortex-A特有模式)

工作模式的理解

不同的模式拥有不同的权限

不同的模式执行的代码不同

不同的模式拥有不同的功能

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

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

CPU运行原理

根据下载的程序运行,程序就是指令的有序集合

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

3、指令的解析

一条指令机器码的执行通常分为三个阶段:

1)取指:控制器将PC寄存器中的值发送给内存,内存将对应地址中的指令(机器码)传送回CPU的指令寄存器IR中

2)译码:指令译码器对IR中的指令进行识别,将指令(机器码)解析(翻译)成具体的运算操作(+/-/*...)

3)执行:控制器控制运算器中对应的运算单元进行运算,运算结果写入寄存器

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

 注意:PC每取地址一次,自加一次。PC的值自动增加使PC指向内存中的下一条指令

思考:

  1. 运算器不同,处理指令不同。不同的处理器上如何运行同一个c语言程序?
  2. 假设指令集有乘法指令,结果并没有乘法运算器,怎么办?

可以转换为加法指令

寻址空间

一个处理器能够访问(读写)的存储空间是有限的,我们把这个空间称为地址空间(寻址空间)。通常情况下地址空间的大小2的N次方

32位操作系统,寻址为32位。0x00000000 ~ 0xFFFFFFFF寻址空间位2^32,4G。

指令流水线

指令的执行是按照流水线

取指--》取指器  根据PC值取指令

译码--》译码器

执行--》执行器

以上三个器件,都是单周期的器件,三个器件的工作是独立

指令1 指令2 指令3 指令4 指令5

1 取指 

2 译码 取指 

3 执行 译码 取指 

4 执行 译码 取指 

5 执行 译码 取指

6 执行 译码

7 执行

PC永远指向当前取指指令的地址,一旦取到指令,pc后移4byte,保存下一条指令地址。

指令流水线机制的引入确实能够大大的提升指令执行的速度,但在实际执行程序的过程中很多情况下流水线时是无法形成的,比如芯片刚上电的前两个周期、执行跳转指令后的两个周期等。

所以指令流水线的引入以及优化只能使平均指令周期不断的接近1而不可能真正的达到1,且流水线级数越多芯片设计的复杂,程度就越高,芯片的功耗就越高。

4、ARM的异常处理

1)异常

概念:处理器在正常执行过程中可能遇到一些不正常的事件发生,这时处理器就要将当前程序暂停下来转而去执行这个异常事件,异常事件处理完之后返回被异常打断的地方继续执行。

2)ARM异常源

概念:导致异常产生的事件称为异常源

ARM异常源 

FIQ 快速中断请求引脚有效

IRQ 外部中断请求引脚有效

Reset 复位电平有效

Software Interrupt 执行swi指令

Data Abort 数据终止

Prefetch Abort 指令预取终止

Undefined Instruction 遇到不能处理的指令

3)ARM异常模式

在ARM的基本工作模式中有5个属于异常模式,ARM遇到异常后会切换成对应的异常模式

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

4)异常处理机制

不同的处理器对异常的处理的流程大体相似,但是不同的处理器在具体实现的机制上有所不同;比如处理器遇到哪些事件认为是异常事件遇到异常事件之后处理器有哪些动作、处理器如何跳转到异常处理程序如何处理异常、处理完异常之后又如何返回到被打断的程序继续执行等我们将这些细节的实现称为处理器的异常处理机制。

5)异常向量表

  1. 异常向量表的本质是内存中的一段代码
  2. 表中为每个异常源分配了四个字节的存储空间(32位处理器)
  3. 遇到异常后处理器自动将PC修改为对应的地址
  4. 因为异常向量表空间有限一般我们不会这里写异常处理程序,而是在对应的位置写一条跳转指令使其跳转到指定的异常处理程序的入口

注:ARM的异常向量表的基地址默认在0x00地址但可以通过配置协处理器来修改其地址

6)ARM异常响应(四大步、三小步)

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

ARM产生异常后的动作(自动完成)

1、拷贝CPSR中的内容到对应的异常模式下的SPSR

2、修改CPSR的值

2.1修改中断禁止位禁止相应的中断

2.1修改模式位进入相应的异常模式

2.3修改状态位进入ARM状态

3、保存返回地址到对应模式下的LR中

4、设置PC相应的异常向量

------------------------------------------------------------------------------------------------------------

7)异常返回

ARM异常返回动作(自己编写)

1、将SPSR的值复制给CPSR-->恢复为跳转之前的模式

  1. 将LR的值复制给PC-->返回跳转之前程序执行的地方

8)IRQ异常举例

IRQ异常是指当CPU接收到一个中断请求时,会暂停当前正在执行的程序,转而去执行与中断请求相关的处理程序。

例子:键盘中断

当用户按下键盘上的某个键时,键盘会向CPU发送一个中断请求,CPU会暂停当前正在执行的程序,转而去执行与键盘中断相关的处理程序,以响应用户的操作。在处理完中断请求后,CPU会返回到原来的程序继续执行。

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

9)异常优先级

ARM开发基础知识,ARM开发,arm开发,嵌入式硬件

Reset(重置)

处理器上电或者复位时发生的异常

Data Abort(数据中止)

数据访问错误时发生的异常,一般是与Memory 误操作有关,如对0地址写操作,或对一些Memory 越界操作。或者指令不支持

FIQ (快速中断)、IRQ (普通中断)

FIQ 具有更高的优先级,即当 FIQ 发生时,CPU 会在当前指令执行完成后立即响应 FIQ 中断,而忽略其他 IRQ 中断。这使得 FIQ 更适合处理紧急、实时性要求较高的中断。

Prefetch Abort(指令预取错误时发生的异常)

当CPU在执行指令时,发现指令缓存中没有下一条指令时,就会发生预取指中止异常。这种异常通常是由于程序中的错误或者硬件故障引起的。由于预取指中止异常的信息不够详细,因此很难定位和修复问题。

Software Interrupt(软件中断)

软件中断是一种由应用程序发起的中断,用于请求操作系统提供服务或执行某些操作。当应用程序需要访问受保护的资源或请求操作系统提供服务时,它会发出一个软件中断信号,这个信号会被CPU接收并暂时将控制切换到一个中断处理程序,内核中被中断挂起的进程将在中断被接受后恢复。软件中断可以被看作是同步事件,因为它是由应用程序主动发起的,而不是由外部设备触发的。

Undefined instruction(执行了未定义指令时发生的异常)

Undefined instruction异常是ARM处理器中的一种异常类型,当CPU遇到不认识的指令时,就会触发该异常。在异常处理函数中,可以对该异常进行处理,例如打印debug信息或者进行其他操作。文章来源地址https://www.toymoban.com/news/detail-785490.html

到了这里,关于ARM开发基础知识的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 嵌入式:ARM常用开发编译软件介绍

    ADS(ARM Developer Suite),是在1993年由Metrowerks公司开发是ARM处理器下最主要的开发工具。 他的前身是SDT,SDT是ARM公司几年前的开发环境软件,目前SDT早已经不再升级。ADS包括了四个模块分别是:SIMULATOR;C 编译器;实时调试器;应用函数库。ADS对汇编、C/C++、java支持的均很好,

    2024年02月06日
    浏览(45)
  • 嵌入式硬件基础知识——1

    目录 SOC、MCU、MPU、CPU SPI STM32的时钟系统 can是什么 串口和并口 传感器输出引脚高阻抗好还是低阻抗好? iic 运算放大器特点 MOS管和三极管 同步电路和异步电路         SOC 片上系统  手机的核心芯片         MCU 微控系统  单片机         MPU 嵌入式微处理器    

    2024年02月05日
    浏览(43)
  • 嵌入式基础知识-总线带宽

    带宽,最容易想到的是上网用的网络带宽,在嵌入式软件开发中,也会用到带宽,这个带宽的含义就不一样了,区别是什么?本篇就来介绍一下,并通过一些例子来进行带宽的计算。 先来简单看下不同领域的带宽: 显示器中的带宽,单位是MHz,是一个频率的概念 通讯领域的

    2024年02月13日
    浏览(40)
  • 嵌入式基础知识-DMA

    本篇来介绍DMA的一些基础知识。 DMA(Direct Memory Access),中文名为直接内存访问,它是一些计算机总线架构提供的功能,能使数据从附加设备(如磁盘驱动器)直接发送到计算机主板的内存上。对应嵌入式处理器来说,DMA可以提供外设和存储器之间,或存储器与存储器之间的高

    2024年02月09日
    浏览(33)
  • 嵌入式基础知识大杂烩

    u-boot(或称为Das U-Boot)是一种广泛应用于嵌入式系统的开源引导加载程序。它通常存放在嵌入式系统的非易失性存储器中,具体位置可以根据具体的嵌入式系统架构和设计来确定。 以下是几种常见的u-boot存放位置: 1. Flash存储器: 类似于 单片机 的情况,u-boot可以被烧写到

    2024年02月09日
    浏览(40)
  • 嵌入式入门基础知识有哪些?

    嵌入式系统 是指在特定应用领域内为满足特定要求而设计的计算机系统,通常被嵌入到设备中,具有实时性、可靠性、低功耗等特点。嵌入式系统应用广泛,例如:智能家居、智能手表、汽车控制系统、医疗设备等。 在本篇博客中,我们将讨论嵌入式入门基础知识,包括嵌

    2024年02月15日
    浏览(40)
  • 嵌入式系统入门基础知识分析(一)

      目录 ​编辑 一、什么是嵌入式 二、嵌入式系统的组成 三、实时系统 四、实时系统的调度 五、嵌入式微处理器体系结构 六、逻辑电路基础 七、总线电路及信号驱动 八、电平转换电路 九、嵌入式系统中信息表示与运算基础 十、差错控制编码 十一、嵌入式系统的度量项目

    2024年02月05日
    浏览(51)
  • 嵌入式:ARM汇编语言程序设计基础教程

    ① 合理地分配存储器资源,将前述的目标系统‘数据结构模型’表示到各存储器单元。 ② CPU寄存器数量有限,在程序中,大多数操作都要使用寄存器;并且有的操作使用特定的寄存器(如堆栈操作使用SP/R13等),程序中要合理分配各寄存器的用途。 用计算机语言,对数据结

    2023年04月23日
    浏览(75)
  • [ARM 汇编]高级部分—ARM汇编编程实战—3.3.2 嵌入式开发环境搭建

    搭建一个嵌入式开发环境主要包括以下几个部分: 安装交叉编译器 配置集成开发环境(IDE) 安装调试工具 下载和烧录程序 接下来,我们将详细介绍每个部分,并提供相应的实例。 安装交叉编译器 交叉编译器是用于将您编写的ARM汇编代码编译成可执行文件的工具。在本教程

    2024年02月11日
    浏览(42)
  • 第二章 嵌入式系统硬件基础知识

    (1)信号特性 用 “ 逻辑真 ” “ 1 ” 或 “ 确定 ”来表示 高电平 用 “ 逻辑假 ” “ 0 ” 或 “ 不确定 ”来表示 低电平 1和0称为 互补信号 (2)信号转换 1、数字集成电路的分类         按照开关元件的不同,数字集成电路分为两大类:一类是 双极型集成电路

    2024年01月21日
    浏览(61)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包