《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 成功的嵌入式設計需要指令集之外的諸多因素
成功的嵌入式設計需要指令集之外的諸多因素
摘要: 當談到32 位微控制器時,基于ARM 的產品已經占據重要地位。那么,這會是故事的全部嗎?不見得,行業內最重要的公司之一,Microchip Technology,正全力推動其基于MIPS 架構的芯片。他們最新推出的產品在提醒我們,成功的嵌入式設計需要指令集之外的諸多因素。
Abstract:
Key words :

 當談到32 位微控制器時,基于ARM 的產品已經占據重要地位。那么,這會是故事的全部嗎?不見得,行業內最重要的公司之一,Microchip Technology,正全力推動其基于MIPS 架構的芯片。他們最新推出的產品在提醒我們,成功的嵌入式設計需要指令集之外的諸多因素。

在計算機歷史上,從實驗室走出過多少種不同的指令集架構?可能曾經有數百種架構取得過一些商業上的成功; 如果算上諸多博士論文中出現過的,數目可能會多達幾千種。拿流行時尚做比喻,計算機體系結構發展就好似女生裙擺的高度一般,經常來回變化。

曾經有一段時間它非常要緊—— 比如在匯編語言編程的時期。至于兼容性,至少在表面上它依舊是件重要的事情,特別是在電腦或視頻游戲方面(例如,有一些需要執行以前的二進制文件)。但實際上,嚴格的目標代碼兼容性對多數嵌入式設計來說已經不再是一個大問題。更多的問題是關于工具鏈的兼容性和代碼模塊的可用性,指令集本身已經不是問題之一。

隨著芯片不斷地集成系統功能,設計人員需要的是一個擁有全部所需存儲器、外設和膠合邏輯的芯片。并且這個芯片必須省電、有良好的工具和支持,以及合適的價格。

這并不是說在特定的應用當中,體系結構并沒有優劣之分。事實上,這個問題很有趣,看看那些當初為“計算機”設計的架構—— 如 ARM 和MIPS,不斷下沉,以更好地適應嵌入式“控制器”應用的需求。這些“計算機”架構最后都終于認識到要在嵌入式應用里面解決諸如代碼密度、低功耗、快速并確定的中斷響應等問題。

認識 PIC32

在 MCU 領域的競爭里,無疑MIPS 是在追趕ARM。但是,擁有像Microchip 這樣的重量級選手支持,差距正在縮小??纯葱碌腜IC32 5XX/6XX/7xx 系列產品,高度集成了以太網、USB 和CAN 應用。

我在以前的文章中(“MIPS for the Masses”,Circuit cellar 216 期,2008)介紹過PIC32的內核。擁有5 級流水線,性能相對較高(比如與ARM Cortex - M3 相比)。不過,這只是處理器內核級別的性能差異。比如Microchip PIC32 的性能為1.5 DMIPS / MHz,而Cortex - M3是1.25 DMIPS / MHz 的。在實際中,32 位微控制器的flash 存儲器訪問時間是性能瓶頸。如以80MHz 運行的PIC32 可能需要2 個等待周期。通常采用寬總線(128 位)、高速緩存和預取等技術來減輕flash 訪問的瓶頸問題。

或者,可以使用片內的RAM來達到0 等待周期。’5xx 系列包含64KB 的RAM,’6xx’和7xx 系列中的部分型號有多達128KB 的RAM。不過要記住,代碼和數據訪問之間的爭搶可能導致一些延遲。此外,256KB 或512KB 的flash 空間足夠用來放置你的代碼(加上額外12 KB 的啟動代碼空間)。

外設方面,這些新產品提供了完整的I/O(見圖1)。 ‘5xx/6xx/7xx 編號代表了大的接口功能:USB、CAN 和以太網。‘5xx 系列包含一個USB 2.0 和一個CAN(2.0b)模塊;‘6xx系列包含USB 模塊與一個10/100 以太網MAC。而‘7xx 系列集成了所有這些,包含USB、以太網和兩個CAN 模塊。

普通 I/O 方面,這些產品遵循了不同應用需求的趨勢。我們看到5 個16 位計數器/定時器,其中任何兩對可以組合成為32 位單元。由于封裝尺寸(有64 腳和100 腳可選)和引腳復用的限制,你能得到最多六個UART、四個SPI 以及五個I2C 接口。在模擬方面,有一個16通道多路復用器連接一個10 位1 MSPS 的ADC 和兩個模擬比較器。除了這些MCU 能力,另外還有8/16 位數據總線和16 位地址總線擴展功能,外加兩個片選。所有的數據流可以通過8個通用DMA通道控制,輔以4個專用DMA通道(''5XX 和''6XX 系列)或8個專用DMA通道(''7XX 系列)。

