| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 嵌入式 -> 第一章:ARM公司Cortex-M 系列处理器介绍,第二章:嵌入式软件开发介绍和第三章:Cortex-M3和Cortex-M4处理器的一般介绍 -> 正文阅读 |
|
[嵌入式]第一章:ARM公司Cortex-M 系列处理器介绍,第二章:嵌入式软件开发介绍和第三章:Cortex-M3和Cortex-M4处理器的一般介绍 |
?????
C
o
r
t
e
x
?
M
3
Cortex-M3
Cortex?M3和
C
o
r
t
e
x
?
M
4
Cortex-M4
Cortex?M4处理器使用32位体系结构,
R
e
g
i
s
t
e
r
b
a
n
k
Register\quad bank
Registerbank里面的内部寄存器和,
d
a
t
a
p
a
t
h
data\quad path
datapath和总线接口都是32位的。
C
o
r
t
e
x
?
M
Cortex-M
Cortex?M系列处理器的指令集体系结构
(
I
n
s
t
r
u
c
t
i
o
n
S
e
t
A
r
c
h
i
t
e
c
t
u
r
e
,
I
S
A
)
(Instruction\quad Set\quad Architecture,ISA)
(InstructionSetArchitecture,ISA)叫做
T
h
u
m
b
I
S
A
Thumb\quad ISA
ThumbISA,它是基于
T
h
u
m
b
?
2
Thumb-2
Thumb?2技术。这种技术支持16位指令和32位指令的混合。
C
o
r
t
e
x
?
M
3
Cortex-M3
Cortex?M3和
C
o
r
t
e
x
?
M
4
Cortex-M4
Cortex?M4处理器是哈弗体系结构(最明显的特征是指令和数据的存储是分开的,接入路径也是分开的,这一点和冯洛伊曼体系结构是不同的),32位寻址,支持
4
G
B
4GB
4GB存储空间,支持
B
i
t
B
a
n
d
Bit\quad Band
BitBand特性。当然还有很多其它的特性我这里没有提到,有需要的可以直接查询文档。 ?????
A
R
M
ARM
ARM公司的所有
C
o
r
t
e
x
?
M
Cortex-M
Cortex?M处理器都是32位的
R
e
d
u
c
e
d
I
n
s
t
r
u
c
t
i
o
n
S
e
t
C
o
m
p
u
t
i
n
g
,
R
I
S
C
Reduced\quad Instruction\quad Set\quad Computing,RISC
ReducedInstructionSetComputing,RISC处理器,这些处理器都是32位的寄存器,32位的总线接口,32位的内部数据路径。除了32位数据,所有
C
o
r
t
e
x
?
M
Cortex-M
Cortex?M处理器,也包括其它
A
R
M
ARM
ARM公司的处理器,也可以处理8比特和16比特数据。
C
o
r
t
e
x
?
M
3
Cortex-M3
Cortex?M3和
C
o
r
t
e
x
?
M
4
Cortex-M4
Cortex?M4处理器也支持一些64比特的数据操作。
C
o
r
t
e
x
?
M
3
Cortex-M3
Cortex?M3和
C
o
r
t
e
x
?
M
4
Cortex-M4
Cortex?M4处理器都是三级流水线设计(取指令,解码,执行),并且都是哈弗总线架构,也就是取指令和数据接入可以同时进行。
C
o
r
t
e
x
?
M
Cortex-M
Cortex?M处理器的存储系统使用32比特寻址,因为这样多以它最有只能有最大
4
G
B
4GB
4GB的地址空间。和其它
A
R
M
ARM
ARM公司的处理器一样,
C
o
r
t
e
x
?
M
Cortex-M
Cortex?M处理器基于
L
o
a
d
?
S
t
o
r
e
Load-Store
Load?Store架构,这就意味着数据先要从存储空间中取出来,然后处理,最后再写入到存储空间中。取出,操作,写入的每一步都有对应的指令去操作。
?????这些年
A
R
M
ARM
ARM公司发布了很多不同的处理器,针对这些不同的处理器它们的
A
R
M
ARM
ARM架构也有很多不同的版本。例如,
C
o
r
t
e
x
?
M
3
Cortex-M3
Cortex?M3和
C
o
r
t
e
x
?
M
4
Cortex-M4
Cortex?M4处理器都是基于
A
R
M
v
7
?
M
ARMv7-M
ARMv7?M架构的,一种指令集架构可以有不同的具体的实现,也就是不同的
微
架
构
,
M
i
c
r
o
?
a
r
c
h
i
t
e
c
t
u
r
e
微架构,Micro-architecture
微架构,Micro?architecture(不同的流水线等级,不同的总线协议)。 ?????随着 T h u m b ? 2 Thumb-2 Thumb?2技术的引进, T h u m b Thumb Thumb指令集被扩展到同时支持16比特和32比特的指令编码,现在 T h u m b ? 2 Thumb-2 Thumb?2就可以满足所有的处理需求且不需要在两种状态之间进行切换。其实实际上 C o r t e x ? M Cortex-M Cortex?M处理器是不支持32位的 A R M ARM ARM指令的。 C o r t e x ? M Cortex-M Cortex?M处理器的中断处理也是在 T h u m b Thumb Thumb状态,但是经典的 A R M ARM ARM处理器的中断处理是在 A R M ARM ARM状态。图是经典的 A R M ARM ARM处理器和 C o r t e x ? M Cortex-M Cortex?M处理器的指令集的区别对比,从图中可以看出经典的 A R M ARM ARM处理器同时支持32位的 A R M ARM ARM指令和16位的 T h u m b Thumb Thumb指令集, C o r t e x ? M Cortex-M Cortex?M处理器只支持16位和32位混合的 T h u m b Thumb Thumb指令集。有了 T h u m b ? 2 Thumb-2 Thumb?2技术之后,有以下几项好处:
????? C o r t e x ? M 3 Cortex-M3 Cortex?M3和 C o r t e x ? M 4 Cortex-M4 Cortex?M4处理器本身是没有储存器的,但是它们提供了总线接口,因此微控制器生产商可以自己根据自己的需求来配置相应的存储系统。一般微控制器生产商需要添加以下模块到自己的存储系统:
|
|
嵌入式 最新文章 |
基于高精度单片机开发红外测温仪方案 |
89C51单片机与DAC0832 |
基于51单片机宠物自动投料喂食器控制系统仿 |
《痞子衡嵌入式半月刊》 第 68 期 |
多思计组实验实验七 简单模型机实验 |
CSC7720 |
启明智显分享| ESP32学习笔记参考--PWM(脉冲 |
STM32初探 |
STM32 总结 |
【STM32】CubeMX例程四---定时器中断(附工 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 22:54:39- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |