以NXP的Cortex-M系列为基础的linux系统与内存管理单元的关系详解.doc
《以NXP的Cortex-M系列为基础的linux系统与内存管理单元的关系详解.doc》由会员分享,可在线阅读,更多相关《以NXP的Cortex-M系列为基础的linux系统与内存管理单元的关系详解.doc(3页珍藏版)》请在三一文库上搜索。
1、以NXP的Cortex-M系列为基础的linux系统与内存管理单元的关系详解单片机与应用处理器的核心区别到底是什么呢?是核心主频的差异?还是Linux系统的支持?又或者是处理器的架构?本文将以NXP的Cortex-M系列为例做简要介绍。一、Cortex-M的定位处理器的体系结构定义了指令集(ISA)和基于这一体系结构下处理器的程序员模型,通俗来讲就是相同的ARM体系结构下的应用软件是兼容的。从ARMv1到ARMv8,每一次体系结构的修改都会添加实用技术。在ARMv7版本中,内核架构首次从单一款式变成3种款式。Cortex-M系列属于ARMv7结构下的一个款式:款式M。款式M包含的处理器有Cor
2、tex-M0、Cortex-M1、Cortex-M3、Cortex-M4以及Cortex-M7,以上处理器常被用于低成本、低功耗、高可靠的嵌入式实时系统中。它们既可以用于裸片开发又能运行实时操作系统,比如us/os-ll、VxWorks以及Aworks(致远电子开发)等。 款式A:高性能的处理器级平台,性能比肩计算机。 款式R:定位应用于高端嵌入式系统,高可靠及高时效性。 款式M:用于深度嵌入、定制的嵌入式系统。值得注意的是,Cortex-M下的处理器没有内存管理单元MMU。二、内存管理单元MMU内存管理单元简称MMU,它负责虚拟地址到物理地址的映射,并提供硬件机制的内存访问权限检查。在多用户
3、、多进程的操作系统中,MMU使得各个用户进程都有独立的地址空间。任何微控制器都存在一个程序能够产生的地址集和,被称为虚拟地址范围。以32为机为例,虚拟地址范围为00xFFFFFFFF (4G)。当该控制器寻址一个256M的内存时,它的可用地址范围被限定为0x000000000x0FFFFFFF(256M)。在没有MMU的控制器中,虚拟地址被直接发送到内存总线上,以读写该地址下的物理存储器。在拥有MMU的控制器中,虚拟地址首先被发送到MMU中,被映射为物理地址后再发送到内存总线上。注:上图仅简单反映内存管理的映射机制,权限映射、TLB快表、页表等概念不做深入讨论。虚拟内存管理最主要的作用是让每个
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- NXP Cortex 系列 基础 linux 系统 内存 管理 单元 关系 详解
链接地址:https://www.31doc.com/p-3375165.html