0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

NXP的Cortex-M系列為例做簡要介紹Linux開發(fā)

AGk5_ZLG_zhiyua ? 來源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2018-05-20 08:00 ? 次閱讀

本文導(dǎo)讀

單片機(jī)與應(yīng)用處理器的核心區(qū)別到底是什么呢?是核心主頻的差異?還是Linux系統(tǒng)的支持?又或者是處理器的架構(gòu)?本文將以NXP的Cortex-M系列為例做簡要介紹。

一、Cortex-M的定位

處理器的體系結(jié)構(gòu)定義了指令集(ISA)和基于這一體系結(jié)構(gòu)下處理器的程序員模型,通俗來講就是相同的ARM體系結(jié)構(gòu)下的應(yīng)用軟件是兼容的。從ARMv1到ARMv8,每一次體系結(jié)構(gòu)的修改都會添加實用技術(shù)。

在ARMv7版本中,內(nèi)核架構(gòu)首次從單一款式變成3種款式。Cortex-M系列屬于ARMv7結(jié)構(gòu)下的一個款式:款式M。款式M包含的處理器有Cortex-M0、Cortex-M1、Cortex-M3、Cortex-M4以及Cortex-M7,以上處理器常被用于低成本、低功耗、高可靠的嵌入式實時系統(tǒng)中。它們既可以用于“裸片”開發(fā)又能運(yùn)行實時操作系統(tǒng),比如us/os-ll、VxWorks以及AWorks(ZLG致遠(yuǎn)電子開發(fā))等。

圖1 ARMv7下的Cortex系列

  • 款式A:高性能的處理器級平臺,性能比肩計算機(jī)。

  • 款式R:定位應(yīng)用于高端嵌入式系統(tǒng),高可靠及高時效性。

  • 款式M:用于深度嵌入、定制的嵌入式系統(tǒng)。

值得注意的是,Cortex-M下的處理器沒有內(nèi)存管理單元MMU。

二、內(nèi)存管理單元MMU

內(nèi)存管理單元簡稱MMU,它負(fù)責(zé)虛擬地址到物理地址的映射,并提供硬件機(jī)制的內(nèi)存訪問權(quán)限檢查。在多用戶、多進(jìn)程的操作系統(tǒng)中,MMU使得各個用戶進(jìn)程都有獨(dú)立的地址空間。

圖2 MMU的地位

任何微控制器都存在一個程序能夠產(chǎn)生的地址集和,被稱為虛擬地址范圍。以32為機(jī)為例,虛擬地址范圍為0~0xFFFFFFFF (4G)。當(dāng)該控制器尋址一個256M的內(nèi)存時,它的可用地址范圍被限定為0x00000000~0x0FFFFFFF(256M)。在沒有MMU的控制器中,虛擬地址被直接發(fā)送到內(nèi)存總線上,以讀寫該地址下的物理存儲器。在擁有MMU的控制器中,虛擬地址首先被發(fā)送到MMU中,被映射為物理地址后再發(fā)送到內(nèi)存總線上。

圖3 內(nèi)存管理機(jī)制

注:上圖僅簡單反映內(nèi)存管理的映射機(jī)制,權(quán)限映射、TLB快表、頁表等概念不做深入討論。

虛擬內(nèi)存管理最主要的作用是讓每個進(jìn)程有獨(dú)立的地址空間。不同進(jìn)程中的同一個虛擬地址被MMU映射到不同的物理地址,并且在某一個進(jìn)程中訪問任何地址都不可能訪問到另外一個進(jìn)程的數(shù)據(jù),這樣使得任何一個進(jìn)程由于執(zhí)行錯誤指令或惡意代碼導(dǎo)致的非法內(nèi)存訪問都不會意外改寫其它進(jìn)程的數(shù)據(jù),不會影響其它進(jìn)程的運(yùn)行,從而保證整個系統(tǒng)的穩(wěn)定性。另一方面,每個進(jìn)程都認(rèn)為自己獨(dú)占整個虛擬地址空間,這樣鏈接器和加載器的實現(xiàn)會比較容易,不必考慮各進(jìn)程的地址范圍是否沖突。

三、Linux系統(tǒng)

一般將操作系統(tǒng)分為實時操作系統(tǒng)和非實時操作系統(tǒng)。實時操作系統(tǒng)大多為單進(jìn)程、多線程(多任務(wù)),因此不涉及到線程間的地址空間分配,不需要使用MMU,例如VxWorks。Linux系統(tǒng)屬于非實時性操作體統(tǒng),多進(jìn)程是其主要特點(diǎn)。

