|
DSP的硬件測試說明:
平臺說明:

圖1-1 Code Composer Studio 6.0.0.00190 C/C++開發(fā)環(huán)境
硬件平臺基于TMS320F28335芯片,軟件平臺基于TI的Code Composer Studio 6.0.0.00190 C/C++開發(fā)環(huán)境,如圖1-1所示。
工作進度說明:
1.完成了DSP外擴SRAM的硬件的完整測試,通過修改TI官方的.cmd文件和庫函數(shù)調(diào)用,
可以將FLASH中的函數(shù)復(fù)制到外部SRAM中運行,大大提高DSP程序的運行速度,附有詳細說明。
2. 完成了RS485的驅(qū)動編寫及應(yīng)用測試。
3.利用官方的ADC_DMA、I2C例程,完成ADC和EEPROM的測試,整合了ADC_DMA例程。
4.CAN通訊和轉(zhuǎn)速中斷的代碼公司已有,未整理。
5.DSP內(nèi)置的看門狗模塊已開啟。
一、DSP擴展的外部SRAM應(yīng)用說明(已測試完畢)
前言: DSP可以工作中150MHz的頻率下,為了發(fā)揮其高速運行的特性, 一般會將
FLASH程序內(nèi)容復(fù)制到外部高速SRAM中運行,TMS320F28335內(nèi)部有34K X 16bit的SRAM,
TI將內(nèi)部SRAM分成了多塊(見F28335.cmd)。
一般的程序在內(nèi)置FLASH中運行,程序在FLASH中的運行速度由FLASH的讀取速度決定,
如果沒有采用FLASH的加速技術(shù),一般需要設(shè)置等待時間。 要想使程序高速運轉(zhuǎn),
最少要擴展一塊SRAM 來高速運行DSP算法或中斷函數(shù)。
1.外部SRAM分區(qū)說明
本項目的硬件擴展了256K 16bit SRAM 時鐘延遲為10ns
SRAM型號為: IS61LV25616AL-10T
定位地址為: 0x0200000 前128K 用作程序空間,后128K用作數(shù)據(jù)空間
定位地址和ARM的內(nèi)部SRAM地址一樣,DSP中文數(shù)據(jù)手冊參考內(nèi)容如下圖所示(可放大):

圖1-2 DSP典型的16位和32位數(shù)據(jù)總線連接示意圖
IS61LV25616AL-10T芯片的數(shù)據(jù)總線是16位,后面的STM32F429板子也用了這個芯片,但增加了高低位選通線,
因此可以讀高低字節(jié),比DSP更靈活:DSP最少一次讀2字節(jié),ARM想讀任何字節(jié)都可以。另外ARM內(nèi)部有FLASH加速,
可以直接跑180MHz,外設(shè)是90MHz,但比DSP性能相差已經(jīng)比較小了。
DSP的GPIO37/XZCS7引腳控制的外部SRAM的物理地址如下圖所示:
圖1-3 GPIO37/XZCS7引腳控制的外部SRAM的物理地址說明
在F28335.CMD文件分配,詳細內(nèi)容如下:
XINTF zone 7 - program space
ZONE7A : origin = 0x0200000, length = 0x020000
XINTF zone 7 - data space
ZONE7B : origin = 0x0220000, length = 0x020000
2.外部DATA SRAM使用說明
內(nèi)部SRAM不夠用,則使用外部DATA SRAM,用法如下
#pragma DATA_SECTION(bufferB, "ZONE7DATA");
uint16_t bufferB[512];
仿真測試結(jié)果:
觀察數(shù)據(jù)0x22000區(qū)域,可以看到bufferB區(qū)域被程序設(shè)置了正確的數(shù)據(jù)。
2.外部CODE SRAM使用說明
外部中斷函數(shù)或一般函數(shù)使用如下格式的聲明
#pragma CODE_SECTION(cpu_timer0_isr,"xintffuncs");
#pragma CODE_SECTION(cpu_timer1_isr,"xintffuncs");
編譯器會將這些特定的函數(shù)分配在一個固定的FLASH區(qū)域
起始地址為XintffuncsLoadStart
結(jié)束地址為XintffuncsLoadEnd
主程序中XINTF Zone 7初始化后,調(diào)用如下函數(shù)將這個區(qū)域的特定函數(shù)
復(fù)制到外部SRAM的運行程序空間(0x0200000-0x021FFFF)
MemCopy(&XintffuncsLoadStart, &XintffuncsLoadEnd, &XintffuncsRunStart);
頻繁運行或調(diào)用的捕獲函數(shù)、定時器函數(shù)或特定算法,只有在高速SRAM中運行,
才能真正發(fā)揮TMS320C28335的實際性能。
仿真測試結(jié)果:
cpu_timer0_isr和cpu_timer1_isr定位在0x200000-0x21FFFF區(qū)域
對這兩個中斷函數(shù)設(shè)置斷點,可以正常進入中斷運行。
定時器0中斷函數(shù)的實際仿真結(jié)果如下圖所示:

