arm64汇编b带条件跳转指令和bl跳转带返回ret指令

本文介绍了ARM汇编中的基本跳转指令,包括ret返回指令、B无条件跳转、BL带返回跳转,并详细解析了如何结合cmp进行条件跳转。通过实例代码展示了各指令的执行流程,帮助读者理解这些指令在函数调用和流程控制中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ret返回指令

cpu遇到ret之后,会把lr赋值给pc,这样cpu执行了pc里的地址的指令,就是执行调用这个函数的下一条指令

B 跳转指令

b 跳转指令,相当于win32汇编的jmp无条件跳转指令
下面代码遇到 label4以后就跳转到label4,然后就返回了

_fn2:
mov x0,#0x1
mov x1,#0x2
b label4
label3:
mov x0 ,1
ret
label4:
mov x0 , 0
ret;执行完这局以后就返回上一层了

BL 带返回的跳转指令

bl指令跳转以后遇到第一个ret,就会返回到bl的下一条指令继续执行
同样这段代码把b换成bl就会遇到执行完label4以后遇到ret,还会跳到b label4的下一条指令label3:处继续执行,知道遇到ret才会返回

_fn2:
mov x0,#0x1
mov x1,#0x2
bl label4 ;跳转到label4以后遇到ret后会返回执行下面的label3:
label3:
mov x0 ,1
ret
label4:
mov x0 , 0
ret  ;执行完这句以后会跳到label3:

B指令可以接上后缀,用来和cmp比较后待条件的跳转

EQ:equal 相等
NE:not equal,不相等
GT:great than,大于
GE greate equal,大于等于
LT:less than,小于
LE:less equal,.小于等于

  • 使用的时候可以连着使用beq 就是 前面cmp比较结果相等的时候跳转.也可以写成b.eq
  • 下面代码距离b.lt小于的时候跳转
_fn1:
mov x0,#0x1 ;立即数以#井号开头,0x是16进制
mov x1,#0x2
cmp x0,x1 ;这里做比较,用来下面的b跳转做比较条件
b.lt label2  //lt小于时候跳转,上面cmp 比较练x0和x1,x0<x1成立,所以 b.lt会跳转
label1:
mov x0 ,1
label2:
mov x0 , 0

ret
### Linux ARM64 架构下的初始化汇编详解 #### 初始引导阶段 在嵌入式 Linux 开发中,Cortex-A 芯片刚上电时 SP 指针尚未初始化,C 环境也未准备好,因此无法立即执行 C 代码。此时必须通过汇编语言来设置必要的环境,例如初始化 DDR 配置 SP 指针等[^1]。 对于 ARM64 架构而言,初始引导程序通常位于 ROM 或 Flash 存储器中,并由硬件自动跳转到该位置开始执行。这段代码的主要职责是: - 设置堆栈指针 (SP) - 初始化内存控制器 - 加载并解压内核镜像至 RAM - 执行进一步的系统初始化工作 #### 堆栈初始化 ARM 架构中的堆栈通常是全降序类型的(Full Descending Stack),这意味着随着数据被推入堆栈,地址会逐渐减小。为了确保程序能够正常运行,必须正确地初始化堆栈指针(SP)[^2]。这一步骤至关重要,因为它决定了函数调用局部变量存储的位置。 ```assembly .global _start _start: ldr sp, =_stack_top /* Load the address of stack top into SP */ ``` 上述代码片段展示了如何将预定义好的 `_stack_top` 地址加载到 SP 寄存器中作为堆栈顶部。 #### 内存初始化 DDR/SDRAM 的初始化是一个复杂的过程,涉及到多个寄存器的操作以及特定序列的要求。这部分逻辑往往依赖于具体的 SoC 设计及其配套文档。以某款基于 X210 平台的产品为例,其内存初始化分为两个主要部分——分别针对 DRAM0 DRAM1 进行配置[^4]。 ```assembly /* Example pseudo-code for initializing DRAM on a specific platform */ init_ddr: mov x0, #CONFIG_DRAM_BASE_ADDR /* Set base address */ bl configure_dram_controller /* Call function to setup controller */ configure_dram_controller: ... ret /* Return from subroutine */ ``` 请注意实际实现可能更加繁琐,并且需要依据具体芯片手册编写相应的控制命令。 #### 数据传输指令 LDR STR 是用于加载存储数据的核心指令。默认情况下它们处理的是 32-bit 字单位的数据访问;然而也可以指定不同的宽度来进行更精细的操作,如字节(B)或半字(H)级别的读写[^5]。 ```assembly ldr w0, [x1] /* Load word from memory location pointed by x1 into register w0 */ strb w2, [x3, #4] /* Store byte from lower bits of w2 at offset +4 relative to address in x3 */ ldrh w4, [sp, #-8]! /* Pre-decrementing load halfword with update pointer */ ``` 以上仅是对 Linux ARM64 启动过程中涉及的关键汇编概念进行了概述。完整的启动流程还包括更多细节,比如中断向量表安装、CPU模式切换等高级主题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值