http://www.kadhoai.com.cn 2026-04-09 21:01:47 來源:工業以太網
互連嵌入式係統的演變
過(guo)去(qu)嵌(qian)入(ru)式(shi)係(xi)統(tong)通(tong)常(chang)是(shi)深(shen)嵌(qian)於(yu)最(zui)終(zhong)產(chan)品(pin)之(zhi)中(zhong),以(yi)係(xi)統(tong)控(kong)製(zhi)為(wei)基(ji)礎(chu),一(yi)般(ban)不(bu)與(yu)外(wai)界(jie)連(lian)接(jie)。其(qi)微(wei)控(kong)製(zhi)器(qi)在(zai)一(yi)個(ge)相(xiang)當(dang)封(feng)閉(bi)的(de)係(xi)統(tong)中(zhong)工(gong)作(zuo),定(ding)時(shi)查(zha)詢(xun)外(wai)設(she)、收集數據、完成簡單的處理工作,以及控製開關和LED指示燈。此外,微控製器也進行少量的數據操作或數據傳輸。由於它們不會與局域網 (LAN)或互聯網(Internet)連接,所以不存在保安的問題。然而,這一切現在都改變了。現今的嵌入式係統一般都要連接到局域網,這樣就有數十、甚至上百個控製器連接在一起。舉例說,汽車製造和工業控製領域中的CAN有上百個微控製器在相互作用;ZigBee 無線控製網絡也有若多數量的微控製器互連在一起。而且,隨著嵌入式網絡越來越複雜(因此需要更大的網絡帶寬和更遠的傳輸距離),嵌入式以太網也開始涉足於工業控製、建築物自動化、醫療和保安產品市場。
muqianshichangdefazhanqushishijiangzhexiejuyuwangxuyaotongguoqiyeneilianwanghuowailianwangtebieshihulianwangyuwaijielianjie。qianrushixitonglianwangyaoqiudebuduanzengjia,daozhiweikongzhiqibixujubeigengduoxingneng:更強的互連性,增加程序和數據內存空間來支持相應的通信協議,提高性能和處理帶寬以進行係統傳輸數據、執行通信協議和提供嚴密的保安能力。在需要通過內聯網或互聯網監控CAN或ZigBee 網絡的應用環境中,嵌入式微控製器必須能支持10/100M以太網、CAN、ZigBee 網絡以及其他網絡協議,更必須具有先進的安全加密算法。
另一個影響嵌入式係統的因素是通用串行總線 (USB) 的快速普及,尤其是在 PC 及其外設領域。與提供基本通信鏈路的傳統通用異步收發器 (UART) 接口不同,USBshiyizhongneizhifengfuqudongchengxudejichajiyongshizongxianjiekou,nengsuoduankaifazhouqiheshebeianzhuangshijian。budanshejirenyuanxihuanzhezhongjiekou,zhongduanyonghuyeyinweibubiweixingoudewaisheanzhuangjiazaixindeshebeiqudongchengxuerleyushiyong。zaikaolvdaocaiyongbijibendiannaoduifuyinji、自助售貨機、ATM機,工廠自動化設備、家用安全係統等完成係統設置和現場服務,可以預計USB在嵌入式係統將占一重要席位。新款的筆記本電腦都隻配備了USB接口,所以由它們服務的係統也必須有USB接口,否則這些係統便得采用舊款PC或USB適配器。
還hai有you一yi點dian,隨sui著zhe嵌qian入ru式shi係xi統tong越yue來lai越yue多duo地di通tong過guo使shi用yong外wai部bu網wang絡luo來lai監jian控kong,尤you其qi是shi該gai係xi統tong可ke以yi通tong過guo互hu聯lian網wang或huo無wu線xian網wang絡luo來lai訪fang問wen時shi,對dui保bao安an的de要yao求qiu必bi然ran會hui更geng高gao。沒mei有you人ren能neng容rong忍ren局ju外wai人ren惡e意yi破po壞huai係xi統tong、關斷防火報警係統,或隨便打開輸油管的閥門,所以保安就成為了嵌入式係統非常重要的一環。
對微控製器結構的意義:高帶寬、高互連性、高可預見性
嵌qian入ru式shi係xi統tong朝chao著zhe嵌qian入ru式shi網wang絡luo的de趨qu勢shi發fa展zhan從cong根gen本ben上shang改gai變bian了le其qi結jie構gou,而er結jie構gou卻que是shi人ren們men在zai選xuan擇ze一yi個ge微wei控kong製zhi器qi時shi必bi須xu考kao慮lv的de。微wei控kong製zhi器qi必bi須xu具ju有you多duo種zhong網wang絡luo協xie議yi接jie口kou,能neng傳chuan輸shu並bing驗yan證zheng大da量liang數shu據ju,足zu夠gou的de安an全quan性xing以yi及ji內nei存cun和he處chu理li能neng力li,以yi容rong納na眾zhong多duo的de協xie議yi堆dui棧zhan;而且,在許多情況下,還必須在能耗很少的前提下完成這些任務。8位和16位處理器顯然在內存資源和處理能力上達不到這些要求,許然需要 8 位和 16 位處理器具備的“確定過程式性能” (deterministic performance) 和監管功能,而這些對32位處理器來說卻很罕有。此外,對成本敏感的係統還得與8位和16位微控製器的價格相若,而且配套開發工具的價格也必須容易接受。
yaoshiyingqianrushishichangbuduanzengchangdehulianxuqiuhezhichizheleiyingyongdeshishixingyaoqiu,zhezhongchuliqihaishibugoude。yaomanzuxianjindehulianyingyonghuanjing,qianrushiweikongzhiqixuyaonenggouzhichiduozhongtongxinxieyi、高速數據傳輸,係統安全和確定過程式實時處理。Atmel公司的SAM7 微控製器係列基於ARM技術,並具有USB接口,其最新的SAM7X 微控製器正朝著上述的領域發展。這種微控製器的工作頻率達50 MIPS,配備片上以太網和CAN通信協議,采用硬件實現的AES/3DES加密技術,安全鍵存儲技術以及各種外部接口包括USB、USART、串行外圍接口 (SPI)、同步串行接口 (SSC)、雙線接口SSC/I2S和雙線接口 (TWI)。該微控製器采用一個外設DMA控製器獨立實現高速數據的傳輸,無需占用 ARM7 處理器資源,並具有 8 位和 16 位處理器常備的實時係統控製功能 (32 位係統很少有這些功能),包括欠壓檢測器、上電複位電路、實時時鍾和監控定時器。SAM7X 微控製器還包括一些外設:一個 10位模數轉換器、脈衝寬度調製以及功率管理控製器。SAM7X 的存儲密度從 128 到 256Kbit 閃存和 32 到 64Kbit SRAM 不等。這些功能才可真正滿足嵌入式網絡環境的需求。
嵌入式互連的發展趨勢
隨著越來越多設備互連在一起,連接電纜的長度和網絡帶寬均大幅增長。最大帶寬為1Mbps的CAN網絡逐漸達到極限,開始被100Mbps以太網取代。事實上,以太網和互聯網使用的都是相同的通信協議,即TCP/IP。由於在將一個遠程傳感器通過互聯網連接到某一台PC時(shi)無(wu)需(xu)轉(zhuan)換(huan)協(xie)議(yi),因(yin)此(ci)整(zheng)個(ge)網(wang)絡(luo)便(bian)會(hui)簡(jian)化(hua),設(she)備(bei)的(de)互(hu)操(cao)作(zuo)性(xing)得(de)以(yi)增(zeng)強(qiang)。采(cai)用(yong)互(hu)聯(lian)網(wang)這(zhe)類(lei)公(gong)共(gong)通(tong)信(xin)網(wang)絡(luo)對(dui)安(an)全(quan)性(xing)的(de)要(yao)求(qiu)也(ye)大(da)為(wei)提(ti)高(gao)。不(bu)過(guo),CAN 也不會在一夜之間消失,而是繼續存在於嵌入式網絡世界內一段時間。ZigBee 很可能在低數據傳輸率控製應用中占一重要席位;而與PC 連接方麵, USB 勢將成為標準。
通用串行接口 (USB) 是一種用於將外設作為即插即用設備連接到PC上的接口標準。因此,USB替代了PC上的串行接口 (UART),而且比後者的傳輸速率更大,在全速模式下可達12Mbps。
隨著以太網協議滲透到嵌入式領域,嵌入式係統網絡必須能與以太網絡接口。SAM7X采用10/100-Mbps IEEE 802.3兼容的以太網媒體訪問控製器,該控製器可配置為全雙工或半雙工模式,並有一個能確保提供100Mbps數據吞吐速率的專用 DMA控製器;可編程的數據包收發間隔,並支持虛擬局域網標記幀以及自動暫停幀的生成及終止功能。雙模式接口能讓SAM7X通過媒體獨立接口或簡化的媒體獨立接口 (RMII) ,無縫地接入高速以太網應用中的各種物理層 (PHY)。MII 能擴大係統在物理層的選擇,而RMII 則可節省微控製器上的一些 I/O。SAM7X MCU 可直接與 POS-PHY 第2層/SPI-3 兼jian容rong的de設she備bei連lian接jie,包bao括kuo與yu標biao準zhun網wang絡luo處chu理li器qi連lian接jie。通tong過guo片pian上shang係xi統tong緩huan衝chong器qi進jin行xing的de無wu損sun失shi流liu量liang控kong製zhi,可ke省sheng去qu外wai部bu存cun儲chu器qi或huo流liu量liang控kong製zhi裝zhuang置zhi。此ci外wai,還hai支zhi持chi高gao達da10240字節的巨型幀。SAM7X 的地址檢查器能識別4個特定的48位地址,並包含一個64位(wei)散(san)列(lie)寄(ji)存(cun)器(qi),用(yong)於(yu)匹(pi)配(pei)多(duo)點(dian)廣(guang)播(bo)和(he)單(dan)點(dian)廣(guang)播(bo)地(di)址(zhi)。它(ta)能(neng)識(shi)別(bie)所(suo)有(you)廣(guang)播(bo)地(di)址(zhi),複(fu)製(zhi)所(suo)有(you)數(shu)據(ju)幀(zhen),並(bing)可(ke)用(yong)於(yu)匹(pi)配(pei)外(wai)部(bu)地(di)址(zhi)。其(qi)統(tong)計(ji)寄(ji)存(cun)器(qi)模(mo)塊(kuai)包(bao)含(han)各(ge)種(zhong)寄(ji)存(cun)器(qi),用(yong)於(yu)記(ji)錄(lu)與(yu)收(shou)發(fa)操(cao)作(zuo)相(xiang)關(guan)的(de)各(ge)種(zhong)事(shi)件(jian)。這(zhe)些(xie)寄(ji)存(cun)器(qi)與(yu)存(cun)儲(chu)在(zai)接(jie)收(shou)緩(huan)衝(chong)列(lie)表(biao)中(zhong)的(de)狀(zhuang)態(tai)字(zi)可(ke)通(tong)過(guo)軟(ruan)件(jian)讀(du)取(qu),生(sheng)成(cheng)符(fu)合(he) IEEE 802.3 標準的網絡管理統計數據。
能否高速傳輸數據?如何快速傳輸數據?
在絕大多數32weikongzhiqizhong,chuliqibenshenzaiwaisheheneiwaicunjianchuanshushujushimeicizhichuanshuyigezijie。ruguoyaochuanshudeshujuliangbuda,zhemeishenmewenti。danruoshujuchuanshusulvdadao1Mbps,即使是快速處理器也要癱瘓。在1Mbps速率下,數據傳輸占用 28% 的處理器資源;速率到 2Mbps 時,數據傳輸占用 50% 以上的處理器資源;而速率達到 4Mbps 時,處理器就不能處理其他事務了。如果考慮到全速 USB2.0 的數據速率為 12Mbps,CAN 的數據速率為 1Mbps,以太網絡的數據速率為 100 Mbps,SAM7 SPI 和 USART 外設的數據速率也能達到 25Mbps,那(na)麼(me)很(hen)明(ming)顯(xian)任(ren)何(he)一(yi)個(ge)需(xu)要(yao)在(zai)大(da)範(fan)圍(wei)互(hu)連(lian)的(de)嵌(qian)入(ru)式(shi)控(kong)製(zhi)係(xi)統(tong)都(dou)必(bi)須(xu)解(jie)決(jue)數(shu)據(ju)傳(chuan)輸(shu)的(de)問(wen)題(ti)。在(zai)一(yi)個(ge)涉(she)及(ji)大(da)量(liang)數(shu)據(ju)傳(chuan)輸(shu)的(de)應(ying)用(yong)中(zhong),微(wei)控(kong)製(zhi)器(qi)能(neng)否(fou)既(ji)是(shi)網(wang)關(guan)又(you)是(shi)控(kong)製(zhi)器(qi)?
Atmel的DMA方案產品有一個外設DMA控製器 (PDC),能直接將每個SAM7X 外設連接到片上內存,並配有一個更高級的專門DMA,針對以太網MAC。由於 PDC 完全獨立於處理器運行,因此它沒有任何中斷的成本,並能大幅度降低數據傳輸所需的時鍾周期數。每個 SAM7X 外設都有兩條專用 PDC 通道,各用於接收和發送數據。每個 PDC 通道的用戶接口都集成在各外設的內存中,並有一個 32 位內存指針寄存器;一個 16 位傳輸計數寄存器;一個用於下一個存儲的 32 位內存指針寄存器和一個用於下一個傳輸的傳輸計數寄存器。外設通過收發信號觸發 PDC 傳輸。當第一個編程好的數據塊被傳輸後,對應的外設會產生一個傳輸結束中斷,第二個數據塊便會自動開始傳輸,而ARM處理器此時可並行處理第一個數據塊。這樣,就可以消除為更新處理器上DMA內存指針所帶來的實時中斷限製,對於維持外設上的高速數據傳輸來說,這是非常關鍵的。
在這個方案下,可以隨時讀取下一個數據傳輸的存儲位置和剩餘要傳輸的數據塊。PDC 有(you)一(yi)些(xie)專(zhuan)用(yong)的(de)狀(zhuang)態(tai)寄(ji)存(cun)器(qi),它(ta)們(men)顯(xian)示(shi)各(ge)個(ge)傳(chuan)輸(shu)通(tong)道(dao)是(shi)否(fou)激(ji)活(huo)。通(tong)過(guo)一(yi)些(xie)控(kong)製(zhi)位(wei),便(bian)可(ke)安(an)全(quan)地(di)讀(du)取(qu)指(zhi)針(zhen)和(he)計(ji)數(shu)寄(ji)存(cun)器(qi),而(er)不(bu)會(hui)出(chu)現(xian)兩(liang)次(ci)讀(du)數(shu)不(bu)同(tong)的(de)情(qing)況(kuang)。PDC將狀態標誌發送給在狀態寄存器中可見的那個外設。當該外設接收到一個外部字符,便會發送一個接收就緒的信號給PDC,而 PDC 便會請求訪問係統總線。當該請求獲得允許,PDC便開始讀取外設的接收保持寄存器,然後觸發一個內存寫操作。每次傳輸後,相關的PDC內存指針地址將增加,剩餘的傳輸數目將減少。當內存塊滿時,下一個內存塊的傳輸便會自動開始;或者會有一個信號傳送到外設,以停止傳輸。至於向外設發送數據,傳輸過程正好與此相反。如果在相同的外設上同時出現相同類型 (接收或發送) 的請求,請求的優先級別由外設的編號決定;當請求不是同時發生,則按請求出現的先後而處理。來 自接收方的請求先處理,然後處理發送方的請求。
SAM7X 結構中的 DMA 方案使其能同時充當網關和控製器,甚至在高數據速率下也能如此。
實時應用的支持
雖然許多 32 位係統廠商都努力在其微控製器上增加連通性,采用USB、以(yi)太(tai)網(wang)或(huo)其(qi)他(ta)協(xie)議(yi),但(dan)大(da)部(bu)分(fen)都(dou)不(bu)曾(zeng)解(jie)決(jue)實(shi)時(shi)應(ying)用(yong)的(de)問(wen)題(ti)。大(da)多(duo)數(shu)的(de)嵌(qian)入(ru)式(shi)控(kong)製(zhi)應(ying)用(yong)是(shi)確(que)定(ding)過(guo)程(cheng)式(shi)的(de),即(ji)指(zhi)令(ling)和(he)數(shu)據(ju)必(bi)須(xu)在(zai)一(yi)個(ge)可(ke)以(yi)準(zhun)確(que)預(yu)計(ji)的(de)時(shi)鍾(zhong)周(zhou)期(qi)內(nei)到(dao)達(da)正(zheng)確(que)的(de)地(di)方(fang)。這(zhe)是(shi)“實時”應用的本質所在。可惜,絕大多數 32 位控製器都不具備實時應用所要求的性能。
ARM結構最初是為了便攜式PC而er開kai發fa的de,其qi操cao作zuo係xi統tong管guan理li中zhong斷duan處chu理li和he製zhi定ding處chu理li的de優you先xian級ji別bie。但dan它ta從cong來lai不bu是shi麵mian向xiang確que定ding過guo程cheng式shi實shi時shi應ying用yong的de。為wei克ke服fu在zai外wai部bu非fei易yi失shi性xing內nei存cun中zhong存cun儲chu代dai碼ma導dao致zhi的de性xing能neng下xia降jiang,PC 處(chu)理(li)器(qi)在(zai)高(gao)速(su)緩(huan)存(cun)中(zhong)采(cai)用(yong)代(dai)碼(ma)遮(zhe)蔽(bi)技(ji)術(shu)。但(dan)當(dang)某(mou)一(yi)需(xu)要(yao)的(de)指(zhi)令(ling)代(dai)碼(ma)正(zheng)好(hao)不(bu)在(zai)高(gao)速(su)緩(huan)存(cun)中(zhong)時(shi),這(zhe)種(zhong)技(ji)術(shu)就(jiu)會(hui)導(dao)致(zhi)不(bu)可(ke)預(yu)見(jian)的(de)延(yan)遲(chi)。如(ru)果(guo)不(bu)用(yong)借(jie)助(zhu)操(cao)作(zuo)係(xi)統(tong)來(lai)實(shi)現(xian)外(wai)設(she)連(lian)接(jie),那(na)就(jiu)需(xu)要(yao)中(zhong)斷(duan)屏(ping)蔽(bi)和(he)額(e)外(wai)的(de)軟(ruan)件(jian)支(zhi)出(chu)。總(zong)之(zhi),這(zhe)種(zhong)使(shi) ARM 適合於 PC 應用的結構同時也使它不太適合實時應用。AT91SAM7 器件是ARM7微控製器中獨特的產品,配備了一整套支持實時應用的功能,包括一個有8個優先級別的中斷控製器、基於硬件的細致位操作、上電複位電路、單電源電壓、欠壓監測器和實時時鍾。
[page_break]
確定過程式處理
SAM7X 微控製器上的 25ns 高速非易失性閃存允許其在單周期內直接從閃存讀取指令,而無需代碼遮蔽,並能確保以確定過程式的方式完成指令處理。SAM7X可在不借助高速緩存的情況下以 38MIPS 的速度處理閃存的原始數據;而在處理片上SRAM的數據時速度可達50MIPS。
中斷控製
實時控製應用通常是由中斷驅動的應用,其特點是有多個中斷源,且對每個中斷都會有一個可預計的響應。ARM核結構采用了一個簡單的雙中斷機製;在zai該gai機ji製zhi中zhong,其qi中zhong一yi個ge中zhong斷duan負fu責ze處chu理li所suo有you非fei緊jin急ji的de中zhong斷duan任ren務wu,並bing沒mei有you硬ying件jian製zhi定ding優you先xian級ji別bie。這zhe在zai高gao度du互hu連lian的de嵌qian入ru式shi係xi統tong中zhong是shi不bu能neng接jie受shou的de,因yin為wei這zhe樣yang互hu連lian環huan境jing下xia的de高gao吞tun吐tu量liang通tong信xin接jie口kou要yao求qiu快kuai速su中zhong斷duan處chu理li與yu低di優you先xian級ji係xi統tong功gong能neng並bing行xing。Atmel 公司的AT91ARM7通過一套可獨立屏蔽的中斷向量源和一個有8個優先級的中斷控製器解決了這個問題。其基本的中斷處理程序永久駐留在SRAM中,負責判別各中斷源的優先級別。一旦需要,它便會執行一條指令,使用中斷號 (每一個中斷源均獲分配專用的中斷號) 把相應中斷服務程序的向量直接加載到程序計數器中。可惜的是,ARM7 結構沒有細致的位操作指令,因而要15條指令 (即要15個時鍾周期) 才能完成這些置位/複位操作。ARM7先用6個指令取消中斷,然後用9個指令執行RMW操作,完成複位,最後用6個指令重新激活中斷。這牽涉大量的編程、除錯調試和處理操作,尤其是當支持這些操作的指令來自8位或16位處理器時,工作量更加龐大。
細致位操作
在現今對成本敏感的應用中,節省代碼和數據空間是首要考慮的問題,因此能在I/O空間中對個別位字進行設置 (set) 和清除 (clear) 就最理想不過。如果不具備這種位操作的能力,則需要在目標的 I/O地址內執行一個讀、改、寫 (Read-Modify-Write, RMW) 操作;也就是說,將該 I/O 空間讀入 SRAM、修改目標位,然後將結果寫回I/O寄存器。當然,這很耗費閃存和SRAM等的係統資源,而且也增加功耗。位操作得以發揮優勢的另一種情況是激活和取消中斷。如果要利用 RMW操作來激活或取消某個中斷,你必須先取消所有中斷,接著進行 RMW操作來激活或取消特定的中斷,然後重新激活所有中斷。Atmel 公司已對 ARM7 結構進行了擴充,允許在 I/O 空間內設置和清除位字。每個外設都有一個“設置”控製寄存器和一個“清除”控製寄存器。這樣,就可用一個 6 個周期的加載/移動/存儲序列來處理所有中斷屏蔽以及位設置和清除操作,從而減少 60% 的處理開支和代碼。
單電源
隨著工藝技術的尺度越來越小,微控製器的核心電源的電壓範圍必須適當。在0.18微米工藝節點,核心電源一般在1.8V。然而,為了與傳統的8位係統兼容,32位微控製器必須由一個電壓範圍從 3.0V 到 3.6V 的單電源來供電。新的微控製器用一個片上調壓器產生核心部分和其他片上子係統所要求的1.8V電壓。具有這個帶外部連接的1.8V電(dian)源(yuan),能(neng)更(geng)好(hao)地(di)基(ji)於(yu)係(xi)統(tong)板(ban)提(ti)供(gong)的(de)功(gong)能(neng)來(lai)控(kong)製(zhi)各(ge)個(ge)功(gong)率(lv)源(yuan)。至(zhi)於(yu)使(shi)用(yong)這(zhe)個(ge)片(pian)上(shang)調(tiao)壓(ya)器(qi)還(hai)是(shi)使(shi)用(yong)具(ju)有(you)更(geng)高(gao)效(xiao)率(lv)或(huo)更(geng)低(di)待(dai)機(ji)功(gong)耗(hao)的(de)外(wai)接(jie)電(dian)源(yuan),可(ke)完(wan)全(quan)由(you)終(zhong)端(duan)用(yong)戶(hu)自(zi)行(xing)決(jue)定(ding)和(he)控(kong)製(zhi)。這(zhe)個(ge)調(tiao)壓(ya)器(qi)具(ju)有(you)在(zai)CPU低速 (500Hz 到1.5MHz) 時進入待機模式的特點,這可降低調壓器的功耗,使電流降到20mA。在這種情況下,最大輸出電流為1mA,足以驅動CPU和大多數外設,這有助於彌補32位微控製器較高的待機電流。
現今嵌入式係統逐步朝著嵌入式網絡發展,常常要與其它網絡聯網。為這樣的設計選擇一個微控製器需要同時考慮器件的互連能力、數據傳輸能力、安全性,且又不失實時應用處理所要求的監管和控製功能。微控製器供貨商正紛紛推出針對這類應用的32位微控製器。設計人員需要根據自己的特定係統來評估每一種產品。