在油田生產中為了節省電能并減小故障率,變頻器得到越來越多的應用。但由于油井負載的非周期大脈動性質,從能量的流向來看,變頻器有兩種運行狀態——電動運行和回饋制動。不同運行狀態的控制變量和控制方法是不同的,這就要采用所謂的變結構控制。本應用是實現抽油電機變頻驅動中的變結構控制,不同的控制結構通過任務間的切換實現。 系統控制核心采用DSP56F803,它是Motorola公司推出的16位DSP型微控制器,運算速度可達40MIPS,片內資源豐富,有強大的軟件支持,是嵌入式應用的理想選擇。本系統應用了其SPI、SCI、PWM、鍵盤中斷及通用I/O口等功能模塊。 1 系統設計 1.1 uC/OS-II的移植與配置 Motorola公司提供的軟件開發工具包SDK為使用uCC/OS-II做好了鋪墊工作,與硬件相關的文件OS_CPU.H、OS_CPU_A.ASM和OS_CPU_C.C已經給出,只需購得系統源代碼,然后將其考入指定的文件目錄,系統的移植就完成了。本文采用最新版本uCC/OS-II V2.51。 系統移植成功后,需要對操作系統進行配置(裁剪),把用不到的功能去掉,以最大限度地節省存儲空間。這項工作是通過os_cfg.h中的宏定義進行的,本文只用到了多任務管理、信號量、互斥量等功能。在本應用中,uCC/OS-II內核經過剪裁后只有3KB左右,相對DSP56F803的32KB內部程序Flash只用了不到十分之一。需注意的另一個關鍵設置是時鐘節拍中斷頻率OS_TICKS_PER_SEC,它是系統多任務運行所依賴的時間基準,也決定了任務重復調用的最快頻率。這里缺省設為1000,要比文獻中的推薦值高出一個數量級。但實際應用表明,DSP56F803以其高運算速度在這個設置下是完全勝任的。 1.2 系統功能 根據油田生產的要求,系統要實現以下功能:鍵盤輸入、參數顯示、三相電流采集、直流側電壓采集、溫度采集、變頻指令輸出以及保護等。系統對電流、電壓、溫度進行周期性采樣,采樣值經過數字信號處理,作為控制器的參數,最后由控制算法得出控制量,經PWM和D/A轉換器發送給變頻器,形成反饋閉環控制。系統運行過程中實時顯示電流、溫度等參數,并可以通過鍵盤對控制器進行參數在線設定。另外,高溫、過流等保護功能必不可少。系統原理如圖1。控制器根據直流側電容C上電壓的大小來確定以哪一種控制結構運行。當直流側電壓不超過設定值時,系統以電動狀態運行。超過設定值時要以回饋制動方式運行,要求兩種工作狀態要互鎖,切換要準確、及時。 1.3 任務的創建及變結構控制的實現 根據功能要求,本著盡量減少任務數以減輕CPU運行負擔的原則,本文設計了AD采集、電動運行、回饋制動和顯示四個任務。另外還設計了兩個中斷服務子程序:用PortA口的中斷功能實現8個鍵盤輸入,用外部中斷IrqA實現短路、過流、缺相保護功能。 每個任務都有自己的名稱、內存空間和優先級。不同的任務必須有不同的優先級,它們可以是0"62之間的任意值,數值越小優先級越高。優先級的設置有不同的依據,以本文為例,回饋運行任務對時間要求最苛刻,如果不能及時啟動或過早結束都會對變頻器造成危害,所以其優先級設為最高;AD采集任務運行最頻繁,必須為其它任務提供可靠的參數,優先級設為次高;電動運行任務是常規運行狀態,優先級低于AD采集任務;顯示任務只實現人機交互,顯示狀態和參數對控制器性能沒有直接影響,優先級設為最低。uCC/OS-II要求為每個任務分配OS_STK類型的堆棧空間,并且它們占用的RAM存儲空間必須是連續的。 任務延時是指任務執行完畢處于掛起等待狀態到下一次重新運行之間的時間間隔,它的單位是時鐘中斷節拍。由于OS_TICKS_PER_SEC為1000,每一拍為1ms。每個任務的調用間隔不能小于一個節拍,它將影響模擬量的采樣頻率。各個任務的屬性定義如表1所示。 1.4 任務間的通信 各個任務是通過搶占CPU的使用權來運行的,它們之間存在一定的邏輯關系,彼此互相聯系又互相制約。信號量、郵箱、消息隊列等功能為實現任務間通信提供了有力工具,它們的使用方法靈活多變,如用信號量設置事件標志,喚醒任務、用郵箱在任務間傳遞參數、用消息隊列的循環尋址功能進行模擬通道的數據采集等。本文設計了兩個信號量,在系統運行開始后,任務TASK_AD檢測直流側電壓的大小。當電壓未超過設定值時,發出信號DC_NORM喚醒任務Task_NORMAL;當電壓高出設定值時,發出信號DC_OVER喚醒任務Task_FEBACK。雖然這兩個任務基于不同的控制結構,采用不同的算法,但都要使用PWM輸出和SPI通信口,所以在喚醒一個任務的同時必須讓另外一個任務掛起。這里引入了互斥型信號量T_MUTEX實現這個功能。得到T_MUTEX信號的任務將獨自占有共享資源的使用權,兩個任務不會因資源沖突而同時掛起,解決了任務間優先級反轉問題,避免了系統功能失效。任務間邏輯關系如圖2所示。 操作系統為任務間通信提供了多種途徑,但最簡單有效的方法是共享全局變量。本文使用共享全局變量的方法實現了顯示任務與鍵盤中斷服務之間的通信,代碼如下: 鍵盤中斷: static void KeyboardISR(void) { UWord16 cpu_sr; OS_ENTER_CRITICAL(); //臨界區代碼保護 asm{ move X:$0FB7,A1 //讀鍵盤中斷狀態表 move A1,state1 //將中斷狀態放入全局變量 }; OS_EXIT_CRITICAL(); //臨界區代碼保護結束 } 這里state1是全局變量,鍵盤中斷的工作僅僅是將PORTA口中斷狀態寄存器(IESR,地址$0FB8)讀入state1中。為防止其他任務在此期間對state1的修改,使用了臨界區代碼保護。 顯示任務的部分代碼: switch(state1) {case 1: //PTA_0對應的鍵被按下 …… //相應的服務程序,略 case 128: //PTA_7對應的鍵被按下 break; } asm{move $00,X:$0FB8}; //清鍵盤中斷狀態, 以備下次中斷 顯示任務中采用多分支結構,根據statel=2n,(n=0,1,2,3,,4,5,6,7),不同的值代表不同的鍵被按下,程序進行相應的處理;最后將IESR寄存器清零。用同樣的方法,兩位之間互相組合可擴展形成16個按鍵。這樣只用一個全局變量就完成了中斷與任務間的通信,程序用內嵌匯編的C來寫,簡捷高效。 2 系統設計中需注意的問題 首先是存儲器分配問題。多任務、郵箱等功能的使用會增加RAM的額外開銷,在不擴展外部RAM的情況下,可用的只有片內2KB數據RAM和512字的程序RAM,資源相對有限,存儲空間的合理分配就顯得很重要。任務堆棧所占用的RAM空間要根據實際應用來確定,必須考慮任務調用的嵌套情況、任務中函數為局部變量所分配的內存數目。另外,它必須能保存DSP的所有22個寄存器和16個存儲器字。如果為任務分配的存儲空間富余過多則造成資源緊張,甚至會因內存溢出導致系統崩潰。解決方法是調用系統函數OSTaskStkChk(),它可以檢測每個任務運行時使用的內存大小,為合理分配內存空間提供了依據。另外,可采用一些簡化方法節省RAM空間。例如SDK為AD采集的每個通道都定義一個結構體,它包括三個元素:句柄、數值長度和采樣值;如果使用五路AD采集,就得定義五個結構體。通常不進行初始化,DSP內核在運行時將它們放入RAM空間,占用RAM較多。通常關心的只是采樣值一個元素,其他兩個只完成輔助功能。如果使用一個存放采樣值的變量代替這個結構體,或直接采用匯編語言寫這段代碼,就可大幅度地節省RAM空間。本文的AD采集程序就是用匯編完成。 SDK沒有提供在DSP56F803下使用SPI函數的例程。 仿照在807中的成功應用,筆者調用spiWrite()函數,通過SPI驅動D/A轉換芯片。但在編譯連接時出現系統錯誤,數據類型unsigned short與const void不匹配,在const.c中將spiWrite做強制類型轉換(void*)(&spiWrite),解決了這一問題。 利用SDK與uC/OS-II相配合,充分發揮了DSP型控制器DSP56F803的功能,采用內嵌匯編的C語言編程,大大提高了代碼的可讀性和可移植性,縮短了系統開發周期,成功實現了系統的變結構控制功能,也體現了操作系統的多任務功能在實現多算法結構上的優越性。 參考文獻 1 Motolora DSP56F80X User′s Manual. 2000 2 Motolora SDK Programmer′s Guide. 2001 3 Labrosse Jean J.,邵貝貝譯.嵌入式實時操作系統μC/OS-II.北京:北京航空航天大學出版社,2003 4 邵貝貝.Motolora DSP型16位單片機原理與實踐. 北京:北京航空航天大學出版社,2003 |