当前位置: 首页 > news >正文

day43-硬件学习之ARM基础知识

一、RAM分类及ROM分类

1.1 RAM的分类

1.2 ROM的分类

注意:flash闪存中,nor flash是可被CPU直接寻址的,用于存放系统启动程序;

                                 nand flash不可被CPU寻址,用于存放额外文件,如文件视频等

ARM的指令集:

        ARM指令集(32bit)

        Thumb指令集(16bit) 

二、ARM处理器工作模式

2.1 ARM的工作模式

ARM有7个基本工作模式:

  • User:非特权模式,大部分任务执行在这种模式;
  • FIQ :当一个高优先级(fast)中断产生时将会进入这种模式;
  • IRQ:当一个低优先级(normal)中断产生时将会进入这种模式;
  • Supervisor:当复位或软中断指令执行时将会进入这种模式;
  • Abort:当存取异常时将会进入这种模式;
  • Undef:当执行未定义指令时会进入这种模式;
  • System:使用和User模式相同寄存器集的特权模式;
  • Cortex-A特有模式;
  • Monitor:(监视模式)是为了安全而扩展出的用于执行安全监控代码的模式:也是一种特权模式; 

2.2 寄存器组织概要

  • 不同的工作模式下,各自管理不同的栈(SP和LR); 

2.3 程序状态寄存器

2.4 异常处理


 注意:

  • 中断的本质也是一种异常;
  • 异常向量表:用于存储不同类型异常发生时,处理器跳转到特定的异常处理程序的地址;

        FIQ中断;

        IRQ中断;

        (保留);

        数据异常;

        预取异常;

        软中断异常;

        未定义异常;

        复位异常;

三、RAM指令学习

  • Keil学习基础指令;
  • 使用指令操作相应端口; 

 

3.1 mov指令

mov指令:加载12位立即数到寄存器或转移一个寄存器的值到另外一个寄存器

mov r0, #2 ;加载立即数2到寄存器r0,MOV{S}<c> <Rd>, #<const>

mov r1, r0 ;将r0寄存器的值加载到r1,MOV{S}<c> <Rd>, <Rm>


  • ASR算术右移
  • LSL逻辑左移

3.2 mvn指令

将要装载的数按位取反

 

3.3 add指令

add指令常用的两种方式:

ADD{S}<c> <Rd>, <Rn>, #<const>

ADDS}<c> <Rd>, <Rn>, <Rm>{, <shift>}

3.4 sub指令

SUB{S}<c> <Rd>, <Rn>, #<const>

SUB{S}<c> <Rd>, <Rn>, <Rm>{, <shift>}

以上四条指令都有立即数作为第二操作数的情况,那么是什么立即数呢?准确的说这里所指的是12位立即数imm12。先说怎么判断某数是不是12位立即数,12位立即数的条件是:

  1. 如果某个数的数值范围是0~0xFF之间,那么这个数一定是立即数;
  2. 把某个数展开成2进制,这个数的最高位1至最低位1之间的二进制数序列的位数不能超过8位;
  3. 这个数的二进制序列凑够8位之后的的右边必须为偶数个连续的 0

3.5 ldr指令

ldr寄存器加载指令:

LDR{<c>}{<q>} <Rt>, <label> ;如ldr r0, =0x2FAB4

ldr指令多用于从ram中将一个32位的字数据传送到目的寄存器中

LDR<c> <Rt>, [<Rn>{, #+/-<imm12>}]

如:LDR   R0,[R1,#4]             //将内存地址为R1+4的字数据读入寄存器R0

LDR<c> <Rt>, [<Rn>], #+/-<imm12>

如:ldr r0, [r1], #8 ;将内存地址R1的字数据读入r0,之后r1+8

LDR<c> <Rt>, [<Rn>, #+/-<imm12>]!

如:LDR   R0,[R1,#8] !          ;将存储器地址为R1+8的字数据读入寄存器R0,并将新地址R1+8写入R1。

 

3.6 str指令

str 将数据存入地址中

如上图中,将r1的内容,写入r0+4的地址 

3.7 bic指令

bic指定位清零指令:

BIC{S}<c> <Rd>, <Rn>, #<const>;将rn中的字数据const为1的比特清零,把结果放入rd 

3.8 orr指令

orr指定位置位指令:

ORR{S}<c> <Rd>, <Rn>, #<const>

        汇编指令的s后缀,几乎所有的汇编指令都可以在指令后面加上s后缀,s后缀的含义是在指令执行过程中会更新cpsr寄存器的N,V,C,Z位

  1. N:在结果是有符号的二进制补码情况下,如果结果为负数,则N=1;如果结果为非负数,则N=0
  2. Z:如果结果为0,则Z=1;如果结果为非零,否则Z=0
  3. C:是针对无符号数最高有效位向更高位进位时C=1;减法中运算结果的最高有效位从更高位借位时C=0
  4. V:该位是针对有符号数的操作,会在下面两种情形变为1,两个最高有效位均为0的数相加,得到的结果最高有效位为1;两个最高有效位均为1的数相加,得到的结果最高有效位为0;除了这两种情况以外V位为0

<c>自选地增加执行条件

3.9 cmp指令

CMP比较指令用于比较两个寄存器的值或者比较一个寄存器和立即数的值,其原理是对待比较的两个数求差,看结果是否为0,这个指令会无条件修改N,V,C,Z位。

3.10 b指令

        b指令类似c语言的goto语句,能够实现无条件跳转。跳转时需要一个lable,表示要跳转到什么地方去 

 

http://www.xdnf.cn/news/1061299.html

相关文章:

  • 从生活场景学透 JavaScript 原型与原型链
  • 棱镜观察|EMB“重构”卡钳,车企降本压力与Brembo困局
  • 力扣-62.不同路径
  • Cesium、ThreeWebGL详解(二)渲染引擎向GPU传数据、性能优化、引擎对比
  • Docker容器常用命令汇总
  • 华为云Flexus+DeepSeek征文 | 利用Dify平台构建多智能体协作系统:从单体到集群的完整方案
  • python自助棋牌室管理系统
  • 全面掌握 C++ 基础:关键特性与进化
  • Llama 4 模型卡及提示格式介绍
  • svn客户端使用教程简易入门:附外网远程访问内网SVN服务通用方法
  • 【服务器R环境架构】基于 micromamba下载 R 库包
  • React封装框架dvajs(状态管理+异步操作+数据订阅等)
  • Windsurf SWE-1模型评析:软件工程的AI革命
  • TensorFlow+CNN垃圾分类深度学习全流程实战教程
  • Python设计模式终极指南:18种模式详解+正反案例对比+框架源码剖析
  • STM32 HAL 初始化I2C启动DS1307
  • FPGA基础 -- Verilog 命名事件
  • QT6与VS下实现没有CMD窗口的C++控制台程序
  • MySQL 的 WITH ROLLUP 功能
  • python画三维立体图
  • 容器运行时保护:用Falco构建云原生安全防线
  • angular 图斑点击,列表选中并滚动到中间位置
  • ROS学习之服务通信
  • 2025虚幻引擎文件与文件夹命名规律
  • Tensorflow C++ API从入门到放弃
  • STUN (Session Traversal Utilities for NAT) 服务器是一种网络协议
  • MySQL八股文
  • AIGC - Prompt Optimizer 提示词优化器
  • 编程马拉松的定义、运作与发展
  • 解锁微服务潜能:深入浅出 Nacos