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

相关推荐
在学了加油9 分钟前
ResNet50V2学习笔记
笔记·学习
wljt9 分钟前
Spring boot学习笔记六:SpringBoot实用技术整合
spring boot·笔记·学习
MY_TEUCK26 分钟前
【Agent Skills学习笔记】2小时从会用到会造:什么是Skills?怎么用?怎么写?
人工智能·笔记·学习
skilllite作者27 分钟前
SkillLite 技术演进笔记:Workspace、沙箱与进化
java·开发语言·前端·笔记·安全·agentskills
明月清了个风31 分钟前
libmodbus笔记
笔记·嵌入式软件·libmodbus
YaBingSec1 小时前
玄机靶场-第三届-长城杯-初赛-SnakeBackdoor WP
java·运维·笔记·tomcat·ssh
handler0110 小时前
从源码到二进制:深度拆解 Linux 下 C 程序的编译与链接全流程
linux·c语言·开发语言·c++·笔记·学习
寒秋花开曾相惜13 小时前
(学习笔记)4.1 Y86-64指令集体系结构(4.1.4 Y86-64异常&4.1.5 Y86-64程序)
开发语言·jvm·数据结构·笔记·学习
Theodore_102214 小时前
深度学习(15):倾斜数据集 & 精确率-召回率权衡
人工智能·笔记·深度学习·机器学习·知识图谱
不会聊天真君64714 小时前
JavaScript基础语法(Web前端开发笔记第三期)
前端·javascript·笔记