ARM学习笔记5——程序状态寄存器】的更多相关文章

当前程序状态寄存器CPSR可以在任何位处理器模式下被访问,它包含条件码标志.中断控制.当前处理器模式以及其他状态和控制信息.CPSR的结构图如下: 一.条件标志位 CPSR最高4位:N(Negative).Z(Zero).C(Carry)和V(oVerflow)称为条件标志位.程序名中的算术或逻辑指令可以根据其执行结果修改这些条件标志位,之后的条件执行指令可以根据这些条件标志决定相应的指令是否被执行.各条件标志位的具体含义如下: 1.N(符号位) 该位设置为当前指令运行结果的BIT[31]的值.…
这两条指令结合,可用于对CPSR或SPSR进行读/写操作. 当需要保存或修改当前模式下CPSR或SPSR的内容时,首先必须将这些内容传递到通用寄存器中 1.MRS指令(Move to Register from Status Register) 1.1.作用 它将程序状态寄存器内容传输到通用寄存器 1.2.语法格式 MRS{<condition>} <Rd>,CPSR MRS{<condition>} <Rd>,SPSR 1.3.参数说明 <Rd>…
学习ARM也有一定时间了,想想还是记点东西,要不以后就忘了.这是我的第一片,简简单单.但比较基础.1. ARM中一些常见英文缩写解释MSB:最高有效位:LSB:最低有效位:AHB:先进的高性能总线:VPB:连接片内外设功能的VLSI外设总线:EMC:外部存储器控制器:MAM:存储器加速模块:VIC:向量中断控制器:SPI:全双工串行接口:CAN:控制器局域网,一种串行通讯协议:PWM:脉宽调制器:ETM:嵌入式跟踪宏:CPSR:当前程序状态寄存器:SPSR:程序保护状态寄存器: 2. MAM 使…
ARM微处理器上有37个32位的寄存器,其中有6个状态寄存器(一个CPSR,5个SPSR),其它31个为通用寄存器.在ARM的不同模式下,可以访问的物理寄存器是不同,如下图所示: 从图中可知,用户模式和系统模式使用相同的物理寄存器,R0-R15,CPSR,共17个物理寄存器: FIQ模式(快速中断请求模式)中:R0-R7,R15,CPSR是和用户模式相同的物理寄存器,R8-R14是FIQ模式专有的: IRQ模式(中断请求模式)中:R0-R12,R15,CPSR和用户模式共用相同的物理寄存器,R1…
首先我们要根据开发板原理图得到控制LED灯的引脚是哪个,我们现在以LED1为例,我们已经知道LED1由S5PV210的GPC1_3控制,因此我们按如下步骤进行: 第一步是配制S5PV210的GPC1_3为输出口: 第二步我们禁止GPC1_3的上.下拉电阻功能: 第三步就是控制GPC1_3输出高电平或低电平. 要想对GPC1进行配置,那我们需要知道其配置寄存器的地址,根据S5PV210的编程手册我们可以知道:  GPC1的配置寄存器地址是:0xE0200080 GPC1数据寄存器地址是:0xE02…
GNU ARM汇编程序设计中,每行的语法格式如下: [<label>:] [<instruction | directive | pseudo-instruction>] @comment 如果语句太长,可以将一条语句分几行来书写,在行末用“\”表示换行.“\”后不能有任何字符,包含空格和制表符(Tab) 参数说明: label:为标号,可选,可以使用字母,数字,下划线:除局部标号外,必须以字母或下划线开头.标号必须以“:”号结尾.标号大小写敏感 instruction | dir…
ARN汇编器支持ARM伪指令,这些伪指令在汇编阶段被翻译成ARM或Thumb指令.ARM伪指令包含ADR.ADRL.MOV32和LDR.一.ADR伪指令 1.作用 ADR是小范围地址读取伪指令,基于PC相对偏移地址或基于寄存器相对偏移地址读取到寄存器中,当地址值是字节对齐时,取值范围为-255到255,当地址值是字对齐时,取值范围-1020到1020 2.语法格式 ADR{<condition>}{.W} register,label 3.参数说明 3.1..W:可选项,指定指令宽度 3.2.…
交换指令将一个存储单元内容与制定的寄存器内容相交换,交换指令为进程间同步提供了一种方便的解决途径.该指令产生一堆原子Load/Store操作,该操作发生在一个连续的总线操作中,在操作期间阻止其他任何指令对该存储单元的读/写.一.通用寄存器和存储器字数据交换指令SWP 1.作用 将一个内存单元(该单元地址放在寄存器Rn中)的内容读取到一个寄存器Rd中,同时将另一个寄存器Rm的内容写入到该内存单元中. 2.语法格式 SWP{<condition>} <Rd>,<Rm>,[&…
ARM乘法指令完成两个数据的乘法,两个32位二进制数相乘的结果是64位的4积. 其中: 1.“RadHi:RdLo”是由RdHi(最高有效32位)和RdLo(最低有效32位)链接形成的64位数,“[31:0]”只选取结果的最低有效32位 2.简单的赋值由“:=”表示 3.累加(将右边加到左边)是由“+=”表示 一.MUL乘法指令 1.作用 将Rm和Rs中的值相乘,结果的最低32位保存到Rd中 2.语法格式 MUL{<condition>}{S} <Rd>,<Rm>,&l…
一.Arm指令条件码和条件助记符 二.跳转指令B 1.作用 跳转指令B使程序跳转到指定的地址执行程序(跳转范围是PC-32MB到PC+32MB) 2.指令格式(注:B后面如果有条件,条件就是紧跟在B后面,没有空格) B{<condition>} <target_address> 3.参数说明 3.1.<condition>:它指示指令在什么条件下执行,可省略 3.2.<target_address>:指令跳转的目标地址,指令通过下面的方法计算目标地址: A.…