資料介紹
在當今的嵌入式多媒體應用中,系統控制(通常的MCU作用)和信號處理(通常的DSP作用)之間的交互性不斷增強。現在推出的一種嵌入式媒體處理器能夠同時處理MCU和DSP的任務,從而將那些熟悉用MCU方式進行應用開發的C程式師帶入一個新的領域,其中對代碼和資料流程的智慧管理會顯著提高系統的性能。這對于採用“已經掌握”的編程方法和簡單的使用指令高速緩沖記憶體(cache, 簡稱快取記憶體)和資料快取記憶體來管理這些資料流程的程式師很有吸引力。然而,對媒體處理器的高性能直接記憶體訪問(DMA)能力應認真地考慮。因爲懂得在這些應用中對使用快取記憶體和DMA進行權衡將有助于更好地理解如何編程來優化系統。
記憶體結構——對記憶體管理的要求
當今的媒體處理器具有分級的記憶體結構,用來平衡幾種不同容量和性能等級的記憶體。通常,離核心處理器最近的記憶體(稱爲“1級”或“L1”記憶體)以全時鐘速率工作,通常支援單時鐘周期指令的運行 了高效地利用記憶體匯流排的帶寬,L1記憶體一般分爲指令段和資料段。通常,該記憶體被配置成SRAM或快取記憶體。對于那些許可權最高的應用,在一個單時鐘周期內就能夠訪問片內SRAM。對于要求較長代碼的系統,則可以提供附加的片內和片外記憶體——同時增加了等待時間。
這種層次結構本身作用有限 了適應僅配合低速外部記憶體的大部分應用,當今的高速處理器卻以很低的速度降級使用 了提高性能,程式師可以人工地選擇將關鍵代碼移入或移出內部SRAM。另外,將資料快取記憶體和指令快取記憶體加入這種結構使程式師能夠更方便地人工管理外部記憶體。快取記憶體減少了將指令和資料流程送入處理器內核的人工管理傳送。這樣程式師無需考慮如何把資料和指令流送入處理器內核,從而極大地簡化了編程模式。
指令記憶體管理——快取記憶體還是DMA?
對嵌入式媒體處理器市場的快速調查表明,核心處理器的速度大于或等于600 MHz。盡管這種性能可以開闢許多新應用,但只有在從內部L1記憶體中讀取代碼時才能達到這種最高速度。當然,理想嵌入式處理器可以具有無限容量的L1記憶體,但這不切實際。因此,程式師在爲其實際系統優化記憶體和資料流程時,必須考慮幾種可選方案以充分利用置于處理器內的L1記憶體。讓我們來考慮一下其中的一些方案。
第一種方案同時也是最直接的方案,目標應用代碼可以完全放入L1指令記憶體。對于這種情況,程式師只需將應用代碼直接映射到該記憶體空間,無需特殊操作。這就是爲什麼包含MCU和DSP兩種功能的媒體處理器必然在這種體系架構支援的代碼密度方面具有獨特優勢的原因。
第二種方案,採用一種快取記憶體機構允許程式師訪問更大容量、較低成本的外部記憶體。根據需要,這種快取記憶體可以作爲一種將代碼自動送入L1指令記憶體的方法。這種方法的主要優點是程式師無需管理代碼移入和移出快取記憶體。當執行線性代碼時,這種方法達到最好的效果。當執行非線性代碼時,快取記憶體線可能會被替換得太頻繁,以致于不能提高即時性能。
指令快取記憶體實際上具有兩個作用。第一,它以更有效率的方式從外部記憶體中預取指令。第二,由于快取記憶體一般使用某種“最近使用的指令”的演算法,所以那些用得最頻繁的指令往往就被保持在快取記憶體中。這樣做很有好處,因爲存在L1快取記憶體中的指令能夠在一個單時鐘周期內完成,就像指令在L1 SRAM中一樣。也就是說,如果該代碼一旦被取走,并且還沒有被覆蓋,即準備在下一個指令周期執行該代碼。
? ? ? ??
大多數嚴格的即時程式師一般不相信這種快取記憶體能帶來最佳的系統性能。他們的理由是如果一系列指令在需要執行的時候卻沒有在快取記憶體內,將導致影響性能。採用快取記憶體鎖定機構能彌補這個問題。一旦將關鍵的指令裝入快取記憶體,快取記憶體線就被鎖住,因此指令不會被覆蓋。這樣,程式師就能夠在快取記憶體中保持他們所需指令,并且使該快取記憶體機構管理次要指令。
最后一種方案,通過使用一個獨立于處理器內核的DMA通道將代碼移入或移出L1記憶體。當該處理器內核在記憶體的一個存儲塊運行時,該DMA將代碼送入下一個存儲塊去執行。這種方案通常被稱爲一種覆蓋技術。
雖然通過DMA將覆蓋代碼送入L1指令記憶體可以比快取記憶體方式提供更多的關鍵指令,但其代價是要增加程式師的工作量。換句話,程式師需要預先安排一種覆蓋代碼的方法和恰當地配置DMA通道。對于一種能夠做有價值的額外管理程式的詳細計劃,這種性能仍然會提高。
記憶體結構——對記憶體管理的要求
當今的媒體處理器具有分級的記憶體結構,用來平衡幾種不同容量和性能等級的記憶體。通常,離核心處理器最近的記憶體(稱爲“1級”或“L1”記憶體)以全時鐘速率工作,通常支援單時鐘周期指令的運行 了高效地利用記憶體匯流排的帶寬,L1記憶體一般分爲指令段和資料段。通常,該記憶體被配置成SRAM或快取記憶體。對于那些許可權最高的應用,在一個單時鐘周期內就能夠訪問片內SRAM。對于要求較長代碼的系統,則可以提供附加的片內和片外記憶體——同時增加了等待時間。
這種層次結構本身作用有限 了適應僅配合低速外部記憶體的大部分應用,當今的高速處理器卻以很低的速度降級使用 了提高性能,程式師可以人工地選擇將關鍵代碼移入或移出內部SRAM。另外,將資料快取記憶體和指令快取記憶體加入這種結構使程式師能夠更方便地人工管理外部記憶體。快取記憶體減少了將指令和資料流程送入處理器內核的人工管理傳送。這樣程式師無需考慮如何把資料和指令流送入處理器內核,從而極大地簡化了編程模式。
指令記憶體管理——快取記憶體還是DMA?
對嵌入式媒體處理器市場的快速調查表明,核心處理器的速度大于或等于600 MHz。盡管這種性能可以開闢許多新應用,但只有在從內部L1記憶體中讀取代碼時才能達到這種最高速度。當然,理想嵌入式處理器可以具有無限容量的L1記憶體,但這不切實際。因此,程式師在爲其實際系統優化記憶體和資料流程時,必須考慮幾種可選方案以充分利用置于處理器內的L1記憶體。讓我們來考慮一下其中的一些方案。
第一種方案同時也是最直接的方案,目標應用代碼可以完全放入L1指令記憶體。對于這種情況,程式師只需將應用代碼直接映射到該記憶體空間,無需特殊操作。這就是爲什麼包含MCU和DSP兩種功能的媒體處理器必然在這種體系架構支援的代碼密度方面具有獨特優勢的原因。
第二種方案,採用一種快取記憶體機構允許程式師訪問更大容量、較低成本的外部記憶體。根據需要,這種快取記憶體可以作爲一種將代碼自動送入L1指令記憶體的方法。這種方法的主要優點是程式師無需管理代碼移入和移出快取記憶體。當執行線性代碼時,這種方法達到最好的效果。當執行非線性代碼時,快取記憶體線可能會被替換得太頻繁,以致于不能提高即時性能。
指令快取記憶體實際上具有兩個作用。第一,它以更有效率的方式從外部記憶體中預取指令。第二,由于快取記憶體一般使用某種“最近使用的指令”的演算法,所以那些用得最頻繁的指令往往就被保持在快取記憶體中。這樣做很有好處,因爲存在L1快取記憶體中的指令能夠在一個單時鐘周期內完成,就像指令在L1 SRAM中一樣。也就是說,如果該代碼一旦被取走,并且還沒有被覆蓋,即準備在下一個指令周期執行該代碼。
? ? ? ??
大多數嚴格的即時程式師一般不相信這種快取記憶體能帶來最佳的系統性能。他們的理由是如果一系列指令在需要執行的時候卻沒有在快取記憶體內,將導致影響性能。採用快取記憶體鎖定機構能彌補這個問題。一旦將關鍵的指令裝入快取記憶體,快取記憶體線就被鎖住,因此指令不會被覆蓋。這樣,程式師就能夠在快取記憶體中保持他們所需指令,并且使該快取記憶體機構管理次要指令。
最后一種方案,通過使用一個獨立于處理器內核的DMA通道將代碼移入或移出L1記憶體。當該處理器內核在記憶體的一個存儲塊運行時,該DMA將代碼送入下一個存儲塊去執行。這種方案通常被稱爲一種覆蓋技術。
雖然通過DMA將覆蓋代碼送入L1指令記憶體可以比快取記憶體方式提供更多的關鍵指令,但其代價是要增加程式師的工作量。換句話,程式師需要預先安排一種覆蓋代碼的方法和恰當地配置DMA通道。對于一種能夠做有價值的額外管理程式的詳細計劃,這種性能仍然會提高。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 嵌入式MCU 程序和數據存儲空間分配理解-知識點
- 嵌入式系統常用指令集表格整理
- FPGA中嵌入式塊存儲器的設計
- 嵌入式Linux應用程序例程
- 嵌入式硬件系統教程之嵌入式存儲技術的詳細資料說明 14次下載
- TI的嵌入式分析技術使設備更加智能 13次下載
- 嵌入式圖形用戶界面系統設計分析 1次下載
- ARM嵌入式技術原理與應用_劉尚軍 0次下載
- ARM7在嵌入式應用中啟動程序的實現
- 基于ARM的嵌入式系統實驗分析
- 嵌入式實時程序設計中C/C++代碼的優化
- 嵌入式CPU指令Cache的設計與實現
- 嵌入式系統中的Flash設計與分析
- 嵌入式系統中的Flash 存儲管理
- 嵌入式系統中采樣限幅電路分析
- 嵌入式系統中的實時操作系統 517次閱讀
- 嵌入式系統中堆棧監控的作用 529次閱讀
- 基于嵌入式軟件的JNI技術應用解析 1106次閱讀
- 基于μC/OS嵌入式操作系統的嵌入式數據管理設計 1241次閱讀
- 什么是嵌入式技術 1w次閱讀
- 嵌入式設計須知: MCU如何在擴展的SDRAM上運行程序? 4220次閱讀
- 嵌入式處理器中cache數據不一致性的解決方法 3485次閱讀
- 嵌入式系統開發中驅動程序設計的5個方法盤點 3244次閱讀
- 隨機存儲器在嵌入式操作系統中的應用設計詳解 1433次閱讀
- 基于嵌入式數據庫的海量存儲技術解析 2819次閱讀
- 一文知道嵌入式存儲交換技術的可靠性如何增加 2015次閱讀
- 嵌入式行業發展狀況_嵌入式行業人才需求_嵌入式系統就業前景分析 2.4w次閱讀
- 嵌入式C實現延時程序的不同變量的區別 幾種Linux嵌入式開發環境的簡單介紹 1673次閱讀
- 嵌入式開發就業前景分析_嵌入式領域的職業發展方向 1.8w次閱讀
- 基于Nand Flash 存儲技術的嵌入式linux 系統設計 1606次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費下載
- 0.00 MB | 1489次下載 | 免費
- 2單片機典型實例介紹
- 18.19 MB | 91次下載 | 1 積分
- 3S7-200PLC編程實例詳細資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關電源原理及各功能電路詳解
- 0.38 MB | 9次下載 | 免費
- 6基于AT89C2051/4051單片機編程器的實驗
- 0.11 MB | 4次下載 | 免費
- 7基于單片機和 SG3525的程控開關電源設計
- 0.23 MB | 3次下載 | 免費
- 8基于單片機的紅外風扇遙控
- 0.23 MB | 3次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費
- 4LabView 8.0 專業版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費
- 5555集成電路應用800例(新編版)
- 0.00 MB | 33562次下載 | 免費
- 6接口電路圖大全
- 未知 | 30319次下載 | 免費
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費
- 8開關電源設計實例指南
- 未知 | 21539次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537791次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191183次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183277次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138039次下載 | 免費
評論
查看更多