亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 1144853503.txt

?? uCOS-II 初級程序員指南本文面向首次接觸uC/OS-II的程序員
?? TXT
字號:
uCOS-II 初級程序員指南

本文面向首次接觸uC/OS-II的程序員,為他們介紹一下這個系統的一些基本特征和編程上的注意事項,并介紹幾個值得了解的API。本文作者已經成功的將uC/OS-II移植到幾種不同CPU之上。包括EPSON S1C33和Sunplus unSP?等,積累了豐富的經驗,現在愿意和朋友們分享這些經歷。希望本文的資料對于希望使用這個系統來開發的朋友有所幫助,作者樂意與您分享任何您成功的喜悅。 

  This passage is written for the basic programmers who are first developed with the uC/OS-II real time OS。I will talk about the basic structure of this system。And I will discuss how to use some of the useful API。I will also discuss the imp of the mutilty-tasking in uC/OS-II。 

  (一) uC/OS-II 簡介 

  uC/OS-II是一種基于優先級的可搶先的硬實時內核。自從92年發布以來,在世界各地都獲得了廣泛的應用,它是一種專門為嵌入式設備設計的內核,目前已經被移植到40多種不同結構的CPU上,運行在從8位到64位的各種系統之上。尤其值得一提的是,該系統自從2.51版本之后,就通過了美國FAA認證,可以運行在諸如航天器等對安全要求極為苛刻的系統之上。鑒于uC/OS-II可以免費獲得代碼,對于嵌入式RTOS而言,選擇uC/OS無疑是最經濟的選擇。 

  (二) uC/OS-II 應用程序基本結構 

  應用uC/OS-II,自然要為它開發應用程序,下面論述基于uC/OS-II的應用程序的基本結構以及注意事項。 

  每一個uC/OS-II應用至少要有一個任務。而每一個任務必須被寫成無限循環的形式。以下是推薦的結構: 

void task ( void* pdata ) 

{ 

INT8U err; 

InitTimer(); // 可選 

For( ;; ) 

{ 

// 你的應用程序代碼 

……. 

…….. 

OSTimeDly(1); // 可選 

} 

} 

  以上就是基本結構,至于為什么要寫成無限循環的形式呢?那是因為系統會為每一個任務保留一個堆棧空間,由系統在任務切換的時候換恢復上下文,并執行一條reti 指令返回。如果允許任務執行到最后一個花括號(那一般都意味著一條ret指令)的話,很可能會破壞系統堆棧空間從而使應用程序的執行不確定。換句話說,就是“跑飛”了。所以,每一個任務必須被寫成無限循環的形式。程序員一定要相信,自己的任務是會放棄CPU使用權的,而不管是系統強制(通過ISR)還是主動放棄(通過調用OS API)。 

  現在來談論上面程序中的InitTimer()函數,這個函數應該由系統提供,程序員有義務在優先級最高的任務內調用它而且不能在for循環內調用。注意,這個函數是和所使用的CPU相關的,每種系統都有自己的Timer初始化程序。在uC/OS-II的幫助手冊內,作者特地強調絕對不能在OSInit()或者OSStart()內調用Timer初始化程序,那會破壞系統的可移植性同時帶來性能上的損失。所以,一個折中的辦法就是象上面這樣,在優先級最高的程序內調用,這樣可以保證當OSStart()調用系統內部函數OSStartHighRdy()開始多任務后,首先執行的就是Timer初始化程序。或者專門開一個優先級最高的任務,只做一件事情,那就是執行Timer初始化,之后通過調用OSTaskSuspend()將自己掛起來,永遠不再執行。不過這樣會浪費一個TCB空間。對于那些RAM吃緊的系統來說,還是不用為好。 

  (三) 一些重要的uC/OS-II API介紹 

  任何一個操作系統都會提供大量的API供程序員使用,uC/OS-II也不例外。由于uC/OS-II面向的是嵌入式開發,并不要求大而全,所以內核提供的API也就大多和多任務息息相關。主要的有以下幾類: 

1)任務類 

2)消息類 

3)同步類 

4)時間類 

5)臨界區與事件類 

  我個人認為對于初級程序員而言,任務類和時間類是必須要首先掌握的兩種類型的API。下面我就來介紹比較重要的: 

1) OSTaskCreate函數 

  這個函數應該至少再main函數內調用一次,在OSInit函數調用之后調用。作用就是創建一個任務。目前有四個參數,分別是任務的入口地址,任務的參數,任務堆棧的首地址和任務的優先級。調用本函數后,系統會首先從TCB空閑列表內申請一個空的TCB指針,然后將會根據用戶給出參數初始化任務堆棧,并在內部的任務就緒表內標記該任務為就緒狀態。最后返回,這樣一個任務就創建成功了。 

