Cortex-M可以跑Linux操作系统吗? | MCU加油站
文章推薦指數: 80 %
在Linux等多用户、多进程的操作系统中,MMU使得各个用户进程都有独立的地址空间,以防止内存越界。
“图2. 图2 MMU的地位. MCU都有一个地址集和,被称为 ...
跳转到主要内容
Main-menu-for-MCU
单片机、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:主要指应用型处理器;
值得注意的是,Cortex-M下的处理器没有内存管理单元MMU。
内存管理单元MMU
MMU:MemoryManagementUnit,内存管理单元。
内存管理单元主要负责从虚拟地址到物理地址的映射,并在硬件层对内存访问权限的检查。
在Linux等多用户、多进程的操作系统中,MMU使得各个用户进程都有独立的地址空间,以防止内存越界。
图2MMU的地位
MCU都有一个地址集和,被称为虚拟地址范围。
以Cortex-M32为机为例,虚拟地址范围为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。
图4shell1中的bash地址
我们打开另一个shell,查看该shell中bash进程的地址范围,如图5。
不难发现,两个不同bash进程的地址范围完全相同。
其实操作系统或者用户在fork()进程时完全不需要考虑物理内存的地址分配,该工作由微控制器的内存管理单元MMU来做。
图5shell2中的bash地址
既然是多进程依赖了内存管理单元,那么在使用嵌入式Linux时只开一个进程可以吗?肯定是不可行的!开机后即使用户什么都不做,可见的系统运行必须的进程已经运行了几十至上百个,如图6。
图6进程树
总结
通过上述描述我们可以知道,Linux操作系统对MMU(内存管理单元)有极强的依赖,若在没有内存管理单元的CPU中运行Linux,恐怕整个系统只能停留在Uboot阶段了。
由于ARM的Cortex-M处理器没有内存管理单元,,一般来说不建议跑Linux操作系统。
当然,任何事情都不是绝对的,如果你重写了Linux内核且搭配足够大的内存芯片,从理论上来说是可以省掉MMU的。
但是,这样的工作量,真的值得吗?实际上,MMU就是为了解决操作系统越来越复杂的内存管理而产生的。
来源:致远电子,StrongerHuang
免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。
本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理(联系邮箱:[email protected])。
围观30
评论0
邮箱或用户名*
密码*
注册忘记密码
本土热门MCU
国民技术
芯海科技
华大半导体
航顺
应用
IOT
无人机
智能工厂
智能家居
汽车电子
可穿戴产品
热门产品
STM32系列
RX系列
LPC系列
MSP430系列
PIC系列
PSoC系列
关键技术
Cortex-M3
Cortex-M4
Cortex-M0/M0+
算法
近期活动
精彩推荐
微信公众号
近期产品推荐
©www.eetrend.com
延伸文章資訊
- 1許多人對於8051 MCU常有的錯誤觀念討論與闢除(2020/10/12 ...
8051 MCU好教材分享& 錯誤觀念闢除] 對於想學MCU(單晶片微控制器)韌 ... 會寫APP或接觸過Embedded Linux系統不代表就懂MCU的應用設計,更不代表 ...
- 2Cortex-M可以跑Linux操作系统吗? | MCU加油站
在Linux等多用户、多进程的操作系统中,MMU使得各个用户进程都有独立的地址空间,以防止内存越界。 “图2. 图2 MMU的地位. MCU都有一个地址集和,被称为 ...
- 3Re: [請益] 研替Linux/MCU - 看板Soft_Job - 批踢踢實業坊
我覺得可以先從MCU下手在轉linux kernel。 好處是MCU架構相對支援linux的ARM A系列,或是mips到x86等CPU相對簡單很多很多,透過JTAG配合簡單的程式碼 ...
- 4用于MCU/MPU的uCLinux与Linux有什么区别? - CSDN博客
uClinux是针对控制领域的嵌入式linux操作系统,它从Linux 2.0/2.4内核派生 ... uCLinux主要用于MCU和MPU,对于市面上常见的STM32也是做了很好的支持。
- 5ARM-Linux与MCU开发的不同之处 - 与非网
今天我们来看看ARM-Linux 开发和MCU 开发的不同点,以及ARM-Linux 的基本开发 ... 针对ARM-Linux 程序的开发,主要分为三类:应用程序开发、驱动程序 ...