DSP應用基礎知識
DSP的內部指令周期較高,外部晶振的主頻不夠,因此DSP大多數(shù)片內均有PLL。但每個系列不盡相同。
1)TMS320C2000系列:
TMS320C20x:PLL可以÷2,×1,×2和×4,因此外部時鐘可以為5MHz-40MHz。
TMS320F240:PLL可以÷2,×1,×1.5,×2,×2.5,×3,×4,×4.5,×5和×9,因此外部時鐘可以為2.22MHz-40MHz。
TMS320F241/C242/F243:PLL可以×4,因此外部時鐘為5MHz。 TMS320LF24xx:PLL可以由RC調節(jié),因此外部時鐘為4MHz-20MHz。
TMS320LF24xxA:PLL可以由RC調節(jié),因此外部時鐘為4MHz-20MHz。
2)TMS320C3x系列:
TMS320C3x:沒有PLL,因此外部主頻為工作頻率的2倍a。
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的指令周期較快,訪問慢速存儲器或外設時需加入等待。等待分硬件等待和軟件等待,每一個系列的等待不完全相同。
1)對于C2000系列: 硬件等待信號為READY,高電平時不等待。 軟件等待由WSGR寄存器決定,可以加入最多7個等待。其中程序存儲器和數(shù)據(jù)存儲器及I/O可以分別設置。
2)對于C3x系列: 硬件等待信號為/RDY,低電平是不等待。 軟件等待由總線控制寄存器中的SWW和WTCNY決定,可以加入最多7個等待,但等待是不分段的,除了片內之外全空間有效。
3)對于C5000系列: 硬件等待信號為READY,高電平時不等待。 軟件等待由SWWCR和SWWSR寄存器決定,可以加入最多14個等待。其中程序存儲器、控制程序存儲器和數(shù)據(jù)存儲器及I/O可以分別設置。
4)對于C6000系列(只限于非同步存儲器或外設): 硬件等待信號為ARDY,高電平時不等待。 軟件等待由外部存儲器接口控制寄存器決定,總線訪問外部存儲器或設備的時序可以設置,可以方便的同異步的存儲器或外設接口。
仿真工作正常對于DSP的基本要求
1)DSP電源和地連接正確。 2)DSP時鐘正確。 3)DSP的主要控制信號,如RS和HOLD信號接高電平。 4)C2000的watchdog關掉。 5)不可屏蔽中斷NMI上拉高電平。
CCS或Emurst運行時提示“Can't Initialize Target DSP”
1)仿真器連接是否正常?
2)仿真器的I/O設置是否正確?
3)XDSPP仿真器的電源是否正確?
4)目標系統(tǒng)是否正確?
5)仿真器是否正常?
6)DSP工作的基本條件是否具備。
建議使用目標板測試。
為什么CCS需要安裝Driver?
CCS是開放的軟件平臺,它可以支持不同的硬件接口,因此不同的硬件接口必須通過標準的Driver同CCS連接。
Driver安裝的常見問題?
請認真閱讀“安裝手冊”和 Driver盤中的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連接后,主機將自動激活相應的Driver。 4)對于SEED-XDSPCI,安裝Readme中的步驟,將I/O口設為240,PCI接口板插入主機后,主機將自動激活相應的Driver。 5)對于Simulator,需要選擇不同的CFG文件,以模擬不同的DSP。 6)對于C5402 DSK,將I/O口設為請認真閱讀“安裝手冊”和Driver盤中的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連接后,主機將自動激活相應的Driver。 4)對于SEED-XDSPCI,安裝Readme中的步驟,將I/O口設為240/280/320/340,PCI接口板插入主機后,主機將自動激活相應的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。
2.Link的cmd文件的作用是什么?
Link的cmd文件用于DSP代碼的定位。由于DSP的編譯器的編譯結果是未定位的,DSP沒有操作系統(tǒng)來定位執(zhí)行代碼,每個客戶設計的DSP系統(tǒng)的配置也不盡相同,因此需要用戶自己定義代碼的安裝位置。以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進制的文件格式?
DSP的開發(fā)軟件集成了一個程序,可以從執(zhí)行文件OUT轉換到編程器可以接受的格式,使得編程器可以用次文件燒寫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仿真器為什么必須連接目標系統(tǒng)(Target)?
DSP的仿真器同單片機的不同,仿真器中沒有DSP,提供IEEE標準的JTAG口對DSP進行仿真調試,所以仿真器必須有仿真對象,及目標系統(tǒng)。目標系統(tǒng)就是你的產品,上面必須有DSP。仿真器提供JTAG同目標系統(tǒng)的DSP相接,通過DSP實現(xiàn)對整個目標系統(tǒng)的調試。
仿真工作正常對于DSP的基本要求
1) DSP電源和地連接正確。
2)DSP時鐘正確。
3)DSP的主要控制信號,如RS和HOLD信號接高電平。
4)C2000的watchdog關掉。
5)不可屏蔽中斷NMI上拉高電平。
CCS或Emurst運行時提示“Can't Initialize Target DSP”
1) 仿真器連接是否正常?
2)仿真器的I/O設置是否正確?
3)XDSPP仿真器的電源是否正確?
4)目標系統(tǒng)是否正確?
5)仿真器是否正常?
6)DSP工作的基本條件是否具備。
建議使用目標板測試。
為什么CCS需要安裝Driver?
CCS是開放的軟件平臺,它可以支持不同的硬件接口,因此不同的硬件接口必須通過標準的Driver同CCS連接。
評論