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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

UCOS2系統(tǒng)內(nèi)核講述_ 總體描述

黃工的嵌入式技術圈 ? 來源:黃工的嵌入式技術圈 ? 2020-03-25 10:39 ? 次閱讀

Ⅰ、寫在前面

學習本文之前可以參考我前面基于STM32硬件平臺移植UCOS2的幾篇文章,我將其匯總在一起:

UCOS2_STM32F1移植詳細過程(匯總文章)

要想學習,或使用系統(tǒng)配套的資源(如:信號量、消息郵箱、消息隊列等),就需要先了解一下系統(tǒng)內(nèi)核大致的原理,也就是先了解大致,在研究細節(jié)的東西(從外到內(nèi)),本文就是接著前面移植的文章來講述關于系統(tǒng)內(nèi)核的知識。

本文主要是結合前面移植好、可以運行的源代碼來進行講述關于最新版本UCOS2系統(tǒng)內(nèi)部代碼。

關于本文的更多詳情請往下看。

Ⅱ、UCOS操作系統(tǒng)配置

看過我前面移植UCOS的文章,或打開過我移植成功的軟件工程,都應該大體知道一個簡單的UCOS系統(tǒng)大概需要一些什么配置,包含哪些部分等。

本節(jié)將對UCOS軟件工程總體的一些知識進行講述(從大方向來描述一下),也算是對某些知識的再次回顧。

UCOS系統(tǒng)配置就是修改os_cfg.h文件,就是使能或失能某些功能,也就是所謂的系統(tǒng)裁剪。


比如:

我們不使能APP應用HOOK函數(shù)

則#defineOS_APP_HOOKS_EN0u

如果使能APP應用HOOK函數(shù)

則#define OS_APP_HOOKS_EN1u

再比如:

我們定義最低優(yōu)先級(值)為63

則#defineOS_LOWEST_PRIO63u

定義最大數(shù)10個任務

則#define OS_MAX_TASKS 10u

其實這里的配置在系統(tǒng)中很多通過預處理(配置了的才編譯,未配置不編譯)來實現(xiàn)的,也就是直接影響程序編譯的大小,所以叫系統(tǒng)裁剪。

我提供(移植完成)的實例里面有很多資源(如:信號量、消息郵箱、消息隊列等)都沒有實現(xiàn),所以那些都是失能的(即都配置為0)。

Ⅲ、主函數(shù)描述

主函數(shù)在裸機程序和操作系統(tǒng)程序中都是有的,也是程序的入口函數(shù),這里大體講述一下UCOS操作系統(tǒng)主函數(shù)中重要的三個函數(shù):

OSInit操作系統(tǒng)初始化

OSTaskCreateExt創(chuàng)建任務

OSStart啟動任務


1.OSInit系統(tǒng)初始化

跟蹤代碼可以知道,這個函數(shù)的函數(shù)體位于os_core.c文件中。操作系統(tǒng)初始化顧名思義就是對UCOS系統(tǒng)的初始化,其中包含內(nèi)核與系統(tǒng)資源這些的初始化,如下面代碼截圖:


從上面截圖就可以看得出來,紅色框標記的是系統(tǒng)內(nèi)核必須初始化部分,藍色框標記是選配(由系統(tǒng)配置決定)。

我們上面說的“系統(tǒng)配置”,在這里就能體現(xiàn)的出來。比如:我藍色框標記的部分中,沒有使能“事件標志”也就是在配置中沒有使能使能該選項,那么程序也不會初始化事件標志組。接著的其他選項一樣的道理。

2.OSTaskCreateExt創(chuàng)建任務

跟蹤代碼可以知道,這個函數(shù)的函數(shù)體位于os_task.c文件中。該函數(shù)從命名及意思上可以知道,它就是創(chuàng)建任務的函數(shù)。我們使用“擴展版本”創(chuàng)建任務,主要是配置及初始化任務相關的堆棧、優(yōu)先級、以及檢測參數(shù)的正確性等,如下面代碼截圖:


