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)

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

相关推荐
切糕师学AI12 小时前
ARM APSR中的 GE 位
arm开发·apsr
物随心转13 小时前
芯片的Serdes
arm开发
ARM&开发(Haidong)1 天前
ARM64 Stress-ng 工具
arm开发
swan4161 天前
SCAU期末笔记 - 计算机网络雨课堂习题整理
arm开发·笔记·计算机网络
佑白雪乐2 天前
<王道操作系统第2集>1.4~2.1.3
arm开发
听情歌落俗2 天前
ARM架构-硬件架构和汇编指令
汇编·arm开发·硬件架构
云qq3 天前
x86操作系统23——进程相关系统调用
linux·c语言·汇编·ubuntu
KeLin&3 天前
讯为iTOP4412-Qt5.7环境搭建
开发语言·arm开发·qt·arm
切糕师学AI3 天前
ARM 应用程序状态寄存器APSR的整数状态(NZCV)位
arm开发·寄存器·apsr
早日退休!!!4 天前
ARM Cortex-M核 【保存上下文&恢复上下文】
arm开发·单片机·嵌入式硬件