ARM 汇编指令:UBFX

ARM 汇编指令:UBFX

本文来自于我关于 ARM 汇编指令系列文章。欢迎阅读、点评与交流~
1、汇编指令在不同架构中的联系与区别
2、ARM 汇编指令:MOV
3、ARM 汇编指令:LDR
4、ARM 汇编指令:STR
5、ARM 汇编指令:MRS 和 MSR
6、ARM 汇编指令:ORRS
7、ARM 汇编指令:BEQ
8、ARM 汇编指令:TST
9、ARM 汇编指令:B
10、ARM 汇编指令:BX
11、ARM 汇编指令:ERET
12、ARM 汇编指令:STP\LDP
13、ARM 汇编指令:UBFX

UBFX 是 ARM 架构中的一条汇编指令,全称是 Unsigned Bit Field Extract ,即 无符号位域提取


1. 指令格式

assembly 复制代码
UBFX <Rd>, <Rn>, #<lsb>, #<width>
  • Rd:目标寄存器,用于存放提取后的结果。
  • Rn:源寄存器,存放要提取位域的数据。
  • lsb:要提取的位域的最低有效位位置(从 0 开始计数)。
  • width:要提取的位域的宽度(1 到 32 位)。

2. 功能说明

该指令从源寄存器 Rn 中提取一个连续的位域,从指定的 lsb 位置开始,提取长度为 width 的位,然后将这个位域零扩展 到 32 位,存入目标寄存器 Rd

操作伪代码:

复制代码
Rd = ZeroExtend(Rn[lsb + width - 1 : lsb])

约束条件:

  • 0 ≤ lsb ≤ 31
  • 1 ≤ width ≤ 32 - lsb
  • 如果 width 为 0,则行为是不可预测的 (在 ARMv6T2 及更高版本中,width=0 表示 width=32,但最好显式写 32)。

3. 举例

假设 R1 = 0xABCD1234,执行以下指令:

assembly 复制代码
UBFX R0, R1, #4, #8
  • lsb = 4:从第 4 位开始(bit4)。
  • width = 8:提取 8 位。
  • 提取过程
    • 源数据 0xABCD1234 二进制位 4 到 11(共 8 位)是:
      从 bit4 到 bit11 对应 0xABCD1234 中的半字节:
      0xABCD1234 二进制(部分相关位):
      bit11~bit4:0011 0010(对应十六进制 0x32)。
    • 提取后,零扩展为 32 位:0x00000032
  • 结果:R0 = 0x00000032

4. 与其它指令的关系

  • UBFX 对应的是 SBFX
    SBFX 是带符号位域提取,提取后会进行符号扩展,而不是零扩展。

  • 与移位、AND 指令的比较

    例如 UBFX R0, R1, #4, #8 等价于:

    assembly 复制代码
    MOV R0, R1, LSR #4   ; 右移 4 位,将 bit4 移到 bit0
    AND R0, R0, #0xFF    ; 保留低 8 位

    UBFX 是一条指令完成,效率更高。


5. 支持的架构

  • ARMv6T2 及更高版本(包括 Thumb-2 指令集)。
  • 在 AArch64 中,有类似的 UBFX 指令,但语法略有不同(在 64 位寄存器上操作)。

6. 常见用途

  • 从打包的数据结构中提取特定字段(如协议头、标志位等)。
  • 替代移位和掩码操作,提高代码可读性和执行效率。
  • 硬件寄存器位域提取(如外设状态寄存器)。

示例应用

assembly 复制代码
; 假设 R1 存放一个 32 位数据,其中位域 [15:8] 表示"长度字段"
UBFX R2, R1, #8, #8    ; 提取位 15~8 到 R2,无符号
; 现在 R2 中即为长度值(0~255)

这条指令在嵌入式编程、驱动开发中经常用到,特别是在处理硬件寄存器或数据包解析时。

相关推荐
ShiMetaPi4 小时前
GM-3568JHF丨ARM+FPGA异构开发板系列教程:外设教程 07 音频
arm开发·fpga开发·音视频·fpga·rk3568
切糕师学AI4 小时前
ARM 汇编指令:STP\LDP
汇编·arm开发
管理大亨1 天前
Linux vs Windows:五大维度深度对决
linux·arm开发·windows
Trouvaille ~1 天前
【Linux】库制作与原理(三):动态链接与加载机制
linux·c语言·汇编·got·动静态库·动态链接·plt
XXYBMOOO1 天前
理解 C++ 中的字节序转换函数 `swapEndian`
开发语言·arm开发·c++
猫猫的小茶馆1 天前
【ARM】从零封装STM32标准库
汇编·arm开发·stm32·单片机·嵌入式硬件·架构
切糕师学AI1 天前
ARM 汇编指令:PUSH 和 POP
汇编·arm开发·assembly
切糕师学AI1 天前
ARM 汇编指令:ERET
汇编·arm开发
AI_56782 天前
从“3秒一帧”到“实时识别”——ARM平台OpenCV优化实战
arm开发·人工智能·opencv