源自上世紀80 年代的MIPS 是RISC 方面“精簡”特性的杰出代表。當響應中斷時,它們可以要對PC 和狀態寄存器壓棧,不然的話就轉由軟件去處理。對這種極端簡約存在一些爭議,可能少了一些有用的東西??紤]到這一點,PIC32 系列包括一個全功能優先級/向量可編程的中斷控制器;以及一組替代寄存器組用于快速中斷響應和上下文切換。

另外,不要忽視那些可能導致嚴重預算問題的膠合邏輯,如看門狗定時器、低電壓檢測、電壓整流器、主時鐘/外設時鐘/實時時鐘等。這些功能的集成,使PIC32 系列成為真正適用于“控制”應用的芯片,有別于“計算機”芯片。

入門

跟以前一樣,Microchip 的芯片評估很容易,而且便宜。PIC32 以太網入門套件(見照片1)定價$72,提供一切你需要的部件。雖然名字為“以太網”入門套件,該套件配備了高端的''795 型號MCU,同時支持USB 功能。

該套件還包括配有一個“輕量級”GCC 編譯器的Microchip MPLAB IDE。文檔中關于“輕量級”編譯器的說明有點矛盾。“輕量級”版本編譯器暗示不支持先進的代碼優化,但是我拿到的版本顯然不是這樣,在下一節你將看到這一點?;蛟S實際上該工具包是所謂的“評估”版本,支持所有功能,但只有60 天有效期。

PIC32 采用的架構來源于“計算”,因此它非常適合管理面向PC 的以太網和USB 接口。讓我們看一些演示程序,你就會明白我的意思。

多年來Microchip 一直在為其小型的PIC 芯片提供部分網絡軟件棧,PIC32 做得更多,它提供了全功能、免費的BSD TCP/IP 網絡堆棧。包含所有的網絡服務、套接字等,以及這些常用的協議:DHCP、UDP、ICMP、ARR 等。''795 型芯片中有512KB 的片上flash,有充足的空間存儲一些漂亮的演示程序,讓我們瀏覽一下入門電路板(見照片2)。

USB 支持不錯,。OTG功能允許一個設備在USB 主、從設備之間動態切換。一個典型的應用案例是打印機,當連接到PC 時它是一個從設備,而當連接到相機時它成為主設備?,F在所有的USB 芯片似乎都有OTG 了,不過我自己從沒有遇到過需要以這種方式切換的情況。

不管 OTG 是否真正有用,它使得PIC32 能在更多的傳統領域中得到應用,無論是作為主設備或從設備。USB“嵌入式主設備”在使用中有一些限制,不像“標準主設備”如電腦,舉例來說PIC32 不提供VBUS 電源(100-500 mA),但是你可以在個人電腦的USB接口上找到這種電源——當然這完全可以理解。另外,速度限制也需要注意,,作為從設備時能夠“全速”(12 Mbps),而作為主設備時只能提供“低速”(1.5 Mbps)。

這個套件包含了一些實用的演示。其中一個演示讓該板子成為一個標準人機接口設備(HID)——比如鼠標。因為HID 驅動已經是標準,你可以把它直接插入PC 使用。另外,你可以把這個套件配置成USB 主設備,從而利用PIC32 不斷完善的FAT 文件管理軟件庫,有一些演示展示了如何訪問廣泛使用的USB 存儲器(見照片3)。

不過需要指出的是這個套件中沒有包含CAN 演示。因為我不懂也沒有實驗條件進行有意義的CAN 測試,如果你需要該功能,你需要自己來評估和結論。

優化的迷宮

結構體系進化的重要標志之一,曾經是編譯器的優化。您可能還記得有些人把“RISC”縮寫調侃為“Relegate the Impossible Stuff to the Compiler”,即“把不可能完成的任務丟給編譯器”。然而,在調試時,一個太過自我聰明的編譯器其問題也是顯而易見的。比如PIC32 的“C”編譯手冊有提到說,當調試經過優化的代碼時“可能偶爾會碰到令人驚訝的結果。”

