百科解釋
哈佛結(jié)構(gòu) 哈佛結(jié)構(gòu)是一種將程序指令存儲(chǔ)和數(shù)據(jù)存儲(chǔ)分開(kāi)的存儲(chǔ)器結(jié)構(gòu)。中央處理器首先到程序指令存儲(chǔ)器中讀取程序指令內(nèi)容,解碼後得到數(shù)據(jù)地址,再到相應(yīng)的數(shù)據(jù)存儲(chǔ)器中讀取數(shù)據(jù),并進(jìn)行下一步的操作(通常是執(zhí)行)。程序指令存儲(chǔ)和數(shù)據(jù)存儲(chǔ)分開(kāi),可以使指令和數(shù)據(jù)有不同的數(shù)據(jù)寬度,如Microchip公司的PIC16芯片的程序指令是14位寬度,而數(shù)據(jù)是8位寬度。 哈佛結(jié)構(gòu)的微處理器通常具有較高的執(zhí)行效率。其程序指令和數(shù)據(jù)指令分開(kāi)組織和存儲(chǔ)的,執(zhí)行時(shí)可以預(yù)先讀取下一條指令。 目前使用哈佛結(jié)構(gòu)的中央處理器和微控制器有很多,除了上面提到的Microchip公司的PIC系列芯片,還有摩托羅拉公司的MC68系列、Zilog公司的Z8系列、ATMEL公司的AVR系列和安謀公司的ARM9、ARM10和ARM11。 哈佛結(jié)構(gòu)是指程序和數(shù)據(jù)空間獨(dú)立的體系結(jié)構(gòu), 目的是為了減輕程序運(yùn)行時(shí)的訪存瓶頸. 例如最常見(jiàn)的卷積運(yùn)算中, 一條指令同時(shí)取兩個(gè)操作數(shù), 在流水線處理時(shí), 同時(shí)還有一個(gè)取指操作, 如果程序和數(shù)據(jù)通過(guò)一條總線訪問(wèn), 取指和取數(shù)必會(huì)產(chǎn)生沖突, 而這對(duì)大運(yùn)算量的循環(huán)的執(zhí)行效率是很不利的. 哈佛結(jié)構(gòu)能基本上解決取指和取數(shù)的沖突問(wèn)題. 而對(duì)另一個(gè)操作數(shù)的訪問(wèn), 就只能采用Enhanced 哈佛結(jié)構(gòu)了, 例如像TI那樣,數(shù)據(jù)區(qū)再split, 并多一組總線. 或向AD 那樣, 采用指令cache, 指令區(qū)可存放一部分?jǐn)?shù)據(jù). 不過(guò)C6200 不了解, 那位大俠能解釋一下呢? 總之, 這個(gè)問(wèn)題對(duì)DSP 的性能很關(guān)鍵呢, 如果斑竹能總結(jié)一下就好了.
移動(dòng)通信網(wǎng) | 通信人才網(wǎng) | 更新日志 | 團(tuán)隊(duì)博客 | 免責(zé)聲明 | 關(guān)于詞典 | 幫助