2) OSTaskSuspend函數 

  這個函數很簡單,一看名字就該明白它的作用,它可以將指定的任務掛起。如果掛起的是當前任務的話,那么還會引發系統執行任務切換先導函數OSShed來進行一次任務切換。這個函數只有一個參數,那就是指定任務的優先級。那為什么是優先級呢?事實上在系統內部,優先級除了表示一個任務執行的先后次序外,還起著分別每一個任務的作用,換句話說,優先級也就是任務的ID。所以uC/OS-II不允許出現相同優先級的任務。 

3) OSTaskResume函數 

  這個函數和上面的函數正好相反,它用于將指定的已經掛起的函數恢復成就緒狀態。如果恢復任務的優先級高于當前任務,那么還為引發一次任務切換。其參數類似OSTaskSuspend函數,為指定任務的優先級。需要特別說明是,本函數并不要求和OSTaskSuspend函數成對使用。 

4) OS_ENTER_CRITICAL宏 

  很多人都以為它是個函數,其實不然,仔細分析一下OS_CPU.H文件,它和下面馬上要談到的OS_EXIT_CRITICAL都是宏。他們都是涉及特定CPU的實現。一般都被替換為一條或者幾條嵌入式匯編代碼。由于系統希望向上層程序員隱藏內部實現,故而一般都宣稱執行此條指令后系統進入臨界區。其實,它就是關個中斷而已。這樣,只要任務不主動放棄CPU使用權,別的任務就沒有占用CPU的機會了,相對這個任務而言,它就是獨占了。所以說進入臨界區了。這個宏能少用還是少用,因為它會破壞系統的一些服務,尤其是時間服務。并使系統對外界響應性能降低。 

5) OS_EXIT_CRITICAL宏 

  這個是和上面介紹的宏配套使用另一個宏,它在系統手冊里的說明是退出臨界區。其實它就是重新開中斷。需要注意的是,它必須和上面的宏成對出現,否則會帶來意想不到的后果。最壞的情況下,系統會崩潰。我們推薦程序員們盡量少使用這兩個宏調用,因為他們的確會破壞系統的多任務性能。 

6) OSTimeDly函數 

  這應該程序員們調用最多的一個函數了,這個函數完成功能很簡單,就是先掛起當起當前任務,然后進行任務切換,在指定的時間到來之后,將當前任務恢復為就緒狀態,但是并不一定運行,如果恢復后是優先級最高就緒任務的話,那么運行之。簡單點說,就是可以任務延時一定時間后再次執行它,或者說,暫時放棄CPU的使用權。一個任務可以不顯式的調用這些可以導致放棄CPU使用權的API,但那樣多任務性能會大大降低,因為此時僅僅依靠時鐘機制在進行任務切換。一個好的任務應該在完成一些操作主動放棄使用權,好東西要大家分享嘛! 