例如,有些變量和代碼會消失,如果編譯器認為你其實并不需要它們。舉例說你聲明了一個變量,然后給它賦值一個常數,接著在某個計算時調用了這個變量。不要為找不到那個變量和賦值語句而抓狂,編譯器只是比你更聰明一點,它在計算中直接調用了常數。

當你在一個條件分支指令處點擊了單步執行,然后看到光標移動到了下一條指令處,這是否意味該條件分支的條件未被滿足呢?未必,請注意這是MIPS 架構的一個特性,即分支指令的下一條指令總是會被執行,當編譯器找不到合適的指令時會填充一條NOP 指令。你必須再執行一次單步操作,才能確認分支條件是否被滿足(在這種情況下,你會看到光標跳到分支目標處)或不滿足(光標跳轉到下一條順序指令)。更先進的“代碼移動”優化能夠導致更多的優化干預。請記住,有時指令可以被挪動很遠的距離,甚至超出你認為應在的循環之外。

不過,調試優化過的代碼也是可能的,尤其是你喜歡頭腦風暴的話(例如,在分支指令后跟一個分支指令會發生什么?)。通常缺省的編譯器優化只生成簡單的代碼,會完整保留你的意圖即使可能它效率底下。當調試時在斷點觸發處,,你可以放心地修改某個變量的值,而不用擔心編譯器會搗什么鬼(比如雖然你從源代碼中看不到,但一些賦值語句已經被挪動并執行了)。

需要緊記的是,編譯器優化設置(見照片4)能夠產生很大影響。我試著跑過一個USB主機演示程序,采用了如表1 所示的不同編譯器設置,你可以看到,不同設置下(速度/大小取向、循環展開,采取MIPS-16 的16 位代碼優化選項)生成的代碼大小相差能夠高達2倍。


保持簡潔

PIC32 在精簡MIPS 架構使其服務于嵌入式應用方面做得很好。比如,全部的活動功耗只有1mA/MHz 水平,從它提供的性能來看這是非常難得的。它們的批量價格也比較合理,特別考慮到那些完整的外設和存儲器配備。

