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

发布者:心若清泉最新更新时间:2018-05-24 来源: ZLG致远电子关键字: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以及Cortex-M7,以上处理器常被用于低成本、低功耗、高可靠的嵌入式实时系统中。它们既可以用于“裸片”开发又能运行实时操作系统,比如us/os-ll、VxWorks以及Aworks(致远电子开发)等。

image.png

图1  ARMv7下的Cortex系列


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

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

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


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


二、内存管理单元MMU


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


image.png

图2  MMU的地位


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


image.png

图3  内存管理机制


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


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


三、linux系统


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


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


image.png

4  shell 1中的bash地址


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


image.png

5  shell 2中的bash地址


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


image.png

6  进程树


四、总结


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


五、拓展部分


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


AWorks的诞生极大的降低了开发者门槛,为开发者提供便利,使开发者可以忽略底层技术细节,专注产品“核心域”,更快的开发出具有竞争力的产品。同时,AWorks为开发者提供的是高度抽象的通用接口,基于AWorks平台的软件与底层硬件无关,可以“随心所欲”的跨平台复用(如更换MCU等等)。跨界硬件搭载AWoeks IoT实时操作系统,让您的开发更容易,功能更强大。


image.png


关键字:Cortex-M  linux 引用地址:为何Cortex-M处理器运行不了linux

上一篇:AWorks的哲学思想
下一篇:uC/OS-II嵌入式实时操作系统的几大特点

推荐阅读最新更新时间:2024-05-03 02:55

ARMv8 Linux内核源码分析:__flush_dcache_all()
1.1 /* * __flush_dcache_all() * Flush the wholeD-cache. * Corrupted registers: x0-x7, x9-x11 */ ENTRY(__flush_dcache_all) //保证之前的访存指令的顺序 dsb sy //读cache level id register mrs x0, clidr_el1 // read clidr //取bits (Level of Coherency for the cache hierarchy.) //需要遵循cache一致性的cac
[单片机]
ARMv8 <font color='red'>Linux</font>内核源码分析:__flush_dcache_all()
基于嵌入式Linux的步进电机驱动程序设计
  1.引言   随着嵌入式技术的飞速发展,基于嵌入式系统的新一代工业控制器也日益增多。同以往的控制器不同,新的仪器大多以32位嵌入式处理器为核心,并且安装有嵌入式操作系统,从而大幅度提高了处理能力,方便了设计开发。在各种嵌入式操作系统中,嵌入式Linux是免费的自由软件,其构建的系统成本较低,而且Linux是单内核的操作系统,并可按要求进行任意剪裁,因此越来越多的研究人员开始在用Linux平台来开发自己的产品 。   嵌入式开发过程中,经常需要为特定设备开发驱动程序。这些驱动程序的编写和编译与PC上的Linux驱动开发相比存在明显的差异,需要考虑的因素更多,实现过程更为复杂。本文以Samsung公司S3C2410X CPU为
