• 九、ARM 汇编与 C 的混合编程


    9.1 ARM 汇编与 C 的混合编程

    9.1.1 内嵌汇编 __asm

    __asm("指令")
    例如关闭/打开总中断开关 CPSR

    __asm //使用 C 中变量名代替寄存器
    {
        MOV var,x
        ADD y,var,x/y
    }

    内联汇编语言中的寄存器名被编译器视为 C 或 C++语言中的变量,所以内联汇编中出现的寄存器名不一定和同名的物理寄存器相对应。
    这些寄存器名在使用前必须声明, 否则编译器将提示警告信息

    9.1.2 汇编访问 C 中的全局变量

    【1】用 IMPORT 声明全局变量

    【2】利用 LDR 得到其地址

    AREA globals, CODE, READONLY
    EXPORT asmadd
    IMPORT gvar; 声明外部变量 gvar
    asmadd
    LDR R1, =gvar; 装载变量地址
    LDR R0, [R1] ; 读出数据
    ADD R0, R0, #1; 加 1 操作
    STR R0, [R1]; 保存变量值
    MOV PC, LR
    END

    9.1.3 ATPS(ARM-Thumb Produce Call Standard)

    • ATPCS(ARM-Thumb Produce Call Standard): ARM 程序和 Thumb 程序中子程序调用的基本规则
    • 子程序调用过程中寄存器的使用规则
      • 利用 R0-R3 来传递参数, R4-R11 用来保存局部变量。
    • 数据栈的使用规则
      • 栈采用的是满递减(FD),当参数超过 4 个时, 超过的部分使用栈来传递参数, 返回值存于 R0

    9.2 ARM 汇编 THUMB2 指令集

    9.2.1 ARM THUMB THUMB2

    • ARM 指令: 32 位, 支持所有功能, 所有指令都可以条件执行
    • THUMB: 16 位, 不能访问协处理器, 特权指令和特殊功能指令, 只有 B 指令才能条件执行
    • THUMB2: Thumb-2 是 16 位 Thumb 指令集的一个超集, 指令是 32 位或者是 16 位。与 ARM 指令 32 位编码格式是不同的。由汇编器来决定使用 16 位指令还是 32 位指令。

    9.2.2 ARMV8(64bit 体系结构)

    • ARMv8 提供 AArch32state 和 AArch64 state 两种 Execution State, 不在区分 ARM 状态与 THUMB 状态。
    • 在 AArch32 状态下, 提供两个指令集 A32(32bit)、 T32(16/32bit), 两种指令是通过 BX 切换的。
    • 在 AArch64 状态下, 只支持 A64 指令集, 固定长度为 32bit.
    • ARMV8 提供了不同的运行级别: Exception Level 与 Security (EL0(app), EL1, EL2,EL3) 类比于 X86 的 Ring0-ring3(app)

    9.2.3 CORTEX-M3

    • Cortex-M3 只支持 Thumb-2 指令, 在 STM32 单片机课程中会详细讲解 Thumb-2 指令集。
  • 相关阅读:
    搜索
    c++ map与unordered_map区别及使用
    01BFS
    宇智波程序笔记55-Flutter 混合开发】嵌入原生View-iOS
    宇智波程序笔记54-解Bug之路-记一次线上请求偶尔变慢的排查
    宇智波程序笔记53-从红黑树的本质出发,彻底理解红黑树!
    宇智波程序笔记52-最受欢迎的微服务框架概览
    宇智波程序笔记51-JDK 15安装及新特性介绍
    宇智波程序笔记50-解Bug之路-记一次线上请求偶尔变慢的排查
    宇智波程序笔记49-link JDBC Connector:Flink 与数据库集成最佳实践
  • 原文地址:https://www.cnblogs.com/kele-dad/p/10940542.html
Copyright © 2020-2023  润新知