新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 基于μC/OS-II的CAN總線驅動程序設計

        基于μC/OS-II的CAN總線驅動程序設計

        作者: 時間:2016-09-12 來源:網絡 收藏

        引言

        本文引用地址:http://www.104case.com/article/201609/303942.htm

        應用實時多任務操作系統(RTOS)作為嵌入式設計的基礎和開發平臺將成為嵌入式應用設計的主流。μC/OS-II是一種源碼公開、可移植性、可固化、可裁剪、占先式的實時多任務操作系統,目前已經得到廣泛的應用。

        在為電力系統接地選線裝置開發的監測系統的設計中,筆者設計了集散式的結構,靈活的組態適應了目前國內多數中低壓輸配電網的需求。在此硬件平臺上,筆者將實時操作系統 μC/OS-II移植到TMS320LF2407A型號的DSP上,實現了多任務的并行執行,系統的可靠性和實時性得到大幅提升;設計了驅動程序,使得下位采集處理模塊與上位的主控制器具備了可靠快速的通信功能和協調功能。

        1.集散式的數據采集系統設計

        系統的整體結構如圖1所示:

        集散式選線系統整體結構

        圖1集散式選線系統整體結構

        圖中反映出目前變電站常見的網絡結構。一般的基于集中式數據采集方式在應用上存在一定的缺點,比如針對不同變電站實際情況配置不夠靈活等。而基于集散式的數據采集系統卻具有系統適應能力強,組態方便,可靠性高等優點。因此,根據變電站網絡的這種結構,本裝置設計采用集散式數據采集的方式,即在每條支路上均掛接一個獨立的智能數據采集及處理模塊負責實時采集和數據預處理;主控制器與各智能采集處理模塊通過CAN現場總線進行通訊,從而不僅實現主控的功能,還具備靈活的集散擴充性能。

        2.接口的設計

        在各種現場總線網絡中,最早為汽車電子設備互連而開發的由于其簡單靈活的配置以及強大的實時控制和檢錯糾錯能力而在諸多自動化領域中得到了廣泛的使用。

        美國TI公司DSP產品線中的2000系列是專為工業控制應用設計的數字信號處理器,具有強大的數字信號處理能力,還集成了豐富的外設和I/O,成為現代電機控制、電力系統自動化等應用中很好選擇。在這款DSP處理器上,自帶了兼容CAN2.0B標準的CAN總線控制器,因此只需外接一片CAN總線收發芯片即可使模塊具有完整的CAN總線通信能力,在此使用支持1Mbps的PCA82C250收發器芯片,接口設計見圖2。

        采集模塊CAN總線接口

        圖2采集模塊CAN總線接口

        3.μC/OS-II在2407上的移植

        絕大部分μC/OS-II的源碼是用移植性很強的ANSIC寫的,只有和微處理器硬件相關的那部分是用匯編語言寫的。而TI公司提供的編譯器CodeComposerStudio(C2000)V2.20支持C語言和匯編語言開發,筆者在此編譯器的基礎上完成了μC/OS-II的移植。移植工作主要集中在三個文件的修改工作:修改頭文件OS_CPU.H相關的內容,包括:數據類型定義、堆棧增長方向、中斷相關的一些宏定義等;OS_CPU_C.C中編寫任務堆棧初始化函數及系統HOOK函;OS_CPU_A.ASM中編寫四個匯編語言函數:OSStartHighRdy(),OSCtxSw(),OSIntCtxSw()和OsTickISR()。

        具體移植過程由于不是本文重點,恕筆者不再詳述。

        4.基于緩沖隊列支持下的CAN總線驅動程序設計

        驅動程序是連接底層的硬件和上層的API函數的紐帶,有了驅動程序模塊,就可以把操作系統的API函數和底層的硬件分開來。任何一個硬件的改變、刪除或者添加,只需要隨之改變、刪除或者添加提供給操作系統的相應的驅動程序就可以了,并不會影響到API函數的功能,更不會影響到用戶的應用程序。同時,為了保證在實時多任務操作系統中,對硬件訪問的唯一性,系統的驅動程序要受控于相應的操作系統的多任務之間的同步機制。

        (1)μC/OS-II的通信機制

        μC/OS-II在處理任務之間的通信和同步的時候,主要通過以下幾種方式:信號量(Semaphore),郵箱(Mailbox),消息隊列 (Queue)和互斥信號量(Mutex)。具體的通過事件控制塊(ECB)來實現。μC/OS-II中定義的數據結構OS_EVENT能夠維護任務間通信和同步的所有信息,該數據結構不僅包含了事件本身的定義,如信號量的計數器、指向郵箱的指針、指向消息隊列的指針數組、互斥量中能否獲得資源的Flag 和正在使用該互斥量的任務,還定義了等待該事件的所有任務列表。事件發生后,等待的優先級最高的任務進入就緒態。

        (2)緩沖隊列的設計和通信任務的配合

        在微機系統中,一般串行設備或者其他字符型設備都存在外設處理速度和CPU速度不匹配的問題,所以需要建立相應的緩沖區。向CAN口發送數據時,只要把數據寫到緩沖區,然后由CAN控制器逐個取出往外發送。從CAN口接收數據時,往往等收到若干個字節后才需要CPU進行處理,所以這些預收的數據可以先存在緩沖區。緩沖區可以設置收到若干個字節后再中斷CPU,這樣就避免了因為CPU的頻繁中斷而降低系統的實時性。

        在對緩沖區讀寫的過程中,經常會遇到想發送數據的時候,緩沖區已滿;想去讀的時候,接受緩沖卻是空的。對于用戶程序端,采用傳統的查詢工作方式,頻繁的讀取使得程序效率大為降低。如果引入讀、寫兩個信號量分別對緩沖區兩端的操作進行同步,問題自然解決:用戶任務想寫但緩沖區滿時,在信號量上休眠,讓CPU運行別的任務,待ISR從緩沖區讀走數據后喚醒這個休眠的任務;類似的,用戶任務想讀但緩沖區空時,也可以在信號量上休眠,待外部設備有數據來了再喚醒。其中,μC/OS-II的信號量提供了超時等待機制,CAN端口本身也有超時讀寫能力。

        接受和發送的數據緩沖區數據結構定義如下:

        typedefstruct{

        INT16UBufRxCtr;//接受緩沖中的字符的數目

        OS_EVENTBufRxSem;//接受信號量

        INT8UBufRxInPtr;//接收緩沖中下一個字符的寫入位置

        INT8UBufRxOutPtr;//接收緩沖中下一個待讀出字符的位置

        INT8UBufRx[CAN_BUF_SIZE];//接收環形緩沖區的大小

        INT16UBufTxCtr;//發送緩沖中字符的數目

        OS_EVENTBufTxSem;//發送信號量

        INT8UBufTxInPtr;//發送緩沖中下一個字符的寫入位置


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 昌乐县| 乌鲁木齐县| 渭源县| 江北区| 门头沟区| 时尚| 精河县| 陕西省| 辽中县| 新源县| 石狮市| 聂拉木县| 阿拉善盟| 武胜县| 文水县| 普兰店市| 东丰县| 莆田市| 百色市| 惠东县| 茂名市| 凤山县| 错那县| 东安县| 临颍县| 延寿县| 宁武县| 萨嘎县| 九江县| 龙胜| 唐河县| 张家川| 桃江县| 武强县| 丰顺县| 隆尧县| 太康县| 越西县| 玛多县| 承德市| 和龙市|