久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 21673|回復(fù): 3
打印 上一主題 下一主題
收起左側(cè)

DSP外擴SRAM的應(yīng)用測試心得體會

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:75926 發(fā)表于 2015-4-4 01:54 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式


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




分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏3 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:152336 發(fā)表于 2016-12-7 12:13 | 只看該作者
如果外擴SRAM是用于數(shù)據(jù)存儲,可以考慮價格便宜的多的SQPI PSRAM;只要有SPI或Quad SPI接口就可以連接,容量范圍2MB ~ 8MB,比SRAM大很多。它支持突發(fā)數(shù)據(jù)存取,比如一次讀寫1024byte
回復(fù)

使用道具 舉報

板凳
ID:663267 發(fā)表于 2022-11-9 10:14 | 只看該作者
請問怎么能把函數(shù)放到片外RAM中,用到了一些DLL,里面的函數(shù)都有很大的數(shù)組,
執(zhí)行函數(shù)后會有奇怪的問題,剛開始發(fā)現(xiàn)是結(jié)構(gòu)體被覆蓋,使用 CODE_SECTION 把一些大結(jié)構(gòu)體放到片外了。但是今天又發(fā)現(xiàn)系統(tǒng)函數(shù)也被覆蓋了,如 atof 之類的。
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产在线视频一区 | 国产视频第一页 | 一区二区三区中文字幕 | 欧美精产国品一二三区 | 成人免费xxxxx在线视频 | 国产一区二区精品在线观看 | 我要看黄色录像一级片 | 91国产精品 | 亚洲国产精品91 | 亚洲精品在线免费播放 | 亚洲欧美国产毛片在线 | 男女视频免费 | 精品久久久久久中文字幕 | 午夜99| 国产精品久久久久久久久污网站 | 国产精品久久久久久二区 | 精品欧美一区二区三区久久久 | 成人国产精品色哟哟 | 国产精品久久久久久久 | 亚洲aⅴ | 三级在线视频 | a毛片视频网站 | 亚洲色综合 | 四色永久 | 啪一啪 | 国产精品久久久久久久久免费相片 | 在线视频第一页 | 久久国产精品无码网站 | 青草福利 | 国产精品久久久久久久久免费相片 | 国产精品久久久久久久久久免费看 | 成人精品免费视频 | 最新日韩av | 福利片在线观看 | 波多野结衣中文视频 | www成年人视频 | 久久99这里只有精品 | 中文字幕在线免费观看 | 在线日韩欧美 | 欧美一区二区视频 | 国产自产c区 |