《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于MATLAB 的DSP 調試方法
基于MATLAB 的DSP 調試方法
摘要: 由MathWorks 公司和TI 公司聯合開發的MATLAB Link for CCS Development Tools(簡稱CCSLink)是MATLAB6.5 版本(Release13)中增加的一個全新的工具箱,它提供了MATLAB、CCS 和DSP 目標板的接口
關鍵詞: 開發工具 Matlab DSP CCS
Abstract:
Key words :

  MATLAB 具有強大的分析、計算和可視化功能,利用MATLAB 提供的數十個專業工具箱,可以方便、靈活地實現對自動控制、信號處理、通信系統等的算法分析和仿真,是算法設計人員和工程技術人員必不可少的軟件工具。

  數字信號處理器(DSP)作為一種可編程專用芯片,是數字信號處理理論實用化過程的重要技術工具,在語音處理、圖像處理等技術領域得到了廣泛的應用。但對于算法設計人員來講,利用匯編語言或C 語言進行DSP 功能開發,對于具有周期長、效率低的缺點,不利于算法驗證和產品的快速開發。

  由MathWorks 公司和TI 公司聯合開發的MATLAB Link for CCS Development Tools(簡稱CCSLink)是MATLAB6.5 版本(Release13)中增加的一個全新的工具箱,它提供了MATLAB、CCS 和DSP 目標板的接口,利用此工具可以像操作MATLAB變量一樣來操作DSP 器件的存儲器和寄存器,使開發人員在MATLAB 環境下完成對DSP 的操作,從而極大地提高DSP 應用系統的開發進程。

  本文結合具體例證,介紹基于MATLAB 的DSP 應用程序調試方法。

  1 CCSLink 初步

  CCSLink 工具通過雙向連接將MATLAB、CCS 和DSP 目標板聯系起來,允許開發者利用MATLAB 強大的可視化、數據處理和分析函數對來自CCS 的數據進行分析和處理,極大地簡化TI 公司DSP 軟件的分析、調試和驗證過程。三者關系如圖1示。

CCSLink連接關系

圖1 CCSLink連接關系

  CCSLink 的主要特點為:在MATLAB 環境下完成對DSP器件的調試、數據傳遞和驗證;在MATLAB 和DSP 之間實現數據實時傳遞;支持XDS510 和XDS560 仿真器;提供嵌入式對象,可以訪問C/C++變量;擴展了MATLAB 和eXpressDSP工具調試能力。

  MATLAB 6.5 版集成了CCSLink1.0 工具,支持CCS 能識別的所有板卡及硬件DSP,包括TIC2000、C5000、C6000 DSP及EVM 板、DSK 板、simulator 及任何符合標準的用戶板和第三方板。CCSLink 正常工作除了需要MATLAB 及其信號處理工具箱外,還需要TI 的編譯器(compiler)、匯編器(assembler)、鏈接器(linker)、CCS IDE2.1、CCS 配置工具信其他軟件工具。

  在MATLAB 環境下輸入命令

help ccslink

  若CCSLink 已正確安裝,則會顯示產品信息及進行CCS 和RTDX 操作的函數列表:

MATLAB Link for Code Composer Studio(tm)
Version 1.0 (R13) 28-Jun-2002。

  若MATLAB 不能返回信息,則表明CCSLink 未安裝成功,需進行重新安裝。

  2 CCSLink 對象的建立

  在對DSP 進行操作之前,應該首先建立一個DSP 目標。對于配置了多DSP 系統的用戶,CCSLink 提供了兩種選擇DSP目標的工具:ccsboardinfo 函數和boardprosel 圖形用戶界面,用戶可以根據返回值和自己需求選擇相應的對象。以采用圖形用戶界面為例,若配置有XDS510 Emulator 和C5416 Simulator 二種DSP 系統,運行[boardNum,procNum] = boardprocsel,則MATLAB 通過對CCS 配置的自動檢測,出現圖2 所示的目標選擇界面。本文根據需要選擇硬件仿真器C54xxXDS510Emulator 并點擊Done,則可返回板卡編號和處理器編號:
boardNum=1,procNum=0。

CCSLink對象選擇

