当前位置: 首页 > news >正文

【ARM64 常见汇编指令学习 15 -- ARM 标志位的学习】

文章目录

    • ARM 标志位介绍
      • Zero Condition flag(零标志位)
      • 零标志位判断实例

上篇文章:ARM64 常见汇编指令学习 14 – ARM 汇编 .balign,.balignw,.balign 伪指令学习
下篇文章:ARM64 常见汇编指令学习 16 – ARM64 SMC 指令

ARM 标志位介绍

在这里插入图片描述
在ARM架构中,处理器的状态寄存器(例如CPSR)有一些标志位,用于表示特定的状态或结果。以下是这些标志位的含义:

  • N(Negative):负标志位。如果操作的结果是负数,那么N位将被设置为1。
  • Z(Zero):零标志位。如果操作的结果是零,那么Z位将被设置为1
  • C(Carry):进位标志位。如果操作导致了进位或借位,那么C位将被设置为1。
  • V(Overflow):溢出标志位。如果操作的结果导致了算术溢出,那么V位将被设置为1。

这些标志位主要用于条件指令,如CMP(比较)、ADD(加法)、SUB(减法)等,以及条件跳转指令,如BEQ(等于时跳转)、BNE(不等于时跳转)、BGT(大于时跳转)、BLT(小于时跳转)等。

例如:

  • 使用CMP指令比较两个值后,可以通过检查Z位是否被设置来判断这两个值是否相等。
  • 使用ADD指令进行加法操作后,可以通过检查C位是否被设置来判断是否发生了进位。
  • 使用SUB指令进行减法操作后,可以通过检查N位是否被设置来判断结果是否为负数。
  • 使用任何可以导致溢出的算术操作(如加法或乘法)后,可以通过检查V位是否被设置来判断是否发生了溢出。

总的来说,这些标志位为ARM处理器提供了一种检查和响应各种操作结果的机制,这对于许多编程任务来说是非常重要的。

Zero Condition flag(零标志位)

在ARM架构中,有许多指令在执行后会影响零标志位(Z),或者根据零标志位(Z)的状态来决定其行为。以下是一些常见的例子:

  • CMP(Compare):这条指令用于比较两个寄存器的值。它会执行一个减法操作,并根据结果设置条件标志,包括零标志位。如果两个值相等,那么结果为零,零标志位会被设置

  • TST(Test):这条指令用于测试两个寄存器的值。它会执行一个位与(AND)操作,并根据结果设置条件标志,包括零标志位。如果两个值的AND结果为零,那么零标志位会被设置

  • ANDS(Bitwise AND with Set Flags):这条指令执行一个位与操作,并根据结果设置条件标志,包括零标志位。

  • BEQ(Branch if Equal)和BNE(Branch if Not Equal):这两条指令都会根据零标志位的状态决定是否跳转如果零标志位被设置(表示最后一次比较或测试的结果为零),BEQ会导致处理器跳转到指定的位置,BNE不会跳转;如果零标志位被清除,BEQ不会跳转,BNE会跳转。

这只是零标志位在ARM中的一些用途。在实际编程中,零标志位的状态通常用于判断某个操作的结果是否为零,或者两个值是否相等。

零标志位判断实例

tst r0 , #0x2         //进行and运算,如果bit2为1,zero==0,如果bit2为0,则zero==1,即该指令测试bit2是否为0
bne led_blink         //非零则跳转,若zero==1,跳转到led_blink处执行;若zero==0,则继续执行下一步指令
sub r1 , r1 , #1      //r1=r1-1
cmp r1 , #0            //r1是否等于0,并更改标志位     
bne led_blink          //zero==1时跳转至led_blink处,zero==0时则继续执行

上篇文章:ARM64 常见汇编指令学习 14 – ARM 汇编 .balign,.balignw,.balign 伪指令学习
下篇文章:ARM64 常见汇编指令学习 16 – ARM64 SMC 指令

http://www.lryc.cn/news/120004.html

相关文章:

  • 【论文阅读】基于深度学习的时序预测——FEDformer
  • 编写简单的.gitlab-ci.yml打包部署项目
  • 哪些CRM的报价公开且透明?
  • springmvc下完成文件上传,使静态资源生效的三种方法
  • 数据归一化:优化数据处理的必备技巧
  • 常量池-JVM(十九)
  • java+springboot+mysql智能社区管理系统
  • pve组网实现公网访问pve,访问电脑,访问pve中的openwrt同时经过openwrt穿透主路由地址nginx全公网访问最佳办法测试研究...
  • 远程运维大批量IT设备?向日葵批量部署、分组授权与安全功能解析
  • Harbor内网离线安装使用HTTPS访问
  • Python“牵手”京东工业商城商品详情数据方法介绍
  • 接口测试意义及工作流程
  • QT-如何使用RS232进行读写通讯
  • 05 神经网络语言模型(独热编码+词向量的起源)
  • PyTorch Lightning教程八:用模型预测,部署
  • 桂林小程序https证书
  • html input 设置不允许修改
  • BI技巧丨利用Index计算半累计
  • 第三章:前端UI框架介绍
  • javaScript:文档流写入和元素写入
  • 【BI系统】选型常见问题解答二
  • docker版jxTMS使用指南:使用jxTMS采集数据之一
  • 【js】日期、时间正则匹配
  • 专利研读-SIMD系列-向量化引擎
  • C#--设计模式之单例模式
  • RWEQ风蚀方程模型与ArcGIS数据处理Python代码库添加结合理论研究和科研实践
  • 基于STM32微控制器的物联网(IoT)节点设计与实现
  • 篇二十一:中介者模式:解耦对象之间的交互
  • tomcat的多实例,动静分离(web服务基础结束)
  • LeetCode150道面试经典题--判断子序列(简单)