以Ubuntu為例,打開一個shell并且查看bash進(jìn)程的地址范圍如圖4,它的地址范圍為0x0000000000400000~0xffffffffff600000。

圖4 shell 1中的bash地址

我們打開另一個shell,查看該shell中bash進(jìn)程的地址范圍,如圖5。不難發(fā)現(xiàn),兩個不同bash進(jìn)程的地址范圍完全相同。其實操作系統(tǒng)或者用戶在fork()進(jìn)程時完全不需要考慮物理內(nèi)存的地址分配,該工作由微控制器的內(nèi)存管理單元MMU來做。

圖5 shell 2中的bash地址

既然是多進(jìn)程依賴了內(nèi)存管理單元,那么在使用嵌入式Linux時只開一個進(jìn)程可以嗎?肯定是不可行的!開機(jī)后即使用戶什么都不做,可見的系統(tǒng)運(yùn)行必須的進(jìn)程已經(jīng)運(yùn)行了幾十至上百個,如圖6。

圖6 進(jìn)程樹

四、總結(jié)

綜合以上內(nèi)容,Linux系統(tǒng)對內(nèi)存管理單元有極強(qiáng)的依賴,若在沒有MMU的處理器中運(yùn)行Linux,恐怕整個系統(tǒng)只能停留在Uboot階段了。由于Cortex-m處理器沒有內(nèi)存管理單元,因此跑不了Linux系統(tǒng)。任何事情都不是絕對的,如果你重寫了Linux內(nèi)核且搭配足夠大的內(nèi)存芯片,從理論上來說是可以省掉MMU的。但是,這樣的工作量,真的值得嗎?實際上,MMU就是為了解決操作系統(tǒng)越來越復(fù)雜的內(nèi)存管理而產(chǎn)生的。

五、拓展部分

很大一部分開發(fā)者選用嵌入式Linux系統(tǒng)未能發(fā)揮出它的優(yōu)勢,僅僅是為了獲得開發(fā)上的便利,比如以太網(wǎng)、4G上云、LCD驅(qū)動、文件系統(tǒng)、圖像識別、python應(yīng)用等等。那么有沒有方法既能使用傳統(tǒng)高實時性、低成本的單片機(jī)又不用面對繁瑣的硬件驅(qū)動開發(fā)呢?ZLG致遠(yuǎn)電子推出的全新AWorks平臺——IoT物聯(lián)網(wǎng)生態(tài)系統(tǒng)正是為此而生。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • NXP
    NXP
    +關(guān)注

    關(guān)注

    60

    文章

    1286

    瀏覽量

    184843
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11329

    瀏覽量

    209971
  • MMU
    MMU
    +關(guān)注

    關(guān)注

    0

    文章

    91

    瀏覽量

    18326

原文標(biāo)題:Cortex-M處理器跑得了Linux嗎?

