采用分而治之的方法設計嵌入式系統(tǒng)
主控制器和從控制器
最基本的原理就是:用主控制器進行集中決策,再交由從控制器分別執(zhí)行。在最為復雜的系統(tǒng)中,這種方法必不可少,并能夠自動執(zhí)行。比如,手機中的主處理器用于決定屏幕的顯示內容以及外設(如LCD顯示控制器或無線電收發(fā)器)需要完成的工作,而不會直接控制顯示的各個像素或是無線電的編/解碼。主控制器將告知顯示器需要顯示什么信息,并由顯示器來決定如何顯示;同樣,主控制器向收發(fā)器提供需要編碼的音頻信號,而收發(fā)器則提供解碼后的信號。
在其他嵌入式系統(tǒng)中,任務的劃分或許不那么明顯,但基本思想都是相同的。如果一個中央主控制器能夠與遠程從設備以及本地設備進行通信,那么整個系統(tǒng)中就可以有統(tǒng)一的控制。另外,為了使一個分布式系統(tǒng)獲得成功,需要對接口作明確的定義。
雖然微控制器有許多標準的通信方法,但在主/從嵌入式系統(tǒng)中,最常用的是RS23 2串行接口、SPI和I2C。采用這些通信接口的從設備包括較低級的ADC、DAC、串行EEPROM、各類數(shù)字I/O,以及較高級的電壓排序和監(jiān)控器件以及閉環(huán)風扇控制器等。
將任務分而治之
在目前嵌入式市場的從器件以及可被用作主控制器或定制從控制器的微控制器中,比較流行的通信方法是I2C。這主要是由于I2C價格較低,只需雙線/引腳和兩個上拉電阻器即可構成,并且簡單易用。就分布式嵌入系統(tǒng)而言,I2C(400kHz)往往是最佳選擇。
將任務分而治之的關鍵在于:簡單的問題要比復雜的問題更加容易解決。此外,將器件彼此分開可以減少它們之間的耦合,并提高系統(tǒng)的可靠性。如果能夠正確地分配功能、定義接口,就可以避免普遍存在的一些故障。最后,如果能夠很好地利用自己的經(jīng)驗,則在劃分任務的過程中就將能產(chǎn)生許多可重用的設計,從而使得工程師在設計下一個項目時不用從頭開始。
實現(xiàn)任務的分而治之需要依靠一根通信總線,在有些情況下,總線會影響到某些主控制器/從控制器的特性。在本文中使用I2C作為總線,是因為支持該總線的器件比較普遍,而且測試和調試I2C所需的外部工具價格較低或比較容易創(chuàng)建。
這種主控制器/從控制器的原理在任何嵌入式設計中都是以相同的方法來處理的。首先,確定需要集中做出那些決策,并將它們分配給主控制器;然后把具體操作分配給從控制器去執(zhí)行。關鍵在于如何進行任務的劃分。一種高效的策略是:不要讓主控制器因為任何事情而去等待某個從控制器;如果從控制器需要主控制器提供某些信息,它必須先呼叫主控制器。在有些情況下,這種方法還需要一根中斷線,以使從控制器能夠呼叫主控制器。
采用I2C I/O擴展器件的面板控制器
本文在一個控制設備面板的系統(tǒng)中采用了該方法,面板由按鈕、開關和LED組成。在該面板系統(tǒng)中,主控制器是負責管理該系統(tǒng)的主處理器,如嵌入式的Windows或Linux計算機;從控制器為I2C總線連接I/O擴展器。
通過讓主處理器在上電時對I/O擴展器進行配置,按鈕/開關檢測輸入和LED狀態(tài)輸出將被傳至主處理器。任何一個具有I2C總線的處理器都可以是主控制器,它對設備進行軟件配置,并可以方便地改變按鈕和LED的配置。
這種簡單的系統(tǒng)如圖1所示。圖中藍色的圓圈代表按鈕輸入,紅色和綠色形狀代表LED。在設計中使用了兩個小的I2C I/O擴展器,是為了實現(xiàn)智能設計的模塊化,把輸入子系統(tǒng)的變化與輸出子系統(tǒng)分隔開。當在主控制器中進行決策時,可使某一特定功能的變化不影響到其他的功能。
圖1 面板系統(tǒng)簡圖
而且,由于所有的控制功能都由主控制器完成,因此系統(tǒng)中的硬件部分很簡單,而且易于改變。但這種簡單的方法也有缺點,當希望增加一個用于調節(jié)LED亮度的環(huán)境光傳感器時,增加的工作負擔將全部由主控制器來承擔,它要保證所有的從控制器能夠適應設計變化,并正常工作。但其實主控器只需要知道按鈕的狀態(tài),并控制LED的接通和關斷。
設計定制的I2C從控制器件
在圖1的系統(tǒng)中,所有的邏輯信息都存儲在主控制器中,一切變化都要通過主控制器完成。作為替代方案,可以定義一個面板接口,并將所有的細節(jié)問題交給一個分布式的從控制器系統(tǒng)來處理,這樣可減少主處理器的負擔,如圖2所示。
圖2 采用定制從器件的面板系統(tǒng)
設計定制器件時應采用定義了穩(wěn)定協(xié)議和接口且經(jīng)過驗證的I2C從控制器實現(xiàn)方案,最常用的協(xié)議是目前大多數(shù)I2C從控制器件所采用的、基于寄存器的協(xié)議。相關概要信息如下:
對于I2C,所有的事務處理均由主控制器啟動;
每個從器件都具有一個I2C 7位地址(最低有效位表明事務處理是“讀”還是“寫”);
每個從器件都具有一個內部地址寄存器,用于存儲一個指向包含了數(shù)據(jù)、命令或狀態(tài)信息的內部表指針;
每個從器件均定義了其寄存器的地址及其功能,指明它們是只讀型的還是讀/寫型的;
一個寫處理事務由一個具有I2C器件7位地址和寫操作位的字節(jié)以及一個位于其后的、用于設定內部地址寄存器的字節(jié)組成,如果在處理事務中有更多的字節(jié),則它們將被寫入以新設定的內部地址為起點的從器件;
一個讀處理事務由一個具有I2C器件7位地址和讀操作位的字節(jié)以及一個位于其后的主控制器組成,該主控制器用于記錄從器件的字節(jié)數(shù),并在結束時提供停止信號。由此可見,I2C從控制器與雙端口RAM很相似,非常易于使用。
接下來要選擇可編程器件,賽普拉斯公司推出的微控制器件PSoC擁有處理大多數(shù)I2C從控制器所需的全部功能,并提供了一種易用的工具,從而簡化了增加I2C從控制器的工作,只需“拖、放、選擇地址”即可。
首先,定義一個按鈕輸入的從器件,創(chuàng)建一個具有3個地址引腳和7個按鈕輸入的器件,并通過配置使之接受一個靠近5V直流系統(tǒng)電源的常開開關。按鈕狀態(tài)將在一個由I2C主控制器進行存取的單字節(jié)中提供。
其次,定義用于控制LED的從器件,創(chuàng)建一個具有2個地址引腳并能夠以10mA的電流來驅動8個LED(分為4紅4綠)的器件。定義被稱為“Command”的單字節(jié)用于執(zhí)行I2C的命令輸入,以控制LED。該字節(jié)的4個低位用于控制紅光LED,而4個高位則負責控制綠光LED。
接下來,還可以更加細致地定義定制I2C主控制器/從控制器的接口,進一步實現(xiàn)從控制級的客戶化設計。如果想把系統(tǒng)主控制器從一個輪詢器件變?yōu)橐粋€接收報警信號的中斷器件時,則可以給按鈕輸入設備增加一根輸出線。這些改動能夠進一步地把主系統(tǒng)處理器與低級設備相隔離,并提供了在不影響主系統(tǒng)的情況下繼續(xù)改善子系統(tǒng)的更大靈活性。
將分而治之的概念推廣到所有的通信總線
本文所討論和說明的概念可適用于任何的總線類型,需要做的是定義滿足各種不同需要的協(xié)議,以最大限度地縮短無線、便攜系統(tǒng)中的傳輸時間,或是在苛刻的工業(yè)環(huán)境中實現(xiàn)完善的檢錯/糾錯。
主控制器可以被稱為集線器,從控制器可以被看作一個節(jié)點并具有預定的響應時間,但是,分而治之的思想仍然適用:把普通、重復的測量和低級控制分配給級別最低的點,而將重要的工作留給系統(tǒng)控制器來完成。另外,在各種情況下都必須建立功能強大、精確定義的接口,以便為下一級的設計留出一定的自由度,在不影響較高級設備的情況下方便地改變設計方案。