当前位置:首页 > 单片机 > 单片机
[导读] 一:指令可选后缀“S”后缀:指令中使用“S”后缀,指令执行后状态寄存器的条件标志位将被刷新;不使用“S”后缀时,指令执行后状态寄存器的条件标志位不会发生变化。此标志经常用于对条件进行测试,例

 

一:指令可选后缀

“S”后缀:指令中使用“S”后缀,指令执行后状态寄存器的条件标志位将被刷新;不使用“S”后缀时,指令执行后状态寄存器的条件标志位不会发生变化。此标志经常用于对条件进行测试,例如:是否溢出,是否进位等;根据这些变化,就可以进行一些判断,是否大于,是否相等,从而可能影响指令执行顺序。

“!”后缀

如果指令地址表达式中不含“!”后缀,则基址寄存器中的地址不会发生变化,指令中含有则变化,变化结果如下:

基址寄存器中的值(指令执行后)=指令执行前的值+地址偏移量

注意:

“!”后缀必须紧跟在地址表达式后面,而地址表达式要有明确的地址偏移量。

“!”后缀不能用于R15(PC)的后面

当用于单个寄存器后面时,必须确性这个寄存器有隐性的偏移量,eg:“STMDB SP!,{R3,R5,R7}”此时地址基址寄存器SP的隐性偏移量是4.

二:具体的指令

LDR/STR 字数据加载/存储指令

LDRB/STRB 字节数据加载/存储指令

LDRH/STRH 半字数据加载/存储指令

Eg:LDR R4,START ;将存储地址为START的字数据读入R4

LDR R0,[R1] ;将存储地址为R1的字数据读入R0

LDR R0,[R1,R2] ;将存储地址为R1+R2的字数据读入R0

LDR R0,[R1,#8] ;将存储地址为R1+8的字数据读入R0

LDR R0,[R1,R2,LSL#2] ;将存储地址为R1+R2<<2的字数据读入R0

STR R5,DATA1 ;将R5存入存储地址为DATA1中

同理可以判断出其他STR的形式所表达的意思。

数据加载与存储(Load-store)指令用于存储器和处理器的寄存器之间数据传输。

Load用于把内存中的数据装载到寄存器中去。

Store用于把寄存器的数据存储到内存中去。

注意:LDRR5,[R6,#0x04]! 是先把R6+4作为地址,把数据传输结束后,在把R6=R6+4.

LDR R5,[R6],#0x04 是先把R6作为地址,把数据传输结束后,把R6=R6+4

 

STMFDSP!,{R0-R4} 将R0-R4中的数据压入堆栈,R13为堆栈指针。

LDMFDSP!,{R0-R4} 将数据出栈,恢复R0-R4的值。

 

DCD用于分配一段字内存单元,并用伪指令中的expr初始化.DCD伪指令分配的内存需要字对齐,一般可用来定义数据表格或其它常数。??

 

Eg:DATA DCD 4,5,6 DATA指向这块内存起始地址,内存为3个单元,并且内容为4,5,6.

注意,,标号相当与一个常数,所以在 LDR R0,DATA,时,R0中内容就是DATA的值。

 

LR就是ARM中R14,子程序链接寄存器,SP就是ARM中R13栈指针寄存器,R15就是PC,程序计数器。

当执行BL子程序调用指令时,R14中得到R15(程序计数器PC)的备份。

读状态寄存器指令.在 ARM 处理器中,只有 MRS 指令可以状态寄存器CPSR或SPSR读出到通用寄存器中.指令格式如下;

写状态寄存器指令.在 ARM 处理器中.只有 MSR 指令可以直接设置状态寄存器 CPSR或 SPSR.指令格式如下

 

SPSR是用来备份CPSR的寄存器,当异常发生时,SPSR自动将上一个状态的CPSR备份出来,便于在后面恢复上一个状态。

 

 

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

据《日经新闻》报道,软银旗下英国芯片制造商Arm计划到2025年销售AI芯片。该公司专门成立一个AI芯片部门,并将在2025年春季之前制造出原型产品,并于秋季开始大规模生产。

关键字: 软银 AGI ARM AI芯片

业内消息,近日日本软件银行集团(SoftBank Group)旗下安谋国际科技公司(Arm)计划研发人工智能(AI)芯片,先成立一个AI芯片部门,目标是明年春季建立AI芯片原型产品,然后将量产工作交由代工厂制造,预估20...

关键字: ARM AI芯片

Arm CPU正在从根本上推动AI变革,并造福地球。Arm架构是未来AI计算的基石。​

关键字: ARM AI

近日,Arm推出了Arm® Ethos™-U85神经网络处理器(NPU)和Arm Corstone™-320物联网参考设计平台,旨在满足海量的数据处理和大规模计算,加速推进边缘AI的发展进程。

关键字: ARM

为了赶超云计算市场上的竞争对手,谷歌正试图通过定制的Arm服务器芯片降低云计算服务成本。

关键字: 谷歌 ARM 定制芯片

嵌入式开发作为一个融合了计算机软硬件和系统工程的综合性领域,其成功与否往往取决于三个核心要素的有效整合与协调。这三个要素分别是:硬件平台的选择与设计、软件开发及其优化、以及系统级的设计与集成。深入理解并熟练掌握这三个方面...

关键字: 嵌入式开发 ARM

随着汽车软件数量爆发式的增长,整个行业都需要重新思考汽车产品的开发流程。为此,Arm推出了丰富的硬件IP、新的系统IP,以及全新的汽车计算与计算子系统产品路线图,旨在为各种汽车应用实现性能、功能安全、可扩展等方面的支持。

关键字: ARM 汽车电子

知名移动芯片设计公司ARM最近迈出重要一步,它正式推出汽车芯片设计。ARM推出的芯片设计方案名叫Neoverse,随同芯片一起推出的还有面向汽车制造商、汽车供应商的新系统。

关键字: ARM 汽车芯片 芯片

随着通用人工智能的发展,数据中心的计算需求逐步提高。针对多模态数据、大模型的推理和训练需要更高的算力支持,而随着算力提升与之而来的还需更关注在功耗方面的优化。对于头部云计算和服务厂商而言,针对专门用例提高每瓦性能变得至关...

关键字: ARM 服务器 AI Neoverse CSS

一直以来,riscv架构都是大家的关注焦点之一。因此针对大家的兴趣点所在,小编将为大家带来riscv架构的相关介绍,详细内容请看下文。

关键字: riscv ARM riscv架构
关闭
关闭