1907_Arm Cortex-M3的基本了解

1907_Arm Cortex-M3的基本了解

全部学习汇总: g_arm_cores: ARM内核的学习笔记 (gitee.com)

我发现Arm Coretex-M3有一个专门的DataSheet,看起来这个的确是被当做了一个设计的产品来对待的。正好,基于这个文件来看看M3具备哪些基本的特性,尤其是我关注的软件设计方面。

  • ATB是高级trace总线的意思。一直听说trace是很高级的调试功能,但是时至今日我没有用过。惭愧、惭愧!
  • M3的MPU这里描述是可选的,在之前看M系列内核的对比表的时候还以为这个是必然会集成的。
  • 串口的调试方式,就是调试器设置的时候需要选择的SWD模式。

增加之前看过的文档关于MPU部分的截图,的确是让我在这里产生了疑惑。

支持的基本功能:内核、NVIC中断控制器、各种总线、可选的MPU、调试以及trace的支持。

这里提到了一个printf风格的调试,不知道是一个什么样的具体功能。而我个人的确是很喜欢在软件调试的时候一通printf的。

调试口是直接接到总线上而不是CPU上,trace的模块ETM则是靠近CPU一些。

指令中是支持基本的push以及pop操作的。不过,这两个指令在我看各种汇编代码的时候似乎是没看到。

看起来,trace不仅是硬件到位了就能够顺利开启的一个功能。这个也是需要软件配置寄存器来支持一下的,或者,也可能是调试器来修改寄存器?

这个是一个指令集的图,看的一知半解。几个想到的点记录一下:

  • M3和M4都是基于v7的指令集的,但是在指令集上也有不同。其实,从之前的M系列的对比表上也是可以看出一些信息的。M4是有DSP的,而M3是没有DSP的。DSP肯定是有自己的指令集的,因此M4肯定有多于M3的指令。
  • v6以及v7中似乎有一些指令是完全相同的名称,比如ADC、ADD等。大概看了下,可能左下角的小方块是v6的架构,其他的全都是v7?这么看,v7相对于v6来说在指令集上的扩种的确是多很多。
  • 两个坐标方向中的箭头,我觉得可能是划定对应矩形的意思。如果是这样,M4比M3多出来的指令是很多的。不过,从这个包含的关系上来看,或许M4可以完全按照M3来使用?
  • 这么看下来,可能M4的优势是在于DSP的指令扩展。不知道现在的编译器是否会优先考虑这方面的使用,否则两者的算力或者性能岂不是没有过多的差距?

这个术语表还是可以复习看一下的,里面很多功能块需要关注下。算是丰富对这个架构理解的很好的语言元素。

相关推荐
森G8 小时前
七、04ledc-sdk--------makefile有变化
linux·c语言·arm开发·c++·ubuntu
VekiSon12 小时前
Linux内核驱动——杂项设备驱动与内核模块编译
linux·c语言·arm开发·嵌入式硬件
AI+程序员在路上13 小时前
Nand Flash与EMMC区别及ARM开发板中的应用对比
arm开发
17(无规则自律)19 小时前
深入浅出 Linux 内核模块,写一个内核版的 Hello World
linux·arm开发·嵌入式硬件
梁洪飞1 天前
内核的schedule和SMP多核处理器启动协议
linux·arm开发·嵌入式硬件·arm
代码游侠2 天前
学习笔记——Linux字符设备驱动
linux·运维·arm开发·嵌入式硬件·学习·架构
syseptember2 天前
Linux网络基础
linux·网络·arm开发
代码游侠2 天前
学习笔记——Linux字符设备驱动开发
linux·arm开发·驱动开发·单片机·嵌入式硬件·学习·算法
程序猿阿伟3 天前
《Apple Silicon与Windows on ARM:引擎原生构建与模拟层底层运作深度解析》
arm开发·windows
wkm9563 天前
在arm64 ubuntu系统安装Qt后编译时找不到Qt3DExtras头文件
开发语言·arm开发·qt