91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

RT-Thread內(nèi)核對象管理器設(shè)計思路

璟琰乀 ? 來源:嵌入式資訊精選 ? 作者:嵌入式資訊精選 ? 2020-11-04 18:09 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

[導(dǎo)讀] 前面寫了些文章分享C語言面向?qū)ο笤O(shè)計的一些個人體會,個人認為RT-Thread內(nèi)核對于面向?qū)ο髮崿F(xiàn)思想是一個非常好的設(shè)計。向這些在基礎(chǔ)軟件上深耕的國人大牛們致敬。本文基于學(xué)習(xí)RT-Thread內(nèi)核設(shè)計的初衷,來分享一下個人對于其內(nèi)核對象子系統(tǒng)設(shè)計的理解與體會。在此,也給各位RT-Thread原創(chuàng)大牛們打call,分享本文也期望有更多的盆友去學(xué)習(xí)并使用RT_Thread。

RT-Tread內(nèi)核架構(gòu)RT-Thread,全稱是 Real Time-Thread,顧名思義,它是一個嵌入式實時多線程操作系統(tǒng),基本屬性之一是支持多任務(wù),允許多個任務(wù)同時運行并不意味著處理器在同一時刻真地執(zhí)行了多個任務(wù)。其內(nèi)核架構(gòu)如下圖所示:

RT-Thread 內(nèi)核及底層結(jié)構(gòu)

對于各部分的功能,這里不做展開描述。RT-Tread內(nèi)核吸引我的方面:

代碼優(yōu)雅、可讀性非常高

體積小巧、代碼類Linux風格,可裁剪

社區(qū)活躍,國人自主開發(fā),用戶越來越多

優(yōu)秀的設(shè)計,對于面向?qū)ο笤O(shè)計思想可以說是非常優(yōu)秀的實踐

主要定位于物聯(lián)網(wǎng)應(yīng)用,各種組件豐富,融合的也很好。

所以如果是RTOS應(yīng)用或者開發(fā)從業(yè)者,面對這么優(yōu)秀且比較容易深入學(xué)習(xí)的內(nèi)核,如果不去好好讀讀,實在有點可惜。要去體會RT-Thread對象設(shè)計思想,從其對內(nèi)核對象object的管理入手,不失為一個非常好的切入點。

什么是RT-Thread內(nèi)核對象管理?RT-Thread 采用內(nèi)核對象管理系統(tǒng)來訪問 / 管理所有內(nèi)核對象,內(nèi)核對象包含了內(nèi)核中絕大部分設(shè)施,這些內(nèi)核對象既可以是靜態(tài)分配的靜態(tài)對象,也可以是從系統(tǒng)內(nèi)存堆中分配的動態(tài)對象。通過這種內(nèi)核對象的設(shè)計方式,RT-Thread 做到了不依賴于具體的內(nèi)存分配方式,系統(tǒng)的靈活性得到極大的提高。

RT-Thread 內(nèi)核對象包括:線程,信號量,互斥量,事件,郵箱,消息隊列和定時器,內(nèi)存池,設(shè)備驅(qū)動等。對象容器中包含了每類內(nèi)核對象的信息,包括對象類型,大小等。對象容器給每類內(nèi)核對象分配了一個鏈表,所有的內(nèi)核對象都被鏈接到該鏈表上,如圖 RT-Thread 的內(nèi)核對象容器及鏈表如下圖所示:

RT-Thread 的內(nèi)核對象容器及鏈表

這個集中管理的內(nèi)核對象容器在內(nèi)存的開銷方面代價很小,但卻具有高度的靈活性,從設(shè)計的角度看其代碼也非常利于擴展,增加新的內(nèi)核對象類別,以及對于相應(yīng)的內(nèi)核對象功能的裁剪適配。

內(nèi)核對象主要干什么?RT-Thread內(nèi)核對象子系統(tǒng)其主體實現(xiàn)代碼為object.c,本文嘗試從整體到局部來嘗試解讀其設(shè)計思想。object.c這個子系統(tǒng)從外部以黑盒的角度看,就個人理解主要實現(xiàn)了這樣些用例需求:

所以個人理解內(nèi)核對象管理器,主要是為其他內(nèi)核功能模塊提供數(shù)據(jù)管理支撐,屬于內(nèi)核底層支持功能組件,并從設(shè)計上兼顧了可擴展、可裁剪的需求。