圖1-4 定時器0中斷函數(shù)的加載到外部SRAM前后對比分析圖
定時器1中斷函數(shù)的實際斷點仿真如下(是無損壓縮圖片,可以放大):

圖1-5 定時器1中斷代碼的運行地址分析
可以得出結(jié)論,在反匯編窗口,看到定時器1中斷的入口地址是0x2002a,在1ms的定時器1中斷內(nèi)翻轉(zhuǎn)GPIO50腳,產(chǎn)生一個方波。

圖1-6 定時器1中斷的應(yīng)用測試截圖
該圖比較小,是因為用的是小示波器保存到U盤的圖片。用該示波器保存成csv格式,僅有2500個數(shù)據(jù)。
錄波儀錄制數(shù)據(jù)波形比較長,十幾秒就可以存下超過100萬個點的數(shù)據(jù),當(dāng)然普通的.xls或.xlsx文件是存不下的。
二、通信配置說明(進行中)
1. RS485通信配置和應(yīng)用測試代碼
以下是網(wǎng)絡(luò)參考代碼,實際的配置比較繁瑣,這里簡略不寫了。
// 重新映射 PIE - Timer 0的中斷
- EALLOW; // 解除寄存器保護
- PieVectTable.TXBINT = &SCI_TX_isr;
- PieVectTable.RXBINT = &SCI_RX_isr;
- EDIS; // 使能寄存器保護
- // 使能接收中斷
- PieCtrlRegs.PIEIER8.bit.INTx3 = 1;
- // 使能發(fā)送中斷
- // PieCtrlRegs.PIEIER9.bit.INTx4 = 1;
- IER |= 0x100;
- // 全局中斷使能和更高優(yōu)先級的實時調(diào)試事件
- EINT; // 全局中斷使能INTM
- ERTM; // 使能實時調(diào)試中斷DBGM
SCIC串口發(fā)送和接收的大致流程如圖1-6所示。

