今天半導體工藝幾何尺寸的不斷減小正在改變微控制器的經(jīng)濟學。新的嵌入式設計開發(fā)工具成本快速增長,但微控制器上的數(shù)字邏輯線路成本正不斷下降。這使得提供具有更多外圍的微控制器更具經(jīng)濟性,尤其是如果這些外圍屬于數(shù)字類電路、uart、can控制器和以太網(wǎng)mac等。目前市場上帶有更復雜外圍的微控制器正不斷出現(xiàn)。如果我們將閃存和ram也看作是外圍,那么今天許多微控制器的結構中90%以上的部分都是外圍。 這里以目前銷售的8051和許多衍生器件為例進行說明。10年前,8051幾乎要被棄用,但是現(xiàn)在有許多新產(chǎn)品還在采用8051內(nèi)核,為提高性能,其外圍的數(shù)量和種類都有了顯著增加。許多熟悉8051的工程師都在關注這些新產(chǎn)品。他們認為自己了解8051內(nèi)核,所以采用基于8051的器件比采用基于其它內(nèi)核的器件會更簡單。但僅僅熟悉微控制器內(nèi)核就足夠了嗎? 用c編譯器編寫控制器軟件 在回答這個問題之前,先了解一下新微控制器發(fā)展的過程。大多數(shù)微控制器制造商都有許多不同的變種產(chǎn)品,某個廠商甚至擁有500多個不同的變種。這些變種對于設計者為特定應用充分選擇外圍提供了條件。 圖1:cyanide集成開發(fā)環(huán)境。(點擊看大圖)一種更好的方式就是選擇已經(jīng)具備很多項目所需的所有外圍和靈活輸入輸出排列的微控制器。因此,用戶可以選擇和配置每個項目要求的具體外圍組合,顯著降低了pcb重新設計所需的工作量。選擇這類微控制器可以使硬件修改更加容易。這可使用戶更加靈活地選取恰當?shù)耐鈬M合來滿足設計要求。 此外,工程師通過降低不同零部件購買和庫存的數(shù)量,將獲得公司內(nèi)的物料供應人員認同,因為在過去很長的一段時間內(nèi),我們看到制造商都以能提供各種各樣的微控制器為榮,實際上,這對于客戶和制造商本身來說都無異于一場物流供應方面的噩夢。事實上,供貨商應更好地利用不斷降低的硅成本制造更少變種、但功能更強大的微控制器。 大多數(shù)工程師會爭辯說軟件功能是他們不能放棄現(xiàn)有微控制器系列的原因之一,所以我們來談談軟件問題。 考慮一款新的微控制器時,需要解決2個主要軟件問題:1. 編寫完全運行在內(nèi)核中的算法,包括數(shù)學算法(如濾波算法)或主循環(huán);2. 外圍初始化和接口的軟件。 首先來談談在微控制器內(nèi)核中運行的軟件。過去幾年里,c編譯器的使用不斷普遍,并且效率也有所提高。這意味著,c編譯器可節(jié)省的編程工作比所有應用程序中性能損失的程度更重要。仍有一些與時間精確性相關的軟件功能需要用匯編程序編寫,但是這些程序也可能打包在c編譯器編寫的主程序中。 除了編譯器的效率外,微控制器總體性能也有了明顯的提高。許多工程師都利用比以前性能強10倍的現(xiàn)代控制器并轉(zhuǎn)變成用c編譯器編寫軟件,而設計出的產(chǎn)品比前幾代產(chǎn)品運行起來要快得多。 采用c編譯器的另外一個驅(qū)動因素就是許多產(chǎn)品普遍都需要增加代碼數(shù)量。在匯編程序中編寫8k代碼可能相當于100張a4紙的軟件。編寫和維護這種數(shù)量的代碼需要耗費大量的工作量。一旦你開始著眼于需要32k或64k代碼的應用程序,那么使用編譯器自然而然就成了99%應用程序的唯一實際選擇。 如果我們決定下一個要開發(fā)項目使用c編譯器,那么就可以做出一個大膽得結論。包括c語言在內(nèi)的高級語言可以使工程師避開微控制器內(nèi)核的繁雜工作。如果我們編寫: counter=counter+1; (or counter++;), 我們可以意識到其實我們不必在乎它在應用程序中究竟如何執(zhí)行。這就是編譯器的主要目的所在,所以也就不足為怪。只要變量counter增加,我們并不需要知道是否使用累加器或寄存器架構獲得結果。 應對復雜外圍電路編程挑戰(zhàn) 現(xiàn)在來討論外圍電路編程的問題。在市場上許多新款微控制器中,外圍數(shù)量迅速增長。越來越多的芯片面積都被外圍電路占用,它們的復雜性和功率似乎也在不斷增加。今天市場上的一些8051微控制器擁有300~400頁的數(shù)據(jù)手冊。其中,你會發(fā)現(xiàn)只有25頁內(nèi)容是介紹內(nèi)核工作原理的,剩下的都是關于外圍的,從復位控制器、復雜的adc到更復雜的通信控制器(如can、usb、以太網(wǎng))。 這讓我們得出一個結論,涉及外圍的軟件比完全在內(nèi)核中運行的軟件要花費更多得多的工作量。 進一步說就是,專門針對外圍的datasheet越多,對熟悉這種控制器內(nèi)核來說就越無益。 圖2:賽恩的16位微控制器μcog1m集成了密集的外圍電路作為面對復雜外圍的工程師,為了避免淹沒在那些外圍實現(xiàn)所有預期用途的繁重任務時,你會怎樣做呢?有些微控制器制造商提供能夠生成源代碼的工具