ARM芯片架构(RTOS)

前言:笔记韦东山老师的rtos教程,连接放在最后

#ARM介绍

arm芯片属于精简指令集risc,所用的指令比较简单,ARM架构是一种精简指令集(RISC)架构,广泛应用于移动设备、嵌入式系统、物联网等领域。ARM芯片采用ARM架构设计,通常具有较低的功耗和更高的性能效率。

所以arm架构也就是32位精简指令集处理器架构。精简指令集相对于复杂指令集来说,指令数目少,在通道中只包含最有用的指令;执行时间短,确保数据通道快速执行每一条指令;使CPU硬件结构设计变得更为简单;每条指令都采用标准字长。这就是,RISC:精简指令集(Reduced Instruction Set Computer)

在操作系统创建一个任务的时候,通常要创建栈,分配栈的大小,理解栈之后才能理解rtos的本质,对arm芯片的架构有着一些理解能够帮助我们更好的理解,rtos的多任务本质。

ARM架构:System on Chip 缩写SOC,翻译:在一个芯片上有着完整的系统,ARM单片机芯片,集成了一个完成的系统,cpu 内存 flash(对应电脑的硬盘)flash用于保存程序,cpu用来运行程序,和计算功能,在keil5下载选型里面有一个选型,是擦除flash,就是擦除arm芯片里面存储程序的flsh,在程序运行的过程中,会用到内存的空间去存储变量,没有计算功能,使用单纯为了访问数据,写数据,

汇编指令介绍:掌握汇编指令可以理解程序的本质,理解rtos的本质,

可以将汇编语言分为 地址 寄存器 目的 然后分别带入,将地址什么样的目的写入寄存器

读内存:Load

LDR R0,[R1,#4];//读地址"R1+4",得到的4字节数据放入R0
目的LDR 寄存器 R0 地址[R1,#4]

写内存:Store

STR R0,[R1,#4];//把R0的四字节数据写入"R1+4"

加减:ADD SUB

ADD R0 ,R1 ,R2;//将R1 R2 的值相加放入 R0
SUB R0,R0,#1;将R0与R1的值相减放入R0

比较:Compare

DMP R0,R1;R0与R1二者比较的结果存放在PSR中

转跳:Branch

B main ; Branch,//直接跳转
BL main ;Branch and Link //先把返回地址保存在LR寄存器里在转跳

实际函数的反汇编语言:

cpp 复制代码
int add(volatile int a,volatile int b)
{
    volatile int sun;
    sum = a+b;
    return sum;

}

这里是add()函数变量赋值,然后再调用add函数,进行响应。

地址 机器码 汇编码

烧录在芯片上的只有机器码,汇编码是用来给人看的,这一步是什么意思,这些地址和机器码烧录在flash里面,cpu通过读取,地址来获得机器码,也就是 读flash地址 得到机器码 执行机器码 这么一个过程,上面这个汇编语言是add这个函数的反汇编程序。

欢迎指正,希望对你有所帮助!!!

[3-2-1]_ARM架构简明教程_硬件架构与汇编指令_哔哩哔哩_bilibili

相关推荐
DKPT42 分钟前
Java设计模式之行为型模式(责任链模式)介绍与说明
java·笔记·学习·观察者模式·设计模式
崔高杰1 小时前
微调性能赶不上提示工程怎么办?Can Gradient Descent Simulate Prompting?——论文阅读笔记
论文阅读·人工智能·笔记·语言模型
KhalilRuan2 小时前
Unity Demo——3D平台跳跃游戏笔记
笔记·游戏·unity·游戏引擎
MUTA️3 小时前
《MAE: Masked Autoencoders Are Scalable Vision Learners》论文精读笔记
人工智能·笔记·深度学习·transformer
使一颗心免于哀伤4 小时前
《设计模式之禅》笔记摘录 - 6.原型模式
笔记·设计模式
刘孬孬沉迷学习4 小时前
5G标准学习笔记15 --CSI-RS测量
网络·笔记·学习·5g·信息与通信·信号处理
jiang_bluetooth5 小时前
AIC8800M40低功耗wifi在ARM-LINUX开发板上做OTA的调试经验
linux·arm开发·ota·sdio·aic8800·sdio wifi
给自己记录用5 小时前
qt笔记(1)——Qtablewidget使用
笔记·qt
飞升不如收破烂~5 小时前
英语学习笔记2.0
笔记·学习
金色光环5 小时前
概率论:理解区间估计【超详细笔记】
笔记·数学·概率论·数理统计·区间估计