您好, 登录| 注册|
论坛导航
您好, 登录| 注册|
子站:
商城:

为何Cortex-M处理器运行不了linux

2018-05-23 16:26 来源:ZLG致远 编辑:电源网

单片机与应用处理器的核心区别到底是什么呢?是核心主频的差异?还是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(致远电子开发)等。

为何Cortex-M处理器运行不了linux

图1  ARMv7下的Cortex系列

●款式A:高性能的处理器级平台,性能比肩计算机。

●款式R:定位应用于高端嵌入式系统,高可靠及高时效性。

●款式M:用于深度嵌入、定制的嵌入式系统。

值得注意的是,Cortex-M下的处理器没有内存管理单元MMU。

二、内存管理单元MMU

内存管理单元简称MMU,它负责虚拟地址到物理地址的映射,并提供硬件机制的内存访问权限检查。在多用户、多进程的操作系统中,MMU使得各个用户进程都有独立的地址空间。

为何Cortex-M处理器运行不了linux

图2  MMU的地位

任何微控制器都存在一个程序能够产生的地址集和,被称为虚拟地址范围。以32为机为例,虚拟地址范围为0~0xFFFFFFFF (4G)。当该控制器寻址一个256M的内存时,它的可用地址范围被限定为0x00000000~0x0FFFFFFF(256M)。在没有MMU的控制器中,虚拟地址被直接发送到内存总线上,以读写该地址下的物理存储器。在拥有MMU的控制器中,虚拟地址首先被发送到MMU中,被映射为物理地址后再发送到内存总线上。

为何Cortex-M处理器运行不了linux

图3  内存管理机制

注:上图仅简单反映内存管理的映射机制,权限映射、TLB快表、页表等概念不做深入讨论。

虚拟内存管理最主要的作用是让每个进程有独立的地址空间。不同进程中的同一个虚拟地址被MMU映射到不同的物理地址,并且在某一个进程中访问任何地址都不可能访问到另外一个进程的数据,这样使得任何一个进程由于执行错误指令或恶意代码导致的非法内存访问都不会意外改写其它进程的数据,不会影响其它进程的运行,从而保证整个系统的稳定性。另一方面,每个进程都认为自己独占整个虚拟地址空间,这样链接器和加载器的实现会比较容易,不必考虑各进程的地址范围是否冲突。

1 2 下一页 
标签: linux 处理器

声明:本网站原创内容,如需转载,请注明出处;本网站转载的内容(文章、图片、视频)等资料版权归原网站所有。如我们采用了您不宜公开的文章或图片,未能及时和您确认,避免给双方造成不必要的经济损失,请电邮联系我们,以便迅速采取适当处理措施;欢迎投稿,邮箱:editor@netbroad.com。

技术专题 更多>>
中国芯崛起未来专题报道
PCB设计高手养成攻略
专业的PCB板制作过程相当复杂。设计人员在过程中要在各种设计规则之间做取舍,兼顾性能、成本、工艺等方面的同时,又要注意板子布局的合理整齐,需要更多的智慧。

头条推荐

2018年电源网工程师巡回研讨会-沈阳站
2018年电源网工程师巡回培训会-沈阳站于7月21日召开,会议共计4个议题,参会工程师近200人,陶显芳陶老师分享了关于"高效率开关电源的设计及应用“议题,将现场工程师交流推向了高潮!
2018慕尼黑上海电子展
关注我们
新浪微博
官方Q群
客服热线
服务时间:周一至周五9:00-18:00
微信关注
免费技术研讨会
获取一手干货分享

互联网违法不良信息举报

Reporting Internet Illegal and Bad Information
editor@netbroad.com
022-58392381