《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > 基于XC166單片機(jī)的DSP優(yōu)化方法
基于XC166單片機(jī)的DSP優(yōu)化方法
摘要: 用于英飛凌XC166單片機(jī)的DSP優(yōu)化技術(shù)分為兩類:與硬件相關(guān)的優(yōu)化技術(shù)和獨(dú)立于硬件的優(yōu)化技術(shù)。獨(dú)立于硬件的優(yōu)化技術(shù)也可以用于其他的單片機(jī)或?qū)S脭?shù)字信號(hào)處理器。
Abstract:
Key words :

       引言

       與專用數(shù)字信號(hào)處理器(DSP)相比,英飛凌的C166單片機(jī)的DSP性能相當(dāng)差,為了提高C166單片機(jī)的DSP處理能力,英飛凌推出了新的16位單片機(jī)系列XC166,XC166系列單片機(jī)與C166單片機(jī)的最主要的區(qū)別在于,XC166中的CPU核加入了乘法-累加(MAC)單元,用于提高DSP的功能。MAC單元在XC166中是以一個(gè)算法處理單元出現(xiàn)的,類似于CPU中的算術(shù)邏輯(ALU)單元。這種結(jié)構(gòu)的優(yōu)點(diǎn)是可以保持XC166與C166的兼容性。

       MAC單元有自己的尋址模式和指令集,MAC指令集是專為開發(fā)DSP程序而設(shè)計(jì)的。獨(dú)立的尋址模式是為了保證MAS指令能在1個(gè)機(jī)器周期內(nèi)完成對(duì)2個(gè)操作數(shù)的間接尋址。與XC166中的一般尋址模式不同,MAC尋址模式有2個(gè)地址指針(IDX0/IDX1)及2對(duì)地址偏移指針(QX0/QX1,QR0/QR1)用于對(duì)雙操作數(shù)尋址。另外,單機(jī)器周期的MAC指令還要求MAC單元具有Harvard結(jié)構(gòu),也即代碼與數(shù)據(jù)獨(dú)立尋址。但英飛凌的16位單片機(jī)的存儲(chǔ)器地址都是線性的,采用的是Von Neumann結(jié)構(gòu),代碼與數(shù)據(jù)在一個(gè)線性存儲(chǔ)空間。為了在線性空間中實(shí)現(xiàn)Harvard結(jié)構(gòu),XC166專門把MAC指令的兩個(gè)操作數(shù)中的一個(gè)定義在DPRAM中,所以,在使用MAC單元時(shí)要特別注意,有些操作數(shù)只能存在DPRAM中,否則,指令無法正常運(yùn)行。目前,XC166系列單片機(jī)配有2KB的DPRAM,從地址0xF600到0xFDFF。

       由于硬件的要求,XC166單片機(jī)的指令流水線存在著不可避免的阻塞現(xiàn)象,MAC單元指令也一樣。盡管在硬件設(shè)計(jì)時(shí)已經(jīng)采用了專用模塊來減少阻塞,但有些阻塞是不可避免的,從程序優(yōu)化的角度來說,可以充分利用指令流水線阻塞現(xiàn)象,通過重排指令流水線上的指令,消除阻塞,以使得程序的運(yùn)行時(shí)間縮短,從而達(dá)到優(yōu)化的目的。

       通常DSP優(yōu)化方法可以分為兩類:一類是與芯片相關(guān)的,另一類是與芯片無關(guān)的。與芯片無關(guān)的優(yōu)化方法獨(dú)立于單片機(jī)硬件,適用于所有單片機(jī)及DSP處理器,下面根據(jù)使用XC166單片機(jī)的經(jīng)驗(yàn)總結(jié)一些優(yōu)化DSP程序的方法。

       1 通用優(yōu)化方法

       1.1 數(shù)據(jù)組處理

       數(shù)據(jù)組處理的基本思想是通過成組的處理數(shù)據(jù),以節(jié)約每次調(diào)用處理子程序所需的附加指令。數(shù)據(jù)組處理可以在C語(yǔ)言或匯編語(yǔ)言程序中實(shí)現(xiàn)。一般而言,對(duì)于開發(fā)DSP程序,最常用的程序語(yǔ)言為C和匯編。下面分別介紹如何在C和匯編程序中使用數(shù)據(jù)組處理優(yōu)化方法。

       (1)C程序

       在C環(huán)境中開發(fā)DSP程序,通常算法本身由匯編編寫,以便優(yōu)化實(shí)現(xiàn)。C主程序通過調(diào)用匯編實(shí)現(xiàn)的核心處理子程序來完成對(duì)數(shù)據(jù)的處理。核心處理子程序有兩種實(shí)現(xiàn)方法,一種是數(shù)組處理,另一種是單值處理,假設(shè)單值處理子程序的核心部分與數(shù)組處理子程序的核心部分所需機(jī)器周期相同,并且調(diào)用子程序的前期處理需M個(gè)機(jī)器周期,后期處理需要N個(gè)機(jī)器周期,如果子程序被調(diào)用K次,那么理想情況下,數(shù)據(jù)組處理可以節(jié)約(K-1)(M+N)個(gè)機(jī)器周期,如圖1所示。

                             單值處理子程序
 

 

       (2)匯編程序

       在匯編程序中實(shí)現(xiàn)數(shù)據(jù)組處理有多種方法,比如數(shù)組操作,數(shù)組讀入/寫出等。

       1、數(shù)組操作。數(shù)組操作是將多個(gè)不同的短操作數(shù)裝入一個(gè)長(zhǎng)位數(shù)的寄存器,然后進(jìn)行運(yùn)算操作。比如,1個(gè)16位的寄存器可以裝入2個(gè)8位的來自A/D轉(zhuǎn)換器的數(shù)據(jù)。下面舉例說明數(shù)據(jù)組處理在匯編程序中的應(yīng)用。

      數(shù)據(jù)組處理在匯編程序中的應(yīng)用

       2、數(shù)組讀入寫出。這種方法是將多個(gè)短操作數(shù)合并為一個(gè)長(zhǎng)操作數(shù)后進(jìn)行讀入/寫出操作,如上面例子中的輸入/輸出部分。

       1.2 數(shù)據(jù)存儲(chǔ)器交織 

       數(shù)據(jù)存儲(chǔ)器交織的目的是通過重新排列數(shù)據(jù)在存儲(chǔ)器中的位置,以使得程序讀寫數(shù)據(jù)的時(shí)間最短,比如有2個(gè)8位的復(fù)數(shù)x和y,一般情況下,復(fù)數(shù)將按下列順序存入內(nèi)存:real(x),image(x),real(y),image(y)。但如果想使得讀取復(fù)數(shù)的實(shí)部更容易,可以把數(shù)據(jù)重新排列如下:real(x),real(y),image(x),image(y),如圖2所示。

 

                          數(shù)據(jù)存儲(chǔ)器交織
 

       1.3 循環(huán)展開

       循環(huán)展開是一種非常傳統(tǒng)的程序優(yōu)化方法,可以用于所有程序優(yōu)化中,循環(huán)展開的目的是通過重復(fù)循環(huán)中的程序,減少循環(huán)次數(shù),從而減少循環(huán)判斷指令的執(zhí)行次數(shù),以此來降低程序執(zhí)行所需的機(jī)器周期,下面舉一個(gè)例子來說明循環(huán)展開在XC164CS單片機(jī)中的應(yīng)用。 

 循環(huán)展開在XC164CS單片機(jī)中的應(yīng)用

