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

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

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

基于ECOS操作系統(tǒng)在S3C2510開發(fā)板上的應(yīng)用研究

電子設(shè)計 ? 來源:電子設(shè)計應(yīng)用 ? 作者:趙楚瑩,尹俊勛 ? 2020-09-19 16:34 ? 次閱讀

引言

ECOS(Embedded Configurable Operating System,嵌入式可配置操作系統(tǒng))是一種針對16位、32位和64位處理器的可移植嵌入式實時操作系統(tǒng)。由于其源代碼是公開的,因而有越來越多的設(shè)計人員開始關(guān)注ECOS操作系統(tǒng)。ECOS最大的特點是模塊化,內(nèi)核可配置。最小版本的ECOS只有幾百字節(jié),非常適合小型嵌入式系統(tǒng)的開發(fā)。相對于嵌入式Linux來說,ECOS有配置靈活和節(jié)省資源的優(yōu)勢。它的另一個優(yōu)點是使用多任務(wù)搶占機(jī)制,具有最小的中斷延遲,支持嵌入式系統(tǒng)所需的所有同步原語,并擁有靈活的調(diào)度策略和中斷處理機(jī)制,因而具有良好的實時性。與?Clinux和COS等操作系統(tǒng)相比,ECOS更適合于處理實時信號的設(shè)備,如移動通信、WLAN等通信設(shè)備的開發(fā)。

S3C2510是一款低功耗、高效能、面向以太網(wǎng)系統(tǒng)的微處理器。它的系統(tǒng)時鐘可達(dá)133MHz,并包含了16/32位寬的ARM940T核、4KB的I-CACHE和4KB的D-CACHE。S3C2510帶有兩個獨立的10/100Mbps的以太網(wǎng)控制器,這兩個接口能夠以硬件完成IEEE802.3的MAC層處理,因此更適合用作SOHO路由器、internet網(wǎng)關(guān),甚至寬帶無線接入設(shè)備的開發(fā)。ECOS操作系統(tǒng)也非常適合這些網(wǎng)絡(luò)設(shè)備的開發(fā),本文將介紹S3C2510的移植方案,給各種以ARM為內(nèi)核處理器的ECOS底層移植開發(fā)提供一個系統(tǒng)的范例。

ECOS底層移植的基礎(chǔ)知識

ECOS系統(tǒng)的主要組成部分如圖1所示。操作系統(tǒng)的主要功能及特點是由其內(nèi)核所決定的,底層移植一般不會涉及到系統(tǒng)內(nèi)核的內(nèi)容。由圖1可見,硬件抽象層是嵌入式操作系統(tǒng)和硬件直接接觸的基本層,其將系統(tǒng)內(nèi)核和具體的硬件平臺徹底隔離開, 實現(xiàn)了系統(tǒng)內(nèi)核與硬件的無關(guān)性,這就是操作系統(tǒng)具有良好可移植性的體現(xiàn)。因此,對于開發(fā)人員來說,移植操作系統(tǒng)真正的意義和工作在于移植操作系統(tǒng)的硬件抽象層。

基于ECOS操作系統(tǒng)在S3C2510開發(fā)板上的應(yīng)用研究

圖 1 ECOS操作系統(tǒng)結(jié)構(gòu)圖

硬件抽象層HAL對處理器結(jié)構(gòu)和系統(tǒng)硬件平臺進(jìn)行抽象,當(dāng)要在一個新的目標(biāo)平臺上運行ECOS時,只需要對底層的硬件抽象層進(jìn)行修改,便可迅速地將整個ECOS系統(tǒng)移植到新的平臺上。硬件抽象層主要包括三大模塊——體系結(jié)構(gòu)抽象層(Architecture HAL)、變體抽象層(Variant HAL)和平臺抽象層(Platform HAL)。體系結(jié)構(gòu)抽象層主要是指ECOS所支持的具有不同體系結(jié)構(gòu)的處理器系列,如ARM系列、PowerPC系列、MIPS系列等等。變體抽象層指的是處理器系列中某款處理器在Cache、MMU和FPU等方面所具有的特殊性。如S3C2510屬于ARM系列中的ARM940T,在變體抽象層中就會具體地針對ARM940T的Cache等方面作出定義。平臺抽象層則是對當(dāng)前系統(tǒng)硬件平臺的抽象,包括了平臺的啟動、芯片選擇與配置、定時設(shè)備、I/O寄存器訪問以及中斷寄存器等等。平臺抽象層代碼的編寫是ECOS移植工作的重點。