怎么實現(xiàn)的呢?RT-Thread內(nèi)核對象子系統(tǒng)其主要核心數(shù)據(jù)結(jié)構(gòu)如下:

其中rt_object_class_type枚舉定義內(nèi)核對象類別:

enum rt_object_class_type{ RT_Object_Class_Null = 0, /* 未使用 */ RT_Object_Class_Thread, /* thread對象 */ RT_Object_Class_Semaphore, /* semaphore對象 */ RT_Object_Class_Mutex, /* mutex對象 */ RT_Object_Class_Event, /* event對象 */ RT_Object_Class_MailBox, /* mail box對象 */ RT_Object_Class_MessageQueue, /* message queue */ RT_Object_Class_MemHeap, /* memory heap */ RT_Object_Class_MemPool, /* memory pool */ RT_Object_Class_Device, /* device對象 */ RT_Object_Class_Timer, /* timer對象 */ RT_Object_Class_Module, /* module */ RT_Object_Class_Unknown, /* unknown */ RT_Object_Class_Static = 0x80 /*8位類型變量高位置1表示靜態(tài)對象 */};

而rt_object_information則抽象了對象類型,加入了一個雙向鏈表指針數(shù)據(jù)域rt_list_node,從而將同類別的內(nèi)核對象利用該雙鏈指針鏈接起來,這些同類別的內(nèi)核對象具有如下可能的特點:

可能在軟件運行時生成,也可能在os初始化創(chuàng)建。

其存儲類型可能為靜態(tài)類型,也可能為動態(tài)類型(所謂動態(tài)類型這里是確指在內(nèi)核堆上動態(tài)申請的內(nèi)存區(qū)域用于存儲相應(yīng)的內(nèi)核對象)。

在內(nèi)存空間中,其位置并不連續(xù)。

如此以來,將這些內(nèi)核對象在空間上不連續(xù)的變量,利用鏈表形成了可統(tǒng)一管理、可增可刪、可檢索的邏輯結(jié)構(gòu)。

而rt_object_container內(nèi)核容器,其本質(zhì)是一個內(nèi)核對象索引表,主要集中管理了下面的信息:

enum rt_object_class_type type:內(nèi)核對象類別,每項表記錄條目的類別

rt_list_t object_list:每類對象鏈表的頭結(jié)點的鏈表指針數(shù)據(jù)域

rt_size_t object_size:該類個體的大小

利用宏將相應(yīng)的鏈表進行選編譯,在內(nèi)核關(guān)鍵數(shù)據(jù)進行了裁剪管理。而對于內(nèi)核本身的擴展性而言,如果需要增加新的內(nèi)核功能,可以方便的增加新的內(nèi)核對象類,并能方便的加入到這個內(nèi)核對象容器中,利用公共的對外接口,實現(xiàn)統(tǒng)一管理,而不必對數(shù)據(jù)管理層進行額外的接口設(shè)計。

實現(xiàn)了哪些對外接口呢?有了這樣一個優(yōu)雅的數(shù)據(jù)結(jié)構(gòu)設(shè)計,那么基于這樣一個數(shù)據(jù)結(jié)構(gòu)設(shè)計,相應(yīng)就很容易實現(xiàn)其內(nèi)核對象集中管理的對外服務(wù)接口,那么其主要的服務(wù)接口有哪些呢?

其中一部分主要接口實現(xiàn)對象的增加刪除檢索等,這里以rt_object_init接口為例,來簡要分析一下其實現(xiàn):

