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

单片机、Cortex-M、Linux它们和嵌入式有什么区别?
跑 Linux 操作系统需要什么处理器?ARM9、ARM11?
Cortex-M比ARM9更新,为什么不能跑Linux?
相信很多小伙伴都有类似这样的疑问,下面围绕Cortex-M、 ARM、 Linux来讲讲相关内容。

ARM和Cortex-M

ARM处理器的体系结构定义了指令集(ISA)和基于这一体系结构下处理器的模型。ARM的指令集从ARMv1发展到今天的ARMv9,每一次体系结构的修改都会添加实用技术。

在ARMv6之前,其内核指令集架构都是单一款式,但在ARMv7开始,其指令集架构变成3种款式,即目前大家熟知的Cotex-M、 Cotex-R、 Cotex-A,或者ARMv7-A、ARMv7-R、 ARMv7-M这三款。
  • Cotex-M:主要指微处理器;

  • Cotex-R:主要指实时性处理器;

  • Cotex-A:主要指应用型处理器;

更多介绍可以参看文章:STM32、Cortex-M3和ARMv8-M之间的关联

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

内存管理单元MMU

MMU:Memory Management Unit,内存管理单元。

内存管理单元主要负责从虚拟地址到物理地址的映射,并在硬件层对内存访问权限的检查。
在Linux等多用户、多进程的操作系统中,MMU使得各个用户进程都有独立的地址空间,以防止内存越界。

图2 MMU的地位

MCU都有一个地址集和,被称为虚拟地址范围。以Cortex-M 32为机为例,虚拟地址范围为0 ~ 0xFFFFFFFF (4G地址空间)。
当该控制器寻址一个256M的内存时,它的可用地址范围被限定为0 ~ 0x0FFFFFFF(256M)。
1.在没有内存管理的处理器中,虚拟地址被直接发送到内存总线上,以读写该地址下的物理存储器。
这里拓展阅读:无MMU抢占式操作系统的抢占工作原理
2.在有内存管理的控制器中,虚拟地址首先被发送到MMU中,被映射为物理地址后再发送到内存总线上。

图3 内存管理机制

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

Liunx操作系统

操作系统通常分为实时操作系统和非实时操作系统。

1.实时操作系统大多为单进程、多线程(多任务),因此不涉及到线程间的地址空间分配,不需要使用MMU,例如ucos、 FreeRTOS、 RT-Thread等。

2.Linux系统属于非实时性操作体统,多进程是其主要特点,可以参考文章: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(内存管理单元)有极强的依赖,若在没有内存管理单元的CPU中运行Linux,恐怕整个系统只能停留在Uboot阶段了。

由于ARM的Cortex-M处理器没有内存管理单元,,一般来说不建议跑Linux操作系统。

当然,任何事情都不是绝对的,如果你重写了Linux内核且搭配足够大的内存芯片,从理论上来说是可以省掉MMU的。

但是,这样的工作量,真的值得吗?实际上,MMU就是为了解决操作系统越来越复杂的内存管理而产生的。

END
来源:致远电子,StrongerHuang
(0)

相关推荐

  • 计算机操作系统原理

    最近准备i面试,抽时间回顾一下计算机操作系统原理.  -2018.10.1 1.硬件基础 计算机的构成: 处理器(CPU):主要包括运算器.控制器 内存(主存储器) 输入输出设备 详细的讲,CPU内部 ...

  • 按下电源后的几秒钟,CPU在干嘛?

    来电了 "来电了,来电了,起来干活了",一大早,我还在睡梦中就被吵醒了. 我是CPU一号车间的阿Q,好久不见,不知道大家有没有想我呢? "今天不是星期六吗?怎么还要工作& ...

  • 进程是如何使用内存的?

    程序运行概述 先来看一下CPU的多级存储结构,CPU通用寄存器访问速度最快,其次是Cache,再次是内存,磁盘访问速度最慢. CPU的多级存储结构 对于进程而言,可使用的地址空间为2^32=4G,那么 ...

  • 【学术论文】基于ARMv7-A架构的虚拟存储系统技术研究

    摘要: 在机弹载设备综合化.智能化.低功耗的发展趋势下,嵌入式系统设计中近几年也广泛采用了ARM系列处理器.其中ARMv7的VMSA(虚拟存储系统架构)支持虚拟化扩展.安全扩展以及大物理地址扩展,使得 ...

  • 【嵌入式】内存管理,虚拟存储

    内存管理介绍 早期的计算机内存容量非常小,当时的PC主要使用DOS操作系统或者其它操作系统.早期的操作系统由于系统硬件的限制,无法支持内存管理,应用程序占用的空间和程序规模都比较小.随着计算机硬件性能 ...

  • 我们用Windows官方跑了跑Linux GUI应用程序,不愧是“胶水操作系统”

    现在,Windows不仅是最好的Linux发行版,还是最好的Linux桌面了. 怎么回事? 原来是Windows官方的Linux子系统(WSL),终于支持Linux GUI了! 也就是说,你现在可以直 ...

  • linux操作系统入侵检查流程

    linux操作系统入侵检查流程

  • 深度探索Linux操作系统:系统构建和原理解析

    前言 对于编译内核而言,一条make命令就足够了.构建内核最困难的地方不是编译,而是编译前的配置.配置内核时,通常我们都能找到一些参考. 比如,对于桌面系统,可以参考主流发行版的内核配置,比如,对于嵌 ...

  • stat命令支持的文件格式有哪些?linux操作系统

    stat命令支持的文件格式有哪些?stat命令用于详细显示文件或文件系统的状态信息.stat命令是Linux基础命令之一,是Linux运维人员必须要会的知识点.学习Linux运维就必须要学习Linux ...

  • Linux系统Shell脚本如何运行?linux操作系统

    Shell脚本语言很适合用于处理纯文本类型的数据,而Linux系统中几乎所有的配置文件.日志文件以及绝大多数的启动文件都是纯文本类型的文件.因此,学好Shell脚本语言,能够更好的操作Linux系统. ...

  • Linux操作系统收费吗?

    Linux系统,是当下非常热门的系统,因为具有独特的优势以及特点,广受大家的喜欢.那么Linux系统收费吗? Linux是什么系统呢?Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于 ...

  • 10 大黑客专用的 Linux 操作系统...

    原文整理自[民工哥技术之路] 今天列出一些最常用.最受欢迎的Linux发行版来学习黑客和渗透测试! 1. Kali Linux Kali Linux是最著名的Linux发行版,用于道德黑客和渗透测试. ...

  • Linux操作系统应用领域有哪些?

    Linux操作系统在众多技术中是非常受喜欢的,开放.安全.稳定的特性备受用户认可.那么,Linux操作系统主要应用领域有哪些?小编为大家介绍一下. 1.服务器领域:Linux因为价格低廉.灵活性好,现 ...

  • U盘安装Linux操作系统教程,含收费内容,慎入!

    前几天发完小白科普,什么是Linux系统?要不要装一个来玩玩!这个后,有朋友要求发Linux安装教程,由于视频教程非常费时费力,所以视频教程需要收费,图文教程免费,视频教程获取方式看最后介绍. 使用U ...