HAL移植的主要步驟

建立適當(dāng)?shù)奈募夸?/p>

ECOS本身有一個完整的文件目錄,只有把新建的底層文件放在適當(dāng)?shù)奈募夸浵旅?,才能確保配置和編譯工作的成功,也有助于利用ECOS本身已有的源代碼,如結(jié)構(gòu)體系層和變體層中的許多成熟可用的代碼。由于本系統(tǒng)中S3C2510處理器的內(nèi)核是ARM940T,因而可以把S3C2510的目錄建立在ECOS庫路徑packages/hal/arm/arm9/下。 建立S3C2510的cdl文件cdl文件使用cdl腳本語言描述該硬件設(shè)備(包或平臺)的特性和常用指標(biāo)。cdl文件實現(xiàn)系統(tǒng)在源碼級的功能和指標(biāo)配置,猶如一個項目管理高層對其倉庫中組件特性的登記,只有登記后的包、組件和選項才能被操作系統(tǒng)配置工具識別和配置。以下是S3C2510的cdl文件中的幾段重要描述。

* cdl_package CYGPKG_ HAL_ARM_ ARM9_S3C2510 這是S3C2510在ECOSdb中所登記的包的名字,它下面包含了該板的一些基本設(shè)置和組件,如母體體系結(jié)構(gòu)(parent)、包含的頭文件、編譯的C文件等。

* cdl_component CYG_HAL _startUP 系統(tǒng)啟動方式,有3種選擇:ram啟動、rom啟動、romram啟動。

* cdl_component CYGNUM_ HAL_CPUCLOCK平臺的系統(tǒng)時鐘設(shè)置,以便于ECOS其他組件以此時鐘為標(biāo)準(zhǔn)。該平臺系統(tǒng)時鐘的默認(rèn)值設(shè)為133MHz。

* cdl_option CYGNUM_HAL_ RTC_PERIODECOS內(nèi)核的運行時鐘單位。ECOS內(nèi)核以一個tick為時鐘單位,而一個tick的長度就等于該選項的設(shè)定值。

ecos.db中登記S3C2510硬件包

ecos.db是關(guān)于ECOS系統(tǒng)的一個數(shù)據(jù)庫文件(在packages目錄下),它包含了硬件包管理工具和一些在組件配置庫中的包。與cdl文件相比,ecos.db登記了倉庫中的物品,而cdl文件則登記每種物品的特性。只有在ecos.db中登記了的包,才能被ECOS的庫編譯工具(configtool)選中和使用。如果要在配置工具的模板選項中(template)增加可供選擇的硬件目標(biāo)板,那么,需要先在ecos.db中登記其包描述,再增加其目標(biāo)板描述。一般的輔助硬件(如網(wǎng)卡、串口等)只需要第一步的登記。因此,在ecos.db中登記S3C2510平臺硬件包的基本步驟就是登記硬件平臺的包描述(package CYGPKG_HAL_ARM_ ARM9_ S3C2510)和目標(biāo)描述(target S3C2510)。需要注意的是,target S3C2510中所包含的3個硬件描述包CYGPKG_HAL_ARM、CYGPKG_HAL_ARM_ARM9和CYGPKG_HAL_ARM_ARM9_ S3C2510是不能缺少的,因為它們是標(biāo)板的核心——主體系結(jié)構(gòu)包、子體系結(jié)構(gòu)包和主芯片包。另外,還可以可選地添加其他輔助硬件包(如網(wǎng)卡、串口等)。

編寫平臺抽象層的有關(guān)代碼

硬件平臺層所需編寫的代碼文件的一般功能如下所示。

* include /plf_cache.h —— 平臺專用cache處理 (可選)。在本系統(tǒng)中不需要編寫,可直接調(diào)用ARM9變體層的hal_cache.h。

* include / hal_platform_ints.h —— 平臺專用中斷處理,定義平臺中斷向量號。

* include / plf_io.h —— I/O 定義和系統(tǒng)寄存器的宏定義。

* include ?/ hal_platform_setup.h —— 平臺啟動代碼。本文件主要用ARM匯編指令編寫,實現(xiàn)平臺上電后程序的啟動和執(zhí)行。* src/s3c2510_misc.c —— HAL的底層標(biāo)準(zhǔn)函數(shù),包括時鐘平臺初始化、時鐘延時函數(shù)、中斷使能、中斷屏蔽、中斷響應(yīng)等。

