ARM工作模式、汇编学习

一、ARM工作

(一)处理器工作模式,ARM内核工作模式有哪些,分别是在什么情况下被切换?

(二)工作模式:cpsr(1),spsr(5),pc(1),sp和lr(6)

(三)ARM寄存器个数

1.Corte系列:40

2.ARM系列:37

(四)程序状态寄存器(10000 User mode)

(五)异常处理,异常向量表是什么?

1.SPSR:保存CPSR

2.LR:保存PC

二、汇编

(一)启动

学习arm汇编的主要目的是为了编写arm启动代码,启动代码启动以后,引导程序到c语言环境下运行。换句话说启动代码的目的是为了在处理器复位以后搭建c语言最基本的需求。因此启动代码的主要任务有:

1、初始化异常向量表;

2、初始化各工作模式的栈指针寄存器;

3、开启arm内核中断允许;

4、将工作模式设置为user模式;

5、完成上述工作后,引导程序进入c语言主函数执行;

(二)KEIL:伪指令

area reset,code,readonly

code32

entry ;运行代码

....

end

(三)什么是立即数?如何判断某数是非法12位立即数?

1.立即数:可以直接通过mov写入通用寄存器的常量值。指在指令中直接嵌入的常量值,通常用于算术运算、逻辑运算或数据加载等操作。

2.判断方法:

①写成二进制数值,判断前24位是否为0

②若前24位为0,则是立即数

③若前24位不是0,判断循环右移偶数次后是否满足前24位为0

④倒数8到12位写移位次数除2的值

(四)b,bl,bx指令的区别是什么?

1.b:直接跳转到b后面的标志地方执行,与goto类似

2.bl:用于函数调用,跳转前将pc指针中的地址存入链接寄存器(LR)中

3.bx:将链接寄存器LR中的地址赋于pc寄存器中

(五)ARM内核采用的栈是那种栈?

1.栈分类:满减、空减、满增、空增

2.满和空的区别

栈针指向的栈内容为空:空栈,先赋值再移位

栈针指向的栈内容不为空:满栈 ,先移位再赋值

3.增和减

增长方向从高地址向低地址:减栈

增长方向从低地址向高地址:增栈

4.ARM内核中采用的栈:满减栈,0x40000000,大小为0x1000,所以指向0x40001000

三、RAM的细分

(一)IRAM (Integration RAM)

IRAM是一种将处理器和内存集成在同一芯片上的技术,主要目的是减少处理器与内存之间的延迟。IRAM通常使用DRAM或SRAM作为存储单元,但其核心特点是高度集成,适合嵌入式系统或高性能计算场景。

(二)DRAM (Dynamic RAM)

DRAM是一种动态随机存取存储器,需要定期刷新以保持数据。它的存储单元由电容和晶体管组成,结构简单,密度高,成本低,但速度较慢且功耗较高。DRAM通常用于主内存(如计算机的RAM)。

(三)SRAM (Static RAM)

SRAM是一种静态随机存取存储器,不需要刷新即可保持数据。它的存储单元由6个晶体管组成,速度快、功耗低,但成本高、密度低。SRAM通常用于高速缓存(如CPU的L1、L2缓存)。

(四)MRAM (Magnetoresistive RAM)

MRAM利用磁阻效应存储数据,具有非易失性、高速和无限次写入的优点,但成本较高,目前主要用于特定领域(如航空航天)。

(五)SDRAM (Synchronous DRAM)

SDRAM是与系统时钟同步的DRAM,通过同步操作提高数据传输效率。常见的DDR系列内存(如DDR4、DDR5)均基于SDRAM技术。

(六)PRAM (Phase-change RAM)

PRAM利用相变材料的电阻变化存储数据,结合了DRAM和闪存的优点,具有非易失性和较高的读写速度。

(七)RRAM (Resistive RAM)

RAM通过改变材料的电阻值存储数据,具有高密度、低功耗和快速读写的潜力,目前仍在研发阶段。

(八)NVRAM (Non-Volatile RAM)

NVRAM泛指所有非易失性RAM,如MRAM、PRAM和RRAM,断电后仍能保留数据,适合需要持久化存储的场景。

相关推荐
寄思~7 小时前
Excel 数据匹配工具 -笔记
笔记·python·学习·excel
朔北之忘 Clancy8 小时前
2020 年 6 月青少年软编等考 C 语言二级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·尺取法
知识分享小能手8 小时前
Ubuntu入门学习教程,从入门到精通,Ubuntu 22.04 中安装 Docker 容器 —— 知识点详解(26)
学习·ubuntu·docker
听情歌落俗8 小时前
ARM架构-硬件架构和汇编指令
汇编·arm开发·硬件架构
炸膛坦客8 小时前
Cortex-M3-STM32F1 开发:(五十)软件模拟 IIC 和硬件 IIC 的区别,以及软件 IIC 配置步骤及相关函数,以及相关问题
stm32·单片机·嵌入式硬件
开开心心_Every8 小时前
安卓做菜APP:家常菜谱详细步骤无广简洁
服务器·前端·python·学习·edge·django·powerpoint
wdfk_prog8 小时前
WIN11如何可以安装ISO
linux·笔记·学习
Darkershadow8 小时前
蓝牙学习之Provision(2)
学习·蓝牙·ble·mesh
泡泡糖的中文规格书8 小时前
【无标题】
单片机·嵌入式硬件·规格说明书·datasheet
kitsch0x978 小时前
论文学习_IDFUZZ: Intelligent Directed Grey-box Fuzzing
学习