LV.23 D1 ARM体系结构概述 学习笔记

一、必须要了解的ARM知识点

1、ARM公司简介

ARM(Advanced RISC Machines)有三种含义:        

        它是一个公司的名称、它是一类微处理器的通称、它是一种技术的名称。

2、ARM处理器家族

早先经典处理器

        包括ARM7、ARM9、ARM11家族。  

Cortex-M 系列

        为单片机驱动的系统提供的低成本优化方案,应用于传统 的微控制器市场,智能传感器,汽车周边部件等。

Cortex-A 系列

        针对开放式操作系统的高性能处理器;

        应用于智能手机,数字电视,智能本等高端运用。  

Cortex-R 系列

        针对实时系统、满足实时性的控制需求;

        应于汽车制动系统,动力系统等。

3、ARM处理器架构

概念

        体系结构定义指令集和基于这一体系结构下处理器的 编程模型(基本数据类型、工作模型、寄存器组)。基于同种体系结构可以有多种处理器、每个处理器的性能不同,面向的应用领域也不同。

ARM体系结构发展  

        目前ARM体系架构共定义了8个版本V1-V8      

        V1-V3 最早的版本,目前已废弃      

        V4-V6 经典处理器中运用的比较多      

        V7  目前Cortex系列处理器主要是这种架构、支持Thumb-2的32位指令集      

        V8 兼容ARMv7架构的特性,并支持64位数据处理

4、ARM指令集

指令集的概念

        处理器能够识别并执行的指令集合;

        每一条指令可处理一个简单或复杂操作(加、加乘…);

        每一条指令对应一条或几条汇编指令。

指令集常见分类

        复杂指令集(CISC):包含处理复杂操作的特定指令,指令长度不固定,执行需要多个周期。

        精简指令集(RISC):指令简单而有效,格式和长度通常是固定的,大多数指令在一个周期内可以执行完毕,

ARM的内核是基于RISC体系结构的

5、SOC的概念

SOC(片上系统)        

        指的是在单个芯片上集成一个完整的计算机系统,所谓完整的系统一般包括中央处理器(CPU)、存储器、以及外围电路等。

 

 二、Cortex-M0概述

1、Cortex-M0处理器简介

        Cortex-M 系列产品主要包括 Cortex-M0、Cortex-M1、Cortex-M3、Cortex-M4、Cortex-M7 等,其中 Cortex-M0 主打低功耗和混合信号的处理,M3 主要用来替代 ARM7,重点侧重能耗与性能的平衡,而 M7 则重点放在高性能控制运算领域。

注:我们课程中使用的STM32F051微控制器内核就是ARM Cortex-M0、因此我们首先学习一下M0内核的知识

2、Cortex-M0体系结构

Cortex-M0结构框图

        Cortex-M0 微处理器主要包括处理器内核、嵌套向量中断控制器(NVIC)、调试子系统、内部总线系统构成。Cortex-M0 微处理器通过精简的高性能总线(AHB-LITE)与外部进行通信。

 

 

Cortex-M0特性

        Thumb 指令集,高效、高代码密度;

        高性能,使用ARMv6-M的体系架构;

        中断数量可配置(1~32 个),4 级中断优先级,低中断切换时延,提供不可屏蔽中断(NMI)输入保障高可靠性系统;

        门电路少,低功耗,处理器可在休眠状态下掉电以降低功耗,还可被 WIC 唤醒;

        与 Cortex-M1 处理器兼容,向上兼容 Cortex-M3 和 Cortex-M4 处理器,可以很容易地升级到 Cortex-M3。Cortex-M3 和 Cortex-M4 移植到 Cortex-M0 也非常简单。

        支持多种嵌入式操作系统,也被多种开发组件支持,包括 MDK(ARM Keil 微控制器开发套件)、RVDS(ARM RealView 开发组件)、IAR C 编译器等。

Cortex-M0工作模式

Cortex-M0有两种工作模式和两种工作状态

线程模式(Thread Mode):

        芯片复位后,即进入线程模式,执行用户程序;

处理模式(Handler Mode):

        当处理器发生了异常或者中断,则进入处理模式进行处理、处理完成后返回线程模式。

Thumb状态:正常运行时处理器的状态

调试状态:调试程序时处理器的状态

 Cortex-M0寄存器组——通用寄存器

Cortex-M0 处理器内核有 13 个通用寄存器以及多个特殊寄存器,如图 所示。具体介绍如下:

        R0-R12:通用寄存器。其中 R0-R7 为低端寄存器,可作为 16 位或 32 位指令操作数,R8-R12 为高端寄存器,只能用作 32 位操作数

        R13:堆栈指针 SP,Cortex-M0 在不同物理位置上存在两个栈指针,主栈指针 MSP,进程栈指针 PSP。在处理模式下,只能使用主堆栈,在线程模式下,可以使用主堆栈也可以使用进程堆栈,这主要是由 CONTROL 寄存器控制完成。 系统上电的默认栈指针是MSP

        R14:连接寄存器(LR),用于存储子程序或者函数调用的返回地址

         R15:程序计数器(PC),存储下一条将要执行的指令的地址。

