当前位置: 首页 > 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,表示要跳转到什么地方去 

 

相关文章:

  • DAY 54 python打卡
  • c++ 虚析构函数
  • idea中push拒绝,merge,rebase的区别
  • 《汇编语言:基于X86处理器》第3章 汇编语言基础
  • 【笔记】解决部署国产AI Agent 开源项目 MiniMax-M1时 Hugging Face 模型下载缓存占满 C 盘问题:更改缓存位置全流程
  • 基于物联网的智能衣柜系统设计
  • 研英语作文万能模板
  • Maven 之工程化开发核心指南:插件配置、pom 文件与依赖管理
  • 掌握Bash脚本编写:从服务启动脚本到语法精要
  • Tomcat双击startup.bat闪退的解决方法
  • 【Python进阶系列】第9篇:聊聊 Python 中常用的第三方库
  • Nacos Server 界面
  • JetBrains IDE v2025.1 升级,AI 智能+语言支持齐飞
  • 解决 Conda 玑境激活问题:缺少 `bin/activate` 文件的应对方法
  • 以太坊节点搭建私链(POA)
  • 【Mini-F5265-OB开发板试用测评】3、MDS 可编程 IP 互联模块
  • WebServer实现:muduo库的主丛Reactor架构
  • 高并发秒杀系统实战(Redis+Lua分布式锁防超卖与库存扣减优化)
  • JVM对象内存分配机制全解析
  • PCB板高速飞拍检测系统 助力电子制造自动化领域
  • 深圳个人做网站/做竞价推广大概多少钱
  • 网站开发周期是什么意思/网络链接推广
  • 动漫网站建设方案设计/新网seo关键词优化教程
  • 无锡网站制作难吗/疫情防控数据
  • 建设网站属于什么费用/搜索引擎营销分析
  • 浅谈网站建设/成都网站优化平台