微循環(huán)展開程序流程圖
 

       1.4 指令流水線重排

 

       指令流水線重排的意思是通過軟件程序中的指令重排來改變指令流水線,以此來排除由于硬件引起的指令堵塞,從而加快程序的運(yùn)行時(shí)間。這種優(yōu)化操作通常用在匯編程序中,指令流水線重排是一個(gè)一般的優(yōu)化原理,把這個(gè)原理用于不同類型的單片機(jī)可以導(dǎo)出不同的與單片機(jī)硬件相關(guān)的優(yōu)化方法。下面介紹的基于XC166單片機(jī)的優(yōu)化方法主要是應(yīng)用這個(gè)優(yōu)化原理得到的。

       2 與芯片相關(guān)的優(yōu)化技術(shù)

       2.1 XC166指令流水線

       XC166單片機(jī)指令流水線共有7級(jí),前兩級(jí)為取指令流水線,后5級(jí)為執(zhí)行流水線,所有指令都必須經(jīng)過5級(jí)執(zhí)行流水線的每一級(jí)。

       第1級(jí)--指令預(yù)取。這一級(jí)根據(jù)預(yù)測(cè)順序,把指令從程序管理單元(PMU)取出,取出的指令在跳轉(zhuǎn)檢測(cè)單元進(jìn)行前期處理,以檢測(cè)是否有跳轉(zhuǎn),預(yù)測(cè)邏輯決定是否接收轉(zhuǎn)移。

       第2級(jí)--取指令。根據(jù)轉(zhuǎn)移預(yù)測(cè)規(guī)則計(jì)算出下一條被取指令的指針。對(duì)于零機(jī)器周期轉(zhuǎn)移,轉(zhuǎn)移合并單元先預(yù)處理,并將檢測(cè)到的轉(zhuǎn)移與正在執(zhí)行的指令結(jié)合起來。預(yù)取出的指令存在FIFO緩存器中,同時(shí),下一條要執(zhí)行的指令輸出FIFO緩存器,進(jìn)入執(zhí)行流水線。

       第3級(jí)--譯碼。指令被譯碼,如需要,在間接尋址模式中,寄存器文件將被訪問,以讀取通用寄存器GPR。

       第4級(jí)--尋址。計(jì)算所有操作數(shù)地址,對(duì)于所有隱含訪問系統(tǒng)堆棧的指令,堆棧指針遞減或增加。

       第5級(jí)--存儲(chǔ)。所有需要的操作數(shù)被取出。

       第6級(jí)--執(zhí)行。使用已取出的操作數(shù)進(jìn)行MAC單元操作。對(duì)于非MAC單元指令,在這一級(jí)中,指令將由算術(shù)邏輯單元(ALU)執(zhí)行。條件標(biāo)志被更新,執(zhí)行所有直接對(duì)CPU特殊功能寄存器CPU_SFRs進(jìn)行寫操作的指令,在間接尋址時(shí),作為地址指針的GPRs自動(dòng)遞減或增加。

 

       第7級(jí)--寫回。所有外部操作數(shù)以及剩余的,在內(nèi)部DPRAM空間內(nèi)的操作器被寫回。定位在內(nèi)部SRAM中的操作數(shù)進(jìn)入寫回緩沖區(qū)。

       下面給出一個(gè)具體例子:
     具體例子

        指令流水線
       上面程序的指令流水線如表1所列,(Tn表示機(jī)器周期) 

       2.2 數(shù)據(jù)相關(guān)性排除

       在XC166的CPU中,由于指令流水線的設(shè)計(jì)要求,在使用通用寄存器(GPRs)的指令之間存在一些數(shù)據(jù)相互依賴的情況,盡管XC166單片機(jī)已經(jīng)使用了專用硬件來檢測(cè)及解決數(shù)據(jù)相關(guān)性,但仍然有一些不可避免的數(shù)據(jù)相關(guān)性。在編程時(shí),可以充分利用數(shù)據(jù)相關(guān)性來達(dá)到程序優(yōu)化的目的,比如,在用GPR作為間接尋址指針時(shí),如果PGR中的地址值被改變,間接尋址操作必須等待2個(gè)機(jī)器指令周期后,才能使用GPR作為地址指針尋址。在這種情況下,可以在這2個(gè)等待機(jī)器周期內(nèi)插入2條其他單機(jī)器周期指令,充分利用這2個(gè)周期的等待時(shí)間以便程序更優(yōu)化。

       下面舉一個(gè)例子: 

     例子

 

       另外一種數(shù)據(jù)相關(guān)性發(fā)生在間接尋址訪問內(nèi)存時(shí),XC166單片機(jī)中的地址產(chǎn)生單元使用推測(cè)原理,在地址譯碼前,數(shù)據(jù)的讀取路經(jīng)將根據(jù)歷史記錄表中選出;在歷史記錄表中,每個(gè)GPR都有一個(gè)入口。這些入口記錄了用相應(yīng)GPR所訪問的內(nèi)存空間情況。如果這種預(yù)測(cè)發(fā)生錯(cuò)誤,讀取操作必須重新開始。

       因此,如果用GPR作為間接尋址,GPR最好能指向相同內(nèi)存空間。如果更新后的GPR指向不同內(nèi)存空間,下一個(gè)操作將出現(xiàn)訪問錯(cuò)誤,讀操作必須重復(fù),這就產(chǎn)生了指令流水線堵塞。例如:

      匯編程序

       2.3 內(nèi)存帶寬沖突排除

       如果在流水線上的指令在同一時(shí)間訪問同一內(nèi)存,就會(huì)發(fā)生內(nèi)存帶寬沖突,MAC單元的CoXXX指令是特別為實(shí)現(xiàn)DSP設(shè)計(jì)的。為了避免在DPRAM中發(fā)生帶寬沖突,CoXXX指令的其中一個(gè)操作數(shù)必須放在SRAM中,以保證在單個(gè)機(jī)器周期內(nèi)執(zhí)行MAC單元指令。例如:

     內(nèi)存帶寬沖突排除

       2.4 指令重排

       在用MAC單元指令編程時(shí),經(jīng)常要改變MAC單元的特殊功能寄存器,比如IDX0,IDX1、QX0、QX1、QR0以及QR1等,在XC166單片機(jī)中,有一些指令將會(huì)阻塞在譯碼階段,如果這些指令正好在一條修改特殊功能寄存器(SFR)指令之后執(zhí)行,這種阻塞將引起3個(gè)機(jī)器周期的延時(shí)。

       這些指令包括:

       ◇使用長(zhǎng)地址模式的指令;
       ◇使用間接尋址的指令,除JMPS和CALLI外; 
       ◇所有MAC單元指令(CoXXX指令)。 

       為了避免指令阻塞,在使用上述指令時(shí),如有阻塞情況發(fā)生,應(yīng)該重新重排指令,以消除延時(shí),例如:

      指令重排

       3 結(jié)論

       用于英飛凌XC166單片機(jī)的DSP優(yōu)化技術(shù)分為兩類:與硬件相關(guān)的優(yōu)化技術(shù)和獨(dú)立于硬件的優(yōu)化技術(shù)。獨(dú)立于硬件的優(yōu)化技術(shù)也可以用于其他的單片機(jī)或?qū)S脭?shù)字信號(hào)處理器。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲网站啪啪| 亚洲人被黑人高潮完整版| 伊人成人网在线看| 国产欧美日韩视频一区二区三区 | 欧美一区二区三区久久精品茉莉花 | 亚洲欧美韩国| 亚洲一区三区在线观看| 一区二区三区欧美在线| 99国产精品视频免费观看| 日韩天堂在线观看| 一本色道久久综合亚洲精品婷婷| 日韩一区二区久久| av72成人在线| 99爱精品视频| 亚洲午夜女主播在线直播| 亚洲一卡久久| 午夜一区不卡| 久久激情视频久久| 亚洲国产成人一区| 亚洲激情视频在线| 日韩视频专区| 一区二区三区精品视频| 亚洲综合三区| 欧美专区在线播放| 久久久久久亚洲精品杨幂换脸| 久久久综合香蕉尹人综合网| 免费不卡视频| 欧美日韩黄色大片| 国产精品丝袜白浆摸在线| 国产午夜精品久久久| 国产自产精品| 亚洲国产日本| 亚洲图片在线| 欧美在线免费看| 亚洲国产综合视频在线观看| 99日韩精品| 午夜精品区一区二区三| 久久久久久日产精品| 欧美激情视频在线播放| 国产精品99一区| 国产一区二区三区成人欧美日韩在线观看 | 久久久久久999| 美女成人午夜| 欧美精品激情在线| 欧美视频在线观看免费网址| 国产精品免费看久久久香蕉| 国产性天天综合网| 亚洲国产精品一区二区尤物区| 99国内精品| 欧美亚洲综合在线| 亚洲乱码久久| 午夜一区二区三区在线观看| 久久夜色精品国产欧美乱极品| 欧美成人亚洲| 国产精品毛片| 伊人成年综合电影网| 亚洲最新中文字幕| 欧美亚洲综合网| 日韩一级黄色大片| 欧美一区二区三区免费视| 欧美va亚洲va香蕉在线| 欧美手机在线| 激情另类综合| 夜夜嗨一区二区| 性8sex亚洲区入口| 夜久久久久久| 久久久久久久综合狠狠综合| 欧美日韩国产成人在线91| 国产精品一区免费在线观看| 亚洲第一二三四五区| 亚洲特级毛片| 亚洲免费观看高清完整版在线观看熊 | 欧美在线视频一区| 一区二区三区精品国产| 久久国产精品久久国产精品| 欧美成人久久| 国产视频自拍一区| 亚洲精选在线观看| 久久精品国产亚洲aⅴ| 亚洲午夜国产成人av电影男同| 久久久一二三| 国产精品五月天| 亚洲三级免费电影| 亚洲电影一级黄| 欧美有码在线观看视频| 欧美国产精品中文字幕| 国产一区二区精品久久91| 99pao成人国产永久免费视频| 亚洲国产精品成人综合色在线婷婷| 亚洲在线电影| 欧美日韩八区| 在线成人激情| 欧美在线播放高清精品| 亚洲欧美日韩另类| 欧美精品三级日韩久久| 在线观看亚洲a| 久久成人国产精品| 午夜视频久久久| 欧美日韩国产一级片| 国精产品99永久一区一区| 亚洲欧美日本在线| 亚洲欧美综合精品久久成人 | 亚洲精品三级| 亚洲国产小视频在线观看| 欧美影院在线播放| 国产精品爱啪在线线免费观看| 136国产福利精品导航网址应用| 亚洲欧美另类在线观看| 亚洲小说欧美另类社区| 免费观看久久久4p| 精品不卡一区二区三区| 久久国产精品亚洲va麻豆| 久久久久久一区二区三区| 国产亚洲va综合人人澡精品| 亚洲女人天堂av| 欧美亚洲免费| 国产欧美日韩另类视频免费观看| 亚洲欧美日韩久久精品 | 久久精品国产999大香线蕉| 国产精品日韩| 亚洲免费影视第一页| 亚洲一区二区欧美| 国产精品久久久久一区| 一区二区三区国产精华| 亚洲一区视频| 国产精品一区二区久久国产| 9久re热视频在线精品| 亚洲一区二区在线看| 欧美午夜精品久久久久免费视 | 午夜伦理片一区| 国产精品日韩欧美大师| 亚洲女性裸体视频| 久久精品综合| 在线看片成人| 日韩网站在线观看| 欧美视频中文在线看 | 欧美天堂亚洲电影院在线观看| 亚洲人成网站777色婷婷| 宅男噜噜噜66一区二区66| 欧美日韩理论| 亚洲一区在线视频| 欧美一区激情| 精品成人一区二区三区| 日韩视频永久免费观看| 欧美性事免费在线观看| 亚洲一区制服诱惑| 久久久精品999| 亚洲国产婷婷香蕉久久久久久| av成人手机在线| 国产精品久久影院| 性伦欧美刺激片在线观看| 亚洲精选91| 欧美成人有码| 亚洲视频一区在线| 久久国产欧美| 亚洲国产精品黑人久久久| 亚洲视频专区在线| 国产欧美一区二区精品性| 午夜激情综合网| 午夜精品久久久久久久久久久久 | 美女精品在线| 亚洲精品乱码久久久久久久久| 亚洲小说春色综合另类电影| 国产专区综合网| 一区二区三区国产盗摄| 国产裸体写真av一区二区| 91久久久亚洲精品| 欧美日韩亚洲一区二区三区| 9l视频自拍蝌蚪9l视频成人| 国产精品女人网站| 亚洲高清av在线| 国产精品jizz在线观看美国| 亚洲一区免费观看| 欧美a级理论片| 亚洲欧美视频在线观看视频| 欧美黄色网络| 亚洲欧美在线免费| 欧美激情第10页| 小处雏高清一区二区三区| 欧美第一黄色网| 亚洲一级在线观看| 欧美高清视频免费观看| 午夜精品国产| 欧美日韩在线播| 亚洲激情欧美| 国产麻豆9l精品三级站| 99在线热播精品免费99热| 国外成人在线| 午夜视频在线观看一区| 亚洲国内自拍| 久久人人爽爽爽人久久久| 一区二区三区蜜桃网| 欧美a级一区二区| 午夜视频一区二区| 欧美日韩免费高清一区色橹橹| 久久精品导航| 国产精品美女久久久免费| 日韩午夜高潮| 一区二区三区中文在线观看| 亚洲欧美日韩精品久久|