新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 采用硬件加速發揮MicroBlaze處理能力

        采用硬件加速發揮MicroBlaze處理能力

        —— 使MicroBlaze內核性能超越標準控制器或DSP
        作者:Karsten Trott博士 賽靈思(德國慕尼黑) 現場應用工程師 時間:2010-03-09 來源:電子產品世界 收藏

          是賽靈思()在嵌入式開發套件 (EDK) 中提供的兩款32位內核之一,是實現的靈活工具。圖1是的典型設計。該內核含有一個32位乘法器,但不含浮點單元()、桶式移位器或專用器。對公司Spartan 器件而言,默認系統含有區域優化的(采用三級流水線),但大多數客戶通常在開始時使用速度優化版(采用五級流水線)進行性能評估,其優點是小巧簡潔,易于擴展。

        本文引用地址:http://www.104case.com/article/106702.htm

          客戶針對這種設計所要求的兩個實際應用案例可說明MicroBlaze在方面的作用。本文以 Spartan 器件為重點,比較 解決方案和標準控制器內核,展現我們能夠達到的性價比。這一方法同樣適用于Virtex

          案例1:實施位反轉算法

          在第一個應用示例中,假定MicroBlaze的運行速度僅為50MHz。采用 Spartan-3或Spartan-6器件可輕松實現這一速度。諸如本地存儲器總線(指令和數據,LMB)以及處理器本機總線(PLB)等所有內部總線的運行速度均達到50MHz。為簡單起見,假定沒有連接外部DDR存儲器。

          現在假設客戶想要在這個CPU上實施位反轉算法。MicroBlaze自身沒有通過硬件直接提供這個功能。再假定每秒需要完成2萬次位反轉操作。

          要解決這個問題,大多數客戶首先會采用純軟件方案,因為這樣可輕松地實現想要的功能。而且如果性能足夠高,無需進行任何修改。

          為此,讓我們先從簡單的軟件算法出發,實施簡短精悍的解決方案。結果確實簡單、精巧而且容易理解,不過效率很低。
        unsigned int v=value;
        unsigned int r = v;
        int s = sizeof(v) * CHAR_BIT - 1;
        for (v >>= 1; v; v >>= 1)
        {
        r <<= 1;
        r |= v & 1;
        s--;
        }
        r <<= s;
        return r;

          這段程序運行相當順利,不過就算在專門針對速度優化的MicroBlaze(使用五級流水線)上運行處理一個32 位字的算法,也用了220個周期。要執行2萬次位反轉操作,在速度為50MHz的MicroBlaze上約需88ms。

          客戶試圖采用略有不同的方法來優化算法,但仍作為純軟件解決方案來實施。

          要進一步提升性能,就要采用純硬件解決方案,通過一種新的方式來讓硬件加速器充分發揮性能。


        上一頁 1 2 3 4 5 6 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 广昌县| 威远县| 巍山| 耒阳市| 秭归县| 五寨县| 新化县| 保山市| 柯坪县| 新巴尔虎右旗| 古浪县| 当阳市| 东乌珠穆沁旗| 健康| 合作市| 德令哈市| 紫阳县| 昭苏县| 冕宁县| 都昌县| 延边| 湾仔区| 白银市| 东莞市| 贞丰县| 北宁市| 临洮县| 青州市| 嘉峪关市| 泰和县| 马尔康县| 宁晋县| 马山县| 乌恰县| 大安市| 横峰县| 福鼎市| 凤台县| 舞阳县| 民权县| 喜德县|