ARM 嵌入式微处理器指令集(下)

2023-12-21 10:38

本文主要是介绍ARM 嵌入式微处理器指令集(下),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

教材:嵌入式系统及应用,罗蕾、李允、陈丽蓉等,电子工业出版社

目录:

    • ARM v5TE 架构指令体系
      • 前导 0 计数指令
      • 符号乘法操作指令
      • 饱和运算指令
      • 加载存储 2 个寄存器指令
      • 断点指令
      • 高速缓存预加载指令
    • ARMv6 架构指令体系
      • 打包数据类型指令
      • 字节选择指令
      • SIMD 指令
      • 绝对差值求和指令
      • SETEND 指令
      • 字节反转指令
      • 饱和指令
      • 排他加载存储指令
      • 异常进入与退出指令
    • Thumb 指令集
        • 与 ARM 指令集的对比
        • v4T v5TE 的 Thumb 指令集
        • ARMv6 的 Thumb 指令集
    • Thumb-2 指令集


ARM v5TE 架构指令体系

v5TE 架构包含了v4T 架构下所有的 ARM / Thumb 指令集,新增了一些指令,并且对 ARM / Thumb 的交互支持进行了改进

前导 0 计数指令

  • CLZ{cond} Rd, Rm
  • 返回寄存器内容中第一个 1 之前的二进制 0 的个数

符号乘法操作指令

  • SMULxy{cond} Rd, Rm, Rs
    SMULWy{cond} Rd, Rm, Rs
    SMLAxy{cond} Rd, Rm, Rs, Rn
    SMLAWy{cond} Rd, Rm, Rs, Rn
    SMLALxy{cond} RdLo, RdHi, Rm, Rs
  • 不会影响 NZCV标志位 (指令后加‘S’后缀是不允许的)

  • x,y 分别代表第一个操作数 Rm 和第二个操作数 Rs 的高半字(**T**op)或者低半字(**B**ottom)

  • W 代表选择 48 位乘积的高 32 位

  • SMLA 指令会影响 Q 标志位

  • 具体操作流程
    符号乘法流程

    • SMULxy: 16x16->32. For all of these instructions, the upper or lower half of both the source registers can be chosen with ‘T’ and ’B’.
    • SMULWy: 32x16->32. ‘y’ selects top or bottom half of second source. Note 32-bit result is generated by discarding lower 16 bits of intermediate 48-bit product.
    • SMLAxy: 16x16+32->32.
    • SMLAWy: 32x16+32->32.
    • SMLALxy: 16x16+64->64. Accumulation is into pair of registers.

饱和运算指令

  • 饱和运算
    • 向 0x7FFFFFFF 加 1 导致了正值向负值的转变
    • 从 0x80000000 减 1 导致负值向正值的转变
  • QSUB{cond} Rd, Rm, Rn    ;Rd = saturate(Rm - Rn)
    QADD{cond} Rd, Rm, Rn    ;Rd = saturate(Rm + Rn)
    QDSUB{cond} Rd, Rm, Rn   ;Rd = saturate(Rm - saturate(Rn*2))
    QDADD{cond} Rd, Rm, Rn   ;Rd = saturate(Rm + saturate(Rn*2))
  • 在这些指令的执行中,如果饱和发生,那么 Q 标志位就会被置位,并不影响 NZCV

  • 避免信号处理过程中出现不期望的“尖峰”信号

加载/存储 2 个寄存器指令

  • LDR/STR{<cond>}D <Rd>, <addressing_mode>
  • 内存中相邻的两个字与寄存器对 (r0,r1), (r2,r3), (r4,r5), (r6,r7), (r8,r9), (r10,r11) or (r12,r13)的数据传输
  • Rd 需指定为偶数号的寄存器,紧跟其后的奇数号寄存器用来传输第二个字
  • LDRD 指令使用与 LDRH/STRH 指令相同的寻址模式,加载的是两个字中内存较小的地址,较高地址由该地址 + 4 产生,因此要求给出的地址是 8 字节对齐的

断点指令

  • BKPT <#imm16>
  • 执行该指令或将引起一个预取指令(Prefetch Abort)异常,或者使处理器进入调试状态
  • 通常用于调试,立即数供调试工具使用,将被处理器忽略

高速缓存预加载指令

  • PLD [Rn, <offset>]

  • 告诉存储系统对一个指定地址的数据访问即将到来

  • 偏移量可以为
    • 无符号的12位立即数( 0 - 4095 bytes)
    • 寄存器,可选择移位操作
  • PLD 是一条提示指令,若该 ARM 处理器不支持,则相当于执行了一条空操作语句 NOP

ARMv6 架构指令体系

ARM 的 V6 版本包含了 81 条新的指令,扩充的指令几乎都是条件执行的

打包数据类型指令

字节选择指令

SIMD 指令

绝对差值求和指令

SETEND 指令

字节反转指令

饱和指令

排他加载/存储指令

异常进入与退出指令

Thumb 指令集

Thumb 是一个 16 位的指令集

与 ARM 指令集的对比
  • 优点
    • 从 C 代码得到最优的代码密度 (约为 ARM 指令集 65% 左右)
    • 对窄内存系统有更好的指令性能
  • 缺点
    • 它是 ARM 指令集的一个功能子集,也许几条 Thumb 指令才能代替一条ARM 指令
    • 有限制的条件执行
    • 数据处理指令只能使用低编号的寄存器(r0 - r7)
    • 不能使用内嵌的桶型移位器
    • 立即数的范围更小
    • 不能访问协处理器
  • 适合作为编译器的输出,而并非处理代码
