0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

NXP的Cortex-M系列为例做简要介绍Linux开发

AGk5_ZLG_zhiyua 来源:互联网 作者:佚名 2018-05-20 08:00 次阅读

本文导读

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

图1 ARMv7下的Cortex系列

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

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

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

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

二、内存管理单元MMU

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

图2 MMU的地位

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

图3 内存管理机制

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

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

三、Linux系统

一般将操作系统分为实时操作系统和非实时操作系统。实时操作系统大多为单进程、多线程(多任务),因此不涉及到线程间的地址空间分配,不需要使用MMU,例如VxWorks。Linux系统属于非实时性操作体统,多进程是其主要特点。

以Ubuntu为例,打开一个shell并且查看bash进程的地址范围如图4,它的地址范围为0x0000000000400000~0xffffffffff600000。

图4 shell 1中的bash地址

我们打开另一个shell,查看该shell中bash进程的地址范围,如图5。不难发现,两个不同bash进程的地址范围完全相同。其实操作系统或者用户在fork()进程时完全不需要考虑物理内存的地址分配,该工作由微控制器的内存管理单元MMU来做。

图5 shell 2中的bash地址

既然是多进程依赖了内存管理单元,那么在使用嵌入式Linux时只开一个进程可以吗?肯定是不可行的!开机后即使用户什么都不做,可见的系统运行必须的进程已经运行了几十至上百个,如图6。

图6 进程树

四、总结

综合以上内容,Linux系统对内存管理单元有极强的依赖,若在没有MMU的处理器中运行Linux,恐怕整个系统只能停留在Uboot阶段了。由于Cortex-m处理器没有内存管理单元,因此跑不了Linux系统。任何事情都不是绝对的,如果你重写了Linux内核且搭配足够大的内存芯片,从理论上来说是可以省掉MMU的。但是,这样的工作量,真的值得吗?实际上,MMU就是为了解决操作系统越来越复杂的内存管理而产生的。

五、拓展部分

很大一部分开发者选用嵌入式Linux系统未能发挥出它的优势,仅仅是为了获得开发上的便利,比如以太网、4G上云、LCD驱动、文件系统、图像识别、python应用等等。那么有没有方法既能使用传统高实时性、低成本的单片机又不用面对繁琐的硬件驱动开发呢?ZLG致远电子推出的全新AWorks平台——IoT物联网生态系统正是为此而生。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • NXP
    NXP
    +关注

    关注

    60

    文章

    1267

    浏览量

    183193
  • Linux
    +关注

    关注

    87

    文章

    11220

    浏览量

    208881
  • MMU
    MMU
    +关注

    关注

    0

    文章

    91

    浏览量

    18263

原文标题:Cortex-M处理器跑得了Linux吗?

文章出处:【微信号:ZLG_zhiyuan,微信公众号:ZLG致远电子】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    简单介绍NXPCortex-M系列ARM

    浮点运算。也可以理解是DSP+M0的架构,M0用来配置智能I/O口、外围接口以及事件的处理。M4则是数字信号控制器。以上是NXPCortex
    发表于 03-29 10:45

    基于Cortex-M处理器产品开发为什么受欢迎

    基于Cortex-M处理器产品开发为什么受欢迎虽然Cortex-M系列处理器有非常多的特性,但是很容易使用,差不多所有的
    发表于 08-27 16:11

    基于Cortex-M处理器产品开发受欢迎的原因在这里

    虽然Cortex-M系列处理器有非常多的特性,但是很容易使用,差不多所有的开发都可以用像C语言这样的高级编程语言。 虽然基于Cortex-M系列
    发表于 07-04 03:25

    CORTEX-M系列芯片介绍

    1.1 CORTEX-M系列芯片介绍CORTEX-M4为准1.1.1 CORTEX-M4的特点①采用了先进的
    发表于 03-19 20:27

    ARM Cortex-M堆栈机制介绍

      大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是ARM Cortex-M堆栈机制。  今天给大家分享的这篇依旧是2016年之前痞子衡写的技术文档,花了点时间重新编排了一下
    发表于 12-16 06:26

    介绍Cortex-A和Cortex-M的TrustZone之间的差异

    相信关注安全和嵌入式的开发者对TrustZone都不陌生,最近看到有网友在问Cortex-A和Cortex-M的TrustZone之间的差异,我们来简单介绍下。Arm在2003年的Ar
    发表于 07-13 14:45

    ARM Cortex-M 系列微控制器(ST)

    ARM Cortex-M 系列微控制器(ST) 意法半导体(ST)宣布在基于ARM Cortex-M系列处理器内核的微控制器研发项目上取得突破,推出全球业内首款采用90nm技术嵌入式
    发表于 11-02 09:29 946次阅读

    NXPCortex-M系列为基础的linux系统与内存管理单元的关系详解

    单片机与应用处理器的核心区别到底是什么呢?是核心主频的差异?还是Linux系统的支持?又或者是处理器的架构?本文将以NXPCortex-M系列为
    发表于 07-12 12:52 1231次阅读
    以<b class='flag-5'>NXP</b>的<b class='flag-5'>Cortex-M</b><b class='flag-5'>系列为</b>基础的<b class='flag-5'>linux</b>系统与内存管理单元的关系详解

    Cortex-M系列处理器介绍及其特性参数

    本文首先介绍Cortex-M处理器的家族成员,其次介绍Cortex-M处理器的特性,具体的跟随小编一起来了解一下。
    发表于 04-18 17:17 1.9w次阅读
    <b class='flag-5'>Cortex-M</b><b class='flag-5'>系列</b>处理器<b class='flag-5'>介绍</b>及其特性参数

    关于STM32和Cortex-M内核系列介绍(1)

    Cortex-M内核系列和STM32-讲座
    的头像 发表于 07-05 01:07 8001次阅读

    关于STM32与Cortex-M内核系列介绍(2)

    Cortex-M内核系列和STM32-讲座3
    的头像 发表于 07-05 00:45 4499次阅读

    关于Cortex-M 调试应用的介绍

    Cortex-M 调试应用
    的头像 发表于 07-10 00:56 2590次阅读

    米尔科技Cortex-M Prototyping System +介绍

    经济实惠的主板,作为ARM®Versatile™Express系列开发板的一部分。他们提供两种FPGA的选择,用于原型设计基于Cortex-M的设计和一系列不同的调试选项。它提供了一
    的头像 发表于 11-14 10:45 1853次阅读
    米尔科技<b class='flag-5'>Cortex-M</b> Prototyping System +<b class='flag-5'>介绍</b>

    Cortex-MLinux操作系统能行吗

    单片机、Cortex-MLinux它们和嵌入式有什么区别? 跑 Linux 操作系统需要什么处理器?ARM9、ARM11? Cortex-M比ARM9更新,为什么不能跑
    的头像 发表于 07-19 09:35 1893次阅读
    <b class='flag-5'>Cortex-M</b>跑<b class='flag-5'>Linux</b>操作系统能行吗

    Cortex-M可以跑Linux操作系统吗?

    Cortex-M可以跑Linux操作系统吗?
    发表于 12-01 11:36 2次下载
    <b class='flag-5'>Cortex-M</b>可以跑<b class='flag-5'>Linux</b>操作系统吗?