* src/ hal_diag.c —— 硬件抽象層診斷輸出函數(shù),包含ECOS系統(tǒng)中printf打印的硬件設(shè)備驅(qū)動程序。

* misc/ redboot_primary_ ram.ecm —— 基于RAM啟動方式的redboot最小配置文件。

* misc/redboot_primary_ rom.ecm —— 基于ROM啟動方式的redboot最小配置文件。

硬件啟動過程

編寫硬件啟動的初始化過程是HAL移植的一個難點。當(dāng)硬件重新上電后,系統(tǒng)的程序指針會自動指向地址0(通常地址0存放著bootloader代碼段)。在ECOS操作系統(tǒng)中,程序首先會運行vectors.S文件(該文件存在于hal/arm/arch/src/目錄下),它定義了reset_vector、start等各種啟動標(biāo)號。接著調(diào)用S3C2510平臺層的hal_platform_ setup.h文件中的宏platform_setup1和arm9變體層arm9_misc.c文件中的函數(shù) hal_hardware_init。hal_platform_setup.h定義了宏platform_setup1以供vectors.S調(diào)用。該宏定義了目標(biāo)板上SDRAM和FLASH的初始化啟動,其中包括了它們的取數(shù)方式和內(nèi)存大小。然后根據(jù)不同的啟動方式執(zhí)行程序。對于RAM啟動方式,無需進(jìn)行程序段與數(shù)據(jù)段的搬移,系統(tǒng)已認(rèn)為SDRAM的起始地址即為程序的起始地址;對于ROM啟動方式,需要搬移數(shù)據(jù)段,而程序段無需搬移;對于ROMRAM啟動方式,程序段與數(shù)據(jù)段都需要進(jìn)行搬移,然后再把程序起始地址映射為SDRAM的起始地址。在程序搬移完成后,系統(tǒng)會進(jìn)行其他硬件的初始化過程,包括系統(tǒng)時鐘、系統(tǒng)CACHE、監(jiān)控串口等基本硬件設(shè)備。

內(nèi)存布局文件編寫

平臺的內(nèi)存布局文件在include/pkgconf目錄下。通常,每個平臺包括了RAM、ROM和ROMRAM 3種不同啟動方式的內(nèi)存布局文件集。每種啟動方式的內(nèi)存布局文件集都由3個類型的描述文件組成:.h文件包含內(nèi)存域的C宏定義;.ldi文件定義內(nèi)存域和內(nèi)存段位置的鏈接腳本文件;.mlt文件包括由MLT工具產(chǎn)生的對內(nèi)存布局的描述。當(dāng)需要手動修改內(nèi)存布局時,只有.h和.ldi文件可以被修改,.mlt文件只能由MLT工具生成。

下面以S3C2510的ram啟動方式內(nèi)存布局為例,主要說明mlt_arm_s3c2510_ram.h和mlt_arm_s3c2510_ram.ldi的程序結(jié)構(gòu)。由于S3C2510的開發(fā)板有兩個16MB的SDRAM,因而要定義兩個內(nèi)存域ram1和ram2。系統(tǒng)設(shè)置寄存器在初始化時已經(jīng)把內(nèi)存段重新映射,因而兩個SDRAM的基地址就是0x0和0x40000000,兩個內(nèi)存域的大小是16MB,分配方式都是可讀寫的內(nèi)存段。在mlt_arm_s3c2510_ram.ldi中分為兩大部分。首先是MEMORY部分,它定義了在RAM啟動方式下所需要的內(nèi)存域,以及該內(nèi)存域的起始地址和長度。MEMORY部分的內(nèi)容必須與mlt_arm_s3c2510_ ram.h中定義的宏一致。其次是SECTIONS部分,它定義了RAM啟動方式下所規(guī)定的內(nèi)存段,這些內(nèi)存段的定義與系統(tǒng)內(nèi)存管理功能有關(guān)。在SECTION_XXX后帶有相應(yīng)的參數(shù),這些參數(shù)包括了內(nèi)存段所屬的內(nèi)存域、起始地址(或者是對齊方式)、虛擬內(nèi)存地址(VMA)和加載內(nèi)存地址(LMA)。

