国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

時間片輪轉算法在單片機程序設計中的應用

發布時間:2009-11-28 14:56    發布者:silentcircuit
摘要:提出一種采用時間片輪轉算法改進單片機系統程序設計,實現多任務機制的軟件設計方法,并給出了在MCS-51分級分布式系統中應用該算法進行程序設計的實例。

關鍵詞:時間片 多任務機制 單片機系統


傳統的單任務編程思想對于明顯的順序控制要求編程簡單、思路清晰、開發周期短;但對于任務較多、控制功能復雜的問題時,卻難以滿足要求。因此,有必要對傳統的單任務設計思想進行改進。時間片輪轉算法是實現多任務調度的一種常用算法。在這種算法中,系統將所有的任務按順序排成一個隊列,每次調度時把CPU分配給隊首的任務,并令其執行一個時間片,構成微觀上輪流運行、宏觀上并執行的多任務效果。作者在基于單片機的分級分布式控制系統——程控對講系統的用戶控制器程序中引入多任務機制,采用時間片輪轉算法極大地改善了程序結構,實現了對32個獨立用戶的有效控制。這種程序設計思想也可以到其它以單片機為核心的分級分布控制系統軟件設計中。


1 系統組成


程控對講系統是一個基于MCS-51的多級分布式系統,用戶控制器是其中的一級,整個系統總體結構如圖1所示。



主控制器以單片機AT89C52為核心擴展非易失性存儲器及其它功能器件,完成系統各用戶對講關系的編程和存儲,并根據對講關系對用戶模塊進行實時控制。用戶控制器以單片機AT89C52為核心擴展用戶機接口模塊組成,每個用戶控制器負責對其下一級的32個用戶機進行管理與控制。


主控制器與用戶控制器之間的信息交換采用主從方式的串行通信。主控制器對8個用戶控制器輪流查詢,各用戶控制器只對與本模塊相關的命令作出反應,用戶控制器通過雙絞線與用戶機相連,以降低系統成本。用戶機與用戶控制器之間傳輸距離較遠,最遠可達8km。為保證在復雜的環境中正確傳輸數據,兩者之間的通信采用DTMF編碼。


2 任務的分配和時間片的劃分


2.1 用戶控制器子任務的確定


用戶控制器需要實時管理32個獨立的用戶機,一方面實時接收用戶機的呼叫信號進行處理后傳送給主控制器;另一方面根據系統工作狀況向用戶機發送被呼叫信息。


用戶控制器接收來自用戶機的信號有兩類。一類是DTMF編碼信號,用于檢測用戶機是否需要呼叫其它用戶機。用戶機與控制器之間傳送數據的位數是不等長的,每位DTMF編碼數據的發送至少需要104ms,發送時間和空閑時間各占一半。另一類是話,DTMF編碼信號和話音信號的復用可以降低系統的線路成本。



   在每次通信結束后,為使用戶控制器能啟動下一輪的DTMF編碼數據的接收,用戶機需要給用戶控制器發送一個起始信號——掛機信號。用戶機的工作電源直接從用戶線路上提取,在話音和DTMF編碼傳送時用戶線路有一定的工作電流(大于20mA),掛機信號使用戶線路上電流接近于零(小于5mA),用戶控制器檢測用戶線路上電路的這種變化后,進入新一輪的DTMF編碼數據通信。掛機信號的持續時間為78ms。


用戶控制器向用戶機發送的只有DTMF編碼數據,用于告訴用戶機誰正在呼叫它。


要完成一個呼叫過程(即使通話時間為零),至少需要2×104ms(接收、發送DTMF編碼時間)+78ms(掛機時間)=286ms;完成一個被呼叫過程也至少需要2×104ms=208ms。如果每個用戶機的請求就不能實時作出響應。為解決這個問題,在用戶控制器程序設計過程中引入多任務機制。為便于任務調度程序的調度,根據用戶操作流程將用戶機的操作細分為16個字操作,每個子操作構成個子任務,用戶子任務分配表如表1所示。

表1 用戶子任務分配表
子任務號功   能執行時間
0等待接收26×n
1接收預處理26
2用戶機查詢26×4
3應答26×4
4接收第1位數據26×4
5接收第2位數據26×4
6接收第3位數據26×4
7等待上傳26×n
8確認26×n
9響應26×4
10通話26×n
11掛機26×2
12發送預處理26
13發送第1位數據26×4
14發送第2位數據26×4
15發送第3位數據26×4


2.2 時間片的劃分


在時間片的輪轉算法中,時間片的大小對系統性能有很大影響。如果時間片太大,大到每個任務都能在一個時間片內執行完畢,則時間片輪轉算法便退化為FCFS算法。時間片的確定通常要考慮三個因素:任務的數目、系統對響應時間的要求、系統的處理能力。
本系統中用戶控制器需要對32個用戶機進行管理控制,應劃分成32個時間片。在不同時刻每個用戶機處于不同的工作狀況,用戶控制器需要執行不同的用戶機任務,其處理時間也不相同。為縮短程序運行時間把,時間片設置為可變的,時間片的長短取決于各個用戶機子任務的工作量。但用戶控制器與用戶機之間的通信時間要求很嚴,如DTMF的發送定時時間為104ms,包括52ms發送時間和52ms空閑時間,所以用戶控制器必須在52ms內對每個用戶機巡檢一次,才能正確地接收用戶機的編碼數據。也就是說一個任務調度周期不應大于52ms。為滿足用戶機與控制器之間的通信對時間要求,對整個任務調度周期進行精確定時。


