当前位置: 首页 > 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.lqws.cn/news/449767.html

相关文章:

  • uniapp 微信小程序在线引入字体图标
  • 数据集-目标检测系列- 餐具叉子 数据集 fork >> DataBall
  • LibCpr: Windows环境下实现一个C++版本的Http客户端
  • Spring Cloud 服务调用详解:Ribbon 负载均衡与 Feign 声明式接口调用
  • 【MATLAB代码】制导方法介绍与例程——追踪法,适用于二维平面,目标是移动的|附完整源代码
  • C++基础算法————并查集
  • 【Dify精讲】第14章:部署架构与DevOps实践【知识卡片】
  • 虹科案例 | 欣旺达如何实现动力电池测试的长期稳定性+自动化?
  • 【NLP入门系列三】NLP文本嵌入(以Embedding和EmbeddingBag为例)
  • 高效获取速卖通商品实时数据:API 接口开发与接入全流程
  • ReAct
  • 【二进制安全作业】250617课上作业4 - start
  • Linux (2)
  • 【stm32】标准库学习——I2C
  • 指标解读——113页企业信息化成熟度评估指标【附全文阅读】
  • 算法第38天|322.零钱兑换\139. 单词拆分
  • C语言:二分搜索函数
  • 【Java学习笔记】线程基础
  • 【RTSP从零实践】2、使用RTP协议封装并传输H264
  • JetBrains IDE v2025.1 升级,AI 智能+语言支持齐飞
  • Maven 之工程化开发核心指南:插件配置、pom 文件与依赖管理
  • GreatSQL加入openKylin社区,共推开源生态建设
  • keep-alive缓存文章列表案例完整代码(Vue3)
  • Symbol.iterator 详解
  • 《被讨厌的勇气》详细概述
  • 【大数据】java API 进行集群间distCP 报错unresolvedAddressException
  • vue3打包后,图片丢失
  • 【unity游戏开发——热更新】什么是Unity热更新
  • 【精选】基于SpringBoot的宠物互助服务小程序平台开发 微信小程序宠物互助系统 宠物互助小程序平台设计与实现 支持救助发布+领养申请+交流互动功能
  • 无人机不再“盲飞”!用Python搞定实时目标识别与跟踪