| 如何選擇外部時(shí)鐘? DSP的內部指令周期較高,外部晶振的主頻不夠,因此DSP大多數片內均有PLL。但每個(gè)系列不盡相同。 1)TMS320C2000系列: TMS320C20x:PLL可以÷2,×1,×2和×4,因此外部時(shí)鐘可以為5MHz-40MHz。 TMS320F240:PLL可以÷2,×1,×1.5,×2,×2.5,×3,×4,×4.5,×5和×9,因此外部時(shí)鐘可以為2.22MHz-40MHz。 TMS320F241/C242/F243:PLL可以×4,因此外部時(shí)鐘為5MHz。 TMS320LF24xx:PLL可以由RC調節,因此外部時(shí)鐘為4MHz-20MHz。 TMS320LF24xxA:PLL可以由RC調節,因此外部時(shí)鐘為4MHz-20MHz。 2)TMS320C3x系列: TMS320C3x:沒(méi)有PLL,因此外部主頻為工作頻率的2倍。 TMS320VC33:PLL可以÷2,×1,×5,因此外部主頻可以為12MHz-100MHz。 3)TMS320C5000系列: TMS320VC54xx:PLL可以÷4,÷2,×1-32,因此外部主頻可以為0.625MHz-50MHz。 TMS320VC55xx:PLL可以÷4,÷2,×1-32,因此外部主頻可以為6.25MHz-300MHz。 4)TMS320C6000系列: TMS320C62xx:PLL可以×1,×4,×6,×7,×8,×9,×10和×11,因此外部主頻可以為11.8MHz-300MHz。 TMS320C67xx:PLL可以×1和×4,因此外部主頻可以為12.5MHz-230MHz。 TMS320C64xx:PLL可以×1,×6和×12,因此外部主頻可以為30MHz-720MHz 軟件等待的如何使用? DSP的指令周期較快,訪(fǎng)問(wèn)慢速存儲器或外設時(shí)需加入等待。等待分硬件等待和軟件等待,每一個(gè)系列的等待不完全相同。 1)對于C2000系列: 硬件等待信號為READY,高電平時(shí)不等待。 軟件等待由WSGR寄存器決定,可以加入最多7個(gè)等待。其中程序存儲器和數據存儲器及I/O可以分別設置。 2)對于C3x系列: 硬件等待信號為/RDY,低電平是不等待。 軟件等待由總線(xiàn)控制寄存器中的SWW和WTCNY決定,可以加入最多7個(gè)等待,但等待是不分段的,除了片內之外全空間有效。 3)對于C5000系列: 硬件等待信號為READY,高電平時(shí)不等待。 軟件等待由SWWCR和SWWSR寄存器決定,可以加入最多14個(gè)等待。其中程序存儲器、控制程序存儲器和數據存儲器及I/O可以分別設置。 4)對于C6000系列(只限于非同步存儲器或外設): 硬件等待信號為ARDY,高電平時(shí)不等待。 軟件等待由外部存儲器接口控制寄存器決定,總線(xiàn)訪(fǎng)問(wèn)外部存儲器或設備的時(shí)序可以設置,可以方便的同異步的存儲器或外設接口。 仿真工作正常對于DSP的基本要求 1)DSP電源和地連接正確。 2)DSP時(shí)鐘正確。 3)DSP的主要控制信號,如RS和HOLD信號接高電平。 4)C2000的watchdog關(guān)掉。 5)不可屏蔽中斷NMI上拉高電平。 CCS或Emurst運行時(shí)提示“Can‘t Initialize Target DSP” 1)仿真器連接是否正常? 2)仿真器的I/O設置是否正確? 3)XDSPP仿真器的電源是否正確? 4)目標系統是否正確? 5)仿真器是否正常?6)DSP工作的基本條件是否具備。 建議使用目標板測試。 為什么CCS需要安裝Driver? CCS是開(kāi)放的軟件平臺,它可以支持不同的硬件接口,因此不同的硬件接口必須通過(guò)標準的Driver同CCS連接。 Driver安裝的常見(jiàn)問(wèn)題? 請 認真閱讀“安裝手冊”和Driver盤(pán)中的Readme。 1)對于SEED-XDS,安裝Readme中的步驟,將I/O口設為240/280/320/340。 2)對于SEED-XDSPP,安裝Readme中的步驟,將I/O口設為378或278。3)對于SEED-XDSUSB,必須連接目標板,安裝 Readme中的步驟,將I/O口設為A,USB連接后,主機將自動(dòng)激活相應的Driver。 4)對于SEED-XDSPCI,安裝Readme中的步驟,將I/O口設為240,PCI接口板插入主機后,主機將自動(dòng)激活相應的Driver。 5)對于Simulator,需要選擇不同的CFG文件,以模擬不同的DSP。 6)對于C5402 DSK,將I/O口設為請認真閱讀“安裝手冊”和Driver盤(pán)中的Readme。 1)對于SEED-XDS,安裝Readme中的步驟,將I/O口設為240/280/320/340。 2)對于SEED-XDSPP,安裝Readme中的步驟,將I/O口設為378或278。注意主機BIOS中并口的型式必須同xds510pp.ini 中一致。 3)對于SEED-XDSUSB,必須連接目標板,安裝Readme中的步驟,將I/O口設為240/280/320/340,USB連接后,主機將自動(dòng) 激活相應的Driver。 4)對于SEED-XDSPCI,安裝Readme中的步驟,將I/O口設為240/280/320/340,PCI接口板插入主機后,主機將自動(dòng)激活相 應的Driver。 5)對于Simulator,需要選擇不同的CFG文件,以模擬不同的DSP。 6)對于C5402 DSK,將I/O口設為378或278。 7)對于C6211/6711 DSK,將I/O口設為378或278。 8)對于C6201/C6701 EVM,將I/O口設為0。 Link的cmd文件的作用是什么? Link的cmd文件用于DSP代碼的定位。由于DSP的編譯器的編譯結果是未定位的,DSP沒(méi)有操作系統來(lái)定位執行代碼,每個(gè)客戶(hù)設計的DSP系統的配置也不盡相同,因此需要用戶(hù)自己定義代碼的安裝位置。以C5000為例,基本格式為: -o sample.out -m sample.map -stack 100 sample.obj meminit.obj -l rts.lib MEMORY { PAGE 0: VECT: origin = 0xff80, length 0x80 PAGE 0: PROG: origin = 0x2000, length 0x400 PAGE 1: DATA: origin = 0x800, length 0x400 } SECTIONS { .vectors : {} >PROG PAGE 0 .text : {} >PROG PAGE 0 .data : {} >PROG PAGE 0 .cinit : {} >PROG PAGE 0 .bss : {} >DATA PAGE 1 } 如何將OUT文件轉換為16進(jìn)制的文件格式? DSP 的開(kāi)發(fā)軟件集成了一個(gè)程序,可以從執行文件OUT轉換到編程器可以接受的格式,使得編程器可以用次文件燒寫(xiě)EPROM或Flash。對于C2000的程序 為DSPHEX;對于C3x程序為HEX30;對于C54x程序為HEX500;對于C55x程序為HEX55;對于C6x程序為Hex6x。以C32為 例,基本格式為: sample.out -x -memwidth 8 -bootorg 900000h -iostrb 0h -strb0 03f0000h -strb1 01f0000h -o sample.hex ROMS { EPROM: org = 0x900000,len=0x02000,romwidth=8 } SECTIONS { .text: paddr=boot .data: paddr=boot } DSP仿真器為什么必須連接目標系統(Target)? DSP的仿真器同單片機的不同,仿真器中沒(méi)有DSP,提供IEEE標準的JTAG口對DSP進(jìn)行仿真調試,所以仿真器必須有仿真對象,及目標系 統。目標系統就是你的產(chǎn)品,上面必須有DSP。仿真器提供JTAG同目標系統的DSP相接,通過(guò)DSP實(shí)現對整個(gè)目標系統的調試。 仿真工作正常對于DSP的基本要求 1) DSP電源和地連接正確。 2)DSP時(shí)鐘正確。 3)DSP的主要控制信號,如RS和HOLD信號接高電平。 4)C2000的watchdog關(guān)掉。 5)不可屏蔽中斷NMI上拉高電平。 CCS或Emurst運行時(shí)提示“Can‘t Initialize Target DSP” 1) 仿真器連接是否正常? 2)仿真器的I/O設置是否正確? 3)XDSPP仿真器的電源是否正確? 4)目標系統是否正確? 5)仿真器是否正常?6)DSP工作的基本條件是否具備。 建議使用目標板測試。 為什么CCS需要安裝Driver? CCS是開(kāi)放的軟件平臺,它可以支持不同的硬件接口,因此不同的硬件接口必須通過(guò)標準的Driver同CCS連接。 Link的cmd文件的作用是什么? Link的cmd文件用于DSP代碼的定位。由于DSP的編譯器的編譯結果是未定位的,DSP沒(méi)有操作系統來(lái)定位執行代碼,每個(gè)客戶(hù)設計的DSP系統的配置也不盡相同,因此需要用戶(hù)自己定義代碼的安裝位置。以C5000為例,基本格式為: -o sample.out -m sample.map -stack 100 sample.obj meminit.obj -l rts.lib MEMORY { PAGE 0: VECT: origin = 0xff80, length 0x80 PAGE 0: PROG: origin = 0x2000, length 0x400 PAGE 1: DATA: origin = 0x800, length 0x400 } SECTIONS { .vectors : {} >PROG PAGE 0 .text : {} >PROG PAGE 0 .data : {} >PROG PAGE 0 .cinit : {} >PROG PAGE 0 .bss : {} >DATA PAGE 1 } 如何將OUT文件轉換為16進(jìn)制的文件格式? DSP的開(kāi)發(fā)軟件集成了一個(gè)程序,可以從執行文件OUT轉換到編程器可以接受的格式,使得編程器可以用次文件燒寫(xiě)EPROM或Flash。對于 C2000的程序為DSPHEX;對于C3x程序為HEX30;對于C54x程序為HEX500;對于C55x程序為HEX55;對于C6x程序為 Hex6x。以C32為例,基本格式為: sample.out -x -memwidth 8 -bootorg 900000h -iostrb 0h -strb0 03f0000h -strb1 01f0000h -o sample.hex ROMS { EPROM: org = 0x900000,len=0x02000,romwidth=8 } SECTIONS { .text: paddr=boot .data: paddr=boot } DSP的C語(yǔ)言同主機C語(yǔ)言的主要區別? 1) DSP的C語(yǔ)言是標準的ANSI C,它不包括同外設聯(lián)系的擴展部分,如屏幕繪圖等。但在CCS中,為了方便調試,可以將數據通過(guò)prinf命令虛擬輸出到主機的屏幕上。 2)DSP的C語(yǔ)言的編譯過(guò)程為,C編譯為ASM,再由ASM編譯為OBJ。因此C和ASM的對應關(guān)系非常明確,非常便于人工優(yōu)化。 3)DSP的代碼需要絕對定位;主機的C的代碼有操作系統定位。 4)DSP的C的效率較高,非常適合于嵌入系統。 為什么在CCS下編譯工具工作不正常? 在CCS下有部分客戶(hù)會(huì )碰到編譯工具工作不正常,常見(jiàn)錯誤為: 1)autoexec.bat的路徑“out of memory”。修改autoexec.bat,清除無(wú)用的PATH路徑。 2)編譯的輸出文件(OUT文件)寫(xiě)保護,無(wú)法覆蓋。刪除或修改輸出文件的屬性。 3)Windows有問(wèn)題。重新安裝windows。 4)Windows下有程序對CCS有影響。建議用一“干凈”的計算機。 在CCS下,如何選擇有效的存儲器空間? CCS下的存儲器空間最好設置同你的硬件,沒(méi)有的存儲器不要有效。這樣便于調試,CCS會(huì )發(fā)現你調入程序時(shí)或程序運行時(shí),是否訪(fǎng)問(wèn)了無(wú)效地址。 1)在GEL文件中設置。參見(jiàn)CCS中的示例。 2)在Option菜單下,選擇Memory Map選項,根據你的硬件設置。注意一定要將Enable Memory Mapping置為使能。 在CCS下,OUT文件加載時(shí)提示“Data verification failed...”的原因? Link的CMD文件分配的地址同GEL或設置的有效地址空間不符。中斷向量定位處或其它代碼、數據段定位處,沒(méi)有RAM,無(wú)法加載OUT文件。解決方法: 1)調整Link的CMD文件,使得定位段處有RAM。 2)調整存儲器設置,使得RAM區有效。 為什么要使用BIOS? 1)BIOS是Basic I/O System的簡(jiǎn)稱(chēng),是基本的輸入、輸出管理。 2)用于管理任務(wù)的調度,程序實(shí)時(shí)分析,中斷管理,跟蹤管理和實(shí)時(shí)數據交換。 3)BIOS是基本的實(shí)時(shí)系統,使用BIOS可以方便地實(shí)現多任務(wù)、多進(jìn)程的時(shí)間管理。 4)BIOS是eXpress DSP的標準平臺,要使用eXpress DSP技術(shù),必須使用BIOS。 DSP發(fā)展動(dòng)態(tài) 1.TMS320C2000 TMS320C2000系列包括C24x和C28x系列。C24x系列建議使用LF24xx系列替代C24x系列,LF24xx系列的價(jià)格比C24x便 宜,性能高于C24x,而且LF24xxA具有加密功能。 C28x系列主要用于大存儲設備管理,高性能的控制場(chǎng)合。 2.TMS320C3x TMS320C3x系列包括C3x和VC33,主要推薦使用VC33。C3x系列是TI浮點(diǎn)DSP的基礎,不可能停產(chǎn),但價(jià)格不會(huì )進(jìn)一步下調。 3.TMS320C5x TMS320C5x系列已不推薦使用,建議使用C24x或C5000系列替代。 4.TMS320C5000 TMS320C5000系列包括C54x和C55x系列。 其中VC54xx還不斷有新的器件出現,如:TMS320VC5471(DSP+ARM7)。 C55x系列是TI的第三代DSP,功耗為VC54xx的1/6,性能為VC54xx的5倍,是一個(gè)正在發(fā)展的系列。 C5000系列是目前TI DSP的主流DSP,它涵蓋了從低檔到中高檔的應用領(lǐng)域,目前也是用戶(hù)最多的系列。 5.TMS320C6000 TMS320C6000系列包括C62xx、C67xx和C64xx。此系列是TI的高檔DSP系列。 其中C62xx系列是定點(diǎn)的DSP,系列芯片種類(lèi)較豐富,是主要的應用系列。 C67xx系列是浮點(diǎn)的DSP,用于需要高速浮點(diǎn)處理的領(lǐng)域。 C64xx系列是新發(fā)展,性能是C62xx的10倍。 6.OMAP系列 是TI專(zhuān)門(mén)用于多媒體領(lǐng)域的芯片,它是C55+ARM9,性能卓越,非常適合于手持設備、Internet終端等多媒體應用。 5V/3.3V如何混接? TI DSP的發(fā)展同集成電路的發(fā)展一樣,新的DSP都是3.3V的,但目前還有許多外圍電路是5V的,因此在DSP系統中,經(jīng)常有5V和3.3V的DSP混接 問(wèn)題。在這些系統中,應注意: 1)DSP輸出給5V的電路(如D/A),無(wú)需加任何緩沖電路,可以直接連接。 2)DSP輸入5V的信號(如A/D),由于輸入信號的電壓>4V,超過(guò)了DSP的電源電壓,DSP的外部信號沒(méi)有保護電路,需要加緩沖,如 74LVC245等,將5V信號變換成3.3V的信號。 3)仿真器的JTAG口的信號也必須為3.3V,否則有可能損壞DSP。 為什么要片內RAM大的DSP效率高? 目前DSP發(fā)展的片內存儲器RAM越來(lái)越大,要設計高效的DSP系統,就應該選擇片內RAM較大的DSP。片內RAM同片外存儲器相比,有以下 優(yōu)點(diǎn): 1)片內RAM的速度較快,可以保證DSP無(wú)等待運行。 2)對于C2000/C3x/C5000系列,部分片內存儲器可以在一個(gè)指令周期內訪(fǎng)問(wèn)兩次,使得指令可以更加高效。 3)片內RAM運行穩定,不受外部的干擾影響,也不會(huì )干擾外部。 4)DSP片內多總線(xiàn),在訪(fǎng)問(wèn)片內RAM時(shí),不會(huì )影響其它總線(xiàn)的訪(fǎng)問(wèn),效率較高。 為什么DSP從5V發(fā)展成3.3V? 超大規模集成電路的發(fā)展從1um,發(fā)展到目前的0.1um,芯片的電源電壓也隨之降低,功耗也隨之降低。DSP也同樣從5V發(fā)展到目前的 3.3V,核心電壓發(fā)展到1V。目前主流的DSP的外圍均已發(fā)展為3.3V,5V的DSP的價(jià)格和功耗都價(jià)格,以逐漸被3.3V的DSP取代。 如何選擇DSP的電源芯片? TMS320LF24xx:TPS7333QD,5V變3.3V,最大500mA。 TMS320VC33: TPS73HD318PWP,5V變3.3V和1.8V,最大750mA。 TMS320VC54xx:TPS73HD318PWP,5V變3.3V和1.8V,最大750mA; TPS73HD301PWP,5V變3.3V和可調,最大750mA。 TMS320VC55xx:TPS73HD301PWP,5V變3.3V和可調,最大750mA。 TMS320C6000: PT6931,TPS56000,最大3A。 軟件等待的如何使用? DSP的指令周期較快,訪(fǎng)問(wèn)慢速存儲器或外設時(shí)需加入等待。等待分硬件等待和軟件等待,每一個(gè)系列的等待不完全相同。 1)對于C2000系列: 硬件等待信號為READY,高電平時(shí)不等待。 軟件等待由WSGR寄存器決定,可以加入最多7個(gè)等待。其中程序存儲器和數據存儲器及I/O可以分別設置。 2)對于C3x系列: 硬件等待信號為/RDY,低電平是不等待。 軟件等待由總線(xiàn)控制寄存器中的SWW和WTCNY決定,可以加入最多7個(gè)等待,但等待是不分段的,除了片內之外全空間有效。 3)對于C5000系列: 硬件等待信號為READY,高電平時(shí)不等待。 軟件等待由SWWCR和SWWSR寄存器決定,可以加入最多14個(gè)等待。其中程序存儲器、控制程序存儲器和數據存儲器及I/O可以分別設置。 4)對于C6000系列(只限于非同步存儲器或外設): 硬件等待信號為ARDY,高電平時(shí)不等待。 軟件等待由外部存儲器接口控制寄存器決定,總線(xiàn)訪(fǎng)問(wèn)外部存儲器或設備的時(shí)序可以設置,可以方便的同異步的存儲器或外設接口。 中斷向量為什么要重定位? 為了方便DSP存儲器的配置,一般DSP的中斷向量可以重新定位,即可以通過(guò)設置寄存器放在存儲器空間的任何地方。 注意:C2000的中斷向量不能重定位。 DSP的最高主頻能從芯片型號中獲得嗎? TI的DSP最高主頻可以從芯片的型號中獲得,但每一個(gè)系列不一定相同。 1)TMS320C2000系列: TMS320F206-最高主頻20MHz。 TMS320C203/C206-最高主頻40MHz。 TMS320F24x-最高主頻20MHz。 TMS320LF24xx-最高主頻30MHz。 TMS320LF24xxA-最高主頻40MHz。 TMS320LF28xx-最高主頻150MHz。 2)TMS320C3x系列: TMS320C30:最高主頻25MHz。 TMS320C31PQL80:最高主頻40MHz。 TMS320C32PCM60:最高主頻30MHz。 TMS320VC33PGE150:最高主頻75MHz。 3)TMS320C5000系列: TMS320VC54xx:最高主頻160MHz。 TMS320VC55xx:最高主頻300MHz。 4)TMS320C6000系列: TMS320C62xx:最高主頻300MHz。 TMS320C67xx:最高主頻230MHz。 TMS320C64xx:最高主頻720MHz。 DSP可以降頻使用嗎? 可以,DSP的主頻均有一定的工作范圍,因此DSP均可以降頻使用。 如何選擇外部時(shí)鐘? DSP的內部指令周期較高,外部晶振的主頻不夠,因此DSP大多數片內均有PLL。但每個(gè)系列不盡相同。 1)TMS320C2000系列: TMS320C20x:PLL可以÷2,×1,×2和×4,因此外部時(shí)鐘可以為5MHz-40MHz。 TMS320F240:PLL可以÷2,×1,×1.5,×2,×2.5,×3,×4,×4.5,×5和×9,因此外部時(shí)鐘可以為2.22MHz-40MHz。 TMS320F241/C242/F243:PLL可以×4,因此外部時(shí)鐘為5MHz。 TMS320LF24xx:PLL可以由RC調節,因此外部時(shí)鐘為4MHz-20MHz。 TMS320LF24xxA:PLL可以由RC調節,因此外部時(shí)鐘為4MHz-20MHz。 2)TMS320C3x系列: TMS320C3x:沒(méi)有PLL,因此外部主頻為工作頻率的2倍。 TMS320VC33:PLL可以÷2,×1,×5,因此外部主頻可以為12MHz-100MHz。 3)TMS320C5000系列: TMS320VC54xx:PLL可以÷4,÷2,×1-32,因此外部主頻可以為0.625MHz-50MHz。 TMS320VC55xx:PLL可以÷4,÷2,×1-32,因此外部主頻可以為6.25MHz-300MHz。 4)TMS320C6000系列: TMS320C62xx:PLL可以×1,×4,×6,×7,×8,×9,×10和×11,因此外部主頻可以為11.8MHz-300MHz。 TMS320C67xx:PLL可以×1和×4,因此外部主頻可以為12.5MHz-230MHz。 TMS320C64xx:PLL可以×1,×6和×12,因此外部主頻可以為30MHz-720MHz 如何選擇DSP的外部存儲器? DSP的速度較快,為了保證DSP的運行速度,外部存儲器需要具有一定的速度,否則DSP訪(fǎng)問(wèn)外部存儲器時(shí)需要加入等待周期。 1)對于C2000系列: C2000系列只能同異步的存儲器直接相接。 C2000系列的DSP目前的最高速度為150MHz。建議可以用的存儲器有: CY7C199-15:32K×8,15ns,5V; CY7C1021-12:64K×16,15ns,5V; CY7C1021V33-12:64K×16,15ns,3.3V。 2)對于C3x系列: C3x系列只能同異步的存儲器直接相接。 C3x系列的DSP的最高速度,5V的為40MHz,3.3V的為75MHz,為保證DSP無(wú)等待運行,分別需要外部存儲器的速度<25ns和<12ns。建議可以用的存儲器有: ROM: AM29F400-70:256K×16,70ns,5V,加入一個(gè)等待; AM29LV400-55(SST39VF400):256K×16,55ns,3.3V,加入兩個(gè)等待(目前沒(méi)有更快的Flash)。 SRAM: CY7C199-15:32K×8,15ns,5V; CY7C1021-15:64K×16,15ns,5V; CY7C1009-15:128K×8,15ns,5V; CY7C1049-15:512K×8,15ns,5V; CY7C1021V33-15:64K×16,15ns,3.3V; CY7C1009V33-15:128K×8,15ns,3.3V; CY7C1041V33-15:256k×16,15ns,3.3V。 3)對于C54x系列: C54x系列只能同異步的存儲器直接相接。 C54x系列的DSP的速度為100MHz或160MHz,為保證DSP無(wú)等待運行,需要外部存儲器的速度<10ns或<6ns。建議可以用的存儲器有: ROM: AM29LV400-55(SST39VF400):256K×16,55ns,3.3V,加入5或9個(gè)等待(目前沒(méi)有更快的Flash)。 SRAM: CY7C1021V33-12:64K×16,12ns,3.3V,加入一個(gè)等待; CY7C1009V33-12:128K×8,12ns,3.3V,加入一個(gè)等待。 4)對于C55x和C6000系列: TI的DSP中只有C55x和C6000可以同同步的存儲器相連,同步存儲器可以保證系統的數據交換效率更高。 ROM: AM29LV400-55(SST39VF400):256K×16,55ns,3.3V。 SDRAM: HY57V651620BTC-10S:64M,10ns。 SBSRAM: CY7C1329-133AC,64k×32; CY7C1339-133AC,128k×32。 FIFO:CY7C42x5V-10ASC,32k/64k×18。 DSP芯片有多大的驅動(dòng)能力? DSP的驅動(dòng)能力較強,可以不加驅動(dòng),連接8個(gè)以上標準TTL門(mén)。 調試TMS320C2000系列的常見(jiàn)問(wèn)題? 1)單步可以運行,連續運行時(shí)總回0地址: Watchdog沒(méi)有關(guān),連續運行復位DSP回到0地址。 2)OUT文件不能load到片內f(wàn)lash中: Flash不是RAM,不能用簡(jiǎn)單的寫(xiě)指令寫(xiě)入,需要專(zhuān)門(mén)的程序寫(xiě)入。CCS和C Source Debugger中的load命令,不能對flash寫(xiě)入。 OUT文件只能load到片內RAM,或片外RAM中。 3)在flash中如何加入斷點(diǎn): 在flash中可以用單步調試,也可以用硬件斷點(diǎn)的方法在flash中加入斷點(diǎn),軟件斷點(diǎn)是不能加在ROM中的。硬件斷點(diǎn),設置存儲器的地址,當訪(fǎng)問(wèn)該地址時(shí)產(chǎn)生中斷。 4)中斷向量: C2000的中斷向量不可重定位,因此中斷向量必須放在0地址開(kāi)始的flash內。在調試系統時(shí),代碼放在RAM中,中斷向量也必須放在flash內。 調試TMS320C3x系列的常見(jiàn)問(wèn)題? 1) TMS320C32的存儲器配置: TMS320C32的程序存儲器可以配置為16位或32位;數據存儲器可以配置為8位、16位或32位。 2)TMS320VC33的PLL控制: TMS320VC33的PLL控制端只能接1.8V,不能接3.3V或5V。 如何調試多片DSP? 對于有MPSD仿真口的DSP(TMS320C30/C31/C32),不能用一套仿真器同時(shí)調試,每次只能調試其中的一個(gè)DSP; 對于有JTAG仿真口的DSP,可以將JTAG串接在一起,用一套仿真器同時(shí)調試多個(gè)DSP,每個(gè)DSP可以用不同的名字,在不同的窗口中調試。 注意:如果在JTAG和DSP間加入驅動(dòng),一定要用快速的門(mén)電路,不能使用如LS的慢速門(mén)電路。 在DSP系統中為什么要使用CPLD? DSP的速度較快,要求譯碼的速度也必須較快。利用小規模邏輯器件譯碼的方式,已不能滿(mǎn)足DSP系統的要求。 同時(shí),DSP系統中也經(jīng)常需要外部快速部件的配合,這些部件往往是專(zhuān)門(mén)的電路,有可編程器件實(shí)現。 CPLD的時(shí)序嚴格,速度較快,可編程性好,非常適合于實(shí)現譯碼和專(zhuān)門(mén)電路。 DSP系統構成的常用芯片有哪些? 1) 電源: TPS73HD3xx,TPS7333,TPS56100,PT64xx... 2)Flash: AM29F400,AM29LV400,SST39VF400... 3)SRAM: CY7C1021,CY7C1009,CY7C1049... 4)FIFO: CY7C425,CY7C42x5... 5)Dual port: CY7C136,CY7C133,CY7C1342... 6)SBSRAM: CY7C1329,CY7C1339... 7)SDRAM: HY57V651620BTC... 8)CPLD: CY37000系列,CY38000系列,CY39000系列... 9)PCI: PCI2040,CY7C09449... 10)USB: AN21xx,CY7C68xxx... 11)Codec:TLV320AIC23,TLV320AIC10... 12)A/D,D/A:ADS7805,TLV2543... 具體資料見(jiàn)www.ti.com,www.cypress.com 什么是boot loader? DSP的速度盡快,EPROM或flash的速度較慢,而DSP片內的RAM很快,片外的RAM也較快。為了使DSP充分發(fā)揮它的能力,必須將 程序代碼放在RAM中運行。為了方便的將代碼從ROM中搬到RAM中,在不帶flash的DSP中,TI在出廠(chǎng)時(shí)固化了一段程序,在上電后完成從ROM或 外設將代碼搬到用戶(hù)指定的RAM中。此段程序稱(chēng)為“boot loader”。 TMS320C3x如何boot? 在MC/MP管腳為高時(shí),C3x進(jìn)入boot狀態(tài)。C3x的boot loader在reset時(shí),判斷外部中斷管腳的電平。根據中斷配置決定boot的方式為存儲器加載還是串口加載,其中ROM的地址可以為三個(gè)中的一個(gè),ROM可以為8位。 Boot有問(wèn)題如何解決? 1)仔細檢查boot的控制字是否正確。 2)仔細檢查外部管腳設置是否正確。 3)仔細檢查hex文件是否轉換正確。 4)用仿真器跟蹤boot過(guò)程,分析錯誤原因。 DSP為什么要初始化? DSP在RESET后,許多的寄存器的初值一般同用戶(hù)的要求不一致,例如:等待寄存器,SP,中斷定位寄存器等,需要通過(guò)初始化程序設置為用戶(hù)要求的數值。 初始化程序的主要作用: 1)設置寄存器初值。 2)建立中斷向量表。 3)外圍部件初始化。 DSP有哪些數學(xué)庫及其它應用軟件? TI公司為了方便客戶(hù)開(kāi)發(fā)DSP,在它的網(wǎng)站上提供了許多程序的示例和應用程序,如MATH庫,FFT,FIR/IIR等,可以在TI的網(wǎng)頁(yè)免費下載。 如何獲得DSP專(zhuān)用算法? TI有許多的Third Party可以通過(guò)DSP上的多種算法軟件??梢酝ㄟ^(guò)TI的網(wǎng)頁(yè)搜索你所需的算法,找到通過(guò)算法的公司,同相應的公司聯(lián)系。注意這些算法都是要付費的。 eXpressDSP是什么? eXpressDSP是一種實(shí)時(shí)DSP軟件技術(shù),它是一種DSP編程的標準,利用它可以加快你開(kāi)發(fā)DSP軟件的速度。 以往DSP軟件的開(kāi)發(fā)沒(méi)有任何標準,不同的人寫(xiě)的程序一般無(wú)法連接在一起。DSP軟件的調試工具也非常不方便。使得DSP軟件的開(kāi)發(fā)往往滯后于硬件的開(kāi) 發(fā)。 eXpressDSP集成了CCS(Code Composer Studio)開(kāi)發(fā)平臺,DSP BIOS實(shí)時(shí)軟件平臺,DSP算法標準和第三方支持四部分。利用該技術(shù),可以使你的軟件調試,軟件進(jìn)程管理,軟件的互通及算法的獲得,都便的容易。這樣就 可以加快你的軟件開(kāi)發(fā)進(jìn)程。 1)CCS是eXpressDSP的基礎,因此你必須首先擁有CCS軟件。 2)DSP BIOS是eXpressDSP的基本平臺,你必須學(xué)會(huì )所有DSP BIOS。 3)DSP算法標準可以保證你的程序可以方便的同其它利用eXpressDSP技術(shù)的程序連接在一起。同時(shí)也保證你的程序的延續性。 為什么要用DSP? 3G技術(shù)和internate的發(fā)展,要求處理器的速度越來(lái)越高,體積越來(lái)越小,DSP的發(fā)展正好能滿(mǎn)足這一發(fā)展的要求。因為,傳統的其它處理 器都有不同的缺陷。MCU的速度較慢;CPU體積較大,功耗較高;嵌入CPU的成本較高。 DSP的發(fā)展,使得在許多速度要求較高,算法較復雜的場(chǎng)合,取代MCU或其它處理器,而成本有可能更低。 如何選擇DSP? 選擇DSP可以根據以下幾方面決定: 1)速度: DSP速度一般用MIPS或FLOPS表示,即百萬(wàn)次/秒鐘。根據您對處理速度的要求選擇適合的器件。一般選擇處理速度不要過(guò)高,速度高的DSP,系統實(shí)現也較困難。 2)精度: DSP芯片分為定點(diǎn)、浮點(diǎn)處理器,對于運算精度要求很高的處理,可選擇浮點(diǎn)處理器。定點(diǎn)處理器也可完成浮點(diǎn)運算,但精度和速度會(huì )有影響。 3)尋址空間: 不同系列DSP程序、數據、I/O空間大小不一,與普通MCU不同,DSP在一個(gè)指令周期內能完成多個(gè)操作,所以DSP的指令效率很高,程序空間一般不會(huì )有問(wèn)題,關(guān)鍵是數據空間是否滿(mǎn)足。數據空間的大小可以通過(guò)DMA的幫助,借助程序空間擴大。 4)成本: 一般定點(diǎn)DSP的成本會(huì )比浮點(diǎn)DSP的要低,速度也較快。要獲得低成本的DSP系統,盡量用定點(diǎn)算法,用定點(diǎn)DSP。 5)實(shí)現方便: 浮點(diǎn)DSP的結構實(shí)現DSP系統較容易,不用考慮尋址空間的問(wèn)題,指令對C語(yǔ)言支持的效率也較高。 6)內部部件:根據應用要求,選擇具有特殊部件的DSP。如:C2000適合于電機控制;OMAP適合于多媒體等。 要了解DSP芯片的性能,本網(wǎng)中的"DSP及相關(guān)器件"中有介紹。 DSP同MCU相比的特點(diǎn)? 1) DSP的速度比MCU快,主頻較高。 2)DSP適合于數據處理,數據處理的指令效率較高。 3)DSP均為16位以上的處理器,不適合于低檔的場(chǎng)合。 4)DSP可以同時(shí)處理的事件較多,系統級成本有可能較低。 5)DSP的靈活性較好,大多數算法都可以軟件實(shí)現。 6)DSP的集成度較高,可靠性較好。 DSP同嵌入CPU相比的特點(diǎn)? 1) DSP是單片機,構成系統簡(jiǎn)單。 2)DSP的速度快。 3)DSP的成本較低。 4)DSP的性能高,可以處理較多的任務(wù)。 如何編寫(xiě)C2000片內Flash? DSP中的Flash的編寫(xiě)方法有三中: 1.通過(guò)仿真器編寫(xiě):在我們的網(wǎng)頁(yè)上有相關(guān)的軟件,在銷(xiāo)售仿真器時(shí)我們也提供相關(guān)軟件。其中 LF240x的編寫(xiě)可以在CCS中加入一個(gè)插件,F24x的編寫(xiě)需要在windows98下的DOS窗中進(jìn)行。具體步驟見(jiàn)軟件中的readme。有幾點(diǎn)需 要注意: a.必須為MC方式; b.F206的工作頻率必須為20MHz; c.F240需要根據PLL修改C240_CFG.I文件。建議外部時(shí)鐘為20MHz。 d.LF240x也需要根據PLL修改文件。 d.如果編寫(xiě)有問(wèn)題,可以用BFLWx.BAT修復。 2.提供串口編寫(xiě):TI的網(wǎng)頁(yè)上有相關(guān)軟件。注意只能編寫(xiě)一次,因為編寫(xiě)程序會(huì )破壞串口通信程序。 3.在你的程序中編寫(xiě):TI的網(wǎng)頁(yè)上有相關(guān)資料。 如何編寫(xiě)DSP外部的Flash? DSP的外部Flash編寫(xiě)方法: 1.通過(guò)編程器編寫(xiě):將OUT文件通過(guò)HEX轉換程序轉換為編程器可以接受的格式,再由編程器編寫(xiě)。 2.通過(guò)DSP軟件編寫(xiě):您需要根據Flash的說(shuō)明,編寫(xiě)Flash的編寫(xiě)程序,將應用程序和編寫(xiě)Flash的程序分別load到RAM中,運行編寫(xiě)程序編寫(xiě)。 對于C5000,大于48K的程序如何BOOT? 對于C5000,片內的BOOT程序在上電后將數據區的內容,搬移到程序區的RAM中,因此FLASH必須在RESET后放在數據區。由于C5000,數據區的空間有限,一次BOOT的程序不能對于48K。解決的方法如下: 1.在RESET后,將FLASH譯碼在數據區,RAM放在程序區,片內BOOT程序將程序BOOT到RAM中。 2.用戶(hù)初試化程序發(fā)出一個(gè)I/O命令(如XF),將FLASH譯碼到程序區的高地址。開(kāi)放數據區用于其它的RAM。 3.用戶(hù)初試化程序中包括第二次BOOT程序(此程序必須用戶(hù)自己編寫(xiě)),將FLASH中沒(méi)有BOOT的其它代碼搬移到RAM中。 4.開(kāi)始運行用戶(hù)處理程序。 DSP外接存儲器的控制方式 對于一般的存儲器具有RD、WR和CS等控制信號,許多DSP(C3x、C5000)都沒(méi)有控制信號直接連接存儲器,一般采用的方式如下: 1.CS有地址線(xiàn)和PS、DS或STRB譯碼產(chǎn)生; 2./RD=/STRB+/R/W; 3./WR=/STRB+R/W。 GEL文件的功能? GEL文件的功能同emuinit.cmd的功能基本相同,用于初始化DSP。但它的功能比emuinit的功能有所增強,GEL在CCS下有一個(gè)菜單,可以根據DSP的對象不同,設置不同的初始化程序。以TMS320LF2407為例: #define SCSR1 0x7018 ;定義scsr1寄存器 #define SCSR2 0X7019 ;定義scsr2寄存器 #define WDKEY 0x7025 ;定義wdkey寄存器 #define WDNTR 0x7029 ;定義wdntr寄存器 StartUp() ; 開(kāi)始函數 { GEL_MapReset(); ; 存儲空間復位 GEL_MapAdd(0x0000,0,0x7fff,1,1); 定義程序空間從0000-7fff 可讀寫(xiě) GEL_MapAdd(0x8000,0,0x7000,1,1); 定義程序空間從8000-f000 可讀寫(xiě) GEL_MapAdd(0x0000,1,0x10000,1,1); 定義數據空間從0000-10000可讀寫(xiě) GEL_MapAdd(0xffff,2,1,1,1); 定義i/o 空間0xffff可讀寫(xiě) GEL_MapOn(); 存儲空間打開(kāi) GEL_MemoryFill(0xffff,2,1,0x40); 在i/o空間添入數值40h *(int *)SCSR1=0x0200; 給scsr1寄存器賦值 *(int *)SCSR2=0x000C; 給scsr2寄存器賦值,在這里可以進(jìn)行mp/mc方式的轉換 *(int *)WDNTR=0x006f; 給wdntr寄存器賦值 *(int *)WDKEY=0x055; 給wdkey寄存器賦值 *(int *)WDKEY=0x0AA; 給wdkey寄存器賦值 } 使用TI公司模擬器件與DSP結合使用的好處。 1) 在使用TI公司的DSP的同時(shí),使用TI公司的模擬可以和DSP進(jìn)行無(wú)縫連接。器件與器件之間不需要任何的連接或轉接器件。這樣即減少了板卡的尺寸,也降低了開(kāi)發(fā)難度。 2)同為T(mén)I公司的產(chǎn)品,很多器件可以固定搭配使用。少了器件選型的煩惱 3)TI在CCS中提供插件,可以用于DSP和模擬器件的開(kāi)發(fā),非常方便。 C語(yǔ)言中可以嵌套匯編語(yǔ)言? 可以。在A(yíng)NSI C標準中的標準用法就是用C語(yǔ)言編寫(xiě)主程序,用匯編語(yǔ)言編寫(xiě)子程序,中斷服務(wù)程序,一些算法,然后用C語(yǔ)言調用這些匯編程序,這樣效率會(huì )相對比較高 在定點(diǎn)DSP系統中可否實(shí)現浮點(diǎn)運算 當然可以,因為DSP都可以用C,只要是可以使用c語(yǔ)言的場(chǎng)合都可以實(shí)現浮點(diǎn)運算。 JTAG頭的使用會(huì )遇到哪些情況 1) DSP的CLKOUT沒(méi)有輸出,工作不正常。 2)Emu0,Emu1需要上拉。 3)TCK的頻率應該為10M。 4)在3.3V DSP中,PD腳為3.3V 供電,但是仿真器上需要5V電壓供電,所以PP仿真器盒上需要單獨供電。 4)仿真多片DSP。在使用菊花鏈的時(shí)候,第一片DSP的TDO接到第二片DSP的TDI即可。注意當串聯(lián)DSP比較多的時(shí)候,信號線(xiàn)要適當的增加驅動(dòng)。 include頭文件(.h)的主要作用 頭文件,一般用于定義程序中的函數、參數、變量和一些宏單元,同庫函數配合使用。因此,在使用庫時(shí),必須用相應的頭文件說(shuō)明。 DSP中斷向量的位置 1) 2000系列dsp的中斷向量只能從0000H處開(kāi)始。所以在我們調試程序的時(shí)候,要把DSP選擇為MP(微處理器方式),把片內的Flash屏蔽掉,免去每次更改程序都要重新燒寫(xiě)Flash工作。 2)3x系列dsp的中斷向量也只能在固定的地址。 3)5000,6000系列dsp的中斷向量可以重新定位。但是它只能被重新定位到Page0范圍內的任何空間。 有源晶振與晶體的區別,應用范圍及用法 1) 晶體需要用DSP片內的振蕩器,在datasheet上有建議的連接方法。晶體沒(méi)有電壓的問(wèn)題,可以適應于任何DSP,建議用晶體。 2)有源晶振不需要DSP的內部振蕩器,信號比較穩定。有源晶振用法:一腳懸空,二腳接地,三腳接輸出,四腳接電壓。 程序經(jīng)常跑飛的原因 1) 程序沒(méi)有結尾或不是循環(huán)的程序。 2)nmi管腳沒(méi)有上拉。 3)在看門(mén)狗動(dòng)作的時(shí)候程序會(huì )經(jīng)常跑飛。 4)程序編制不當也會(huì )引起程序跑飛。 5)硬件系統有問(wèn)題。 并行FLASH引導的一點(diǎn)經(jīng)驗-阿哲 最近BBS上關(guān)于FLASH和BOOT的討論很活躍,我也多次來(lái)此請教。前幾天自制的DSP板引導成功,早就打算寫(xiě)寫(xiě)這方面的東西。我用的 DSP是5416,以其為核心,做了一個(gè)相對獨立的子系統(硬件、軟件、算法),目前都已基本做好。 下面把在FLASH引導方面做的工作向大家匯報一下,希望能對大家有所幫助。本人經(jīng)驗和文筆都有限,寫(xiě)的不好請大家諒解。 硬件環(huán)境: DSP:TMS320VC5416PGE160 FLASH:SST39VF400A-70-4C-EK 都是貼片的,FLASH映射在DSP數據空間的0x8000-0xFFFF 軟件環(huán)境: CCS v2.12.01 主 程序(要燒入FLASH的程序): DEBUG版,程序占用空間0x28000-0x2FFFF(片內SARAM),中斷向量表在0x0080-0x00FF(片內DARAM),數據空間使 用0x0100-0x7FFF(片內DARAM)。 因為FLASH是貼片的,所以需要自己編一個(gè)數據搬移程序,把要主程序搬移到FLASH中。在寫(xiě)入FLASH數據時(shí),還應寫(xiě)入引導表的格式數據。最后在數 據空間的0xFFFF處寫(xiě)入引導表的起始地址(這里為0x8000)。 搬移程序: DEBUG版,程序空間0x38000-0x3FFFF(片內SARAM),中斷向量表在0x7800-0x78FF(片內DARAM),數據空間使用 0x5000-0x77FF(片內DARAM)。 搬移程序不能使用與主程序的程序空間和中斷向量表重合的物理空間,以免覆蓋。 燒寫(xiě)時(shí),同時(shí)打開(kāi)主程序和搬移程序的PROJECT,先LOAD主程序,再LOAD搬移程序,然后執行搬移程序,燒寫(xiě)OK! 附:搬移程序(僅供參考) volatile unsigned int *pTemp=(unsigned int *)0x7e00; unsigned int iFlashAddr; int iLoop; /* 在引導表頭存放并行引導關(guān)鍵字 */ iFlashAddr=0x8000; WriteFlash(iFlashAddr,0x10aa); iFlashAddr++; /* 初始化SWWSR值 */ WriteFlash(iFlashAddr,0x7e00); iFlashAddr++; /* 初始化BSCR值 */ WriteFlash(iFlashAddr,0x8006); iFlashAddr++; /* 程序執行的入口地址 */ WriteFlash(iFlashAddr,0x0002); iFlashAddr++; WriteFlash(iFlashAddr,0x8085); iFlashAddr++; /* 程序長(cháng)度 */ WriteFlash(iFlashAddr,0x7f00); iFlashAddr++; /* 程序要裝載到的地址 */ WriteFlash(iFlashAddr,0x0002); iFlashAddr++; WriteFlash(iFlashAddr,0x8000); iFlashAddr++; for (iLoop=0;iLoop<0x7f00;iLoop++) { /* 從程序空間讀數據,放到暫存單元 */ asm(" pshm al"); asm(" pshm ah"); asm(" rsbx cpl"); asm(" ld #00fch,dp"); asm(" stm #0000h, ah"); asm(" MVDM _iLoop, al"); asm(" add #2800h,4,a"); asm(" reada 0h"); asm(" popm ah"); asm(" popm al"); asm(" ssbx cpl"); /* 把暫存單元內容寫(xiě)入FLASH */ WriteFlash(iFlashAddr,*pTemp); iFlashAddr++; } /* 中斷向量表長(cháng)度 */ WriteFlash(iFlashAddr,0x0080); iFlashAddr++; /* 中斷向量表裝載地址 */ WriteFlash(iFlashAddr,0x0000); iFlashAddr++; WriteFlash(iFlashAddr,0x0080); iFlashAddr++; for (iLoop=0;iLoop<0x0080;iLoop++) { /* 從程序空間讀數據,放到暫存單元 */ asm(" pshm al"); asm(" pshm ah"); asm(" rsbx cpl"); asm(" ld #00fch,dp"); asm(" stm #0000h, ah"); asm(" MVDM _iLoop, al"); asm(" add #0080h,0,a"); asm(" reada 0h"); asm(" popm ah"); asm(" popm al"); asm(" ssbx cpl"); /* 把暫存單元內容寫(xiě)入FLASH */ WriteFlash(iFlashAddr,*pTemp); iFlashAddr++; } /* 寫(xiě)入引導表結束標志 */ WriteFlash(iFlashAddr,0x0000); iFlashAddr++; WriteFlash(iFlashAddr,0x0000); /* 在數據空間的0xFFFF寫(xiě)入引導表起始地址 */ iFlashAddr=0xffff; WriteFlash(iFlashAddr,0x8000); 關(guān)于LF2407A的FLASH燒寫(xiě)問(wèn)題的幾點(diǎn)說(shuō)明 TI現在關(guān)于LF24x寫(xiě)入FLASH的工具最新為c2000flashprogsw_v112??梢灾С諰F2407、LF2407a、 LF2401及相關(guān)的LF240x系列。建議使用此版本。在http: //focus.ti.com/docs/tool/toolfolder.jhtml?PartNumber=C24XSOFTWARE上可以下載到這 個(gè)工具。我們仿真器自帶的光盤(pán)中也有此燒寫(xiě)程序。 在使用這個(gè)工具時(shí)注意: 一,先解壓,再執行setup.exe。 二、進(jìn)入cc中,在tools圖標下有燒寫(xiě)工具; 1、 關(guān)于FLASH時(shí)鐘的選擇,此燒寫(xiě)工具默認最高頻率進(jìn)行FLASH的操作。根據目標系統的工作主頻重新要進(jìn)行PLL設置。方法:先在advance options下面的View Config file中修改倍頻。存盤(pán)后,在相應的目錄下(tic2xx\algos\相應目錄)運行buildall.bat就可以完成修改了。再進(jìn)行相應的操作即 可。 2、若是你所選的頻率不是最高頻率,還需要設定你自已的timings.xx來(lái)代替系統默認的最高頻率的timings.xx。例如 LF2407a的默認文件是timings.40。Timings.xx可以利用include\timings.xls的excel工作表來(lái)生成。然后 在advance options下面的View Config file中修改相應的位置。存盤(pán)后,在相應的目錄下運行buildall.bat就可以完成修改了。 3、對于TMS320LF240XA系 列,還要注意:由于這些DSP的FLASH具有加密功能,加密地址為程序空間的0x40-0X43H,程序禁止寫(xiě)入此空間,如果寫(xiě)了,此空間的數據被認為 是加密位,斷電后進(jìn)入保護FLASH狀態(tài),使FLASH不可重新操作,從而使DSP報廢,燒寫(xiě)完畢后一定要進(jìn)行Program passwords的操作,如果不做加密操作就默認最后一次寫(xiě)入加密位的數據作為密碼。 4、2407A不能用DOS下的燒寫(xiě)軟件燒寫(xiě),必須用c2000flashprogsw_v112軟件燒寫(xiě); 5、建議如下: 1)、一般調試時(shí),在RAM中進(jìn)行; 2)、程序燒寫(xiě)時(shí),避開(kāi)程序空間0x40-0x43H加密區,程序最好小于32k; 3)、每次程序燒寫(xiě)完后,將word0,word1,word2,word3分別輸入自己的密碼,再點(diǎn)擊 Program password,如果加密成功,提示Program is arrayed,如果0x40-0x43h中寫(xiě)入的是ffff,認為處于調試狀態(tài),flash不會(huì )加密; 4)、斷電后,下次重新燒寫(xiě)時(shí)需要往word0~word3輸入已設的密碼,再u(mài)nlock,成功后可以重新燒寫(xiě)了; 6、VCPP管腳接在+5V上,是應直接接的,中間不要加電阻。 7、具體事宜請閱讀相應目錄下的readme1,readme2幫助文件。 8.注意*.cmd文件的編寫(xiě)時(shí)應該避開(kāi)40-43H單元,好多客戶(hù)由于沒(méi)有注意到這里而把FALSH加密。 如何設置硬件斷點(diǎn)? 在profiler ->profile point -> break point c54x的外部中斷是電平響應還是沿響應? 是沿響應,準確的說(shuō),它要檢測到100(一個(gè)clk的高和兩個(gè)clk的低)的變化才可以。 參考程序,里面好象都要 disable wachdog,不知道為什么? watchdog是一個(gè)計數器,溢出時(shí)會(huì )復位你的DSP,不disable的話(huà),你的系統會(huì )動(dòng)不動(dòng)就reset。 時(shí)鐘電路選擇原則 1,系統中要求多個(gè)不同頻率的時(shí)鐘信號時(shí),首選可編程時(shí)鐘芯片; 2,單一時(shí)鐘信號時(shí),選擇晶體時(shí)鐘電路; 3,多個(gè)同頻時(shí)鐘信號時(shí),選擇晶振; 4,盡量使用DSP片內的PLL,降低片外時(shí)鐘頻率,提高系統的穩定性; 5,C6000、C5510、C5409A、C5416、C5420、C5421和C5441等DSP片內無(wú)振蕩電路,不能用晶體時(shí)鐘電路; 6,VC5401、VC5402、VC5409和F281x等DSP時(shí)鐘信號的電平為1.8V,建議采用晶體時(shí)鐘電路 C程序的代碼和數據如何定位 1,系統定義: .cinit 存放C程序中的變量初值和常量; .const 存放C程序中的字符常量、浮點(diǎn)常量和用const聲明的常量; .switch 存放C程序中switch語(yǔ)句的跳針表; .text 存放C程序的代碼; .bss 為C程序中的全局和靜態(tài)變量保留存儲空間; .far 為C程序中用far聲明的全局和靜態(tài)變量保留空間; .stack 為C程序系統堆棧保留存儲空間,用于保存返回地址、函數間的參數傳遞、存儲局部變量和保存中間結果; .sysmem 用于C程序中malloc、calloc和realloc函數動(dòng)態(tài)分配存儲空間 2,用戶(hù)定義: #pragma CODE_SECTION (symbol, "section name"); #pragma DATA_SECTION (symbol, "section name") cmd文件 由3部分組成: 1)輸入/輸出定義:.obj文件:鏈接器要鏈接的目標文件;.lib文件:鏈接器要鏈接的庫文件;.map文件:鏈接器生成的交叉索引文件;.out文件:鏈接器生成的可執行代碼;鏈接器選項 2)MEMORY命令:描述系統實(shí)際的硬件資源 3)SECTIONS命令:描述“段”如何定位 為什么要設計CSL? 1,DSP片上外設種類(lèi)及其應用日趨復雜 2,提供一組標準的方法用于訪(fǎng)問(wèn)和控制片上外設 3,免除用戶(hù)編寫(xiě)配置和控制片上外設所必需的定義和代碼 什么是CSL? 1,用于配置、控制和管理DSP片上外設 2,已為C6000和C5000系列DSP設計了各自的CSL庫 3,CSL庫函數大多數是用C語(yǔ)言編寫(xiě)的,并已對代碼的大小和速度進(jìn)行了優(yōu)化 4,CSL庫是可裁剪的:即只有被使用的CSL模塊才會(huì )包含進(jìn)應用程序中 5,CSL庫是可擴展的:每個(gè)片上外設的API相互獨立,增加新的API,對其他片上外設沒(méi)有影響 CSL的特點(diǎn) 1,片上外設編程的標準協(xié)議:定義一組標準的APIs:函數、數據類(lèi)型、宏; 2,對硬件進(jìn)行抽象,提取符號化的片上外設描述:定義一組宏,用于訪(fǎng)問(wèn)和建立寄存器及其域值 3,基本的資源管理:對多資源的片上外設進(jìn)行管理; 4,已集成到DSP/BIOS中:通過(guò)圖形用戶(hù)接口GUI對CSL進(jìn)行配置; 5,使片上外設容易使用:縮短開(kāi)發(fā)時(shí)間,增加可移植. 為什么需要電平變換? 1) DSP系統中難免存在5V/3.3V混合供電現象; 2)I/O為3.3V供電的DSP,其輸入信號電平不允許超過(guò)電源電壓3.3V; 3)5V器件輸出信號高電平可達4.4V; 4)長(cháng)時(shí)間超常工作會(huì )損壞DSP器件; 5)輸出信號電平一般無(wú)需變換 電平變換的方法 1,總線(xiàn)收發(fā)器(Bus Transceiver): 常用器件: SN74LVTH245A(8位)、SN74LVTH16245A(16位) 特點(diǎn):3.3V供電,需進(jìn)行方向控制, 延遲:3.5ns,驅動(dòng):-32/64mA, 輸入容限:5V 應用:數據、地址和控制總線(xiàn)的驅動(dòng) 2,總線(xiàn)開(kāi)關(guān)(Bus Switch) 常用器件:SN74CBTD3384(10位)、SN74CBTD16210(20位) 特點(diǎn):5V供電,無(wú)需方向控制 延遲:0.25ns,驅動(dòng)能力不增加 應用:適用于信號方向靈活、且負載單一的應用,如McBSP等外設信號的電平變換 3,2選1切換器(1 of 2 Multiplexer) 常用器件:SN74CBT3257(4位)、SN74CBT16292(12位) 特點(diǎn):實(shí)現2選1,5V供電,無(wú)需方向控制 延遲:0.25ns,驅動(dòng)能力不增加 應用:適用于多路切換信號、且要進(jìn)行電平變換的應用,如雙路復用的McBSP 4,CPLD 3.3V供電,但輸入容限為5V,并且延遲較大:>7ns,適用于少量的對延遲要求不高的輸入信號 5,電阻分壓 10KΩ和20KΩ串聯(lián)分壓,5V×20÷(10+20)≈3.3V 未用的輸入/輸出引腳的處理 1,未用的輸入引腳不能懸空不接,而應將它們上拉活下拉為固定的電平 1)關(guān)鍵的控制輸入引腳,如Ready、Hold等,應固定接為適當的狀態(tài),Ready引腳應固定接為有效狀態(tài),Hold引腳應固定接為無(wú)效狀態(tài) 2)無(wú)連接(NC)和保留(RSV)引腳,NC 引腳:除非特殊說(shuō)明,這些引腳懸空不接,RSV引腳:應根據數據手冊具體決定接還是不接 3)非關(guān)鍵的輸入引腳,將它們上拉或下拉為固定的電平,以降低功耗 2,未用的輸出引腳可以懸空不接 3,未用的I/O引腳:如果確省狀態(tài)為輸入引腳,則作為非關(guān)鍵的輸入引腳處理,上拉或下拉為固定的電平;如果確省狀態(tài)為輸出引腳,則可以懸空不接 |
聯(lián)系客服