文章出處:【微信號:ZLG_zhiyuan,微信公眾號:ZLG致遠(yuǎn)電子】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    簡單介紹NXPCortex-M系列ARM

    浮點(diǎn)運(yùn)算。也可以理解是DSP+M0的架構(gòu),M0用來配置智能I/O口、外圍接口以及事件的處理。M4則是數(shù)字信號控制器。以上是NXPCortex
    發(fā)表于 03-29 10:45

    基于Cortex-M處理器產(chǎn)品開發(fā)為什么受歡迎

    基于Cortex-M處理器產(chǎn)品開發(fā)為什么受歡迎雖然Cortex-M系列處理器有非常多的特性,但是很容易使用,差不多所有的
    發(fā)表于 08-27 16:11

    基于Cortex-M處理器產(chǎn)品開發(fā)受歡迎的原因在這里

    雖然Cortex-M系列處理器有非常多的特性,但是很容易使用,差不多所有的開發(fā)都可以用像C語言這樣的高級編程語言。 雖然基于Cortex-M系列
    發(fā)表于 07-04 03:25

    CORTEX-M系列芯片介紹

    1.1 CORTEX-M系列芯片介紹CORTEX-M4為準(zhǔn)1.1.1 CORTEX-M4的特點(diǎn)①采用了先進(jìn)的
    發(fā)表于 03-19 20:27

    ARM Cortex-M堆棧機(jī)制介紹

      大家好,我是痞子衡,是正經(jīng)搞技術(shù)的痞子。今天痞子衡給大家介紹的是ARM Cortex-M堆棧機(jī)制?! 〗裉旖o大家分享的這篇依舊是2016年之前痞子衡寫的技術(shù)文檔,花了點(diǎn)時間重新編排了一下
    發(fā)表于 12-16 06:26

    介紹Cortex-A和Cortex-M的TrustZone之間的差異

    相信關(guān)注安全和嵌入式的開發(fā)者對TrustZone都不陌生,最近看到有網(wǎng)友在問Cortex-A和Cortex-M的TrustZone之間的差異,我們來簡單介紹下。Arm在2003年的Ar
    發(fā)表于 07-13 14:45

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

    ARM Cortex-M 系列微控制器(ST) 意法半導(dǎo)體(ST)宣布在基于ARM Cortex-M系列處理器內(nèi)核的微控制器研發(fā)項目上取得突破,推出全球業(yè)內(nèi)首款采用90nm技術(shù)嵌入式
    發(fā)表于 11-02 09:29 ?958次閱讀

    NXPCortex-M系列為基礎(chǔ)的linux系統(tǒng)與內(nèi)存管理單元的關(guān)系詳解

    單片機(jī)與應(yīng)用處理器的核心區(qū)別到底是什么呢?是核心主頻的差異?還是Linux系統(tǒng)的支持?又或者是處理器的架構(gòu)?本文將以NXPCortex-M系列為
    發(fā)表于 07-12 12:52 ?1269次閱讀
    以<b class='flag-5'>NXP</b>的<b class='flag-5'>Cortex-M</b><b class='flag-5'>系列為</b>基礎(chǔ)的<b class='flag-5'>linux</b>系統(tǒng)與內(nèi)存管理單元的關(guān)系詳解

    Cortex-M系列處理器介紹及其特性參數(shù)

    本文首先介紹Cortex-M處理器的家族成員,其次介紹Cortex-M處理器的特性,具體的跟隨小編一起來了解一下。
    發(fā)表于 04-18 17:17 ?1.9w次閱讀
    <b class='flag-5'>Cortex-M</b><b class='flag-5'>系列</b>處理器<b class='flag-5'>介紹</b>及其特性參數(shù)

    關(guān)于STM32和Cortex-M內(nèi)核系列介紹(1)

    Cortex-M內(nèi)核系列和STM32-講座
    的頭像 發(fā)表于 07-05 01:07 ?8085次閱讀

    關(guān)于STM32與Cortex-M內(nèi)核系列介紹(2)

    Cortex-M內(nèi)核系列和STM32-講座3
    的頭像 發(fā)表于 07-05 00:45 ?4552次閱讀

    關(guān)于Cortex-M 調(diào)試應(yīng)用的介紹

    Cortex-M 調(diào)試應(yīng)用
    的頭像 發(fā)表于 07-10 00:56 ?2637次閱讀

    米爾科技Cortex-M Prototyping System +介紹

    經(jīng)濟(jì)實惠的主板,作為ARM?Versatile?Express系列開發(fā)板的一部分。他們提供兩種FPGA的選擇,用于原型設(shè)計基于Cortex-M的設(shè)計和一系列不同的調(diào)試選項。它提供了一
    的頭像 發(fā)表于 11-14 10:45 ?1965次閱讀
    米爾科技<b class='flag-5'>Cortex-M</b> Prototyping System +<b class='flag-5'>介紹</b>

    Cortex-MLinux操作系統(tǒng)能行嗎

    單片機(jī)、Cortex-M、Linux它們和嵌入式有什么區(qū)別? 跑 Linux 操作系統(tǒng)需要什么處理器?ARM9、ARM11? Cortex-M比ARM9更新,為什么不能跑
    的頭像 發(fā)表于 07-19 09:35 ?1968次閱讀
    <b class='flag-5'>Cortex-M</b>跑<b class='flag-5'>Linux</b>操作系統(tǒng)能行嗎

    Cortex-M可以跑Linux操作系統(tǒng)嗎?

    Cortex-M可以跑Linux操作系統(tǒng)嗎?
    發(fā)表于 12-01 11:36 ?2次下載
    <b class='flag-5'>Cortex-M</b>可以跑<b class='flag-5'>Linux</b>操作系統(tǒng)嗎?