電子產(chǎn)業(yè)一站式賦能平臺(tái)

PCB聯(lián)盟網(wǎng)

搜索
查看: 21|回復(fù): 0
收起左側(cè)

嵌入式軟件框架,一個(gè)面向單片機(jī)應(yīng)用的事件調(diào)度器。

[復(fù)制鏈接]

449

主題

449

帖子

586

積分

二級(jí)會(huì)員

Rank: 2

積分
586
跳轉(zhuǎn)到指定樓層
樓主
發(fā)表于 2024-9-9 17:50:00 | 只看該作者 |只看大圖 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
我是老溫,一名熱愛(ài)學(xué)習(xí)的嵌入式工程師# U7 r2 T) f1 B/ f9 s
關(guān)注我,一起變得更加優(yōu)秀!
' a9 J5 T% i; ?' O* z% Y5 U一、EventOS是什么?
+ F9 p9 v* a; j. e5 i2 P1 {EventOS,是一個(gè)面向單片機(jī)、事件驅(qū)動(dòng)的嵌入式開(kāi)發(fā)平臺(tái)。它主要有兩大技術(shù)特色:一是事件驅(qū)動(dòng),二是超輕量。& I7 @% v! r+ k  ~/ _
EventOS以及其母項(xiàng)目EventOS,目標(biāo)是開(kāi)發(fā)一個(gè)企業(yè)級(jí)的嵌入式開(kāi)發(fā)平臺(tái),以事件總線為核心,打造一個(gè)統(tǒng)一的嵌入式技術(shù)生態(tài),
8 N& u) ?- F. ~( t% U6 V為廣大企業(yè)用戶和嵌入式開(kāi)發(fā)者們,提供搞可靠性的、高性能的、現(xiàn)代且高開(kāi)發(fā)效率的嵌入式開(kāi)發(fā)環(huán)境。2 F2 ]. B5 m+ b1 X5 U
EventOS的主要特性列舉如下:
1 Z2 j) C) d. w) J: @/ s(1)事件總線為核心組件,靈活易用,是進(jìn)行線程(狀態(tài)機(jī))間同步或者通信的主要手段,也是對(duì)EventOS分布式特性和跨平臺(tái)開(kāi)發(fā)進(jìn)行支持的唯一手段。事件支持廣播發(fā)送,或者發(fā)布-訂閱機(jī)制兩種方式(二選一)。
0 C4 n: i( n5 l; N; B  i( w& f(2)全局事件隊(duì)列,摒棄每個(gè)線程(狀態(tài)機(jī))擁有自己的事件隊(duì)列的方式,只有一個(gè)全局事件隊(duì)列,極限壓縮對(duì)RAM的占用。: w* k& Z3 h& m' S
(3)協(xié)作式內(nèi)核,優(yōu)點(diǎn)是不會(huì)產(chǎn)生資源競(jìng)爭(zhēng),極度可靠。
3 L) I( A" n) v7 @7 J" S(4)極度輕量,便于嵌入其他系統(tǒng),除事件總線外的所有特性(層次狀態(tài)機(jī)、平面狀態(tài)機(jī)、發(fā)布-訂閱機(jī)制、事件攜帶數(shù)據(jù)、事件橋等)均可裁剪,將資源占用降至極限,可低至ROM 1.2KB,RAM 172Byte?梢宰鳛樽酉到y(tǒng),“悄悄”嵌入到其他軟件系統(tǒng)中去。; o) K% D  l8 {: r! ^$ b+ d* J1 r( x# m
(5)功能強(qiáng)大的軟定時(shí)器,以時(shí)間事件的形式,對(duì)軟定時(shí)器功能,進(jìn)行優(yōu)雅且功能強(qiáng)大的實(shí)現(xiàn)。
! A7 ]3 X& T5 j(6)API的設(shè)計(jì),更加簡(jiǎn)明,更加符合本土嵌入式工程師的習(xí)慣。移植方便,只需實(shí)現(xiàn)少數(shù)幾個(gè)接口函數(shù)即可。( j: }* H: j0 Q* N. {
(7)未來(lái)會(huì)使用Event Bridge(事件橋)機(jī)制與EventOS打通事件總線,以便對(duì)EventOS的分布式特性進(jìn)行支持。9 ]+ d3 o2 R& X2 E
(8)重點(diǎn)關(guān)注三種應(yīng)用場(chǎng)景:中小資源單片機(jī),作為模塊向其他軟件系統(tǒng)的嵌入和可靠性要求較高的嵌入式場(chǎng)景。
# @5 ~9 R+ U5 nEventOS的前身,曾經(jīng)讓我在過(guò)去的工作中受益匪淺,讓我非常高效的寫(xiě)出了很多可靠的程序,能力和回報(bào)都有了質(zhì)的提升。
* v) w5 v/ W2 P( C5 j  j; ?現(xiàn)在,我將以前的技術(shù)成果整理重構(gòu),在各方面都向著規(guī)范的開(kāi)源項(xiàng)目靠攏,包括源碼、注釋、文檔、單元測(cè)試和例程等等。0 `$ {+ H6 Y, R- F" ]
未來(lái),EventOS這個(gè)項(xiàng)目我會(huì)一直完善下去。我的目標(biāo)是,將EventOS項(xiàng)目在2022年底前做成Gitee推薦項(xiàng)目,2024年年底前將EventOS項(xiàng)目,做成Gitee的GVP項(xiàng)目。造福更多的嵌入式工程師。
- j6 z  L/ r0 O) r
1 N" Q9 N4 ]) {  {0 p二、文檔與博客
- |. E0 v) ~( V9 C. zEventOS的移植和入門(mén),在documentation文件夾里,可以參考以下幾個(gè)文檔:(1)快速入門(mén)文檔https://gitee.com/event-os/eventos/blob/master/documentation/UM-02-001-QuickStart.md
. e/ Q" W9 x/ |- `. a, |# t(2)裸機(jī)移植文檔https://gitee.com/event-os/eventos/blob/master/documentation/UM-02-002-PortMetal.md
- h/ t+ `- r) H0 O- j(3)開(kāi)發(fā)環(huán)境搭建https://gitee.com/event-os/eventos/blob/master/documentation/UM-02-003-DevEnv.md
* d% g" x( J' b5 A(4)如何理解事件https://gitee.com/event-os/eventos/blob/master/blog/%E5%A6%82%E4%BD%95%E7%90%86%E8%A7%A3%E4%BA%8B%E4%BB%B6.md
3 K- t, H6 G  |3 w# w3 K- n三、為什么叫做EventOS?/ @! R: c) f1 F6 H6 ?9 E
EventOS真的非常輕量。全功能的EventOS目前經(jīng)MDK編譯后,框架本身占用RAM 200Byte,ROM約3.5KB(優(yōu)化等級(jí)為-O3)或4.5KB(優(yōu)化等級(jí)為-O0)。- G# ]' A3 v9 ~" ~
裁剪后,最小功能的EventOS,目前經(jīng)MDK編譯后,框架本身占用RAM 172Byte,ROM約1.2KB(優(yōu)化等級(jí)為-O3)或1.5KB(優(yōu)化等級(jí)為-O0)。
7 R  }- u( {6 l1 L! r之所以叫EventOS,一是因?yàn)樗募夹g(shù)特色與核心思想,就是事件驅(qū)動(dòng);二是因?yàn)樗橇硗庖粋(gè)開(kāi)源項(xiàng)目EventOS(準(zhǔn)備中)的簡(jiǎn)化實(shí)現(xiàn),
* G) f# [4 r$ x4 E2 IEventOS是一個(gè)事件驅(qū)動(dòng)的、分布式的、可跨平臺(tái)開(kāi)發(fā)的嵌入式RTOS,面向32位單片機(jī)和更高處理器的嵌入式開(kāi)發(fā)平臺(tái)。
% z* _1 }$ J' G$ @- A$ H2 s四、EventOS主張的編程思想# {# Q+ w4 Z$ e
事件驅(qū)動(dòng)與事件總線
: w" R+ v8 w* [- [' b' D事件驅(qū)動(dòng)和事件總線,是EventOS的核心,也是EventOS的核心。事件機(jī)制,與RTOS中事件概念完全不同,它更像是windows編程中的消息。
, ~. t' K$ s# O* `& a8 q事件,可以認(rèn)為是主題 + 不定長(zhǎng)數(shù)據(jù),通過(guò)事件,可以極大解耦模塊間的耦合,增強(qiáng)軟件的可測(cè)試性,還可以進(jìn)行跨平臺(tái)開(kāi)發(fā)和分布式擴(kuò)展。! E/ H+ O. H8 q; E& K3 s& T
防御式編程
# t* [; J8 u0 x! J2 s* P0 ~EventOS使用了大量的斷言,對(duì)系統(tǒng)的運(yùn)行過(guò)程和用戶對(duì)EventOS的使用進(jìn)行大量的檢查。9 g0 V) B) P1 E; k
我們強(qiáng)烈建議,用戶要對(duì)斷言接口函數(shù)進(jìn)行精心的設(shè)計(jì)和實(shí)現(xiàn),在實(shí)際的產(chǎn)品代碼中,依然打開(kāi)斷言。這樣,軟件將以非?斓乃俣,收斂于穩(wěn)定狀態(tài)。" r& m5 B. V' X3 l
跨平臺(tái)開(kāi)發(fā)
1 N4 B( p% e' qEventOS提倡跨平臺(tái)開(kāi)發(fā)。所謂跨平臺(tái)開(kāi)發(fā),就是在Windows和Linux等便捷友好的開(kāi)發(fā)環(huán)境里,完成絕大部分的開(kāi)發(fā)工作,包括編程、調(diào)試、運(yùn)行和單元測(cè)試等工作,然后在目標(biāo)平臺(tái)上進(jìn)行最后的移植、調(diào)試和適配工作。6 u2 R7 R( U; E3 s! @! |2 [' ]
跨平臺(tái)的優(yōu)點(diǎn)有很多,比如開(kāi)發(fā)效率非常高、工程師進(jìn)入到更多的編程領(lǐng)域和程序穩(wěn)定可靠等。EventOS主要在32位MinGW平臺(tái)和Linux平臺(tái)上開(kāi)發(fā)。; X  M' K4 E6 J) T1 h/ N& V! {
開(kāi)發(fā)環(huán)境的搭建,見(jiàn)文檔開(kāi)發(fā)環(huán)境搭建。當(dāng)然,也完全可以用MDK在單片機(jī)上直接開(kāi)發(fā),效率稍低而已。1 [! J) G. [2 m
消除耦合
2 A: g1 _/ t6 _9 S1 L! l無(wú)論是廣播式的事件發(fā)送機(jī)制,還是發(fā)布-訂閱式的事件發(fā)送機(jī)制,實(shí)際上,都是為了消除軟件模塊間的耦合。: B1 D, b# c8 F  K$ S$ Q: Q
五、EventOS項(xiàng)目的維護(hù)原則/ G7 q) ~/ J6 x  ~! c
但行好事,不問(wèn)前程
9 V( O, S$ s# z' u( o( r1 N" q' R( ?我完全沒(méi)有考慮過(guò)EventOS將來(lái)能夠如何,而且最近EventOS的發(fā)展有點(diǎn)超出我預(yù)計(jì),我有點(diǎn)受寵若驚。
& ]7 }( c, v/ R7 `' o7 z; ?更多的人了解EventOS是一件好事,敦促這我把EventOS項(xiàng)目盡快做好,做完善,做成一個(gè)工業(yè)級(jí)的軟件產(chǎn)品,為廣大的嵌入式工作者創(chuàng)造便利。
! c$ G+ R: e5 _* o& q希望EventOS最終被眾多工程師和企業(yè)認(rèn)可,并在成千上萬(wàn)的嵌入式產(chǎn)品中廣泛應(yīng)用起來(lái),那就不枉我這些年深挖技術(shù)的努力。
3 W8 Q; ]$ V0 O源碼文檔并進(jìn)7 [+ E9 M, M' A# [# l7 X0 s
我深知完善豐富的文檔,對(duì)一個(gè)開(kāi)源項(xiàng)目的重要意義。因此,我堅(jiān)持每一個(gè)特性的升級(jí),每一個(gè)BUG的修復(fù),都跟隨著相應(yīng)的文檔。3 ~$ g. W' h7 t& U4 J
讓EventOS和EventOS項(xiàng)目的文檔專(zhuān)業(yè)化、體系化,包含用戶手冊(cè)、版本特性、原理說(shuō)明、博客、例程等等。
% Q2 M, d" ^" j3 d! @" d8 C- P( h單元測(cè)試優(yōu)先2 z% O* f( `7 M+ j
嵌入式的開(kāi)源項(xiàng)目,用戶最關(guān)心的,是軟件的可靠性。單元測(cè)試,是保證軟件健壯與可靠的重要手段。對(duì)于EventOS這種系統(tǒng)級(jí)、框架級(jí)的軟件,穩(wěn)定性與可靠性更加重要。$ L$ t! l- F, V# A! r: S4 }0 o0 z# M
從EventOS誕生之日起,它就是面向單元測(cè)試的。詳盡而嚴(yán)謹(jǐn)?shù)膯卧獪y(cè)試,保證了EventOS將絕大多數(shù)的BUG,消除在了開(kāi)發(fā)階段。EventOS的每一次重構(gòu)、升級(jí)與發(fā)布,都是經(jīng)過(guò)了嚴(yán)謹(jǐn)?shù)膯卧獪y(cè)試的。% q9 G  r8 Y% H; y
用戶至上,需求至上  a' t5 K6 Z! t/ h  f: j* a' V
軟件如何發(fā)展,代碼向哪個(gè)方向前進(jìn),EventOS完全聽(tīng)從用戶們的聲音,完全從需求出發(fā)。我們從各個(gè)渠道,微信、QQ、論壇等獲取的意見(jiàn)建議,都將體現(xiàn)到EventOS的開(kāi)發(fā)中去。, B4 R9 L+ y3 ?2 U7 i
六、代碼結(jié)構(gòu)
# P5 P# s0 J1 e核心代碼9 ^% t" d: K3 |+ N
eventos/eventos.c EventOS狀態(tài)機(jī)框架的實(shí)現(xiàn)eventos/eventos.h 頭文件eventos/eventos_config.h 對(duì)EventOS進(jìn)行配置與裁剪+ S- L+ P% I, t
第三方代碼庫(kù): n' T$ y3 [, _( b2 o0 |: H
RTT Segger JLink所提供的日志庫(kù),依賴于JLink硬件。unity 單元測(cè)試框架
2 L; E9 A; L8 O& ^例程代碼/ F5 w4 M% X9 |0 n
freertos 對(duì)FreeRTOS的適配例程(未完成)。posix 對(duì)符合POSIX標(biāo)準(zhǔn)的操作系統(tǒng)(如Linux、VxWork、MinGW等)的適配例程。stm32f030 對(duì)ARM Cortex-M0芯片的裸機(jī)運(yùn)行(無(wú)RTOS)的例程。stm32f103 對(duì)ARM Cortex-M3芯片的裸機(jī)運(yùn)行(無(wú)RTOS)的例程。test 對(duì)源碼進(jìn)行的單元測(cè)試?yán)。digital_watch 電子表例程,狀態(tài)機(jī)的典型應(yīng)用。
, R$ X% S0 N4 W4 j
tools% V3 t3 L3 }8 P5 `5 g2 p& m
一些Python腳本和工具。4 e4 M" c& F( `0 v4 {) L
文檔
- A4 c' h4 d/ q8 H* q文檔包含Doxygen代碼文檔的生成路徑(未完成)、圖片、代碼相關(guān)文檔(如快速入門(mén)文檔、移植文檔、開(kāi)發(fā)環(huán)境搭建說(shuō)明文檔等)。
& f6 u( U; s) q6 C5 _3 {來(lái)自: https://gitee.com/event-os/eventos4 k) s  Z3 q% x7 X2 |% L
-END-$ t, s6 C, x' e! A/ g! h
往期推薦:點(diǎn)擊圖片即可跳轉(zhuǎn)閱讀
! `3 P7 s% i* \7 X6 {                                                        % h0 u1 x/ W& e
                                                                + ^1 v* {* H! ]6 ^1 u2 A
                                                                        . M( B: j* {* M3 h
                                                                                ( c/ t  s, H! F: t0 a: L
& b" S, Q+ c2 z7 V/ H
                                                                               
& `( G9 P  q& P# v. o- Z                                                                                        現(xiàn)場(chǎng)實(shí)測(cè),用數(shù)據(jù)說(shuō)話,星閃通信距離突破3.3公里!
, k7 W$ G: X. I: D                                                        : w6 Y% Y2 E( N# c* n
                                                               
& [, S% @% y  \                                                                        7 t4 f6 `. P; n: q/ k% e8 K
                                                                               
. b* u3 d9 _0 ~& Q9 n- \6 R8 m' w & \! Z( ^- M- c8 c0 w2 k3 p# m# y1 w" `6 q
                                                                               
& A& O. U1 V! R. @+ O: c                                                                                        樹(shù)莓派第二代微控制器 RP2350,終于拿到手了!~
$ N5 ?5 Y6 V0 P$ L& S+ [0 N                                                                1 X/ d5 ^2 \# h7 C8 y3 W
                                                                        2 u: g% S( H) l4 s1 x# M. i
                                                                               
5 F7 ^7 }1 a0 x; X* E& i
8 S) P) L1 s. e9 c2 r1 E8 Y+ U                                                                               
. |/ h8 ?) d# Q                                                                                        跟嵌入式技術(shù)相關(guān)的熱門(mén)應(yīng)用,全都在這里了!
0 X# W! {" N  Z9 o& q( |8 \                                                                               
* N) |+ ?3 N' ~2 f9 i* ]  ?                                                                        ! k6 Q  q$ H& n/ o+ ^
                                                                & g2 X" P+ r' D; M, L$ x
                                                        我是老溫,一名熱愛(ài)學(xué)習(xí)的嵌入式工程師
, ?9 x* z0 f: T- @7 h& |關(guān)注我,一起變得更加優(yōu)秀!

發(fā)表回復(fù)

本版積分規(guī)則

關(guān)閉

站長(zhǎng)推薦上一條 /1 下一條


聯(lián)系客服 關(guān)注微信 下載APP 返回頂部 返回列表