圖2 CCSLink對象選擇

  利用ccsdsp 函數可以確立一個DSP 對象。ccsdsp 以板卡編號和處理器編號為參數,并在建立鏈接對象后返回其它屬性,如處理器型號、處理器名稱等。例如,運行 cc="ccsdsp"('boardnum',boardNum, 'procnum', procNum),則建立起一個CCS IDE 對象的句柄cc。從而可以通過cc,在MATLAB 下實現對CCS 的操作并控制DSP 芯片。

  3 CCSLink 調試DSP 代碼實例

  建立起MATLAB 鏈接之后,就可以通過CCS 為DSP 目標產生可執行代碼,并進行編譯、調試和分析。在以下的介紹中,均以MATLAB 自帶的工程文件為例。

   3.1 加載DSP 目標板

  在MATLAB 環境執行以下代碼:

projfile = fullfile( matlabroot, 'toolb

ox', 'CCSlink', 'ccsdemos', 'ccstutorial','ccstut_54xx.pjt')%選擇工程文件
projpath = fileparts(projfile) %指定工程文件路徑
open(cc,projfile)%打開工程文件
visible(cc,1)%使CCS IDE 前臺可見
cd(cc,projpath)%改變MATLAB 工作路徑
build(cc,'all',60)%編譯工程
load(cc,'ccstut_54xx.out',30)%加載可執行文件
則如代碼注釋所示,在MATLAB 環境下完成了對工程文件的調入、編譯,生成可執行文件并將其加載到DSP 目標板。利用鼠標操作切換到CCS 界面,可以看到在MATLAB 下已經完成了對CCS 的各種操作過程,如圖3 所示。

 

CCSLink調試DSP代碼實例

圖3 CCSLink調試DSP代碼實例

  3.2 利用CCSLink 連接調試訪問DSP 內存

  在編譯并加載.out 文件后,可以直接由CCSLink 讀取目標符號表并獲取變量在DSP 內存中的地址。如輸入ddatA =dec2hex(address(cc,'ddat')),將返回變量ddat 的地址和所在頁:
23AC,0000。

  在MATLAB 中,可以控制CCS IDE 中程序的顯示及斷點的增加和刪除,并控制程序代碼的執行和暫停,讀寫DSP 的內存變量。例如,執行以下程序:

open(cc,'ccstut.c','text')%在CCS 中打開ccstut.c 文件
open(cc,'ccstut_54xx.cmd','text')%在CCS 中打開ccstut_54xx.cmd 文件
activate(cc,'ccstut.c','text')%將ccstut.c 作為當前的活動文件
insert(cc,'ccstut.c',64)%在第64 行加入斷點
halt(cc)%暫停CPU
restart(cc) %繼續與CCS 保持聯系
run(cc,'runtohalt',20)%DSP 程序執行到斷點
ddatV = read(cc,address(cc,'ddat'),'single',4) %(1)讀取C 代碼初始化數據ddat
idatV = read(cc,address(cc,'idat'),'int16',4) %(2)讀取C代碼初始化數據idat
write(cc,address(cc,'ddat'),single([pi, 12.3, exp(-1), sin(pi/4)])) % (3)修改DSP 內存中的數據ddat
write(cc,address(cc,'idat'),int16([1:4]))% (4)修改DSP 內存中的數據idat
run(cc,'runtohalt',20) %從斷點處繼續執行
ddatV = read(cc,address(cc,'ddat'),'single',4)% (5)讀取修改后的數據ddat
idatV = read(cc,address(cc,'idat'),'int16',4) %(6)讀取修改后的數據idat

  閱讀本例工程文件可知,在C 代碼中,變量初始化值為ddat=[16.3,-2.13,5.1,11.8],idat=[1,508,647,7000]。執行上述(1)、(2)兩語句,在MATLAB 中獲得了這兩個變量的值ddatV 和idatV。經過(3)、(4)兩語句的修改,ddat 和idat 分別改為了新值ddat=[3.1416,12.3,0.3679,0.7071]和idat=[1,2,3,4]。這一修改,可從(5)、(6)兩語句的執行在MATLAB 中得到驗證,同時也可在CCS IDE 下通過變量觀測器進行證實。

  在MATLAB 下,同樣可以通過regread 和regwrite 來對CPU寄存器進行讀寫操作。如
tReg = regread(cc,'AL','2scomp') % 按二進制補碼方式讀取AL
regread(cc,'TRN','binary') % 按無符號二進制數讀取TRN
regwrite(cc,'AH','FFFF','binary') % 按無符號二進制數讀寫AH

  3.3 利用CCSLink 嵌入式對象調試訪問DSP 內存

  利用MATLAB 的面向對象編程技術和CSLink,可以為目標程序中的所有C 符號創建嵌入式對象,并通過對象來操作該C 符號。

  仍以上述程序為例,首先復位DSP,并創建一個嵌入式對象:

restart(cc) % 復位程序,使PC 指向程序入口處
goto(cc,'main') %將PC 定位到C 主程序入口
cvar = createobj(cc,'idat') %(7)為操作嵌入式對象idat 創建MATLAB 對象
cvar

 

   語句(7)創建了指向DSP 中C 符號的MATLAB 對象,從而可以在MATLAB 環境下實現對其全部或部分讀取和修改。

read(cvar)%(8)將嵌入式數組讀入到MATLAB 工作空間
read(cvar,2)%只讀取第2 個元素
write(cvar,4,7001)%(9)將第4 個元素修改為7001
set(cvar,'size',[2])%(10)將對象減小到2 個元素

  語句(8)將指向idat 的嵌入式數組cvar 讀入MATLAB,在語句(9)中對其第4 個元素進行了修改,而在語句(10)中對數組的大小進行了改變。

  通過CCSLink,不僅可以為數組變量創建對象,而且也可以為結構體變量創建對象并進行相應的操作,如:

cvar = createobj(cc,'myStruct')%創建指向C 結構體的MATLAB 對象
write(cvar,'iz', 'Simulink') %修改結構體的字符串iz 域為Simulink
cstring = getmember(cvar,'iz')%讀取該域到MATLAB
write(cstring,1,'s')%該寫字符串的首字符
readnumeric(cstring)%按數值方式讀取字符串

  上述5 條語句,均通過MATLAB 環境下的對象cvar,實現了對DSP 的C 語言程序中結構體變量myStruct 的讀寫操作和修改,具有很大的方便性。

  通過CCSlink,無論對CCS IDE 建立了連接對象還是嵌入式對象,均可在MATLAB 環境下進行操作,達到了DSP 內部各種變量的讀寫和修改,并進行相關的調試過程,具有很大的方便性。對于上述示例所有的操作執行結果,均可以在MATLAB和CCS IDE 環境下進行觀測和驗證。

  4 結束語

  本文簡要討論了基于MATLAB 的DSP 程序調試方法,描述了CCSLink 與CCS IDE 的基本概念,介紹了建立CCS 對象的過程,并以MATLAB 提供的實際工程文件為例,演示了利用CCSLink 連接和嵌入式對象進行C 變量操作的實際過程,并對其執行過程和結果進行了簡要解釋。

  應該說明的是,MATLAB提供了大量的進行DSP程序調試的函數,本文只涉及到了其中極少的一部分。要充分利用MATLAB的強大功能進行更深層次的 DSP程序調試,應進一步參考MathWorks公司提供的技術資料MATLAB Link for Code Composer Studio Development Tools。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
韩国视频理论视频久久| 亚洲高清一区二区三区| 老牛国产精品一区的观看方式| 亚洲自拍偷拍福利| 99精品国产一区二区青青牛奶| 欧美一区亚洲一区| 午夜精品福利视频| 亚洲无玛一区| 日韩一级大片在线| 亚洲精品国产精品国自产观看浪潮| 国自产拍偷拍福利精品免费一| 国产精品一区二区久久久久| 欧美日韩国产一区二区三区| 欧美成人综合一区| 蜜桃av一区二区| 玖玖国产精品视频| 久久久亚洲精品一区二区三区| 性欧美1819性猛交| 性色av一区二区三区| 亚洲欧美日韩在线不卡| 亚洲在线视频| 亚洲一区免费视频| 亚洲一区在线免费| 亚洲欧美区自拍先锋| 亚洲欧美视频在线观看视频| 亚洲综合激情| 性欧美video另类hd性玩具| 午夜亚洲福利| 欧美专区在线播放| 亚洲综合第一页| 亚洲欧美日韩国产精品| 亚洲一区国产一区| 亚洲一区二区在线看| 亚洲欧美日韩国产综合在线| 亚洲欧美电影在线观看| 欧美一级二区| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲美洲欧洲综合国产一区| 日韩小视频在线观看| 亚洲一区免费视频| 欧美一二三区在线观看| 久久精品国产亚洲5555| 亚洲欧洲在线一区| aⅴ色国产欧美| 亚洲一区二区黄| 欧美在线观看网址综合| 久久一区亚洲| 欧美精品色网| 国产精品露脸自拍| 国产一区二区三区自拍 | 99re6热在线精品视频播放速度| 亚洲视屏一区| 欧美中文字幕在线| 亚洲人人精品| 亚洲欧美日韩国产一区二区| 久久精品系列| 欧美激情一区三区| 国产精品观看| 欧美日韩综合在线| 国产精品伦子伦免费视频| 国产一区在线免费观看| 亚洲国产专区| 亚洲欧美激情视频在线观看一区二区三区| 欧美一级理论片| 99re热这里只有精品视频| 午夜国产精品影院在线观看| 免费成年人欧美视频| 国产精品成人久久久久| 国产在线精品二区| 亚洲精品在线视频| 亚洲欧美不卡| 99re热这里只有精品视频| 欧美一级淫片aaaaaaa视频| 欧美mv日韩mv国产网站app| 国产精品久久久久9999| 激情婷婷亚洲| 亚洲图片欧美日产| 亚洲国产精品久久久久秋霞蜜臀| 亚洲天堂av在线免费| 久久久精品日韩欧美| 欧美视频在线观看视频极品| 狠狠爱综合网| 在线综合视频| 亚洲国产一区视频| 午夜欧美精品| 欧美精品一区三区在线观看| 国产日韩亚洲欧美| 亚洲伦理中文字幕| 久久精品亚洲国产奇米99| 亚洲无人区一区| 噜噜噜91成人网| 国产精品久久久久久久久久直播| 亚洲国内精品| 久久成人久久爱| 亚洲一区国产| 欧美激情乱人伦| 狠狠色狠狠色综合日日91app| 亚洲先锋成人| 99国产麻豆精品| 免费高清在线一区| 国产亚洲精品一区二555| 一区二区三区四区五区视频| 亚洲三级免费观看| 久久欧美肥婆一二区| 国产精品亚洲а∨天堂免在线| 亚洲日本中文字幕区| 亚洲成色777777在线观看影院| 亚洲欧美另类在线观看| 欧美成人激情视频免费观看| 国产一区观看| 亚洲欧美三级在线| 亚洲自拍三区| 国产精品a久久久久久| 亚洲国产日韩欧美在线图片 | 欧美在线亚洲| 国产精品网站视频| 一区二区三区|亚洲午夜| 亚洲精品国产视频| 免费欧美视频| 伊人影院久久| 亚洲黄网站在线观看| 久久偷窥视频| 狠狠色综合色区| 欧美一区免费视频| 欧美在线日韩| 国产日韩欧美在线观看| 亚洲一区二区三区欧美| 亚洲一区三区视频在线观看 | 国内精品免费午夜毛片| 午夜精品久久久久久| 亚洲一区二区三区精品动漫| 欧美日本高清视频| 亚洲激情国产精品| 亚洲免费电影在线| 欧美精品18+| 日韩视频不卡中文| 中文av一区二区| 欧美天堂在线观看| 一区二区三区精品视频在线观看| 亚洲美女毛片| 欧美日韩国产成人在线91| 亚洲精品一区在线观看| 亚洲天堂网在线观看| 国产精品久久久久久久app| 亚洲一区二区三区免费视频| 欧美一区二区视频在线观看| 国产麻豆精品theporn| 午夜精品久久99蜜桃的功能介绍| 久久精品水蜜桃av综合天堂| 伊人婷婷久久| 一本色道久久综合狠狠躁篇怎么玩 | 国产亚洲精品bv在线观看| 久久精品色图| 免费观看亚洲视频大全| 亚洲精品亚洲人成人网| 亚洲综合导航| 韩国三级在线一区| 亚洲狼人综合| 国产精品任我爽爆在线播放| 欧美在线视频网站| 暖暖成人免费视频| 99精品久久久| 久久成人国产| 亚洲国产精品第一区二区| 一区二区三区四区国产| 国产欧美在线播放| 亚洲欧洲99久久| 欧美在线啊v一区| 怡红院av一区二区三区| 一本久久综合亚洲鲁鲁| 久久另类ts人妖一区二区| 国外精品视频| 亚洲精品裸体| 国产精品美女999| 欧美一级理论片| 免费一级欧美片在线观看| 亚洲第一在线综合网站| 亚洲男人av电影| 国产一级一区二区| 亚洲黄色天堂| 久久精品亚洲精品国产欧美kt∨| 亚洲黄页一区| 亚洲与欧洲av电影| 国产亚洲在线| 亚洲国产美女| 欧美午夜在线一二页| 欧美一区中文字幕| 欧美国产日韩二区| 午夜亚洲一区| 欧美成人精品一区二区三区| 一区二区成人精品 | 香蕉乱码成人久久天堂爱免费| 亚洲电影中文字幕| 亚洲调教视频在线观看| 国产欧美日韩亚洲一区二区三区| 亚洲免费精品| 国产精品香蕉在线观看| 亚洲精品一区二区三| 国产精品毛片在线| 亚洲最新色图|