近期騰訊低調(diào)地在GitHub上開(kāi)源了自己的loT操作TencentOS tiny,截至發(fā)稿,已經(jīng)累積了2000多個(gè)Star,引發(fā)了不小的關(guān)注。由于筆者曾經(jīng)做過(guò)CSDN的嵌入式大版當(dāng)過(guò)很長(zhǎng)時(shí)間的版主,所以第一時(shí)間到https://github.com/Tencent/TencentOS-tiny下載了全部的代碼,第一時(shí)間為大家?guī)?lái)解讀。
TencentOS tiny整體架構(gòu)
TencentOS tiny 提供精簡(jiǎn)的 RTOS內(nèi)核,其架構(gòu)圖如下:
目前看其內(nèi)核部分已經(jīng)開(kāi)發(fā)完成,并已經(jīng)完全開(kāi)源。從目前TencentOS tiny的情況看,騰訊入局物聯(lián)網(wǎng)的相關(guān)鏈條已經(jīng)規(guī)劃完整:
布署了TencentOS tiny的的嵌入式開(kāi)發(fā)板也已經(jīng)制造出來(lái),所以看來(lái)鵝廠在物聯(lián)網(wǎng)時(shí)代對(duì)于入口的爭(zhēng)奪也不會(huì)有絲毫的放松。
下面我將對(duì)于TencentOS tiny代碼中內(nèi)核及l(fā)oT協(xié)議部分進(jìn)行相關(guān)解讀。
TencentOS tiny內(nèi)核信號(hào)量與互斥鎖解讀
TencentOS tiny的官宣文檔中對(duì)于其內(nèi)核的描述如下:TencentOS tiny 實(shí)時(shí)內(nèi)核包括任務(wù)管理、實(shí)時(shí)調(diào)度、時(shí)間管理、中斷管理、內(nèi)存管理、異常處理、軟件定時(shí)器、鏈表、消息隊(duì)列、信號(hào)量、互斥鎖、事件標(biāo)志等模塊。其中定時(shí)器、消息隊(duì)列等在之前都有過(guò)相應(yīng)介紹,這里就為大家來(lái)解讀一下信號(hào)量與互斥鎖的相關(guān)代碼。信號(hào)量與互斥鎖的異同:1.信號(hào)量與互斥鎖最根本的不同點(diǎn)在于:互斥鎖的取值只能是0或者1,而信號(hào)量的取值范圍則可以定義。2.信號(hào)量的作用域可以進(jìn)程也可以是線程,而互斥鎖只能是線程。簡(jiǎn)單來(lái)說(shuō)互斥鎖可以實(shí)現(xiàn)線程對(duì)于唯一資源的使用保護(hù),而信號(hào)量則可以實(shí)現(xiàn)多線程或者進(jìn)程間數(shù)量有限資源的使用保護(hù)。從某種意義上講互斥鎖是只能一個(gè)資源可用的信號(hào)量。關(guān)于TencentOS tiny互斥體的實(shí)現(xiàn),首先來(lái)看其數(shù)據(jù)結(jié)構(gòu)具體解讀如下:
__API__k_err_ttos_mutex_pend_timed(k_mutex_t*mutex,k_tick_ttimeout) { TOS_CPU_CPSR_ALLOC(); k_err_terr; TOS_PTR_SANITY_CHECK(mutex); TOS_IN_IRQ_CHECK(); #ifTOS_CFG_OBJECT_VERIFY_EN>0u if(!pend_object_verify(&mutex->pend_obj,PEND_TYPE_MUTEX)){ returnK_ERR_OBJ_INVALID; } #endif TOS_CPU_INT_DISABLE();//將CPU鎖住,防止其它進(jìn)程進(jìn)入 if(mutex->pend_nesting==(k_nesting_t)0u){//沒(méi)有等待 mutex_fresh_owner_mark(mutex,k_curr_task);//將此mutex的owner置為當(dāng)前task TOS_CPU_INT_ENABLE();//將CPU解鎖 returnK_ERR_NONE;//返回成功 } if(knl_is_self(mutex->owner)){ if(mutex->pend_nesting==(k_nesting_t)-1){//等待數(shù)量如果超限則返回overflow TOS_CPU_INT_ENABLE(); returnK_ERR_MUTEX_NESTING_OVERFLOW; } ++mutex->pend_nesting; TOS_CPU_INT_ENABLE(); returnK_ERR_MUTEX_NESTING; } if(timeout==TOS_TIME_NOWAIT){//如果鎖已經(jīng)被占用超時(shí)時(shí)間為不等待,則直接返回 TOS_CPU_INT_ENABLE(); returnK_ERR_PEND_NOWAIT; } if(knl_is_sched_locked()){//如果任務(wù)被鎖定,則直接返回 TOS_CPU_INT_ENABLE(); returnK_ERR_PEND_SCHED_LOCKED; } if(mutex->owner->prio>k_curr_task->prio){ tos_task_prio_change(mutex->owner,k_curr_task->prio);//如果owner的優(yōu)先級(jí)更低,也就是其數(shù)值更大,則調(diào)整優(yōu)先級(jí) } pend_task_block(k_curr_task,&mutex->pend_obj,timeout);//阻塞pending的任務(wù) TOS_CPU_INT_ENABLE();//解鎖CPU總線 knl_sched();//解鎖任務(wù)高度 err=pend_state2errno(k_curr_task->pend_state); if(err==K_ERR_NONE){//如果沒(méi)有錯(cuò)誤 TOS_CPU_INT_DISABLE(); mutex_new_owner_mark(mutex,k_curr_task);//刷新mutex當(dāng)前的owner TOS_CPU_INT_ENABLE(); } returnerr; }
TencentOS tiny信號(hào)量的實(shí)現(xiàn)
首先來(lái)看k_sem_st的結(jié)構(gòu)體:
__STATIC__k_err_tsem_do_post(k_sem_t*sem,opt_post_topt) { TOS_CPU_CPSR_ALLOC();//為CPU的CPSR進(jìn)行預(yù)分配為后面恢復(fù)做準(zhǔn)備 TOS_PTR_SANITY_CHECK(sem); #ifTOS_CFG_OBJECT_VERIFY_EN>0u if(!pend_object_verify(&sem->pend_obj,PEND_TYPE_SEM)){ returnK_ERR_OBJ_INVALID; } #endif TOS_CPU_INT_DISABLE();//CPU鎖定防止其它進(jìn)程入 if(sem->count==(k_sem_cnt_t)-1){//若資源數(shù)量為-1則返回超限 TOS_CPU_INT_ENABLE(); returnK_ERR_SEM_OVERFLOW; } if(pend_is_nopending(&sem->pend_obj)){//如果無(wú)pending的情況則直接返回 ++sem->count; TOS_CPU_INT_ENABLE(); returnK_ERR_NONE; } pend_wakeup(&sem->pend_obj,PEND_STATE_POST,opt);//喚醒pending的進(jìn)程 TOS_CPU_INT_ENABLE();//恢復(fù)CPU knl_sched();//恢復(fù)任務(wù)調(diào)度 returnK_ERR_NONE; }
所以從上述解讀相信各位讀者也能看到,TencentOS tiny的內(nèi)核的確是被精心修減過(guò),針對(duì)物聯(lián)網(wǎng)場(chǎng)景做了相應(yīng)的優(yōu)化,去掉了一些沒(méi)有必要的功能代碼。
TencentOS tiny對(duì)于MQTT的實(shí)現(xiàn)
在TencentOS tiny的官宣中對(duì)于IoT 協(xié)議棧介紹如下:TencentOS tiny 提供 lwip、AT Adapter、SAL 層,支持不同的網(wǎng)絡(luò)硬件,例如以太網(wǎng)、串口 Wi-Fi、GPRS、NB-IoT、4G等通信模塊。TCP/IP 網(wǎng)絡(luò)協(xié)議棧上提供常用的物聯(lián)網(wǎng)協(xié)議棧,例如 CoAP、MQTT,支撐終端業(yè)務(wù)快速接入騰訊云。其中MQTT可以算是物聯(lián)網(wǎng)時(shí)代比較通用的基于IP網(wǎng)絡(luò)的協(xié)議了,它基于發(fā)布/訂閱消息模式,提供一對(duì)多的消息分發(fā)有三種消息傳遞服務(wù)質(zhì)量。1.最多一次,也就是消息發(fā)布者只會(huì)發(fā)布一次消息,不管對(duì)端是否收到也不會(huì)發(fā)布第二次。一般用于環(huán)境傳感器的數(shù)據(jù)讀取,因?yàn)橐话悱h(huán)境傳感器讀取的密度很高,丟失幾個(gè)數(shù)據(jù)并沒(méi)有什么大問(wèn)題。·2.確保到達(dá),這個(gè)一般用在數(shù)據(jù)非常重要的情況,發(fā)送端將不斷重復(fù)發(fā)送直到對(duì)端響應(yīng)收到。但這樣可能出現(xiàn)數(shù)據(jù)重復(fù)。3.確保恰好一次送達(dá),確保消息正好到達(dá)一次。這個(gè)級(jí)別用于計(jì)費(fèi)系統(tǒng),重復(fù)或丟失的數(shù)據(jù)可能導(dǎo)致一定的損失。由于MQTT適合在低帶寬、高延時(shí)網(wǎng)絡(luò)運(yùn)行的特性所以在特聯(lián)網(wǎng)中的應(yīng)用很多。不過(guò)呢騰訊針對(duì)此部分的實(shí)現(xiàn)則是完全拷貝于Eclipse Paho項(xiàng)目個(gè)人制作的原理動(dòng)畫(huà)如下圖:
但是考慮到物聯(lián)網(wǎng)終端其實(shí)僅需要MQTT的發(fā)布方即可,訂閱方的代碼其實(shí)沒(méi)有太大必要保留,而且從目前發(fā)布支持的場(chǎng)景來(lái)看,MQTT一些通訊質(zhì)量模式其實(shí)用處也不多,不過(guò)在這方面TencentOS tiny是沒(méi)有做任何優(yōu)化與裁減的。所以這應(yīng)該也可以看做是TencentOS tiny的一個(gè)不足吧。
后記
隨著移動(dòng)互聯(lián)網(wǎng)+智能硬件的不斷發(fā)展,IoT的新業(yè)態(tài)大門(mén)徐徐開(kāi)啟,這里不但有眾多互聯(lián)網(wǎng)企業(yè),也有傳統(tǒng)家電甚至金融企業(yè)不斷入局。但是與傳統(tǒng)互聯(lián)網(wǎng)軟件+硬件的模式不同,物聯(lián)網(wǎng)除了軟、硬件外還多了一個(gè)側(cè)面-場(chǎng)景,能將軟、硬件及場(chǎng)景整合化一的公司才能笑到最后。就像HTML整合了互聯(lián)網(wǎng)一樣,MQTT等loT協(xié)議會(huì)是整合全鏈條的利器,所以最后筆者也呼吁各方除了重視操作系統(tǒng)內(nèi)核外也需要大力參與loT通訊協(xié)議,尤其注重標(biāo)準(zhǔn)制訂,這樣才能跟上loT的時(shí)代潮流。
-
操作系統(tǒng)
+關(guān)注
關(guān)注
37文章
7402瀏覽量
129307 -
騰訊
+關(guān)注
關(guān)注
7文章
1684瀏覽量
50918 -
LOT
+關(guān)注
關(guān)注
3文章
15瀏覽量
6259
發(fā)布評(píng)論請(qǐng)先 登錄
投入超十億!四周完成芯片適配!理想宣布開(kāi)源自研汽車(chē)操作系統(tǒng)
openKylin賦能?chē)?guó)防科大構(gòu)建操作系統(tǒng)創(chuàng)新型人才培養(yǎng)體系
普華基礎(chǔ)軟件出席開(kāi)源車(chē)用操作系統(tǒng)人才培養(yǎng)啟動(dòng)儀式
開(kāi)放原子開(kāi)源基金會(huì)與五岳紀(jì)元量子計(jì)算操作系統(tǒng)項(xiàng)目完成捐贈(zèng)簽約
開(kāi)放原子開(kāi)源歐拉社區(qū)亮相2025操作系統(tǒng)大會(huì)
單片機(jī)的操作系統(tǒng)
手持機(jī)PDA三大操作系統(tǒng)Android / 開(kāi)源鴻蒙 / Windows對(duì)比
基于開(kāi)源鴻蒙打造的公路機(jī)電操作系統(tǒng)獲“茅以升科學(xué)技術(shù)特等獎(jiǎng)”!
誠(chéng)邁科技發(fā)布基于鴻志桌面操作系統(tǒng)和龍芯3A6000的開(kāi)源鴻蒙電腦
深度操作系統(tǒng)deepin 25正式發(fā)布
OrangePi 5 Plus 全面兼容openKylin操作系統(tǒng),拓展高性能邊緣計(jì)算新生態(tài)
全面解析騰訊最新開(kāi)源 loT 操作系統(tǒng) TencentOS tiny
評(píng)論