v4T & v5TE 的 Thumb 指令集

ARMv6 的 Thumb 指令集

Thumb-2 指令集

  • 提供了32位和16位的混合指令
  • 在增强了灵活性的同时保持了代码高密度

这篇关于ARM 嵌入式微处理器指令集(下)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/519681

相关文章

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

荣耀嵌入式面试题及参考答案

在项目中是否有使用过实时操作系统? 在我参与的项目中,有使用过实时操作系统。实时操作系统(RTOS)在对时间要求严格的应用场景中具有重要作用。我曾参与的一个工业自动化控制项目就采用了实时操作系统。在这个项目中,需要对多个传感器的数据进行实时采集和处理,并根据采集到的数据及时控制执行机构的动作。实时操作系统能够提供确定性的响应时间,确保关键任务在规定的时间内完成。 使用实时操作系统的

嵌入式Openharmony系统构建与启动详解

大家好,今天主要给大家分享一下,如何构建Openharmony子系统以及系统的启动过程分解。 第一:OpenHarmony系统构建      首先熟悉一下,构建系统是一种自动化处理工具的集合,通过将源代码文件进行一系列处理,最终生成和用户可以使用的目标文件。这里的目标文件包括静态链接库文件、动态链接库文件、可执行文件、脚本文件、配置文件等。      我们在编写hellowor

嵌入式方向的毕业生,找工作很迷茫

一个应届硕士生的问题: 虽然我明白想成为技术大牛需要日积月累的磨练,但我总感觉自己学习方法或者哪些方面有问题,时间一天天过去,自己也每天不停学习,但总感觉自己没有想象中那样进步,总感觉找不到一个很清晰的学习规划……眼看 9 月份就要参加秋招了,我想毕业了去大城市磨练几年,涨涨见识,拓开眼界多学点东西。但是感觉自己的实力还是很不够,内心慌得不行,总怕浪费了这人生唯一的校招机会,当然我也明白,毕业

深入探索嵌入式 Linux

摘要:本文深入探究嵌入式 Linux。首先回顾其发展历程,从早期尝试到克服诸多困难逐渐成熟。接着阐述其体系结构,涵盖硬件、内核、文件系统和应用层。开发环境方面包括交叉编译工具链、调试工具和集成开发环境。在应用领域,广泛应用于消费电子、工业控制、汽车电子和智能家居等领域。关键技术有内核裁剪与优化、设备驱动程序开发、实时性增强和电源管理等。最后展望其未来发展趋势,如与物联网融合、人工智能应用、安全性与

嵌入式技术的核心技术有哪些?请详细列举并解释每项技术的主要功能和应用场景。

嵌入式技术的核心技术包括处理器技术、IC技术和设计/验证技术。 1. 处理器技术    通用处理器:这类处理器适用于不同类型的应用,其主要特征是存储程序和通用的数据路径,使其能够处理各种计算任务。例如,在智能家居中,通用处理器可以用于控制和管理家庭设备,如灯光、空调和安全系统。    单用途处理器:这些处理器执行特定程序,如JPEG编解码器,专门用于视频信息的压缩或解压。在数字相机中,单用途

bash: arm-linux-gcc: No such file or directory

ubuntu出故障重装了系统,一直用着的gcc使用不了,提示bash: arm-linux-gcc: No such file or directorywhich找到的命令所在的目录 在google上翻了一阵发现此类问题的帖子不多,后来在Freescale的的LTIB环境配置文档中发现有这么一段:     # Packages required for 64-bit Ubuntu

编译linux内核出现 arm-eabi-gcc: error: : No such file or directory

external/e2fsprogs/lib/ext2fs/tdb.c:673:29: warning: comparison between : In function 'max2165_set_params': -。。。。。。。。。。。。。。。。。。 。。。。。。。。。。。。。 。。。。。。。。 host asm: libdvm <= dalvik/vm/mterp/out/Inte

基于微信小程序与嵌入式系统的智能小车开发(详细流程)

一、项目概述 本项目旨在开发一款智能小车,结合微信小程序与嵌入式系统,提供实时图像处理与控制功能。用户可以通过微信小程序远程操控小车,并实时接收摄像头采集的图像。该项目解决了传统遥控小车在图像反馈和控制延迟方面的问题,提升了小车的智能化水平,适用于教育、科研和娱乐等多个领域。 二、系统架构 1. 系统架构设计 本项目的系统架构主要分为以下几个部分: 微信小程序:负责用户界面、控制指令的

Cortex-A7:ARM官方推荐的嵌套中断实现机制

0 参考资料 ARM Cortex-A(armV7)编程手册V4.0.pdf ARM体系结构与编程第2版 1 前言 Cortex-M系列内核MCU中断硬件原生支持嵌套中断,开发者不需要为了实现嵌套中断而进行额外的工作。但在Cortex-A7中,硬件原生是不支持嵌套中断的,这从Cortex-A7中断向量表中仅为外部中断设置了一个中断向量可以看出。本文介绍ARM官方推荐使用的嵌套中断实现机