伦伦影院久久影视,天天操天天干天天射,ririsao久久精品一区 ,一本大道香蕉大久在红桃,999久久久免费精品国产色夜,色悠悠久久综合88,亚洲国产精品久久无套麻豆,亚洲香蕉毛片久久网站,一本一道久久综合狠狠老

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

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

3天內不再提示

UCOS2系統內核講述_ 總體描述

黃工的嵌入式技術圈 ? 來源:黃工的嵌入式技術圈 ? 2020-03-25 10:39 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Ⅰ、寫在前面

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

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

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

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

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

Ⅱ、UCOS操作系統配置

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

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

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


比如:

我們不使能APP應用HOOK函數

則#defineOS_APP_HOOKS_EN0u

如果使能APP應用HOOK函數

則#define OS_APP_HOOKS_EN1u

再比如:

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

則#defineOS_LOWEST_PRIO63u

定義最大數10個任務

則#define OS_MAX_TASKS 10u

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

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

Ⅲ、主函數描述

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

OSInit操作系統初始化

OSTaskCreateExt創建任務

OSStart啟動任務


1.OSInit系統初始化

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


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

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

2.OSTaskCreateExt創建任務

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


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

#define OS_TASK_CREATE_EXT_EN 1u

創建任務有兩個函數(請看os_task.c文件):

OSTaskCreate基本版本

OSTaskCreateExt擴展版本

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

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

3.OSStart開啟任務

跟蹤代碼可以知道,這個函數的函數體位于os_core.c文件中。在操作系統初始化、任務創建完成之后,調用OSStart就可以開啟并執行任務了。

該函數也是屬于內核級的,由系統調用,主要包含幾步操作:

1.查找最高優先級任務,使其進入就緒;

2.將當前優先級指向就緒任務的最高優先級;

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


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

Ⅳ、AppTaskStart任務描述

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

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

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

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

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


為什么在這里還要創建任務呢?

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

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

1.BSP_Initializes

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

2.OSTick_Init

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

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


3.OSTaskCreateExt子任務

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


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

OSTimeDly延時函數屬于系統級延時,需要了解系統內核之后對它的理解就容易了。