void rt_object_init(struct rt_object *object, enum rt_object_class_type type, const char *name){ register rt_base_t temp; struct rt_list_node *node = RT_NULL; struct rt_object_information *information;#ifdef RT_USING_MODULE struct rt_dlmodule *module = dlmodule_self();#endif /*1. 在容器中找到這是什么對象類*/ information = rt_object_get_information(type); RT_ASSERT(information != RT_NULL); /* check object type to avoid re-initialization */ /* 進入臨界區(qū)保護 */ rt_enter_critical(); /* try to find object */ for (node = information-》object_list.next; node != &(information-》object_list); node = node-》next) { struct rt_object *obj; obj = rt_list_entry(node, struct rt_object, list); if (obj) /* skip warning when disable debug */ { RT_ASSERT(obj != object); } } /* 離開臨界區(qū) */ rt_exit_critical(); /* 初始化對象參數(shù),并置為靜態(tài)標記 */ object-》type = type | RT_Object_Class_Static; rt_strncpy(object-》name, name, RT_NAME_MAX); RT_OBJECT_HOOK_CALL(rt_object_attach_hook, (object)); /* 禁止硬件中斷 */ temp = rt_hw_interrupt_disable();#ifdef RT_USING_MODULE if (module) { rt_list_insert_after(&(module-》object_list), &(object-》list)); object-》module_id = (void *)module; } else#endif { /* 對象插入容器中相應(yīng)對象分支鏈連 */ rt_list_insert_after(&(information-》object_list), &(object-》list)); } /* 開硬件中斷 */ rt_hw_interrupt_enable(temp);}

對于內(nèi)核對象增加刪除其主要就是利用內(nèi)核容器首先檢索到鏈表頭結(jié)點,然后再進一步做雙向鏈表的基本操作,這里對于具體如何操作鏈表就不做展開贅述了。

對于內(nèi)核對象相關(guān)數(shù)據(jù)域的檢索、查詢有了明確的數(shù)據(jù)結(jié)構(gòu),以及能檢索到結(jié)點鏈表指針,由于結(jié)點鏈表指針與相應(yīng)內(nèi)核對象各數(shù)據(jù)域具有確定的相對位置關(guān)系,所以檢索而言是非常易于實現(xiàn)的。

而對于動態(tài)內(nèi)核對象而言,其差異在于內(nèi)核對象本身是動態(tài)申請的,這里需要注意的是向內(nèi)核堆申請的,而不是C堆申請的,至于什么是內(nèi)核堆,以及為什么要設(shè)計內(nèi)核堆,之前有寫過一篇文章分享,有興趣可以去看看。

內(nèi)核對象有什么相互繼承關(guān)系?RT-Thread管網(wǎng)上給出了這樣一個相互關(guān)系圖:

RT-Thread 內(nèi)核對象繼承關(guān)系

如果不去具體看相應(yīng)數(shù)據(jù)結(jié)構(gòu),或許不易理解為啥有這樣一張圖。這里以上圖中其中幾個內(nèi)核對象來***其相互關(guān)系:

或許有盆友會問,為啥rt_thread對象中明明沒有直接包含rt_object,那為啥說rt_thread也是繼承自rt_object呢?如果你細看看上圖rt_thread中紅框框出來的數(shù)據(jù)域就恍然大悟了,即便沒有直接包含,但在內(nèi)存中框里的內(nèi)容就是rt_object的數(shù)據(jù)內(nèi)容,所以利用指針轉(zhuǎn)換就可以方便訪問了,至于為什么是這樣?我想可能是歷史原因吧?所以rt_thread結(jié)構(gòu)體前面幾個數(shù)據(jù)域的位置是不可以修改的。這里還有盆友可能會問為什么ipc線程通信相關(guān)內(nèi)核對象需要單獨拎出來一個父結(jié)構(gòu)體呢?我想應(yīng)該是此類具有相同的一些共性,具有一些類似的特點。這也是對象設(shè)計提取共性進而抽象封裝的一個體現(xiàn)。

總結(jié)一下本文大致學(xué)習(xí)總結(jié)了一下RT-Thread內(nèi)核對象子系統(tǒng)的設(shè)計思路的理解,從這里個人總結(jié)了一些啟示:

軟件是數(shù)據(jù)結(jié)構(gòu)+算法,而良好的數(shù)據(jù)結(jié)構(gòu)設(shè)計是優(yōu)雅算法的基礎(chǔ),所以在工程開發(fā)中,如何設(shè)計好的數(shù)據(jù)結(jié)構(gòu)抽象是一個可以深入挖掘的話題

RT-Thread的內(nèi)核對象設(shè)計個人認為非常易于理解,也是一個最佳實踐。如有興趣可以細細體會,多多揣摩。

責任編輯:haq

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

    關(guān)注

    4

    文章

    1467

    瀏覽量

    42872
  • 管理器
    +關(guān)注

    關(guān)注

    0

    文章

    265

    瀏覽量

    19518
  • RT-Thread
    +關(guān)注

    關(guān)注

    32

    文章

    1613

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    恩智浦亮相RT-Thread 20周年開發(fā)者大會

    日前,“開源向?qū)崱どa(chǎn)力進化啟示錄”全球峰會暨RT-Thread 20周年開發(fā)者大會在上海成功舉辦,恩智浦作為RT-Thread的緊密合作伙伴,在活動中重磅亮相,展示雙方在共建RT-Thread OS開發(fā)生態(tài)方面的新成果、新方案
    的頭像 發(fā)表于 01-26 09:07 ?550次閱讀

    RT-Thread Studio V2.3.0 版本正式發(fā)布!

    支持針對rt-thread版本號大于5.1.0時使用Env2.0.0高版本2新增支持卸載studio時選擇是否保留已下載的SDK資源包文件3修復(fù)SDK管理器選擇了版
    的頭像 發(fā)表于 11-29 09:29 ?1107次閱讀
    <b class='flag-5'>RT-Thread</b> Studio V2.3.0 版本正式發(fā)布!

    首搭RT-Thread程翧車控平臺| RT-Thread程翧 S32K344 快速原型開發(fā)平臺正式上市!| 產(chǎn)品動態(tài)

    在智能汽車邁向高集成與高安全的時代,VCU/ECU開發(fā)正面臨效率與可靠性的雙重考驗。依賴單一硬件或拼湊軟件方案的傳統(tǒng)模式,已成為制約創(chuàng)新的瓶頸。為此,RT-Thread帶來里程碑式的解決方案
    的頭像 發(fā)表于 10-31 11:53 ?992次閱讀
    首搭<b class='flag-5'>RT-Thread</b>程翧車控平臺| <b class='flag-5'>RT-Thread</b>程翧 S32K344 快速原型開發(fā)平臺正式上市!| 產(chǎn)品動態(tài)

    【CPKCOR-RA8D1】5、運行RT-THREAD的適應(yīng)性調(diào)整

    CPKCOR-RA8D1B開發(fā)板不能直接使用,必須進行適應(yīng)性調(diào)整。 一、安裝env-windows RT-Thread Env 工具包括配置和包管理器,用來對內(nèi)核和組件的功能進行配置
    發(fā)表于 10-27 14:49

    2025年RT-Thread開發(fā)者巡回培訓(xùn)報名正式啟動!

    親愛的RT-Thread社區(qū)成員們:新程再啟,共赴熱愛!2025年RT-Thread開發(fā)者巡回培訓(xùn)正式啟動報名!今年,我們選擇了西安、武漢、北京、杭州、深圳、上海、成都這7座城市,為大家?guī)?/div>
    的頭像 發(fā)表于 09-27 10:39 ?1964次閱讀
    2025年<b class='flag-5'>RT-Thread</b>開發(fā)者巡回培訓(xùn)報名正式啟動!

    rt-thread studio v2.2.7 SDK管理器無法下載怎么解決?

    使用rt-thread studio v2.2.7中sdk管理器下載包時,資源下載源已切換到gitee,但是下載時仍使用github源。 rt-thread 包還不支持導(dǎo)入功能,哎?。。。。?/div>
    發(fā)表于 09-16 08:08

    rt-thread studio 2.2.9如何使用最新的RT-Thread v5.2.0 released?

    rt-thread studio2.2.9如何使用最新的RT-Thread v5.2.0 released? 原先以為修改index_all.json,發(fā)現(xiàn)聯(lián)網(wǎng)的時候,會自動覆蓋 另lastet版本
    發(fā)表于 09-16 06:06

    Windows上使用ENV工具開發(fā)基于先楫MCU的RT-Thread應(yīng)用

    前言Env是RT-Thread推出的開發(fā)輔助工具,針對基于RT-Thread操作系統(tǒng)的項目工程,提供編譯構(gòu)建環(huán)境、圖形化系統(tǒng)配置及軟件包管理功能。其內(nèi)置的menuconfig提供了簡單易用的配置剪裁
    的頭像 發(fā)表于 08-29 12:22 ?1444次閱讀
    Windows上使用ENV工具開發(fā)基于先楫MCU的<b class='flag-5'>RT-Thread</b>應(yīng)用

    在Ubuntu上開發(fā)基于先楫MCU的RT-Thread應(yīng)用指南

    1、前言RT-ThreadEnv是RT-Thread推出的開發(fā)輔助工具,針對基于RT-Thread操作系統(tǒng)的項目工程,提供編譯構(gòu)建環(huán)境、圖形化系統(tǒng)配置及軟件包管理功能。其內(nèi)置的menu
    的頭像 發(fā)表于 08-29 12:22 ?1776次閱讀
    在Ubuntu上開發(fā)基于先楫MCU的<b class='flag-5'>RT-Thread</b>應(yīng)用指南

    【好書推薦】RT-Thread第20本相關(guān)書籍!《嵌入式實時操作系統(tǒng)RT-Thread原理與應(yīng)用》| 技術(shù)集結(jié)

    01內(nèi)容簡介ContentSummary本書為讀者提供了一個全面、系統(tǒng)的RT-Thread學(xué)習(xí)指南,旨在幫助初學(xué)者及有經(jīng)驗的開發(fā)者掌握RT-Thread實時操作系統(tǒng)和STM32嵌入式微控制的核心
    的頭像 發(fā)表于 08-24 10:05 ?1022次閱讀
    【好書推薦】<b class='flag-5'>RT-Thread</b>第20本相關(guān)書籍!《嵌入式實時操作系統(tǒng)<b class='flag-5'>RT-Thread</b>原理與應(yīng)用》| 技術(shù)集結(jié)

    RT-Thread 遇上 Rust:安全內(nèi)核 RusT-Thread 的誕生

    老師的推薦,很快我們就被其極高的安全特性,強大的包管理系統(tǒng)和編譯以及豐富的社區(qū)支持所折服。然后我們在調(diào)研時注意到了RT-Thread。它有著經(jīng)典的操作系統(tǒng)架構(gòu),
    的頭像 發(fā)表于 08-02 11:03 ?3538次閱讀
    <b class='flag-5'>RT-Thread</b> 遇上 Rust:安全<b class='flag-5'>內(nèi)核</b> RusT-<b class='flag-5'>Thread</b> 的誕生

    RT-Thread榮獲2025優(yōu)秀開源項目 | 新聞速遞

    6月底,RT-Thread睿賽德受邀參與由上海開源信息技術(shù)協(xié)會主辦的2025上海開源創(chuàng)新精英薈。上海市商委副主任張杰出席會議并致辭。RT-Thread嵌入式操作系統(tǒng)項目憑借其卓越的技術(shù)創(chuàng)新與開源生態(tài)
    的頭像 發(fā)表于 07-04 09:04 ?2641次閱讀
    <b class='flag-5'>RT-Thread</b>榮獲2025優(yōu)秀開源項目 | 新聞速遞

    RT-Thread BSP全面支持玄鐵全系列RISC-V 處理 | 技術(shù)集結(jié)

    ,RT-Thread標準版已全面適配玄鐵E、R、C系列內(nèi)核,并在C906內(nèi)核上支持RT-Smart微內(nèi)核操作系統(tǒng)。本文將以E906運行
    的頭像 發(fā)表于 07-03 18:03 ?3228次閱讀
    <b class='flag-5'>RT-Thread</b> BSP全面支持玄鐵全系列RISC-V 處理<b class='flag-5'>器</b> | 技術(shù)集結(jié)

    揭秘RT-Thread上的AUTOSAR CP系統(tǒng)

    本文探討了RT-Thread與AUTOSARCP的融合,解決車載ECU開發(fā)中實時性、安全性與靈活性的平衡問題。通過分層安全內(nèi)核rt-safetyos/autoos)和工具鏈整合,兼容AUTOSAR
    的頭像 發(fā)表于 06-23 20:22 ?3221次閱讀
    揭秘<b class='flag-5'>RT-Thread</b>上的AUTOSAR CP系統(tǒng)

    RT-Thread審核團招募: 深度參與開源RTOS社區(qū)治理與演進

    全球開發(fā)者招募:RT-Thread審核團(ReviewTeam)正式開放申請!在開源的世界里,代碼審查(CodeReview)是保證軟件質(zhì)量、促進技術(shù)交流的關(guān)鍵環(huán)節(jié)。RT-Thread作為全球領(lǐng)先
    的頭像 發(fā)表于 05-21 18:02 ?1255次閱讀
    <b class='flag-5'>RT-Thread</b>審核團招募: 深度參與開源RTOS社區(qū)治理與演進