为何为何Cortex-M处理器运行不了处理器运行不了linux
单片机与应用处理器的区别到底是什么呢?是主频的差异?还是Linux系统的支持?又或者是处理器的架构?本文将
以NXP的Cortex-M系列为例做简要介绍。 一、Cortex-M的定位 处理器的体系结构定义了指令集(ISA)和
基于这一体系结构下处理器的程序员模型,通俗来讲就是相同的ARM体系结构下的应用软件是兼容的。从
ARMv1到ARMv8,每体系结构的修改都会添加实用技术。 在ARMv7版本中,内核架构首次从单一款式变成
3种款式。Cortex-M系列属于ARMv7结构下的一个款式:款式M。款式M包含的处理器有Cortex-M0、Cortex-
M1、Cortex-M3、Cortex-M4以及
单片机与应用处理器的区别到底是什么呢?是主频的差异?还是Linux系统的支持?又或者是处理器的架构?本文将以NXP
的Cortex-M系列为例做简要介绍。
一、 一、Cortex-M的定位的定位
处理器的体系结构定义了指令集(ISA)和基于这一体系结构下处理器的程序员模型,通俗来讲就是相同的ARM体系结构下
的应用软件是兼容的。从ARMv1到ARMv8,每体系结构的修改都会添加实用技术。
在ARMv7版本中,内核架构首次从单一款式变成3种款式。Cortex-M系列属于ARMv7结构下的一个款式:款式M。款式M
包含的处理器有Cortex-M0、Cortex-M1、Cortex-M3、Cortex-M4以及Cortex-M7,以上处理器常被用于低成本、低功耗、高
可靠的嵌入式实时系统中。它们既可以用于“裸片”开发又能运行实时操作系统,比如us/os-ll、VxWorks以及Aworks(致远电子
开发)等。
图1 ARMv7下的Cortex系列
● 款式A:高性能的处理器级平台,性能比肩计算机。
● 款式R:定位应用于高端嵌入式系统,高可靠及高时效性。
● 款式M:用于深度嵌入、定制的嵌入式系统。
值得注意的是,Cortex-M下的处理器没有内存管理单元MMU。
二、内存管理单元 二、内存管理单元MMU
内存管理单元简称MMU,它负责虚拟地址到物理地址的映射,并提供硬件机制的内存访问权限检查。在多用户、多进程
的操作系统中,MMU使得各个用户进程都有独立的地址空间。