ARMv8-A架构基础之A64指令

ARMv8-A架构中引入的最重要的变化之一是为AArch64增加了一个新的指令集。 该指令集包含许多与现有AArch32(ARMv7-A)32位指令集相同的功能。

A64的加入提供了对64位宽整数寄存器和数据操作的访问,并能够使用64位指针指向内存。 新指令称为A64,并在AArch64执行状态下执行。 ARMv8-A还包含原始的ARM指令集(现在称为A32)和Thumb®(T32)指令集。

A32和T32都以AArch32状态执行,并提供与ARMv7-A的向后兼容性。 尽管它们在很多方面都相似,但是A64指令集与旧的ISA不同,编码方式不同。 A64增加了一些额外的功能,同时也消除了可能限制高性能实现的速度或能源效率的其他功能。 ARMv8-A体系结构还包括对32位指令集(A32和T32)的一些增强。 但是,如有使用这些新特性的代码与旧版ARMv7-A实现不兼容。 但是,A64指令集中的指令操作码仍然是32位长,而不是64位。

A64指令集还提供了与A32相关的额外寻址模式,通过访问大小对索引进行可选的缩放,允许将64位索引寄存器添加到64位基址寄存器中。 此外,它还提供了一个索引寄存器中的32位值的符号或零扩展,同样可以选择性地进行缩放。


转载链接:https://www.jianshu.com/p/947a92cef080
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值