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

相关推荐
whyTeaFo3 小时前
MIT 6.1810: Lab traps: traps
笔记
小陈phd4 小时前
多模态大模型学习笔记(四十八)——从自然语言到 SQL:大模型时代结构化数据查询的技术革命与落地实践
笔记·sql·学习
元气少女小圆丶4 小时前
SenseGlove Nova 2+Unity开发笔记4
笔记·unity·游戏引擎
ZK_H5 小时前
MFC程序开发自学笔记其一——windows应用程序与c++基础
c++·笔记·mfc
GLDbalala6 小时前
GPU PRO 5 - 2.6 Wire Antialiasing 笔记
笔记
梦076 小时前
学习笔记-ClaudeCode快速安装配置上手
笔记·学习
江华森6 小时前
TDengine 时序数据库深度学习笔记
笔记·时序数据库·tdengine
路人蛃6 小时前
【深入理解计算机系统】第二章第一节(信息存储)笔记
服务器·网络·笔记·计算机网络·系统架构
imDwAaY7 小时前
机器学习入门:从感知机到逻辑回归,理解线性分类器与Softmax CS188 Note20 学习笔记
人工智能·笔记·python·学习·机器学习·逻辑回归
chushiyunen7 小时前
json-rpc笔记
笔记·rpc·json