圖1-7 SCIC串口的發(fā)送和接收流程
// 利用TMS320F28335的SCIC串口FIFO來發(fā)送數(shù)據(jù),只要數(shù)據(jù)包不超過16,
// 都可以無需等待,直接將所有字節(jié)放入FIFO,極大的節(jié)約CPU的時間開銷
// 具體實現(xiàn)如下,至于官方的例程,等待當(dāng)前字節(jié)發(fā)送完畢再發(fā)下一個,
// 這樣太浪費時間,在實際產(chǎn)品中基本上沒人用
if(Flag_CpuTimer0){
Flag_CpuTimer0 = 0; // 10ms 定時周期
GpioDataRegs.GPBSET.bit.GPIO50 = 1; // RS485 DE = 1 RS485切換為發(fā)送狀態(tài)
for(i = 0; i < 10; ++i){
ScicRegs.SCITXBUF = bufferA; // 將10個數(shù)據(jù)放入FIFO,然后自動依次轉(zhuǎn)移到移位寄存器
}
asm(" nop");
asm(" nop");
asm(" nop");
asm(" nop");
asm(" nop");
asm(" nop");
}
// RS485處于發(fā)送狀態(tài),且SCIC移位寄存器為空
if((GpioDataRegs.GPBDAT.bit.GPIO50 == 1)&&(ScicRegs.SCICTL2.bit.TXEMPTY == 1)){
GpioDataRegs.GPBCLEAR.bit.GPIO50 = 1; // RS485 DE = 0 RS485轉(zhuǎn)為接收狀態(tài)
}
2. CAN通信配置
進行中
三、數(shù)據(jù)存儲器配置說明(I2C)
擴展了512K byte EEPROM,打開官方的I2C例程(非GPIO模擬的時序),已測試OK。
四、集成功率芯片測試(GPIO)
主要是對功率器件的測試,進行中
五、看門狗配置說明(已完成)
一般嵌入式系統(tǒng)都需要開啟外部或內(nèi)部看門狗,以防意外的CPU掛起死機
六、TI官方的CMD文件說明(實際應(yīng)用的文件是在官方的基礎(chǔ)上稍作修改)
TI官方提供的CMD文件有三個: 28335_RAM_lnk.cmd、F28335.cmd、DSP2833x_Headers_nonBIOS.cmd
調(diào)試程序時,將28335_RAM_lnk.cmd文件加入工程中,程序被加載到SRAM中運行。
實際的產(chǎn)品運行時,需要將程序下載到FLASH中,并從FLASH中啟動,這時需要
在工程中加入F28335.cmd文件,同時屏蔽28335_RAM_lnk.cmd文件。
TI官方文件F28335.cmd對內(nèi)部SRAM的分配如下:
BOOT_RSVD : origin = 0x000000, length = 0x000050 // Part of M0, BOOT rom will use this for stack PAGE 1
RAMM0 : origin = 0x000050, length = 0x0003B0 // on-chip RAM block M0 PAGE 1
RAMM1 : origin = 0x000400, length = 0x000400 // on-chip RAM block M1 PAGE 1
ZONE0 : origin = 0x004000, length = 0x001000 // XINTF zone 0 PAGE 0
RAML0 : origin = 0x008000, length = 0x001000 // on-chip RAM block L0 PAGE 0
RAML1 : origin = 0x009000, length = 0x001000 // on-chip RAM block L1 PAGE 0
RAML2 : origin = 0x00A000, length = 0x001000 // on-chip RAM block L2 PAGE 0
RAML3 : origin = 0x00B000, length = 0x001000 // on-chip RAM block L3 PAGE 0
RAML4 : origin = 0x00C000, length = 0x001000 // on-chip RAM block L1 PAGE 1
RAML5 : origin = 0x00D000, length = 0x001000 // on-chip RAM block L1 PAGE 1
RAML6 : origin = 0x00E000, length = 0x001000 // on-chip RAM block L1 PAGE 1
RAML7 : origin = 0x00F000, length = 0x001000 // on-chip RAM block L1 PAGE 1
Allocate DMA-accessible RAM sections:
DMARAML4 : > RAML4, PAGE = 1
DMARAML5 : > RAML5, PAGE = 1
DMARAML6 : > RAML6, PAGE = 1
DMARAML7 : > RAML7, PAGE = 1
Allocate uninitalized data sections:
.stack : > RAMM1 PAGE = 1
.ebss : > RAML4 PAGE = 1
.esysmem : > RAMM1 PAGE = 1
TI官方文件DSP2833x_Headers_nonBIOS.cmd對特殊功能寄存器的映射(PAGE 1)如下
DEV_EMU : origin = 0x000880, length = 0x000180 // device emulation registers
FLASH_REGS : origin = 0x000A80, length = 0x000060 // FLASH registers
CSM : origin = 0x000AE0, length = 0x000010 // code security module registers
ADC_MIRROR : origin = 0x000B00, length = 0x000010 // ADC Results register mirror
XINTF : origin = 0x000B20, length = 0x000020 // external interface registers
CPU_TIMER0 : origin = 0x000C00, length = 0x000008 // CPU Timer0 registers
CPU_TIMER1 : origin = 0x000C08, length = 0x000008 // CPU Timer0 registers (CPU Timer1 & Timer2 reserved TI use)
CPU_TIMER2 : origin = 0x000C10, length = 0x000008 // CPU Timer0 registers (CPU Timer1 & Timer2 reserved TI use)
PIE_CTRL : origin = 0x000CE0, length = 0x000020 // PIE control registers
PIE_VECT : origin = 0x000D00, length = 0x000100 // PIE Vector Table
DMA : origin = 0x001000, length = 0x000200 // DMA registers
MCBSPA : origin = 0x005000, length = 0x000040 // McBSP-A registers
MCBSPB : origin = 0x005040, length = 0x000040 // McBSP-B registers
ECANA : origin = 0x006000, length = 0x000040 // eCAN-A control and status registers
ECANA_LAM : origin = 0x006040, length = 0x000040 // eCAN-A local acceptance masks
ECANA_MOTS : origin = 0x006080, length = 0x000040 // eCAN-A message object time stamps
ECANA_MOTO : origin = 0x0060C0, length = 0x000040 // eCAN-A object time-out registers
ECANA_MBOX : origin = 0x006100, length = 0x000100 // eCAN-A mailboxes
ECANB : origin = 0x006200, length = 0x000040 // eCAN-B control and status registers
ECANB_LAM : origin = 0x006240, length = 0x000040 // eCAN-B local acceptance masks
ECANB_MOTS : origin = 0x006280, length = 0x000040 // eCAN-B message object time stamps
ECANB_MOTO : origin = 0x0062C0, length = 0x000040 // eCAN-B object time-out registers
ECANB_MBOX : origin = 0x006300, length = 0x000100 // eCAN-B mailboxes
EPWM1 : origin = 0x006800, length = 0x000022 // Enhanced PWM 1 registers
EPWM2 : origin = 0x006840, length = 0x000022 // Enhanced PWM 2 registers
EPWM3 : origin = 0x006880, length = 0x000022 // Enhanced PWM 3 registers
EPWM4 : origin = 0x0068C0, length = 0x000022 // Enhanced PWM 4 registers
EPWM5 : origin = 0x006900, length = 0x000022 // Enhanced PWM 5 registers
EPWM6 : origin = 0x006940, length = 0x000022 // Enhanced PWM 6 registers
ECAP1 : origin = 0x006A00, length = 0x000020 // Enhanced Capture 1 registers
ECAP2 : origin = 0x006A20, length = 0x000020 // Enhanced Capture 2 registers
ECAP3 : origin = 0x006A40, length = 0x000020 // Enhanced Capture 3 registers
ECAP4 : origin = 0x006A60, length = 0x000020 // Enhanced Capture 4 registers
ECAP5 : origin = 0x006A80, length = 0x000020 // Enhanced Capture 5 registers
ECAP6 : origin = 0x006AA0, length = 0x000020 // Enhanced Capture 6 registers
EQEP1 : origin = 0x006B00, length = 0x000040 // Enhanced QEP 1 registers
EQEP2 : origin = 0x006B40, length = 0x000040 // Enhanced QEP 2 registers
GPIOCTRL : origin = 0x006F80, length = 0x000040 // GPIO control registers
GPIODAT : origin = 0x006FC0, length = 0x000020 // GPIO data registers
GPIOINT : origin = 0x006FE0, length = 0x000020 // GPIO interrupt/LPM registers
SYSTEM : origin = 0x007010, length = 0x000020 // System control registers
SPIA : origin = 0x007040, length = 0x000010 // SPI-A registers
SCIA : origin = 0x007050, length = 0x000010 // SCI-A registers
XINTRUPT : origin = 0x007070, length = 0x000010 // external interrupt registers
ADC : origin = 0x007100, length = 0x000020 // ADC registers
SCIB : origin = 0x007750, length = 0x000010 // SCI-B registers
SCIC : origin = 0x007770, length = 0x000010 // SCI-C registers
I2CA : origin = 0x007900, length = 0x000040 // I2C-A registers
CSM_PWL : origin = 0x33FFF8, length = 0x000008 // Part of FLASHA. CSM password locations
PARTID : origin = 0x380090, length = 0x000001 // Part ID register location
2014.8.5 wjandsq@163.com
|
|