注意:在os_cfg中需要使能“創(chuàng)建任務-擴展”,也就是需要配置:

#define OS_TASK_CREATE_EXT_EN 1u

創(chuàng)建任務有兩個函數(shù)(請看os_task.c文件):

OSTaskCreate基本版本

OSTaskCreateExt擴展版本

擴展版本是在后面升級系統(tǒng)新增加的一個函數(shù),主要是新增加了5個參數(shù)(具體請見源代碼),但為了使程序兼容以前系統(tǒng),這后面的系統(tǒng)中也是保留了基本版本的創(chuàng)建任務函數(shù)接口。

我在主函數(shù)里面創(chuàng)建的任務是AppTaskStart,也是“開始任務”,后面的一些關于應用所需的初始化都是在AppTaskStart下面創(chuàng)建的,子任務也是基于該函數(shù)創(chuàng)建的。

3.OSStart開啟任務

跟蹤代碼可以知道,這個函數(shù)的函數(shù)體位于os_core.c文件中。在操作系統(tǒng)初始化、任務創(chuàng)建完成之后,調(diào)用OSStart就可以開啟并執(zhí)行任務了。

該函數(shù)也是屬于內(nèi)核級的,由系統(tǒng)調(diào)用,主要包含幾步操作:

1.查找最高優(yōu)先級任務,使其進入就緒;

2.將當前優(yōu)先級指向就緒任務的最高優(yōu)先級;

3.執(zhí)行目標代碼,開始任務(OSRunning = OS_TRUE)。


當你初始接觸UCOS系統(tǒng)時,先了解它主要的意思是啟動任務就行了,至于怎樣啟動的,需后續(xù)研究系統(tǒng)內(nèi)核這一塊,我在后面也會講述。

Ⅳ、AppTaskStart任務描述

應用程序(任務)的執(zhí)行可以說就是從AppTaskStart這個函數(shù)(在上面main中創(chuàng)建的任務)開始一步一步執(zhí)行的。

在AppTaskStart函數(shù)體里面主要做了三類事情:

1.BSP_Initializes:初始化應用底層一些代碼,基本實例就是LED的IO驅動;

2.OSTick_Init:滴答時鐘初始化,這個是屬于系統(tǒng),在前面移植的過程中說過由我們自己定義,所以這里需要初始化。

3.OSTaskCreateExt:創(chuàng)建子任務(Demo程序創(chuàng)建了3個子任務)。


為什么在這里還要創(chuàng)建任務呢?

這種寫法是參考UCOS官方提供實例代碼的寫法(在main主函數(shù)只創(chuàng)建一個AppTaskStart任務,再在AppTaskStart函數(shù)創(chuàng)建子任務、系統(tǒng)資源等)。

當然,這個格式寫法不是死的,可根據(jù)自己習慣或要求來寫。

1.BSP_Initializes

跟蹤代碼可以知道,這個函數(shù)的函數(shù)體位于bsp.c文件中。這個函數(shù)是我們自己建的文件,我將它歸類為“應用程序底層代碼初始化”,自己可更加實際情況修改。由于是Demo程序(LED閃爍燈),這里主要是對LED燈IO口的初始化。

2.OSTick_Init

跟蹤代碼可以知道,這個函數(shù)的函數(shù)體位于app_cfg.c文件中。這個函數(shù)也是我們自己設計的源代碼,在前面移植的過程中要求自己初始化系統(tǒng)滴答,這里就需要初始化。當然也可以在UCOS提供的文件“os_cpu_c.c”里面初始化該函數(shù)。

系統(tǒng)滴答是系統(tǒng)的心臟,沒有它就等于沒有心臟。這里需要搭配滴答中斷函數(shù)(如下圖)。


3.OSTaskCreateExt子任務

提供的Demo程序創(chuàng)建了一個開始任務和3個子任務,任務都是實現(xiàn)LED閃爍的內(nèi)容。更加閃爍的頻率(亮滅間隔時間)不同,可以區(qū)分出不同的任務。


