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的指令扩展。不知道现在的编译器是否会优先考虑这方面的使用,否则两者的算力或者性能岂不是没有过多的差距?

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

相关推荐
qq_459730033 小时前
4-3 MCU中ARM存储器的作用
arm开发·单片机·嵌入式硬件
轩辰~13 小时前
网络协议入门
linux·服务器·开发语言·网络·arm开发·c++·网络协议
ARM&开发(Haidong)13 小时前
ARM 获取cpu个数
arm开发
憧憬一下2 天前
PCIe_Host驱动分析_设备枚举
arm开发·嵌入式硬件·嵌入式·pcie·linux驱动开发
7yewh2 天前
嵌入式Linux QT+OpenCV基于人脸识别的考勤系统 项目
linux·开发语言·arm开发·驱动开发·qt·opencv·嵌入式linux
憧憬一下4 天前
PCIe_Host驱动分析_地址映射
arm开发·嵌入式硬件·嵌入式·linux驱动开发·pci/pcie
楼兰公子4 天前
相机主要调试参数
arm开发·驱动·camera·v4l2
7yewh4 天前
嵌入式驱动RK3566 HDMI eDP MIPI 背光 屏幕选型与调试提升篇-eDP屏
linux·arm开发·驱动开发·嵌入式硬件·嵌入式linux·rk·edp
千千道6 天前
深入理解 Linux 内核启动流程
linux·arm开发·驱动开发
徐某人..6 天前
ARM嵌入式学习--第八天(PWM)
arm开发·学习·arm