Cortex-M0寄存器组——特殊寄存器 

xPSR:组合程序状态寄存器,该寄存器由三个程序状态寄存器组成

        应用PSR(APSR):     包含前一条指令执行后的条件标志

        中断PSR(IPSR):  包含当前ISR的异常编号

        执行PSR(EPSR)   :  包含Thumb状态位

PRIMSK:中断屏蔽特殊寄存器。

CONTROL:控制寄存器    

        控制处理器处于线程模式是,使用哪个堆栈=0时,使用MSP,=1时,使用PSP

        处理器模式时,固定使用MSP

3、Cortex-M0异常和中断

        Cortex-M0 处理器最多支持 32 个外部中断(通常称为 IRQ)和一个不可屏蔽中断(NMI),       另外 Cortex-M0 还支持许多系统异常(Reset、HardFault、SVCall、PendSV、SysTick),它们主要用于操作系统和错误处理,参见下表

 

4、Cortex-M0指令集

ARM 处理器支持两种指令集:ARM 和 Thumb。

EPSR 寄存器的 T 标志位负责指令集的切换,Cortex-M0只支持Thumb指令。

 ARM指令集

        32位精简指令集;

        指令长度固定;

        降低编码数量产生的耗费,减轻解码和流水线的负担;

Thumb指令集

        Thumb指令集是ARM指令集的一个子集;

        指令宽度16位;

        与32位指令集相比,大大节省了系统的存储空间;

        Thumb指令集不完整,所以必须配合ARM指令集一同使用。

注:Thumb 与 ARM 相比,代码体积小了 30%,但性能也低了 20%。2003 年,ARM 公司引入了 Thumb-2 技术,具备了一些 32 位的 Thumb 指令,使得原来很多只有 ARM 指令能够完成的功能,用 Thumb 指令也可以完成了。Cortex-M0 基于的 ARMv6-M 体系结构,该体系结构的处理器只是用了16位Thumb指令和部分32位Thumb指令

 

三、认识STM32

1、STM32产品的介绍

2、STM32产品命名规范

以STM32F051K8U6为例:

3、STM32F0体系架构

 系统主要由以下几个模块组成 :

        ● 二个主模块 :  

                – Cortex-M0 内核及先进高性能总线 (AHB bus)    

                – 通用 DMA ( GP-DMA -- general-purpose DMA)

        ● 四个从模块 :    

                – 内部 FLASH    

                – 内部SRAM    

                – 专门用于连接 GPIO 口的 AHB2    

                – AHB 到 APB 的桥 , 所有的外设都挂在 APB 总线上

 

 四、STM32F0硬件平台介绍

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2780458.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

【Java从入门到精通】Java变量类型

Java 变量类型 在 Java 语言中,所有的变量在使用前必须声明。 声明变量的基本格式如下: type identifier [ value][, identifier [ value] ...] ; 格式说明: type -- 数据类型。identifier -- 是变量名,可以使用逗号 , 隔开…

python-分享篇-GUI界面开发-PyQt5-对QListWidget列表进行数据绑定

代码 # -*- coding: utf-8 -*-# Form implementation generated from reading ui file bindlist.ui # # Created by: PyQt5 UI code generator 5.11.3 # # WARNING! All changes made in this file will be lost! 对QListWidget列表进行数据绑定from PyQt5 import QtCore, QtG…

为什么总有人觉得前端很简单?尤其是水平半瓶水的人。

造成这个印象的原因很多,贝格前端工场结合自己的经验,为大家揭开这个谜底。低端的前端确实简单,但是高级阶段确实不简单。 缺乏深入了解: 有些人可能只是对前端开发有一些浅显的了解,没有深入研究过前端开发的技术和知…

车载电子电器架构 —— 电子电气系统车载功能子系统

车载电子电器架构 —— 电子电气系统车载功能子系统 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 本就是小人物,输了就是输了,不要在意别人怎么看自己。江湖一碗茶,喝完再挣扎,出门靠自己,…

数模.微分方程

或者可以建立一个是实时脚本,也可以转化成上图公式 solver只是一个代名词,代表的是后面七种函数的名字 百分之九十用ode45函数 注意df1是在另外一个文件里面 计算导弹追击问题没有记录,去文件找代码

板块一 Servlet编程:第二节 Servlet的实现与生命周期 来自【汤米尼克的JAVAEE全套教程专栏】

板块一 Servlet编程:第二节 Servlet的实现与生命周期 一、Servlet相关概念Serlvet的本质 二、中Web项目中实现Servlet规范(1)在普通的Java类中继承HttpServlet类(2)重写service方法编辑项目对外访问路径 二、Servlet工…

392. Is Subsequence(判断子序列)

题目描述 给定字符串 s 和 t ,判断 s 是否为 t 的子序列。 字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace"是"abcde"的一个子…