以SECTION_fixed_vectors (ram1, 0x200, LMA_EQ_VMA)為例,它表示fixed_vectors段屬于ram1內(nèi)存域,起始地址為0x200,加載內(nèi)存地址等于虛擬內(nèi)存地址。LMA_EQ_VMA同時也可以解釋為該內(nèi)存段不需要在程序運行后重新分配加載。

調(diào)試結(jié)果

S3C2510目標(biāo)板上帶有1塊4MB的FLASH和2塊16MB的SDRAM。 利用ECOS的自帶編譯工具configtool對新建的S3C2510目標(biāo)板進(jìn)行編譯,生成ECOS的庫文件。然后把庫目錄下的install目錄內(nèi)容復(fù)制到應(yīng)用工程目錄下,使ECOS庫包含到應(yīng)用工程中。然后把該工程的.elf文件利用EMBEST公司開發(fā)的IDE仿真器直接下載到目標(biāo)板的SDRAM中。此時的ECOS操作系統(tǒng)應(yīng)為RAM啟動方式。

通過IDE對程序的調(diào)試與測試結(jié)果表明,本文提出的S3C2510移植方案使ECOS操作系統(tǒng)在目標(biāo)板中運行正常穩(wěn)定。該操作系統(tǒng)支持多個工作線程的應(yīng)用程序。S3C2510的串口、網(wǎng)口均能與pc機(jī)正常傳輸數(shù)據(jù)。

結(jié)語

ECOS是一款非常年輕的嵌入式操作系統(tǒng),1997年才正式推廣使用。現(xiàn)階段有關(guān)ECOS開發(fā)的參考資料和專門從事人員仍然很少,造成了ECOS產(chǎn)品研發(fā)周期和開發(fā)成本的增加。因此,本文提出的ECOS操作系統(tǒng)的驅(qū)動底層代碼編寫方法對于使用ECOS開發(fā)產(chǎn)品具有相當(dāng)重要的指導(dǎo)意義。

責(zé)任編輯:gt

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

    關(guān)注

    68

    文章

    19404

    瀏覽量

    230921
  • 嵌入式
    +關(guān)注

    關(guān)注

    5091

    文章

    19176

    瀏覽量

    307119
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6889

    瀏覽量

    123642
