资料介绍
本文将描述Cortex-M0设备的内存映射和内存访问行为。该处理器有一个固定的存储映射,它可以提供高达4GB的可寻址内存。存储映射图如下:
该处理器为处理器核外设寄存器保留了PPB地址范围,关于Cortex-M0处理器以及核外设的内容见
1、存储区、类型和属性
存储映射被分成多个区,每个区都有其存储类型,有些区还有附加属性。存储类型及附加属性决定了如何访问该存储区。
储存类型是下列几种:
普通型(Normal)
为了提高效率、或执行预测读,处理器可以对该类型存储器的存取操作进行重排序。
设备型(Device)
该类型存储器与设备型或强顺序型存储器之间的存取操作,处理器将保持其顺序。
强顺序型(Strongly-ordered)
任何与该类型存储器相关的存取操作,处理器将保持其顺序。
对于设备型和强顺序型存储器的不同顺序要求,意味着存储系统可以将一个写操作缓存到一个设备型存储器中,但是不能缓存到一个强顺序型的存储器中。附加属性有:
可共享(ShaSharreableeable)
对于可共享的存储区,在多总线主设备系统中,存储系统可提供主设备之间的数据同步,例如某个带有DMA控制器的处理器。
强顺序型存储器都具有可共享属性。
如果多个总线主设备访问一个不可分享的存储区域,必须通过软件来保证多个总线主设备之间的数据一致性。
注意:仅当处理器在共享存储器的多处理器系统中时,该属性才有关系。
不可执行(XN)
处理器将阻止不可执行存储区指令的执行。如果从一个不可执行存储区取指令并执行,将会产生一个硬故障。
2、存储系统的访问顺序
对于多数显式的存取指令所产生的存储器访问,存储系统不能保证指令的顺序与实际操作的顺序是一致的,而且对指令的重排序并不会影响到指令序列的行为结果。通常,如果正确的程序执行要求两次内存访问必须按程序的顺序来完成,那么软件必须在内存访问指令之间插入一个存储隔离指令,相关内容见第2-16页存储访问的软件排序。
然而,存储系统能够保证访问设备和强顺序存储区的顺序。对于两个存储访问指令A1和A2,如果A1在A2程序之前发生,则存储访问顺序是:
其中:
- 表示存储系统不能保证访问的顺序。
3、存储访问行为
对内存映射中每个区的访问行为是:
表1、存储访问行为
a、关于存储区、类型和附加属性,可见上文。
其中Code、SRAM和externalRAM区可以存放程序。
关于Cache和可共享存储区的访问限制
当一个系统包含Cache或可共享存储区时,一些存储区有额外的访问限制,有些区被再次细分,如表2所示:
表2、存储区的可共享性和缓存策略
a、更多关于存储区、类型和属性的内容见上文。
b、WT=写通方式,没有写分配。WBWA=写回方式,写分配。更多内容见词汇表(Glossary)。
4、软件对存储访问排序
指令在程序中的顺序并不能始终够保证相应存储操作处理的顺序。这是由于:•处理器可对一些存储访问进行重排列,以提高效率,只要不影响指令顺序的行为。
• 内存映射中的存储器或设备可能有不同的等待状态。
• 有一些存储访问被缓冲或是预测执行的。
上文中存储系统内存访问顺序的内容描述了存储系统如何保证存储访问顺序的情况。此外,如果存储访问的顺序很重要,那么软件必须包括存储隔离指令来保证所希望的顺序。处理器提供以下存储隔离指令:
DMB
数据存储隔离指令,确保DMB之前所有显式存储访问完成之后,其后的存储访问才可以开始执行。DMB的内容见下文。
DSB
数据同步隔离指令,当DSB之前所有的显式存储访问完成之后,其后的指令才可以开始执行。见下文的DSB指令。
ISB
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- ADSP-CM41x混合信号控制处理器,带ARM Cortex-M4/ARM Cortex-M0和16位ADC硬件参考 1次下载
- 基带处理器的一般设计原则资料下载 15次下载
- 处理器的正弦计算资料下载 20次下载
- 到底64位处理器和32位处理器有什么区别呢?资料下载 8次下载
- ARM cortex-M3 异常处理分析资料下载 4次下载
- Cortex-M0处理器及其特性资料下载 15次下载
- Cortex-M3存储器映射资料下载 3次下载
- Cortex-M0处理器的编程模型资料下载 12次下载
- Cortex-M0处理器的故障处理和功耗管理资料下载 4次下载
- Cortex-M0处理器的异常处理模型资料下载 15次下载
- 基于Cortex-M0的USB接口在智能手机底座音响中的应用资料下载 12次下载
- 为什么我的处理器漏电?资料下载 9次下载
- 基于Cortex-M0的BLDC电机驱动和资料详细说明 40次下载
- 深入浅出Cortex-M0学习资料 0次下载
- 基于Cortex-M0内核的LPC111x系列处理器概述及性 36次下载
- Raspberry pico处理器的移植SMP教程 1937次阅读
- Cortex-M0处理器内核异常中断简介 3615次阅读
- Cortex-M0处理器的中断请求形式:电平触发和脉冲输入 1314次阅读
- 浅谈ARM处理器的基础知识 2281次阅读
- 基于ARM Cortex-A5微处理器——SAMA5D4系列 5046次阅读
- Cortex-M3处理器中断和FreeRTOS中断优先级配置 6616次阅读
- 对Cortex-A53处理器的性能分析及特点概述 13.7w次阅读
- 分析Cortex-A7处理器与Cortex-A15处理器各自的优势及区别 6261次阅读
- 关于Cortex-A7处理器性能分析 3.1w次阅读
- 一文教你如何区别ARM Cortex系列处理器 5068次阅读
- 详解ARM Cortex-A32处理器,打造超高能效嵌入式环境 4743次阅读
- 一文解析Cortex-M处理器架构特性 7793次阅读
- ARM实时处理器Cortex-R8介绍_Cortex-R系列处理器盘点 1.6w次阅读
- Cortex-M系列处理器介绍及其特性参数 1.7w次阅读
- cortex-a9是什么处理器_cortex-a9处理器介绍 2.4w次阅读
下载排行
本周
- 1储能电源市场分析
- 7.99 MB | 10次下载 | 免费
- 2储能电源市场分析报告
- 2.61 MB | 6次下载 | 免费
- 3磁环电感定制时应该注意什么
- 0.32 MB | 2次下载 | 免费
- 4labview文档教程资料(一)
- 24.29 MB | 2次下载 | 免费
- 54.5V 至 17V 输入、8A 同步降压 SWIFT™ 转换器TPS568215OA数据表
- 1.27MB | 1次下载 | 免费
- 6轻触三功能+常按 SOS 功能手筒LED驱动ICSD3302数据手册
- 0.60 MB | 1次下载 | 2 积分
- 7英集芯IP5353 QFN32 规格书pdf
- 2.70 MB | 1次下载 | 免费
- 8采用QFN封装且具有2.95V-6V 输入的LMZ30604 4A电源模块数据表
- 1.86MB | 1次下载 | 免费
本月
- 1STM32国内外发展现状
- 1.15 MB | 16次下载 | 免费
- 2传感芯片选型指南
- 3.60 MB | 12次下载 | 免费
- 3储能电源市场分析
- 7.99 MB | 10次下载 | 免费
- 4ATmega8芯片中文手册
- 2.45 MB | 8次下载 | 1 积分
- 5TDK电容器产品指南
- 11.88 MB | 7次下载 | 1 积分
- 62A多电池高效开关充电器AN_SY6912A中文资料规格书
- 1.43 MB | 7次下载 | 免费
- 716A 输出电流,高可靠、高效率 同步降压转换器PCD3201产品手册
- 0.47 MB | 6次下载 | 免费
- 8储能电源市场分析报告
- 2.61 MB | 6次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935091次下载 | 免费
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420050次下载 | 免费
- 3Altium DXP2002下载入口
- 未知 | 233068次下载 | 免费
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191317次下载 | 免费
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183316次下载 | 免费
- 6labview8.5下载
- 未知 | 81567次下载 | 免费
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73788次下载 | 免费
- 8NI LabVIEW中实现3D视觉的工具和技术
- 未知 | 70088次下载 | 免费
评论
查看更多