《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于XC166單片機的DSP優化方法
基于XC166單片機的DSP優化方法
摘要: 用于英飛凌XC166單片機的DSP優化技術分為兩類:與硬件相關的優化技術和獨立于硬件的優化技術。獨立于硬件的優化技術也可以用于其他的單片機或專用數字信號處理器。
Abstract:
Key words :

       引言

       與專用數字信號處理器(DSP)相比,英飛凌的C166單片機的DSP性能相當差,為了提高C166單片機的DSP處理能力,英飛凌推出了新的16位單片機系列XC166,XC166系列單片機與C166單片機的最主要的區別在于,XC166中的CPU核加入了乘法-累加(MAC)單元,用于提高DSP的功能。MAC單元在XC166中是以一個算法處理單元出現的,類似于CPU中的算術邏輯(ALU)單元。這種結構的優點是可以保持XC166與C166的兼容性。

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

       由于硬件的要求,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單片機中的應用。 

 循環展開在XC164CS單片機中的應用

微循環展開程序流程圖
 

       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>
          国产乱码精品一区二区三区忘忧草| 午夜精品视频在线观看一区二区| 亚洲一区二区三区在线看| 欧美黄色影院| 国产一区二区三区高清| 国产精品丝袜久久久久久app| 亚洲在线视频一区| 91久久精品网| 国产精品视频一区二区三区| 亚洲天堂av在线免费观看| 国产精品毛片va一区二区三区| 国产毛片精品国产一区二区三区| 亚洲麻豆av| 亚洲国产裸拍裸体视频在线观看乱了中文| 国产一区亚洲一区| 欧美一级片在线播放| 久久视频国产精品免费视频在线| 狠久久av成人天堂| 亚洲第一中文字幕在线观看| 国产精品羞羞答答xxdd| 亚洲一区日韩| 亚洲国产另类久久久精品极度| 国产欧美日韩一区| 欧美日韩1区2区| 欧美激情自拍| 国产一区二区三区在线观看网站| 欧美日韩中国免费专区在线看| 亚洲高清在线精品| 国产午夜精品麻豆| 精品51国产黑色丝袜高跟鞋| 一区二区三区精品视频在线观看| 国内自拍亚洲| 99伊人成综合| 国产精品普通话对白| 亚洲男女自偷自拍图片另类| 黄色成人在线网址| 欧美激情亚洲精品| 香蕉乱码成人久久天堂爱免费| 毛片基地黄久久久久久天堂| 国产精品中文字幕欧美| 99re在线精品| 亚洲日本理论电影| 欧美高清一区二区| 欧美色偷偷大香| 欧美日韩不卡视频| 亚洲啪啪91| 美女尤物久久精品| 亚洲欧美综合国产精品一区| 欧美亚洲尤物久久| 亚洲国产精品成人综合色在线婷婷| 欧美性感一类影片在线播放| 美女网站在线免费欧美精品| 久久久久综合一区二区三区| 亚洲欧洲午夜| 国产精品免费aⅴ片在线观看| 欧美精品一区二区视频| 亚洲精品日韩在线观看| 欧美精品在线播放| 亚洲最新视频在线播放| 亚洲欧美国内爽妇网| 欧美在线免费视屏| 亚洲三级电影在线观看| 亚洲国产精品成人精品| 亚洲老板91色精品久久| 亚洲精品国产精品国自产观看浪潮| 久久久久综合网| 激情综合激情| 美日韩丰满少妇在线观看| 亚洲线精品一区二区三区八戒| 亚洲日本欧美日韩高观看| 欧美裸体一区二区三区| 久久精品日韩| 国产一区二区三区高清| 在线成人av网站| 欧美刺激性大交免费视频| 噜噜噜久久亚洲精品国产品小说| 亚洲综合精品四区| 欧美中文在线观看| 久久爱91午夜羞羞| 在线一区二区三区四区| 亚洲午夜一级| 欧美国产第二页| 精品成人国产在线观看男人呻吟| 久热精品视频在线| 黄色影院成人| 欧美激情aⅴ一区二区三区| 欧美三级资源在线| 亚洲一区视频| 欧美高清hd18日本| 国产精品高潮粉嫩av| 久久精品动漫| 国产精品久久久久免费a∨大胸| 国产日韩视频一区二区三区| 一区二区三区高清不卡| 欧美金8天国| 亚洲网站在线播放| 国产精品免费网站| 黄色成人在线免费| 欧美日本在线视频| 国产一区二区三区在线观看视频| 欧美精品激情| 欧美日韩在线直播| 亚洲片区在线| 国产精品免费一区豆花| 国产精品视频免费一区| 欧美日本一区二区视频在线观看| 亚洲裸体在线观看| 国产精品捆绑调教| 亚洲影视在线| 国产精品久久久| 美女亚洲精品| 国产欧美一区二区三区久久| 亚洲国产精选| 日韩一级精品| 国产欧美一二三区| 亚洲毛片在线免费观看| 亚洲国产美女精品久久久久∴| 国产日韩一区二区| 欧美成人午夜视频| 日韩午夜中文字幕| 国产欧美日韩中文字幕在线| 亚洲大片一区二区三区| 欧美日本一区二区视频在线观看| 蜜桃av一区二区在线观看| 久久久久久91香蕉国产| 这里只有精品视频在线| 亚洲福利视频免费观看| 欧美精品网站| 国产精品中文字幕欧美| 国产一区二区成人| 久久精品中文| 欧美91大片| 国产亚洲激情视频在线| 国内精品久久久久影院色| 91久久久久久国产精品| 亚洲欧美日韩在线| 欧美日韩一区二| 亚洲欧美大片| 欧美日韩精品一区二区三区四区| 久久亚洲美女| 国产亚洲欧美一区二区| 亚洲一区二区动漫| 欧美日韩在线播放一区二区| 欧美电影免费观看高清完整版| 韩国av一区| 欧美日本一区二区高清播放视频| 亚洲高清电影| 欧美三日本三级少妇三2023| 欧美午夜不卡在线观看免费| 亚洲日韩中文字幕在线播放| 久久久久久日产精品| 国产精品白丝av嫩草影院| 激情成人在线视频| 国产亚洲精品久久久久久| 国产一区二区三区在线播放免费观看| 欧美激情1区2区3区| 中国女人久久久| 亚洲欧美日本精品| 国产精品视频免费观看www| 欧美高清视频www夜色资源网| 国产日韩欧美一区二区三区在线观看| 久久久综合视频| 亚洲综合色在线| 伊人成综合网伊人222| 欧美视频在线不卡| 日韩亚洲欧美综合| 女人香蕉久久**毛片精品| 国产精品久久777777毛茸茸| 欧美一级片在线播放| 欧美日韩天堂| 欧美日韩精品一区二区| 欧美一区二区三区四区在线| 欧美成人午夜视频| 欧美在线免费一级片| 欧美日韩91| 日韩一区二区精品| 国产裸体写真av一区二区| 99re6这里只有精品视频在线观看| 欧美伊人精品成人久久综合97| 嫩草伊人久久精品少妇av杨幂| 久久精品国产清高在天天线| 一本一本大道香蕉久在线精品| 亚洲国产美女精品久久久久∴| 久久久久久久久久久久久9999| 久久精品二区亚洲w码| 国产午夜精品久久久久久免费视| 欧美日韩99| 在线观看日产精品| 蜜乳av另类精品一区二区| 在线一区视频| 欧美日韩国产丝袜另类| 亚洲二区视频| 国产女主播一区二区三区| 亚洲国产另类 国产精品国产免费| 亚洲午夜一区二区| 久久久午夜精品| 99re8这里有精品热视频免费| 国产日产亚洲精品| 亚洲国产精品va在线观看黑人| 亚洲国产另类精品专区| 亚洲免费av片| 欧美午夜女人视频在线| 免费不卡欧美自拍视频| 国产精品在线看| 国产精品久久999| 伊人成综合网伊人222| 国产精品高清网站| 亚洲毛片播放| 在线成人av.com| 香蕉久久久久久久av网站| 亚洲电影免费观看高清完整版在线观看| 久久精品二区三区| 欧美精品免费看| 亚洲欧美另类在线观看| 久久久久久久网| 亚洲国内在线| 国产精品亚洲成人| 欧美色道久久88综合亚洲精品| 国产综合自拍| 免费成人美女女| 亚洲一区二区成人| 亚洲日韩欧美视频| 99ri日韩精品视频| 欧美另类videos死尸| 欧美日韩国产专区| 亚洲欧美电影在线观看| 亚洲精品亚洲人成人网| 欧美国产精品va在线观看| 国产精品日韩久久久久| 午夜性色一区二区三区免费视频| 国产一区二区三区在线播放免费观看| 国产伦一区二区三区色一情| 99精品99| 久热精品在线视频| 欧美成人中文字幕在线| 国产麻豆精品在线观看| 午夜视频久久久久久| 国语自产精品视频在线看| 欧美精品三区| 国产亚洲一区在线播放| 欧美吻胸吃奶大尺度电影| 国产美女高潮久久白浆| 久久综合国产精品台湾中文娱乐网| 日韩视频一区二区三区| 亚洲电影专区| 欧美亚洲一区二区三区| 欧美日韩一区自拍| 欧美性猛片xxxx免费看久爱| 欧美一级视频精品观看| 亚洲国产精品成人久久综合一区| 国产精品av一区二区| 亚洲最新合集| 国产精品一区二区视频| 亚洲精品无人区| 91久久综合亚洲鲁鲁五月天| 欧美无乱码久久久免费午夜一区| 国产精品欧美久久久久无广告| 美女精品国产| 久久久综合香蕉尹人综合网| 国产精品区一区二区三| 欧美电影在线观看| 欧美激情一区二区三区蜜桃视频| 亚洲国产精品一区二区第一页| 欧美日韩综合视频网址| 性色av香蕉一区二区| 性色av一区二区三区红粉影视| 亚洲电影在线播放| 欧美午夜片在线免费观看| 99精品久久| 久久精品国产亚洲高清剧情介绍| 亚洲精品综合久久中文字幕| 欧美尤物一区| 乱中年女人伦av一区二区| 国精品一区二区| 亚洲欧美电影院| 在线电影国产精品| 亚洲国产欧美一区二区三区久久| 欧美精品www在线观看| 欧美尤物一区| 日韩视频在线一区二区| 欧美激情日韩| 国产精品久久久久久影院8一贰佰| 国产麻豆日韩欧美久久| 久久精品国产亚洲一区二区三区| 欧美伦理影院| 久久精品国产久精国产一老狼| 香蕉久久久久久久av网站| 亚洲精品一区二区三区99| 亚洲欧洲一区二区三区久久| 欧美一区激情视频在线观看| 亚洲日本成人| 欧美理论在线播放| 国产日韩欧美日韩大片| 欧美精品不卡| 欧美日韩精品综合| 久久超碰97人人做人人爱| 国产亚洲一区二区精品| 香蕉久久夜色精品| 欧美成人tv| 午夜激情综合网| 欧美一区二区在线播放| 亚洲欧美激情在线视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲另类自拍| 香蕉成人啪国产精品视频综合网| 亚洲国产aⅴ天堂久久| 欧美精品 日韩| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲在线成人精品| 亚洲国产裸拍裸体视频在线观看乱了中文| 免费观看成人www动漫视频| 欧美日韩亚洲高清| 亚洲一区二区三区中文字幕在线| 欧美寡妇偷汉性猛交| 午夜精品视频网站| 国产一区二区三区免费在线观看| 欧美美女喷水视频| 国产欧美视频一区二区| 日韩视频中午一区| 国产精品成人一区二区| 久久久久国产精品一区| 亚洲夜晚福利在线观看| 久久精品国产免费| 午夜在线a亚洲v天堂网2018| 国产精品99久久久久久人| 亚洲在线播放| 香蕉尹人综合在线观看| 欧美一区二区在线观看|