<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于DSP/BIOS 的TI DSP 應(yīng)用程序框架設(shè)計(jì)

          基于DSP/BIOS 的TI DSP 應(yīng)用程序框架設(shè)計(jì)

          作者: 時(shí)間:2011-06-02 來源:網(wǎng)絡(luò) 收藏

            3 改進(jìn)的 ERF5

            隨著嵌入式系統(tǒng)復(fù)雜度的不斷提高,又限于 不適合進(jìn)行復(fù)雜系統(tǒng)的流程控制,所以近年來在系統(tǒng)中往往更多地讓 扮演著協(xié)處理器的角色,將其從繁重復(fù)雜的系統(tǒng)控制任務(wù)中解放出來,而整個(gè)系統(tǒng)的流程控制則交由一個(gè)通用處理器GPP 來完成,這使得DSP 和GPP 能夠優(yōu)勢互補(bǔ)。然而RF5 在多機(jī)通信方面存在很大缺陷,它不適用于多處理器系統(tǒng),尤其是DSP 作為多處理器系統(tǒng)中從設(shè)備的應(yīng)用環(huán)境。另外,RF5 所實(shí)現(xiàn)的是單一功能的多任務(wù)系統(tǒng),其多任務(wù)特性僅僅表現(xiàn)在將一個(gè)功能單一的任務(wù)拆分成輸入-處理-輸出三個(gè)分任務(wù)而已,并沒有實(shí)現(xiàn)真正的多功能多任務(wù)系統(tǒng),即一個(gè)任務(wù)就是一個(gè)獨(dú)立的信號處理功能。

            上述兩個(gè)方面的分析,我們完全有必要改進(jìn) RF5 以滿足多處理器的復(fù)雜信號處理系統(tǒng)的要求。本文所提出的ERF5 的系統(tǒng)框圖如圖2 所示,任務(wù)1、任務(wù)2、任務(wù)3 是系統(tǒng)中定義的三個(gè)任務(wù),它們以同等的優(yōu)先級被 任務(wù)調(diào)度器輪流調(diào)度。每個(gè)任務(wù)皆包含了輸入預(yù)處理、核心信號處理以及輸出后處理三個(gè)模塊,構(gòu)成功能完整且獨(dú)立的信號處理任務(wù),每個(gè)任務(wù)由單個(gè)或多個(gè)數(shù)據(jù)處理通道(Channel)組成,而每個(gè)通道又由一系列算法單元(Cell)構(gòu)成。多處理器系統(tǒng)中的GPP 通過DSP 運(yùn)行控制寄存器DSP_CNTL 來控制DSP 的任務(wù)執(zhí)行過程,而DSP 作為響應(yīng)會將其運(yùn)行狀態(tài)反應(yīng)在DSP 運(yùn)行狀態(tài)寄存器DSP_STAT 中??偟膩碚f,ERF5 從以下三個(gè)方面對RF5 進(jìn)行了改進(jìn):

            定義并實(shí)現(xiàn)了 DSP 與GPP 之間進(jìn)行通信的有效方式;給出了當(dāng) DSP 需要實(shí)現(xiàn)多套信號處理功能并且某一套信號處理任務(wù)的執(zhí)行完全受控于GPP 時(shí)的任務(wù)實(shí)現(xiàn);對 RF5 中不合理的任務(wù)拆分進(jìn)行了合并,減輕了由于 任務(wù)調(diào)度對系統(tǒng)性能的影響。

            圖 2 ERF5



          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();