開始任務、子任務1、子任務2、子任務3依次LED亮滅間隔時間加長。是由OSTimeDly函數(shù)決定的,OSTimeDly函數(shù)是系統(tǒng)延時的意思,它這個延時和我們平常使用的延時相似,但又不同。它在各自的任務了看似屬于自身“阻塞延時”了那么長時間,但自系統(tǒng)看來其實是將該任務掛起了那么長時間。

OSTimeDly延時函數(shù)屬于系統(tǒng)級延時,需要了解系統(tǒng)內(nèi)核之后對它的理解就容易了。

Ⅴ、實例工程下載

筆者針對于初學者提供的例程都是去掉了許多不必要的功能,精簡了官方的代碼,對初學者一看就明白,以簡單明了的工程供大家學習。

筆者提供的實例工程都是在板子上經(jīng)過多次測試并沒有問題才上傳至360云盤,歡迎下載測試、參照學習。

我將最新UCOS2.92操作系統(tǒng)移植到F0、F1、F3、F4各個硬件平臺上,可以根據(jù)你芯片系列選擇下載。

UCOS基于STM32F0系列實例:

https://yunpan.cn/cRCZrQ3dzeVQq訪問密碼 e73f

UCOS基于STM32F1系列實例:

https://yunpan.cn/cRCZxGFsqHa6Q訪問密碼 39ff

UCOS基于STM32F3系列實例:

https://yunpan.cn/cRCZqPRCWs8UW訪問密碼 b305

UCOS基于STM32F4系列實例:

https://yunpan.cn/cRCZPqbFqXSPR訪問密碼 f177

本文是基于上面修改部分注釋為中文:

https://yunpan.cn/cM6tNgShDuj5Y 訪問密碼 889e

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

    關注

    30

    文章

    4788

    瀏覽量

    68616
  • HOOK
    +關注

    關注

    0

    文章

    15

    瀏覽量

    8384
  • ucos2
    +關注

    關注

    0

    文章

    15

    瀏覽量

    3558