(四) uC/OS-II 多任務實現機制分析 

  前面已經說過,uC/OS-II是一種基于優先級的可搶先的多任務內核。那么,它的多任務機制到底如何實現的呢?了解這些原理,可以幫助我們寫出更加健壯的代碼來。由于我們面向的初級程序員,本文不打算寫成又一篇uC/OS-II的源碼分析,那樣的文章太多了,本文打算從實現原理的角度探討這個問題。 

  首先我們來看看為什么多任務機制可以實現?其實在單一CPU的情況下,是不存在真正的多任務機制的,存在的只有不同的任務輪流使用CPU,所以本質上還是單任務的。但由于CPU執行速度非常快,加上任務切換十分頻繁并且切換的很快,所以我們感覺好像有很多任務同時在運行一樣。這就是所謂的多任務機制。 

  由上面的描述,不難發現,要實現多任務機制,那么目標CPU必須具備一種在運行期更改PC的途徑,否則無法做到切換。不幸的使,直接設置PC指針,目前還沒有哪個CPU支持這樣的指令。但是一般CPU都允許通過類似JMP,CALL這樣的指令來間接的修改PC。我們的多任務機制的實現也正是基于這個出發點。事實上,我們使用CALL指令或者軟中斷指令來修改PC,主要是軟中斷。但在一些CPU上,并不存在軟中斷這樣的概念,所以,我們在那些CPU上,使用幾條PUSH指令加上一條CALL指令來模擬一次軟中斷的發生。 

  回想一下你在微機原理課程上學過的知識,當發生中斷的時候,CPU保存當前的PC和狀態寄存器的值到堆棧里,然后將PC設置為中斷服務程序的入口地址,再下來一個機器周期,就可以去執行中斷服務程序了。執行完畢之后,一般都是執行一條RETI指令,這條指令會把當前堆棧里的值彈出恢復到狀態寄存器和PC里。這樣,系統就會回到中斷以前的地方繼續執行了。那么設想一下?如果再中斷的時候,人為的更改了堆棧里的值,那會發生什么?或者通過更改當前堆棧指針的值,又會發生什么呢?如果更改是隨意的,那么結果是無法預料的錯誤。因為我們無法確定機器下一條會執行些什么指令,但是如果更改是計劃好的,按照一定規則的話,那么我們就可以實現多任務機制。事實上,這就是目前幾乎所有的OS的核心部分。不過他們的實現不像這樣簡單罷了。 

  下面,我們來看看uC/OS-II再這方面是怎么處理的。再uC/OS-II里,每個任務都有一個任務控制塊(Task Control Block),這是一個比較復雜的數據結構。在任務控制快的偏移為0的地方,存儲著一個指針,它記錄了所屬任務的專用堆棧地址。事實上,再uC/OS-II內,每個任務都有自己的專用堆棧,彼此之間不能侵犯。這點要求程序員再他們的程序中保證。一般的做法是把他們申明成靜態數組。而且要申明成OS_STK類型。當任務有了自己的堆棧,那么就可以將每一個任務堆棧再那里記錄到前面談到的任務控制快偏移為0的地方。以后每當發生任務切換,系統必然會先進入一個中斷,這一般是通過軟中斷或者時鐘中斷實現。然后系統會先把當前任務的堆棧地址保存起來,僅接著恢復要切換的任務的堆棧地址。由于哪個任務的堆棧里一定也存的是地址(還記得我們前面說過的,每當發生任務切換,系統必然會先進入一個中斷,而一旦中斷CPU就會把地址壓入堆棧),這樣,就達到了修改PC為下一個任務的地址的目的。 

  以上就是uC/OS-II的多任務實現機制,我們在這里大費筆墨談論這個問題,是希望我們的程序員們可以善加利用這個機制,寫出更健壯,更富有效率的代碼來。 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区在线电影| 在线日韩国产精品| 日本一区免费视频| 成人黄页毛片网站| 玉足女爽爽91| 欧美剧在线免费观看网站| 日韩和欧美一区二区三区| 日韩视频一区二区在线观看| 国产一区二区三区在线观看免费视频| 久久久精品国产免大香伊| 成人国产精品免费观看动漫| 亚洲综合一区在线| 欧美一区二区三区人| 国产一区二区三区四区五区入口 | 精品视频在线免费观看| 日韩一区精品视频| 国产日产精品1区| 在线观看日韩av先锋影音电影院| 免播放器亚洲一区| 国产精品毛片无遮挡高清| 欧美日韩你懂得| 国产精品综合视频| 亚洲精品日产精品乱码不卡| 日韩免费一区二区| 成人ar影院免费观看视频| 午夜精品一区二区三区电影天堂| 精品国产1区二区| 91丨porny丨户外露出| 午夜激情一区二区三区| 欧美国产日产图区| 欧美精品三级在线观看| 成人激情视频网站| 偷拍亚洲欧洲综合| 中文字幕在线视频一区| 精品国产乱码久久久久久蜜臀| 成人va在线观看| 蜜桃一区二区三区在线观看| 亚洲婷婷在线视频| 日韩久久久精品| 欧美性大战久久| 成人晚上爱看视频| 另类综合日韩欧美亚洲| 一区二区久久久久| 亚洲国产精品ⅴa在线观看| 91精品国产综合久久蜜臀| 色天天综合久久久久综合片| 国产sm精品调教视频网站| 无码av免费一区二区三区试看| 中文字幕一区二区三区在线不卡| 日韩天堂在线观看| 欧美日产在线观看| 成人av网站在线| 国产在线一区二区综合免费视频| 午夜视频在线观看一区| 亚洲人成影院在线观看| 中文字幕不卡一区| 欧美v日韩v国产v| 3d动漫精品啪啪| 欧美喷潮久久久xxxxx| 色先锋资源久久综合| 粉嫩av一区二区三区| 国产乱妇无码大片在线观看| 免费观看在线综合| 日韩av电影一区| 午夜久久电影网| 亚洲成人在线观看视频| 一区二区三区国产| 玉足女爽爽91| 日韩高清一区在线| 日韩精品在线看片z| 9i在线看片成人免费| 亚洲一二三四区不卡| 欧美视频一区在线观看| 国产精品综合视频| 亚洲素人一区二区| 91搞黄在线观看| 国产一区二区电影| 偷偷要91色婷婷| 中文字幕欧美激情一区| 日韩一级免费一区| 亚洲乱码国产乱码精品精可以看| 久久精品视频一区二区| 久久久三级国产网站| 国产欧美一区二区精品忘忧草| 精品国产乱码久久久久久闺蜜| 欧美一区二区三区婷婷月色| 日韩久久精品一区| 2024国产精品| 国产精品久久久久国产精品日日| 国产精品美女久久久久aⅴ国产馆| 日本一区二区三区四区| 国产精品视频你懂的| 亚洲品质自拍视频| 天天做天天摸天天爽国产一区| 日日夜夜精品视频天天综合网| 亚洲欧美视频在线观看| 亚洲线精品一区二区三区八戒| 亚洲精品成人悠悠色影视| 亚洲一区二区三区激情| 三级不卡在线观看| 国产一区二区三区在线观看免费 | 欧美综合一区二区| 欧美日韩日日摸| 精品久久五月天| 中文字幕视频一区二区三区久| 亚洲国产sm捆绑调教视频 | 一卡二卡三卡日韩欧美| 日精品一区二区三区| 国产剧情一区在线| 91丨九色porny丨蝌蚪| 欧美日韩成人在线一区| 国产亚洲婷婷免费| 亚洲第一激情av| 国产精品996| 在线不卡一区二区| 国产日韩精品一区二区三区在线| 亚洲精品一卡二卡| 国精产品一区一区三区mba桃花 | 亚洲午夜日本在线观看| 日本女人一区二区三区| 成人深夜在线观看| 欧美一三区三区四区免费在线看 | 亚洲综合在线电影| 伦理电影国产精品| 色哟哟国产精品免费观看| 精品国精品自拍自在线| 亚洲免费观看高清完整| 成人动漫一区二区在线| 欧美高清激情brazzers| 国产精品午夜在线观看| 日韩不卡一二三区| jvid福利写真一区二区三区| 日韩视频一区二区| 亚洲一区二区欧美| www.欧美日韩国产在线| 日韩欧美www| 香蕉乱码成人久久天堂爱免费| 岛国精品在线观看| 337p亚洲精品色噜噜狠狠| 亚洲欧洲美洲综合色网| 韩国av一区二区三区在线观看| 欧美日韩综合一区| ...xxx性欧美| 国产成人免费av在线| 欧美一级生活片| 亚洲国产cao| 欧美性一级生活| 亚洲激情第一区| 91亚洲大成网污www| 国产视频在线观看一区二区三区| 奇米精品一区二区三区四区| 欧美在线free| 一区二区三区在线观看国产| 成人a区在线观看| 国产欧美日韩精品在线| 精品无人区卡一卡二卡三乱码免费卡| 欧美日韩一级片网站| 亚洲黄色片在线观看| 99精品视频中文字幕| 国产精品久久久久四虎| 成熟亚洲日本毛茸茸凸凹| 久久久精品影视| 国产成人免费av在线| 国产欧美日韩另类视频免费观看| 国产一区二区三区在线看麻豆| 精品欧美乱码久久久久久| 美女脱光内衣内裤视频久久网站| 91精品国产综合久久久蜜臀图片| 午夜精品免费在线| 欧美精品色综合| 老司机一区二区| 久久精品水蜜桃av综合天堂| 国产福利一区在线| 亚洲国产岛国毛片在线| 97se亚洲国产综合自在线不卡 | 亚洲狠狠爱一区二区三区| 一本大道久久a久久综合| 亚洲天堂久久久久久久| 色狠狠av一区二区三区| 樱桃国产成人精品视频| 欧美在线视频你懂得| 亚洲国产精品精华液网站| 欧美日本在线看| 精品一区二区三区蜜桃| 欧美激情一区二区三区蜜桃视频| www.av亚洲| 亚洲成人资源在线| 精品国产乱码久久久久久久久 | 中文字幕免费不卡在线| 97久久超碰精品国产| 亚洲不卡一区二区三区| 2023国产一二三区日本精品2022| 成人免费黄色在线| 亚洲综合色成人| 精品国产伦一区二区三区免费| 国产不卡视频一区| 亚洲综合色成人| 久久先锋影音av鲁色资源网| www.亚洲国产| 日本午夜精品一区二区三区电影|