[单片机]
基于嵌入式<font color='red'>Linux</font>的步进电机驱动程序设计
基于Linux系统和ZigBee的智能家居系统方案
摘 要:根据现代家居的发展需求,提出了一种智能家居系统的整体设计方案,以ARM11S3C6410为核心处理器,Linux嵌入式系统为家居总中心监控系统,使用Linux Qt完成了控制程序及人机界面的编写,采用GPRS通信技术完成了系统的远程通信及监控,组建基于ZigBee无线通信技术的系统内部网络,并完成了对家电的基于统一协议的控制,实现了家居的智能化。   0 引 言   随着网络技术和通信技术的不断发展以及人们对生活要求的不断提高,实现家庭智能的远程监控已经成为必然的趋势。国家建设部住宅产业化促进中心提出住宅小区要实现六项智能化要求,其中包括实行安全防范自动化监控管理:对住宅的火灾、有害气体的泄漏实行自动报警;防盗报警系统
[模拟电子]
基于<font color='red'>Linux</font>系统和ZigBee的智能家居系统方案
AT91SAM9260搭建LINUX操作系统
一、编写目的 本文档用于记录AT91SAM9260 LINUX学习的过程。使用以前开发过的一个9260核心板进行开发。该核心板参考ATMEL官方的AT91SAM9260-EK开发板设计,因此与官方开发板使用相同的BOOTLOADER、KERNEL。 可从www.linux4sam.org或ftp://www.at91.com/pub/下载AT91SAM9260-EK开发板的软件支持包进行开发。后期ATMEL对此开发板没有单独进行维护了,相关软件源码都整合到最新的AT91源码中了,通过make去选择相应开发板。 www.linux4sam.org有相应软件(bootstrap、uboot、内核)源码和
[单片机]
AT91SAM9260搭建<font color='red'>LINUX</font>操作系统
英特尔加速 Linux 软件开发,为 Arrow Lake 和 Lunar Lake GPU 提供支持
12 月 17 日消息,英特尔在 Linux 6.8 合并之前提交了首个 drm-xe-next Pull Request,用最新的 Xe GPU 驱动取代了 Linux 上的传统的 i915 DRM 内核驱动程序。 实际上,英特尔从 Tiger Lake 开始就已支持 Xe 实验特性,但考虑到 i915 仍是 Meteor Lake 和 Alchemist 平台的主导驱动,英特尔的目标应该是让这个 Intel Xe 驱动程序成为 Lunar Lake 及后续平台的主要驱动程序。 IT之家将英特尔针对 Xe2(Battlemage)GPU 添加的所有更改之处汇总如下: drm/xe: Add performance tuni
[嵌入式]
mini2440 u-boot linux 内核启动,移植较新(Linux3.19)内核至mini2440开发板(一)
s3c24xx-nand s3c2440-nand: Tacls=1, 9ns Twrph0=3 29ns, Twrph1=2 19ns s3c24xx-nand s3c2440-nand: NAND soft ECC nand: device found, Manufacturer ID: 0xec, Chip ID: 0xda nand: Samsung NAND 256MiB 3,3V 8-bit nand: 256 MiB, SLC, erase size: 128 KiB, page size: 2048, OOB size: 64 Creating 5 MTD partitions on nand : 0x000000
[单片机]
OK6410A 开发板 (八) 20 linux-5.11 OK6410A start_kernel 功能角度 第三阶段之kthreadd进程
arch_call_rest_init rest_init pid = kernel_thread(kernel_init, NULL, CLONE_FS); pid = kernel_thread(kthreadd, NULL, CLONE_FS | CLONE_FILES); cpu_startup_entry(CPUHP_ONLINE); 内核进程2的创建过程 arm linux 内核源码剖析.pdf P407 内核进程2开始运行的时刻 start_kernel- rest_init- schedule_preempt_disabled - schedule - __schedule - context_sw
[单片机]
ARM 平台上的Linux系统启动流程
  开始学习嵌入式开发就一直在使用Linux系统作为学习的平台,到现在无论是PC机还是ARM开发板都已经能顺利地跑起了Linux系统,但是对Linux 的启动流程还是不甚了解。于是开始各种百度谷歌,当然看到了各路大神写的介绍。总的来说就是:bootloader - kernel- root filesystem,当然还介绍了哪个阶段完成了哪些工作。比如bootloader 是一上电就拿到cpu 的控制权的,而bootloader实现了硬件的初始化。bootloader俨然就成了power on 之后 第一个吃螃蟹 的代码。   谈到这就得想到硬件机制是如何满足这个功能的了。就拿S3C2440 这个芯片来说(我的硬件平台就是拿这个芯片
[单片机]
ARM 平台上的<font color='red'>Linux</font>系统启动流程
小广播
热门活动
换一批
更多
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

更多精选电路图
换一换 更多 相关热搜器件
更多每日新闻
随便看看
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved