《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 獨立于硬件技術的XC166單片程序優機的DSP化方法
獨立于硬件技術的XC166單片程序優機的DSP化方法
摘要: XC166單片機的指令流水線存在著不可避免的阻塞現象,MAC單元指令也一樣。盡管在硬件設計時已經采用了專用模塊來減少阻塞,但有些阻塞是不可避免的,從程序優化的角度來說,可以充分利用指令流水線阻塞現象,通過重排指令流水線上的指令,消除阻塞,以使得程序的運行時間縮短,從而達到優化的目的。
Abstract:
Key words :

   XC166單片機的指令流水線存在著不可避免的阻塞現象,MAC單元指令也一樣。盡管在硬件設計時已經采用了專用模塊來減少阻塞,但有些阻塞是不可避免的,從程序優化的角度來說,可以充分利用指令流水線阻塞現象,通過重排指令流水線上的指令,消除阻塞,以使得程序的運行時間縮短,從而達到優化的目的。

   通常DSP優化方法可以分為兩類:一類是與芯片相關的,另一類是與芯片無關的。與芯片無關的優化方法獨立于單片機硬件,適用于所有單片機及DSP處理器,下面根據使用XC166單片機的經驗總結一些優化DSP程序的方法。

1 通用優化方法

1.1 數據組處理

    數據組處理的基本思想是通過成組的處理數據,以節約每次調用處理子程序所需的附加指令。數據組處理可以在C語言或匯編語言程序中實現。一般而言,對于開發DSP程序,最常用的程序語言為C和匯編。下面分別介紹如何在C和匯編程序中使用數據組處理優化方法。

(1)C程序

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

單值處理及數據組處理示意圖

(2)匯編程序

    在匯編程序中實現數據組處理有多種方法,比如數組操作,數組讀入/寫出等。

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

程序

2、數組讀入寫出。這種方法是將多個短操作數合并為一個長操作數后進行讀入/寫出操作,如上面例子中的輸入/輸出部分。

1.2 數據存儲器交織

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

數據存儲器交織

 

1.3 循環展開

    循環展開是一種非常傳統的程序優化方法,可以用于所有程序優化中,循環展開的目的是通過重復循環中的程序,減少循環次數,從而減少循環判斷指令的執行次數,以此來降低程序執行所需的機器周期,下面舉一個例子來說明循環展開在XC164CS單片機中的應用。

程序

圖3為循環展開程序流程圖。

循環展開程序流程圖

1.4 指令流水線重排

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

2 與芯片相關的優化技術

2.1 XC166指令流水線

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

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

    第2級--取指令。根據轉移預測規則計算出下一條被取指令的指針。對于零機器周期轉移,轉移合并單元先預處理,并將檢測到的轉移與正在執行的指令結合起來。預取出的指令存在FIFO緩存器中,同時,下一條要執行的指令輸出FIFO緩存器,進入執行流水線。

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

    第4級--尋址。計算所有操作數地址,對于所有隱含訪問系統堆棧的指令,堆棧指針遞減或增加。

    第5級--存儲。所有需要的操作數被取出。

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

    第7級--寫回。所有外部操作數以及剩余的,在內部DPRAM空間內的操作器被寫回。定位在內部SRAM中的操作數進入寫回緩沖區。

下面給出一個具體例子:

程序

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

具體例子

2.2 數據相關性排除

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

下面舉一個例子:

程序

    另外一種數據相關性發生在間接尋址訪問內存時,XC166單片機中的地址產生單元使用推測原理,在地址譯碼前,數據的讀取路經將根據歷史記錄表中選出;在歷史記錄表中,每個GPR都有一個入口。這些入口記錄了用相應GPR所訪問的內存空間情況。如果這種預測發生錯誤,讀取操作必須重新開始。

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

程序

 

2.3 內存帶寬沖突排除

    如果在流水線上的指令在同一時間訪問同一內存,就會發生內存帶寬沖突,MAC單元的CoXXX指令是特別為實現DSP設計的。為了避免在DPRAM中發生帶寬沖突,CoXXX指令的其中一個操作數必須放在SRAM中,以保證在單個機器周期內執行MAC單元指令。例如:

程序

2.4 指令重排

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

這些指令包括:

◇使用長地址模式的指令;

◇使用間接尋址的指令,除JMPS和CALLI外;

◇所有MAC單元指令(CoXXX指令)。

    為了避免指令阻塞,在使用上述指令時,如有阻塞情況發生,應該重新重排指令,以消除延時,例如:

程序

3 結論

   用于英飛凌XC166單片機的DSP優化技術分為兩類:與硬件相關的優化技術和獨立于硬件的優化技術。獨立于硬件的優化技術也可以用于其他的單片機或專用數字信號處理器。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          国产精品久久久一区二区三区| 欧美精品首页| 最新国产の精品合集bt伙计| 欧美日韩岛国| 国产美女精品在线| 久久爱www久久做| 欧美亚洲视频在线看网址| 亚洲天堂视频在线观看| 久久久精品国产99久久精品芒果| 欧美日韩国产不卡在线看| 欧美激情第4页| 亚洲婷婷综合久久一本伊一区| 久久久在线视频| 欧美裸体一区二区三区| 在线观看欧美日本| 久久精品国产免费看久久精品| 1000精品久久久久久久久| 国产亚洲精品久久久| 欧美私人啪啪vps| 国内精品免费午夜毛片| 国产精品高清在线| 国产一区二区三区电影在线观看| 亚洲精品美女在线| 午夜精品久久久久久久蜜桃app| 久久综合网hezyo| 亚洲韩国青草视频| 欧美成人免费全部观看天天性色| 久久青青草综合| 久久久www成人免费无遮挡大片| 国产精品久久久久一区二区三区共| 国产欧美一区二区精品性| 一区二区激情小说| 蜜臀久久99精品久久久画质超高清| 国产亚洲成年网址在线观看| 精品二区久久| 国产欧美一区二区精品秋霞影院| 国产综合色产在线精品| 亚洲欧美日韩久久精品| 开元免费观看欧美电视剧网站| 国产伦精品一区二区三区视频黑人| 久久一区二区三区超碰国产精品| 亚洲尤物视频网| 亚洲国产高清一区二区三区| 久久福利一区| 亚洲电影免费观看高清| 欧美日韩国产片| 欧美精品一区二区三区在线播放| 久久精品夜色噜噜亚洲aⅴ| 欧美日韩中文字幕精品| 亚洲大片av| 18成人免费观看视频| 久久aⅴ国产紧身牛仔裤| 欧美日韩一区二区三区四区五区| 亚洲欧洲精品一区二区| 久久精品二区亚洲w码| 在线日韩av片| 欧美激情网站在线观看| 亚洲福利在线视频| 欧美激情一区二区三区成人| 久久久久国产精品一区| 国产午夜精品一区二区三区视频| 国产麻豆9l精品三级站| 国产精品国产三级国产普通话三级| 欧美性视频网站| 麻豆亚洲精品| 国产精品成人一区二区三区吃奶| 亚洲国产高清自拍| 久久久久久香蕉网| 一区二区免费在线视频| 国产婷婷色一区二区三区四区| 99国产成+人+综合+亚洲欧美| 在线日韩中文字幕| 亚洲综合电影| 国产精品美女在线| 久久人人爽人人| 国产精品毛片va一区二区三区| 亚洲靠逼com| 国产精品每日更新在线播放网址| 亚洲国产精彩中文乱码av在线播放| 国内自拍视频一区二区三区| 欧美精品久久久久a| 欧美在线免费看| 99ri日韩精品视频| 亚洲欧美日韩国产综合| 亚洲国产导航| 欧美电影免费观看高清| 国产精品啊v在线| 亚洲午夜一级| 欧美在线地址| 国产精品久久网站| 欧美三级电影一区| 亚洲香蕉伊综合在人在线视看| 欧美精品首页| 亚洲麻豆视频| 午夜精品久久一牛影视| 久久久女女女女999久久| 欧美14一18处毛片| 亚洲国产精品久久人人爱蜜臀| 在线欧美不卡| 鲁大师成人一区二区三区| 久久另类ts人妖一区二区| 国产曰批免费观看久久久| 久久琪琪电影院| 亚洲欧美中文在线视频| 欧美在线精品一区| 亚洲欧美精品在线观看| 久久精品一本久久99精品| 欧美乱妇高清无乱码| 中国成人黄色视屏| 国产精品国产自产拍高清av王其| 久久精品视频播放| 欧美视频免费看| 久久久久91| 久久久av水蜜桃| 韩国成人理伦片免费播放| 激情成人亚洲| 久久久久久九九九九| 免费观看成人| 久久一区二区精品| 日韩一级成人av| 欧美大片在线观看一区| 制服丝袜激情欧洲亚洲| 正在播放亚洲一区| 欧美日韩p片| 久久视频国产精品免费视频在线| 国产精品成人aaaaa网站| 夜夜嗨av一区二区三区网页| 国产精品v日韩精品v欧美精品网站| 国产中文一区二区三区| 国产一区二区三区免费不卡| 一色屋精品视频在线观看网站| 99re亚洲国产精品| 国产精品免费看片| 欧美一区二区三区另类| 久久精品99国产精品| 禁断一区二区三区在线| 欧美成人乱码一区二区三区| 国产精品99久久久久久宅男| 一区一区视频| 免费看黄裸体一级大秀欧美| 国产亚洲欧美日韩精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美高清视频免费观看| 日韩亚洲视频| 国产一区二区三区久久| 国产精品女主播| 国内精品视频久久| 欧美成人中文字幕| 国产精品美女www爽爽爽视频| 一区二区三区鲁丝不卡| 在线欧美亚洲| 国产精品国产亚洲精品看不卡15| 欧美在线看片| 欧美成人免费视频| 国产精品免费网站在线观看| 亚洲福利视频一区二区| 久久久久久久激情视频| 欧美日韩亚洲综合在线| 久久久国产午夜精品| 亚洲欧美日韩国产综合| 99在线精品免费视频九九视| 欧美午夜视频网站| 在线播放中文一区| 国产精品区一区二区三区| 亚洲欧洲日本mm| 国产美女精品在线| 在线日韩日本国产亚洲| 亚洲欧美日韩天堂一区二区| 欧美日韩在线一区二区| 久久久久久久尹人综合网亚洲| 欧美日本一区二区视频在线观看| 亚洲国产精品嫩草影院| 欧美有码视频| 每日更新成人在线视频| 国产精品国产三级国产普通话三级| 亚洲欧美日韩精品久久久久| 91久久线看在观草草青青| 国产精品高潮粉嫩av| 亚洲一区二区在线免费观看视频| 狠狠做深爱婷婷久久综合一区| 亚洲国产综合在线看不卡| 欧美午夜精品久久久久久超碰| 国产精品国产三级国产| 国产亚洲成精品久久| 欧美激情一区二区三区| 久久不见久久见免费视频1| 9人人澡人人爽人人精品| 久久精品国产精品亚洲| 亚洲精品在线视频| 午夜精品美女自拍福到在线| 亚洲国产成人精品久久| 亚洲视频福利| 亚洲日本久久| 国内成+人亚洲| 久久视频免费观看| 久久婷婷色综合| 欧美一区二区三区四区高清| 性一交一乱一区二区洋洋av| 亚洲综合色噜噜狠狠| 亚洲国产福利在线| 狠狠色综合日日| 欧美一区二区三区在线播放| 一区视频在线看| 香蕉久久国产| 在线免费观看日韩欧美| 久久影音先锋| 一区二区视频免费完整版观看| 国产精品久久婷婷六月丁香| 久久在线观看视频| 亚洲福利在线看| 香蕉成人伊视频在线观看| 欧美一区二区视频网站| 一本久久综合亚洲鲁鲁五月天| 久久久久久久综合日本| 欧美亚一区二区| 激情六月综合| 午夜精品一区二区三区四区| 国产欧美亚洲一区| 亚洲国产免费| 在线免费观看日韩欧美| 久久久久久精| 欧美日本高清一区| 日韩天堂在线观看| 亚洲国产一区二区视频| 亚洲视频免费在线| 狠狠色综合一区二区| 美国十次了思思久久精品导航| 久久亚洲免费| 久久午夜精品一区二区| 亚洲欧美日韩爽爽影院| 亚洲伦理在线观看| 国产一区二区三区电影在线观看| 久久国产精品99精品国产| 蜜桃av噜噜一区二区三区| 国产日韩欧美一区二区| 国产伦精品一区二区三区免费| 99视频在线精品国自产拍免费观看| 亚洲少妇最新在线视频| 国产精品久久久久99| 欧美三级午夜理伦三级中文幕| 亚洲一区在线观看视频| 影音先锋国产精品| 亚洲欧洲日产国产综合网| 久久狠狠一本精品综合网| 欧美黑人在线播放| 亚洲毛片在线| 国产日本欧美在线观看| 国产精品黄视频| 国产精品自拍在线| 久久精品亚洲一区二区三区浴池| 日韩午夜视频在线观看| 亚洲免费视频在线观看| 影音先锋亚洲视频| 久久国产精品免费一区| 欧美色图一区二区三区| 国产精品亚洲综合| 亚洲欧美在线磁力| 亚洲永久免费视频| 亚洲精品视频免费在线观看| 欧美肥婆在线| 国产午夜精品一区二区三区欧美| 欧美一区二区三区免费视| 欧美第一黄网免费网站| 浪潮色综合久久天堂| 国产目拍亚洲精品99久久精品| 国产精品毛片| 欧美成年人视频网站| 欧美日产一区二区三区在线观看| 狠狠色狠狠色综合日日91app| 国产女主播在线一区二区| 欧美精品一区二区三区蜜桃| 性欧美大战久久久久久久免费观看| 国产精品日韩电影| 欧美日韩亚洲一区二| 国产一区二区久久久| 欧美日韩国产三级| 另类国产ts人妖高潮视频| 欧美专区日韩专区| 国产欧美丝祙| 一区福利视频| 正在播放亚洲| 亚洲一区二区三区四区中文| 亚洲一区二区三区中文字幕| 亚洲激情网址| 一区二区三区在线视频观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产一区二区三区黄视频| 国产女优一区| 亚洲日韩中文字幕在线播放| 久久久久久有精品国产| 在线免费一区三区| 亚洲精品美女在线观看播放| 在线日韩av| 欧美性猛片xxxx免费看久爱| 国产真实精品久久二三区| 欧美特黄a级高清免费大片a级| 欧美在线视频观看| 国产麻豆9l精品三级站| 久久亚洲国产精品一区二区| 欧美一区二区黄色| 亚洲天堂成人| 国产精品青草综合久久久久99| 国产精品乱码一区二区三区| 欧美日韩久久精品| 国产欧美在线看| 另类亚洲自拍| 亚洲一区二区精品视频| 欧美专区日韩视频| 好看的日韩视频| 亚洲视频免费观看| 亚洲欧美精品一区| 日韩图片一区| 欧美成年网站| 国产精品福利网| 亚洲视频在线观看一区| 午夜精品久久久久久久白皮肤| 亚洲国产精品成人| 亚洲电影欧美电影有声小说| 久久综合狠狠综合久久综合88| 亚洲国产欧美另类丝袜| 一区二区三区四区五区精品| 久久精品视频在线看| 久久久久99精品国产片| 在线观看国产日韩| 欧美精品一区在线| 国产精品黄页免费高清在线观看| 亚洲一区二区三区视频| 亚洲一区三区视频在线观看|