【AI大模型应用开发】【LangChain系列】6. LangChain的Callbacks模块:监控调试程序的重要手段

大家好,我是【同学小张】。持续学习,持续干货输出,关注我,跟我一起学AI大模型技能。 LangChain提供了一个回调系统,允许您挂接到LLM应用程序的各个阶段。这对于日志记录、监视、流式传输和其他任务非常有用。 0. Lang…

02.数据结构

一、链表 作用&#xff1a;用于写邻接表&#xff1b; 邻接表作用&#xff1a;用于存储图或树&#xff1b; 1、用数组模拟单链表 #include<iostream> using namespace std;const int N 100010;// head 表示头结点的下标 // e[i] 表示结点i的值 // ne[i] 表示结点i的ne…

mac IDEA基础配置和激活+maven配置+scala插件导入+scala文件打包

文章目录 下载IDEA通过插件激活下载Maven在IDEA上配置Maven在IDEA上加载Scala插件在IDEA中创建Maven项目在IDEA上通过Maven打包scala文件 下载IDEA通过插件激活 IDEA从这里下载&#xff0c;下载首次登陆需要创建一个IntelliJ账号&#xff0c;登陆后点击start trail开启一个月的…

获IROS最佳移动操作论文提名|通研院提出首个实现连续操作任务的空中具身智能机器人CORVUS(渡鸦)

论文导读 本文介绍了通研院机器人实验室发表于2023年国际机器人顶级会议IROS上的论文&#xff0c;题为《Sequential Manipulation Planning for Over-actuated Unmanned Aerial Manipulators》[1]。文章介绍了一种可以实现空中全向平稳飞行的过驱动空间机械臂平台Coordinated …

###C语言程序设计-----C语言学习(12)#进制间转换,十进制,二进制,八进制,十六进制

前言&#xff1a;感谢您的关注哦&#xff0c;我会持续更新编程相关知识&#xff0c;愿您在这里有所收获。如果有任何问题&#xff0c;欢迎沟通交流&#xff01;期待与您在学习编程的道路上共同进步。 计算机处理的所有信息都以二进制形式表示&#xff0c;即数据的存储和计算都采…

Python高级进阶--多线程爬取下载小说(基于笔趣阁的爬虫程序)

目录 一、前言 1、写在前面 2、本帖内容 二、编写代码 1、抓包分析 a、页面分析 b、明确需求 c、抓包搜寻 2、编写爬虫代码 a、获取网页源代码 b、提取所有章节的网页源代码 c、下载每个章节的小说 d、 清洗文件名 e、删除子文件夹 f、将下载的小说的所有txt文件…

【数学建模】【2024年】【第40届】【MCM/ICM】【F题 减少非法野生动物贸易】【解题思路】

一、题目 &#xff08;一&#xff09; 赛题原文 2024 ICM Problem F: Reducing Illegal Wildlife Trade Illegal wildlife trade negatively impacts our environment and threatens global biodiversity. It is estimated to involve up to 26.5 billion US dollars per y…

【数据库】Unlogged 表使用

【数据库】Unlogged 表使用 前言普通表和Unlogged 表的写性能比较普通表创建和数据插入Unlogged 表创建和数据插入比较结果 Unlogged 表崩溃和正常关闭测试Unlogged 表特点总结 前言 大神偶像在开会上提及了Unlogged 表&#xff0c;它的特点很不错&#xff0c;很适合实时数据保…

如何部署一个高可用的 Linux 集群?

部署一个高可用的 Linux 集群需要经过多个步骤和考虑因素。以下是一个简要的指南&#xff0c;帮助您了解如何部署一个高可用的 Linux 集群&#xff1a; 确定需求和目标&#xff1a;在开始部署之前&#xff0c;您需要明确高可用性的定义和目标。对于一些组织而言&#xff0c;高…

【51单片机】自定义动态数码管显示(设计思路&原理&代码演示)

前言 大家好吖&#xff0c;欢迎来到 YY 滴单片机系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过单片机的老铁 主要内容含&#xff1a; 本章节内容为【实现动静态数码管】项目的第四个模块完整章节&#xff1a;传送门 欢迎订阅 YY滴C专栏&#xff01;更多干货持…

react函数组件中使用context

效果 1.在父组件中创建一个createcontext并将他导出 import React, { createContext } from react import Bpp from ./Bpp import Cpp from ./Cpp export let MyContext createContext(我是组件B) export let Ccontext createContext(我是组件C)export default function App…

Ubuntu Linux使用PL2302串口和minicom进行开发板调试

调试远程的服务器上面的BMC&#xff0c;服务器上面安装了Ubuntu&#xff0c;想着可以在服务器接个串口到BMC&#xff0c;然后SSH到服务器的Ubuntu&#xff0c;用minicom来查看串口信息。 准备&#xff1a; 服务器Ubuntu安装mimicom 本机可以ssh到Ubuntu 串口工具PL2302 或者CH3…

springboot177健身房管理系统

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…