打印
[DSP编程]

28335片内片外SRAM写入速度

[复制链接]
784|2
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
JonathanChen|  楼主 | 2015-10-28 12:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
写8000个数据到片外SRAM,XINTF6,0x10FC00开始
写8000个数据到片内SRAM,0x00E000开始
发现速度一样,都再1500微秒左右。

SRAM最大支持8ns,配置如下
void init_zone6()
{
        EALLOW;
        // Make sure the XINTF clock is enabled
        SysCtrlRegs.PCLKCR3.bit.XINTFENCLK = 1;
        EDIS;
        // Configure the GPIO for XINTF with a 16-bit data bus
        // This function is in DSP2833x_Xintf.c
        InitXintf16Gpio();

        // All Zones---------------------------------
        // Timing for all zones based on XTIMCLK = SYSCLKOUT
        EALLOW;
        XintfRegs.XINTCNF2.bit.XTIMCLK = 0;//XTIMCLK = SYSCLKOUT
        // Buffer up to 3 writes
        XintfRegs.XINTCNF2.bit.WRBUFF = 3; //3级写缓冲
        // XCLKOUT is enabled
        XintfRegs.XINTCNF2.bit.CLKOFF = 0;//XCLKOUT使能
        // XCLKOUT = XTIMCLK
        XintfRegs.XINTCNF2.bit.CLKMODE = 0;//XCLKOUT = XTIMCLK

        // Zone 6------------------------------------
        // When using ready, ACTIVE must be 1 or greater
        // Lead must always be 1 or greater
        // Zone write timing =150/(1+2+1+1)=30Mhz
        XintfRegs.XTIMING6.bit.XWRLEAD = 1;//建立周期数为1
        XintfRegs.XTIMING6.bit.XWRACTIVE = 2;//激活周期数为2
        XintfRegs.XTIMING6.bit.XWRTRAIL = 1;//跟踪周期数为1
        // Zone read timing  =150/(1+3+0+1)=30Mhz
        XintfRegs.XTIMING6.bit.XRDLEAD = 1;
        XintfRegs.XTIMING6.bit.XRDACTIVE = 3;
        XintfRegs.XTIMING6.bit.XRDTRAIL = 0;

        // don't double all Zone read/write lead/active/trail timing
        XintfRegs.XTIMING6.bit.X2TIMING = 0;

        // Zone will not sample XREADY signal
        XintfRegs.XTIMING6.bit.USEREADY = 0;
        XintfRegs.XTIMING6.bit.READYMODE = 0;

        // 1,1 = x16 data bus
        // 0,1 = x32 data bus
        // other values are reserved
        XintfRegs.XTIMING6.bit.XSIZE = 3;
        EDIS;
        //Force a pipeline flush to ensure that the write to
        //the last register configured occurs before returning.
        asm(" RPT #7 || NOP");
}

程序如下
for(b=0;b<500;b++)
        {
                for(a=0;a<16;a++)
                {
                        *DMADest++ = *DMASource++;
                }
                DMASource = &DMABuf2[0];
        }

数据都搬过去了
不是说片外比较慢么……

相关帖子

沙发
JonathanChen|  楼主 | 2015-10-28 13:37 | 只看该作者
都没人看的啊
测试了下
片内SRAM写到片外SRAM速度比较快
反过来会慢

使用特权

评论回复
板凳
JY-DX-JY| | 2015-10-28 19:09 | 只看该作者
还有这事?

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

4

主题

10

帖子

0

粉丝