然而競爭也非常激烈,像Cortex - M3、瑞薩SH(現在叫RX)、愛特梅爾的AVR32 以及飛思卡爾的ColdFire 等。這些競爭對手在行業里已經有很長的時間,它們的產品也具有很廣的覆蓋面,在高端產品上能提供跟PIC32類似的集成度和性能,同時還有許多入門級的簡單產品。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          欧美色综合网| 欧美激情一区二区三区不卡| 久久精品亚洲一区二区三区浴池| 免费一级欧美片在线播放| 亚洲福利视频三区| 蜜臀av一级做a爰片久久| 亚洲国产三级| 国产精品久久久久久久久动漫| 欧美午夜影院| 亚洲天堂网站在线观看视频| 在线一区免费观看| 久久综合九色综合欧美狠狠| 亚洲电影网站| 好吊妞这里只有精品| 一本大道久久精品懂色aⅴ| 欧美电影打屁股sp| 99香蕉国产精品偷在线观看| 国产精品资源| 欧美精品三级日韩久久| 欧美激情精品久久久久久久变态| 亚洲激情视频网站| 一区二区不卡在线视频 午夜欧美不卡'| 激情自拍一区| 欧美亚男人的天堂| 久久久91精品国产一区二区精品| 欧美日本三级| 亚洲欧美电影院| 销魂美女一区二区三区视频在线| 亚洲国产精品va| 国产精品高精视频免费| 久久久久久久久久看片| 老司机67194精品线观看| 国产精品高清免费在线观看| 欧美日韩影院| 日韩视频―中文字幕| 亚洲国产影院| 亚洲一区二区日本| 亚洲欧洲视频在线| 久久精彩视频| 激情欧美一区二区三区| 亚洲精品一二三区| 亚洲性线免费观看视频成熟| 国产精品激情电影| 狠狠久久亚洲欧美专区| 一本久久a久久精品亚洲| 蜜臀久久久99精品久久久久久| 最新成人av网站| 欧美色视频日本高清在线观看| 韩国成人理伦片免费播放| 欧美高清免费| 国产午夜精品视频| 在线亚洲观看| 亚洲一区三区视频在线观看| 久久久久久久999| 欧美不卡一卡二卡免费版| 亚洲高清不卡av| 欧美视频精品一区| 久久视频这里只有精品| 亚洲精品女人| 伊人久久大香线蕉av超碰演员| 小黄鸭精品aⅴ导航网站入口| 一区二区久久久久久| 一本色道久久88综合日韩精品| av成人国产| 国产性猛交xxxx免费看久久| 日韩亚洲一区二区| 99在线精品免费视频九九视| 久久午夜激情| 一区二区在线免费观看| 欧美日韩不卡一区| 久久综合亚洲社区| 好看不卡的中文字幕| 亚洲人成艺术| 亚洲性感激情| 亚洲人成在线影院| 欧美国产日韩a欧美在线观看| 久久免费黄色| 99pao成人国产永久免费视频| 国产拍揄自揄精品视频麻豆| 黄色精品一区| 国产精品电影网站| 亚洲欧美美女| 好看的av在线不卡观看| 欧美视频一区二区在线观看| 在线亚洲激情| 国产精品中文字幕在线观看| 欧美在线免费观看视频| 一区二区三区精密机械公司| 亚洲女人天堂成人av在线| 欧美一区二区免费观在线| 开元免费观看欧美电视剧网站| 欧美特黄一级大片| 欧美三级韩国三级日本三斤| 国产亚洲欧美日韩一区二区| 欧美日韩精品二区第二页| 正在播放亚洲| 国产日韩欧美一区二区三区四区| 久久综合伊人77777麻豆| 久久综合色天天久久综合图片| 亚洲一区免费视频| 国产精品久久久久久久app| 欧美久久在线| 一区二区三区高清在线观看| 欧美刺激午夜性久久久久久久| 亚洲乱码国产乱码精品精天堂| 国产一区二区三区av电影| 国产一区在线播放| 国产精品一区二区a| 免费看黄裸体一级大秀欧美| 欧美日本精品| 亚洲国产精品免费| 亚洲精品一区二区三区不| 亚洲一区二区在线播放| 中文在线资源观看视频网站免费不卡| 国产精品久久波多野结衣| 久久久精品五月天| 欧美大尺度在线观看| 一区二区三区精品国产| 亚洲国产精品成人va在线观看| 亚洲一区三区视频在线观看| 亚洲欧美电影院| 激情五月综合色婷婷一区二区| 1024日韩| 国产日韩久久| 亚洲黄一区二区| 牛牛精品成人免费视频| 国产精品二区在线观看| 久久精品国产久精国产爱| 一区久久精品| 欧美少妇一区二区| 欧美1区免费| 亚洲伦理网站| 亚洲线精品一区二区三区八戒| 欧美成人一区二区三区片免费| 国产一区二区三区久久精品| 久久午夜影视| 国产亚洲精品久久久久动| 性欧美videos另类喷潮| 一区二区免费在线播放| 一区二区三区视频观看| 欧美一区二区免费视频| 亚洲国产一区二区三区青草影视| 欧美在线地址| 国产精品看片资源| 欧美精品一区二区三区一线天视频| 亚洲精品久久久久中文字幕欢迎你| 欧美精品成人一区二区在线观看| 欧美日韩在线大尺度| 国产精品看片资源| 99re66热这里只有精品4| 欧美在线免费观看视频| 国产欧美一区二区精品仙草咪| 激情久久久久久| 欧美日韩综合精品| 亚洲黄一区二区三区| 国产精品毛片在线| 亚洲精品国产拍免费91在线| 亚洲男人天堂2024| 欧美四级剧情无删版影片| 欧美视频日韩| 蜜臀久久99精品久久久画质超高清| 亚洲激情电影在线| 国产欧美日韩综合精品二区| 亚洲美女电影在线| 久久久久久高潮国产精品视| 欧美午夜不卡| 国产精品免费久久久久久| 欧美午夜片在线观看| 一区二区三区欧美在线| 久久久久久久综合日本| 日韩视频在线观看国产| 在线亚洲伦理| 国产日产精品一区二区三区四区的观看方式| 国产精品国产精品| 欧美性片在线观看| 久久精品视频在线看| 国产精品成人一区二区三区夜夜夜| 亚洲电影在线免费观看| 国产精品天天看| 欧美日韩中文字幕| 国产亚洲综合性久久久影院| 欧美va日韩va| 99re亚洲国产精品| 欧美成人乱码一区二区三区| 久久国产一二区| 欧美亚洲午夜视频在线观看| 国产精品视频福利| 亚洲精品一区二区三区蜜桃久| 国产日韩欧美夫妻视频在线观看| 一区二区三区欧美在线| 久久国产精品久久久久久久久久| 国产精品www994| 亚洲日本aⅴ片在线观看香蕉| 亚洲欧洲日本国产| 亚洲一区二区3| 另类春色校园亚洲| 欧美精品日韩三级| 亚洲午夜三级在线| 亚洲国产日韩欧美在线99| 国产精品久久久久天堂| 国产精品毛片在线| 亚洲欧美日韩在线综合| 欧美日韩一区高清| 亚洲电影毛片| 欧美日韩国产成人| 亚洲成人在线视频网站| 中文一区二区在线观看| 国内一区二区三区在线视频| 亚洲欧美日韩视频二区| 欧美体内she精视频在线观看| 国产精品入口66mio| 先锋a资源在线看亚洲| 欧美日韩在线一区二区三区| 性欧美1819性猛交| 日韩午夜在线视频| 亚洲激情欧美激情| 欧美专区福利在线| 欧美亚洲网站| 国产精品久久久免费| 蜜臀av国产精品久久久久| 免费在线国产精品| 国内精品伊人久久久久av一坑| 国产精品美女久久久久av超清| 国产精品成人观看视频免费| 久久精品99国产精品日本| 亚洲美女少妇无套啪啪呻吟| 国产一区视频在线观看免费| 黄色成人在线免费| 韩国欧美国产1区| 亚洲午夜在线观看视频在线| 亚洲毛片一区二区| 久久免费黄色| 国产日韩精品在线| 欧美亚洲第一页| 亚洲三级毛片| 久久精品中文字幕免费mv| 亚洲精品一级| 欧美黑人国产人伦爽爽爽| 欧美日韩国产限制| 午夜精品久久久久久久99黑人| 国产精品99久久99久久久二8| 一区二区三区欧美成人| 99热免费精品| 国产精自产拍久久久久久蜜| 国产精品国产一区二区| 久久精品成人一区二区三区| 国产欧美视频一区二区| 亚洲香蕉网站| 午夜视频久久久| 亚洲国产婷婷香蕉久久久久久99| 国产一区二区三区高清在线观看| 久久av红桃一区二区小说| 亚洲影院色在线观看免费| 黄色成人免费观看| 亚洲经典自拍| 国产一区二区三区高清| 美日韩精品免费| 欧美激情四色| 亚洲欧美第一页| 亚洲一级二级| 欧美激情中文不卡| 国产精品国产亚洲精品看不卡15| 亚洲高清视频在线观看| 欧美日韩精品一区二区| 久久久免费av| 久久人人精品| 欧美日韩国产小视频在线观看| 欧美亚洲一区| 国产精品wwwwww| 欧美日韩精品| 一区二区高清视频| 国产日韩在线不卡| 欧美高清在线一区| 亚洲国产综合91精品麻豆| 欧美日韩美女在线观看| 免费成人美女女| 亚洲福利在线视频| 欧美日韩亚洲综合在线| 性做久久久久久免费观看欧美| 国产欧美精品在线观看| 久久久噜噜噜久久久| 国产精品久久婷婷六月丁香| 亚洲无毛电影| 久久久久青草大香线综合精品| 亚洲欧洲一区二区三区久久| 牛牛影视久久网| 久久久精彩视频| 午夜精品影院| 国产欧美激情| 99爱精品视频| 亚洲欧美另类久久久精品2019| 日韩视频在线免费| 在线精品国产欧美| 国产精品一区免费观看| 黄色日韩精品| 99re视频这里只有精品| 欧美好骚综合网| 永久免费毛片在线播放不卡| 久久亚洲色图| 国产日韩av一区二区| 亚洲国产精品视频一区| 99精品视频免费| 欧美亚洲综合另类| 国产一区二区高清不卡| 亚洲国产精品欧美一二99| 在线日韩视频| 蜜月aⅴ免费一区二区三区| 亚洲精选久久| 国产精品人人爽人人做我的可爱| 亚洲中字黄色| 中日韩午夜理伦电影免费| 国产一区视频网站| 亚洲欧美成aⅴ人在线观看| 欧美日韩视频| 一区二区三区三区在线| 国产精品捆绑调教| 亚洲视频你懂的| 久久久久国产精品一区三寸| 欧美成人激情视频免费观看| 欧美精品色一区二区三区| 亚洲区中文字幕| 国产女主播视频一区二区| 亚洲国产成人精品久久久国产成人一区| 亚洲欧美不卡| 老司机午夜免费精品视频| 黑人巨大精品欧美一区二区| 国产精品入口夜色视频大尺度| 日韩一级欧洲|