收藏 人收藏

    評論

    相關推薦

    請問PCM1864的驅動在設備樹該如何描述?

    請問PCM1864的驅動在設備樹該如何描述呢: 1. 我使用的不是TI的LINUX內(nèi)核,是另外一款SOC的LINUX內(nèi)核 2. 我在設備樹做了以下
    發(fā)表于 10-23 07:30

    Linux內(nèi)核測試技術

    Linux 內(nèi)核是Linux操作系統(tǒng)的核心部分,負責管理硬件資源和提供系統(tǒng)調(diào)用接口。隨著 Linux 內(nèi)核的不斷發(fā)展和更新,其復雜性和代碼規(guī)模也在不斷增加。因此,確保
    的頭像 發(fā)表于 08-13 13:42 ?493次閱讀
    Linux<b class='flag-5'>內(nèi)核</b>測試技術

    請問MODUS支持LINUX、FREERTOS、UCOS、Mbed、Android所有操作系統(tǒng)嗎?

    請問 MODUS 支持 LINUX、FREERTOS、UCOS、Mbed、Android 所有操作系統(tǒng)嗎?
    發(fā)表于 07-23 06:06

    Cortex R52內(nèi)核Cache的具體操作(2

    本節(jié)內(nèi)容主要講述CortexR52內(nèi)核Cache的具體操作包括使緩存無效(invalidate)操作,清除(clean)緩存。有的時候客戶可能需要對cache做一些清理,比如invalidate
    的頭像 發(fā)表于 07-15 15:44 ?1409次閱讀
    Cortex R52<b class='flag-5'>內(nèi)核</b>Cache的具體操作(<b class='flag-5'>2</b>)

    CortexR52內(nèi)核Cache的具體操作

    本節(jié)內(nèi)容主要講述CortexR52內(nèi)核Cache的具體操作包括使緩存無效(invalidate)操作,清除(clean)緩存。有的時候客戶可能需要對cache做一些清理,比如invalidate
    的頭像 發(fā)表于 07-15 10:32 ?1295次閱讀
    CortexR52<b class='flag-5'>內(nèi)核</b>Cache的具體操作

    鴻蒙開發(fā)ArkUI-X基礎知識:【ArkUI跨平臺設計總體說明】

    本文檔描述ArkUI開發(fā)框架跨平臺運行能力相關的總體技術方案。
    的頭像 發(fā)表于 05-24 15:41 ?1551次閱讀
    鴻蒙開發(fā)ArkUI-X基礎知識:【ArkUI跨平臺設計<b class='flag-5'>總體</b>說明】

    內(nèi)核實時操作系統(tǒng)的介紹

    內(nèi)核實時操作系統(tǒng)(Microkernel Real-Time Operating System, μRTOS)是一種專為實時設計的操作系統(tǒng)。它采用微內(nèi)核架構,以提高
    的頭像 發(fā)表于 05-11 17:13 ?505次閱讀

    請問stm32L4是不是M4內(nèi)核

    為什么L4在ucos 庫里是屬于 M3內(nèi)核,F(xiàn)4系列 在ucos庫里是屬于 M4內(nèi)核
    發(fā)表于 04-17 07:07

    配電系統(tǒng)實施總體綜合設計方案

    配電系統(tǒng)實施總體思路:根據(jù)屏體用電量,現(xiàn)場施工要求,以及配電柜所帶負荷情況,總體綜合設計配電系統(tǒng)。
    發(fā)表于 03-06 10:31 ?415次閱讀
    配電<b class='flag-5'>系統(tǒng)</b>實施<b class='flag-5'>總體</b>綜合設計方案

    智慧管廊監(jiān)控與報警系統(tǒng)總體需求

    電子發(fā)燒友網(wǎng)站提供《智慧管廊監(jiān)控與報警系統(tǒng)總體需求.doc》資料免費下載
    發(fā)表于 01-18 09:17 ?0次下載

    Linux內(nèi)核中信號的傳遞過程

    前面我們已經(jīng)介紹了內(nèi)核注意到信號的到來,調(diào)用相關函數(shù)更新進程描述符以便進程接收處理信號。但是,如果目標進程此時沒有運行,內(nèi)核則推遲傳遞信號?,F(xiàn)在,我們看看內(nèi)核如何處理進程掛起的信號。
    的頭像 發(fā)表于 01-17 09:51 ?1177次閱讀
    Linux<b class='flag-5'>內(nèi)核</b>中信號的傳遞過程

    請問ADuC7060能否移植uCOS II嵌入式操作系統(tǒng)?

    我想問一下ADuC7060能否移植uCOS II嵌入式操作系統(tǒng)
    發(fā)表于 01-15 06:59

    一文詳解Linux內(nèi)核-信號的產(chǎn)生過程

    許多內(nèi)核函數(shù)產(chǎn)生信號:它們完成信號處理的第一階段,也就是更新一個或多個進程描述符。
    的頭像 發(fā)表于 01-13 13:48 ?1318次閱讀

    智慧管廊監(jiān)控與報警系統(tǒng)總體需求

    電子發(fā)燒友網(wǎng)站提供《智慧管廊監(jiān)控與報警系統(tǒng)總體需求.doc》資料免費下載
    發(fā)表于 01-05 11:36 ?1次下載

    RZ/G2L Linux系統(tǒng)如何添加新的內(nèi)核模塊

    RZ/G2L Linux系統(tǒng)的鏡像基于yocto構建,本篇介紹如何添加新的內(nèi)核模塊。
    的頭像 發(fā)表于 01-04 12:19 ?1789次閱讀
    RZ/G<b class='flag-5'>2</b>L Linux<b class='flag-5'>系統(tǒng)</b>如何添加新的<b class='flag-5'>內(nèi)核</b>模塊