Ⅴ、實例工程下載

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

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

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

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

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

    關注

    30

    文章

    4974

    瀏覽量

    74228
  • HOOK
    +關注

    關注

    0

    文章

    15

    瀏覽量

    8850
  • ucos2
    +關注

    關注

    0

    文章

    15

    瀏覽量

    3714
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    西格電力微電網總體架構設計:分層分布式控制體系構建

    隨著分布式新能源規模化滲透、負荷需求多元化升級,微電網作為整合“源、儲、荷、網”多單元的新型能源系統,其安全穩定、高效經濟運行的核心訴求,對總體架構設計與控制體系提出了更高要求。微電網總體架構是
    的頭像 發表于 03-31 11:44 ?359次閱讀
    西格電力微電網<b class='flag-5'>總體</b>架構設計:分層分布式控制體系構建

    如何為 Vision Five 2 編譯自定義 Linux 內核

    Vision Five 2 的 Debian 用戶指南只提供了半頁關于如何編譯自己的內核的相當稀疏的內容。僅從該文檔中,我無法制作我的自定義內核。那里的信息似乎相當不完整。如果有人能提供一些
    發表于 02-24 07:44

    Linux內核伙伴系統內存申請函數詳解:從原理到實戰

    在 Linux 內核中,內存管理是整個系統穩定運行的基石,而伙伴系統(Buddy System) 作為內核物理內存分配的核心機制,更是驅動開發、內核
    的頭像 發表于 02-10 16:58 ?3681次閱讀
    Linux<b class='flag-5'>內核</b>伙伴<b class='flag-5'>系統</b>內存申請函數詳解:從原理到實戰

    深入理解設備樹chosen節點:固件與內核的“配置橋梁”

    在嵌入式 Linux 開發中,設備樹(Device Tree)是連接硬件與內核的關鍵紐帶。但有一個節點很特殊 —— 它不描述任何硬件模塊,卻直接決定內核能否正常啟動,這就是chosen節點。
    的頭像 發表于 02-09 16:36 ?219次閱讀
    深入理解設備樹chosen節點:固件與<b class='flag-5'>內核</b>的“配置橋梁”

    Linux內核bug狩獵指南:從棧跟蹤到修復,官方文檔教你搞定系統核心故障

    內核是 Linux 系統的 “心臟”—— 一旦它出 bug,小則功能異常,大則系統崩潰、死機。但內核 bug 往往藏在百萬行代碼中,想快速定位、修復絕非易事。
    的頭像 發表于 02-06 16:59 ?3221次閱讀
    Linux<b class='flag-5'>內核</b>bug狩獵指南:從棧跟蹤到修復,官方文檔教你搞定<b class='flag-5'>系統</b>核心故障

    Linux內核的“心跳”:jiffies如何為系統計時?

    在 Linux 內核的世界里,有一個默默工作的 "計時器"——jiffies。它不像我們手機上的時鐘那樣顯示年月日,卻掌控著內核中絕大多數時間相關的操作:從進程調度到設備驅動的定時檢查,都離不開它的身影。
    的頭像 發表于 02-04 16:27 ?880次閱讀
    Linux<b class='flag-5'>內核</b>的“心跳”:jiffies如何為<b class='flag-5'>系統</b>計時?

    Linux系統內核參數調優實戰指南

    Linux 內核參數調優是系統性能優化的核心環節。隨著云原生架構的普及和硬件性能的飛速提升,默認的內核參數配置往往無法充分發揮系統潛力。在高并發 Web 服務、大數據處理、容器化部署等
    的頭像 發表于 01-28 14:27 ?583次閱讀

    【「Linux 設備驅動開發(第 2 版)」閱讀體驗】+讀深入理解Linux內核內存分配

    ,目前4KB是廣泛使用的頁大小。在Linux操作系統中,每個進程甚至內核本身都被分配了地址空間,這是處理器的虛擬地址空間的一部分,內核和進程都不處理物理地址,物理地址由MMU處理。 虛擬地址空間被拆分
    發表于 01-16 20:05

    【「Linux 設備驅動開發(第 2 版)」閱讀體驗】Linux內核開發基礎

    感謝電子發燒友論壇提供的《Linux設備驅動開發(第2版)》閱讀機會,測評將從Linux內核開發基礎、Linux內核平臺抽象和設備驅動程序、發揮硬件潛力以及嵌入式領域內的多種內核子系統
    發表于 01-12 22:45

    【「Linux 設備驅動開發(第 2 版)」閱讀體驗】+讀內核處理的核心輔助函數

    上周收到《Linux 設備驅動開發(第 2 版)》書籍,這是一本介紹Linux內核開發的指導性書籍。全面了解Linux內核所提供的一些接口函數,是一位Linux設備驅動開發從業者所必備的知識點。書籍
    發表于 01-10 22:08

    ElfBoard嵌入式教育科普|Linux系統I/O接口:Open函數詳解

    1.函數概述open()是Linux/Unix內核提供的底層系統調用,核心功能是打開或創建文件。成功調用后,內核會返回一個整型的文件描述符作為該文件的句柄,后續的所有讀寫操作都基于此
    的頭像 發表于 12-29 11:41 ?1162次閱讀
    ElfBoard嵌入式教育科普|Linux<b class='flag-5'>系統</b>I/O接口:Open函數詳解

    ucos與freertos哪個好?

    選擇uCOS或FreeRTOS取決于項目的具體需求和資源限制。 FreeRTOS的優點包括: 更小的內核ROM和RAM占用,特別是在RAM方面,適合資源受限的嵌入式系統。 支持協程
    發表于 12-05 07:13

    Linux內核模塊的加載機制

    使用insmod或modprobe命令來加載模塊。insmod是直接加載,而modprobe會處理依賴關系。 2、如何工作 那內核模塊具體是怎么工作的呢?當執行insmod時,會調用系統調用
    發表于 11-25 06:59

    飛凌嵌入式ElfBoard-系統IO接口之刷新內核緩沖

    、權限等等信息,這里統稱為文件的元數據,這些信息也是存儲在磁盤設備中的。1)頭文件#include 2)函數原型int fsync(int fd);3)參數fd:表示要操作文件的文件描述符。4)返回值若
    發表于 11-04 08:59

    強實時運動控制內核MotionRT750(一):驅動安裝、內核配置與使用

    強實時運動控制內核MotionRT750的驅動安裝與內核配置
    的頭像 發表于 07-03 15:48 ?3781次閱讀
    強實時運動控制<b class='flag-5'>內核</b>MotionRT750(一):驅動安裝、<b class='flag-5'>內核</b>配置與使用