收藏 人收藏

    評論

    相關(guān)推薦

    基于嵌入式實時操作系統(tǒng)MQX的內(nèi)核分析及應(yīng)用研究

    基于嵌入式實時操作系統(tǒng)MQX的內(nèi)核分析及應(yīng)用研究
    發(fā)表于 08-18 15:29

    HAL移植步驟

    層和變體層中的許多成熟可用的代碼。由于本系統(tǒng)S3C2510處理器的內(nèi)核是ARM940T,因而可以把S3C2510的目錄建立ECOS庫路徑
    發(fā)表于 06-18 07:20

    嵌入式實時操作系統(tǒng)ECOS移植到S3C2510

    /s3c2510_misc.c —— HAL的底層標(biāo)準(zhǔn)函數(shù),包括時鐘平臺初始化、時鐘延時函數(shù)、中斷使能、中斷屏蔽、中斷響應(yīng)等。* src/ hal_diag.c —— 硬件抽象層診斷輸出函數(shù),包含ECOS
    發(fā)表于 07-16 06:36

    求一款S3C2510的移植方案

    S3C2510是什么?ECOS系統(tǒng)的主要組成部分有哪些?
    發(fā)表于 04-26 07:06

    三星官方S3C2510開發(fā)板的原理圖(PDF格式)

    三星官方S3C2510開發(fā)板的原理圖(PDF格式),僅供參考,不要完全照抄。三星沒說讓我公開,以前我只是提供給真正的OEM商,現(xiàn)在放在這里,希望可以促進(jìn)此芯片更廣的使用。好東西哦
    發(fā)表于 03-25 16:12 ?95次下載

    三星原廠官方的S3C2510開發(fā)板原理圖

    三星原廠官方的S3C2510開發(fā)板原理圖
    發(fā)表于 03-28 09:49 ?77次下載

    嵌入式實時操作系統(tǒng)μC/OS-II與eCos的比較

    敘述嵌入式系統(tǒng)和嵌入式操作系統(tǒng)的概念,簡述嵌入式實時系統(tǒng)的發(fā)展階段。重點介紹μC/OSII和eCos 的發(fā)展歷史,并且對μ
    發(fā)表于 04-15 09:36 ?12次下載

    嵌入式實時操作系統(tǒng)μC OS-II與eCos的比較

    敘述嵌入式系統(tǒng)和嵌入式操作系統(tǒng)的概念,簡述嵌入式實時系統(tǒng)的發(fā)展階段。重點介紹μC/OSII和eCos 的發(fā)展歷史,并且對μ
    發(fā)表于 05-16 14:38 ?20次下載

    ECOS嵌入式系統(tǒng)S3C2510以太網(wǎng)驅(qū)動程序設(shè)計

    本文介紹了實時性操作系統(tǒng)ECOS的一般以太網(wǎng)驅(qū)動程序的開發(fā)方法,并具體研究SAMSUNG公司的以ARM940T為內(nèi)核的S3C2510嵌入式芯
    發(fā)表于 08-11 10:31 ?53次下載

    嵌入式操作系統(tǒng)uClinux和eCos的比較

    uClinux和eCos操作系統(tǒng)是兩種性能優(yōu)良、源碼公開且被廣泛應(yīng)用的免費嵌入式操作系統(tǒng)。本文通過對uclinux和eCos的對比,分析和總結(jié)了嵌入式
    發(fā)表于 04-18 08:36 ?1734次閱讀
    嵌入式<b class='flag-5'>操作系統(tǒng)</b>uClinux和<b class='flag-5'>eCos</b>的比較

    UT-S3C2416開發(fā)板簡介

    S3C2416是低功耗、高性能、低成本的SAMSUNG ARM9(ARM926EJ)處理器,最具性價比優(yōu)勢的芯片,S3C2440最完美的替代者。 UT-S3C2416開發(fā)板是一款以
    發(fā)表于 04-08 16:27 ?97次下載
    UT-<b class='flag-5'>S3C</b>2416<b class='flag-5'>開發(fā)板</b>簡介

    NXPl788lwip的無操作系統(tǒng)移植,基于Embest開發(fā)板

    NXPl788lwip的無操作系統(tǒng)移植,基于Embest開發(fā)板
    發(fā)表于 03-26 15:59 ?85次下載

    基于ARM7的S3C44BOX開發(fā)板的智能家居系統(tǒng)

    選用三星公司的S3C44BOX ARM7開發(fā)板為硬件平臺,以uClinux作為嵌入式操作系統(tǒng),實現(xiàn)對家庭網(wǎng)絡(luò)中的信息家電進(jìn)行監(jiān)控,使用戶能夠了解家庭中信息家電的工作狀況,對信息家電進(jìn)行控制。
    發(fā)表于 09-02 10:06 ?9次下載
    基于ARM7的<b class='flag-5'>S3C</b>44BOX<b class='flag-5'>開發(fā)板</b>的智能家居<b class='flag-5'>系統(tǒng)</b>

    操作系統(tǒng)Nucleus PLUSS3C2410A開發(fā)板應(yīng)用研究

    Nucleus PLUS是美國ATI 公司為實時性要求較高的嵌入式系統(tǒng)應(yīng)用設(shè)計的操作系統(tǒng)內(nèi)核。約95%的Nucleus PLUS代碼用ANSI C語言編寫,因此,非常便于移植并能夠支持大多數(shù)類型
    的頭像 發(fā)表于 03-13 08:04 ?1914次閱讀
    <b class='flag-5'>操作系統(tǒng)</b>Nucleus PLUS<b class='flag-5'>在</b><b class='flag-5'>S3C</b>2410A<b class='flag-5'>開發(fā)板</b><b class='flag-5'>上</b>的<b class='flag-5'>應(yīng)用研究</b>

    基于S3C2410開發(fā)板的Bootloader運行原理與實現(xiàn)

    有點類似于PC機(jī)的BIOS(基本輸入輸出系統(tǒng))程序。它的主要作用是為運行操作系統(tǒng)提供基本的運行環(huán)境,并操作系統(tǒng)的內(nèi)核裝載到存儲器(RAM)中的合適位置上去運行。本文將以Samsung公司的S3
    的頭像 發(fā)表于 09-22 18:02 ?2345次閱讀
    基于<b class='flag-5'>S3C</b>2410<b class='flag-5'>開發(fā)板</b>的Bootloader運行原理與實現(xiàn)