綜合考慮本系統中與時間片劃分相關的三種因素:單片機本身的運算速度、用戶機數目及用戶機與控制器之間信號的傳送要求,確定任務調度周期為26ms。即在26ms內用戶控制器對其下一級的32個用戶機的任務都要執行一次。一般完成一個任務占用一個時間片,較長任務可以占用多個時間片,如14號子任務(發送第2位DTMF編碼數據)需要占用4個時間片才能完成。
為實時掌握各用戶機的運行狀態,在用戶控制器的存儲器開辟出一個緩沖區為任務記錄表,供任務調度程序使用。任務記錄表中設置了三項內容:用戶編號、子任務號及時間片數,如表2所示。

表2 任務記錄表
用戶編號子任務號時間片數
0~310~150~16


3 軟件設計


3.1 任務調度程序的設計


根據上述分析,可以確定任務調度程序的功能:


(1)按用戶機編號調用各用戶子任務;
(2)完成一個調度周期的時間不超過26ms,并在每個周期結束時對26ms進行精確定時;
(3)在調度周期開始時,讀取所有用戶的DTMF編碼和摘/掛機狀態,供各用戶子任務處理;
(4)在調度周期結束前,根據用戶子任務處理結果向用戶機發送DTMF編碼。


調度程序的流程如圖2所示。



    3.2 用戶子任務的設計


用戶子任務根據該用戶緩沖區的數據進行處理,并把處理結果存放于結果單元。各個子任務并不與外部輸入輸出接口直接交換數據,對接口的輸入輸出由任務調度程序在調度周期開始和結束時調用專門子程序完成。用戶子任務的切換工作根據操作流程在各子任務中完成。用戶的操作被細分為16個子操作,相應地有16個子任務,圖3為14號子任務的流程圖。


在該子任務的開始(0ms)和中間(52ms)時刻設置DTMF數據發送緩沖區,分別允許和禁止DTMF編碼的發送。在該子任務結束時根據該用戶緩沖區內需發送的數據計算第2個的DTMF值,并修改任務記錄表中該用戶的調度數據,指向它的下一個子任務。其它子任務的設計思想與此子任務類似。


本文在單片機實時控制系統中引入了現代操作系統的多任務思想,采用時間片輪轉調度算法對傳統單片機編程思想進行了改進,并應用在基于MCS-51的分級分布式系統中,有效地完成了對32個獨立用戶的控制。實踐證明這種結構清晰、調度靈活,適用于定時要求復雜、實時性要求強的系統。

作者: 陳勁松, 程新明, 魏忠, <<電子技術應用>>2003年 第29卷 第03期
本文地址:http://www.qingdxww.cn/thread-6048-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
flysky1124 發表于 2009-12-7 12:24:58
謝謝誒!��!
alpha321 發表于 2009-12-9 10:42:25
謝謝樓主!
這是一篇單片機應用軟件規劃的文章,用時間片輪轉算法實現程控對講系統的用戶控制器任務調度,有效提高程序的實時性能,改善了程序結構。文章中沒有用到某個嵌入式系統,僅用了時間片輪轉的任務調度算法,這是一種不錯的設計思想,值得搞單片機的各位借鑒。
xyzabc123333 發表于 2010-5-27 09:16:26
感謝分享!
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • Dev Tool Bits——使用MPLAB® Discover瀏覽資源
  • Dev Tool Bits——使用條件軟件斷點宏來節省時間和空間
  • Dev Tool Bits——使用DVRT協議查看項目中的數據
  • Dev Tool Bits——使用MPLAB® Data Visualizer進行功率監視
  • 貿澤電子(Mouser)專區

相關在線工具

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲欧美中文日韩二区一区 | 亚洲日本一区二区三区高清在线 | 欧美一区1区三区3区公司 | 精品自在线| www.91..com| 亚洲二三区 | 成人午夜一区二区三区视频 | 四虎最新紧急入口 | 理论片在线免费观看 | 99视频精品全国免费 | 亚洲成熟人网站 | 狠狠色丁香婷婷 | 青草免费免费观看视频在线 | 欧美日韩中文一区二区三区 | 成人午夜性影院视频 | 日韩一区二区三区不卡视频 | 欧美在线看视频 | 一本久道热中字伊人 | 日韩一级二级三级 | 99国产福利 | 日本天堂在线视频 | 成人在线一区二区三区 | 久久国产免费 | 国产手机在线精品 | 国产精品九九九久久九九 | 麻豆视频网站在线观看 | 国产精品老牛影视 | 艳母在线免费看影视网站 | 国产精品66在线观看 | 四虎永久精品免费观看 | 久久九九爱 | 天天尻 | 失乐园日本 | 综合网插菊花 | 四虎在线精品免费高清在线 | 日本欧美一级 | 国内精品一级毛片免费看 | 高清一区高清二区视频 | 亚洲精品第一卡2卡3卡4卡5卡 | 丝瓜草莓视频下载 | 亚洲欧美综合久久 |