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)

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

相关推荐
浩浩测试一下9 小时前
汇编中的JCC指令 (逆向分析)
汇编·逆向·标志位·jcc指令·跳转指令·标志位寄存器
浩浩测试一下11 小时前
汇编中的段与段寄存器(大小)段序 (逆向分析)
汇编·逆向·二进制·字节序·windows编程·内存地址排序
猫猫的小茶馆12 小时前
【Python】函数与模块化编程
linux·开发语言·arm开发·驱动开发·python·stm32
霞姐聊IT13 小时前
x86程序移植到arm平台的四种场景及解决方案简介
arm开发
楼兰公子16 小时前
《深入理解Linux网络技术内幕》配套学习大纲 + 源码Demo + 进阶实战实例
linux·arm开发·学习
lljss202020 小时前
Arm GNU 工具链 命名规则
服务器·arm开发·gnu
底层开发智库1 天前
无需硬件开发板,从零构建并运行ARM aemfvp-a-rme软件栈
arm开发·arm
浩浩测试一下2 天前
汇编 call与ret 函数与堆栈 (逆向分析)
汇编·push·函数·pop·call·ret·堆栈逆向
山屿落星辰2 天前
昇腾NPU算子开发:从“手写汇编“到“搭积木“
汇编
浩浩测试一下2 天前
汇编 汇编寻址 (逆向分析)
汇编·寻址·windows编程·二进制逆向·机器码