upp问题 - TMS320C6748 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 14373|回复: 28
打印 上一主题 下一主题

upp问题

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2014-12-22 14:33:24 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
下面的任务,只能在第一次执行UPP时成功,后面的均不成功,请创龙工程师看看为什么?
Void UPP_TASK(Void)
{

    int i,j,k,target_int_count=2;
    char ch[2];



    upp_interrupt_count  = 0;
    upp_error_count = 0;

    UARTPuts("\tResetting uPP buffers...\r\n",-2);
    // Initialize data buffers
    for (i = 0; i < upp_frame_size; i++)
    {
       upp_buffer_b =i;
       upp_buffer_a = 0xDEAD;
    }

    //for(i=0;i<1024;i++)
    //    temp=0;

    //UPPReset();
    /*启动UPP DMA传输*/
    UARTPuts("upp_prog_dma_i\n",-2);
    upp_reg_hdl->UPID0 = (Uint32)upp_buffer_a;
    upp_reg_hdl->UPID1 = ((Uint32)upp_line_count << 16) | (Uint32)upp_line_size*sizeof(Int16);
    upp_reg_hdl->UPID2 = (Uint32)upp_line_offset*sizeof(Int16);

    UARTPuts("upp_prog_dma_i\n",-2);
    upp_reg_hdl->UPQD0 = (Uint32)upp_buffer_b;
    upp_reg_hdl->UPQD1 = ((Uint32)upp_line_count << 16) | (Uint32)upp_line_size*sizeof(Int16);
    upp_reg_hdl->UPQD2 = (Uint32)upp_line_offset*sizeof(Int16);

    /*等待UPP传输完毕*/
    //i=0;
    //j=0;
    while (upp_interrupt_count < target_int_count && upp_error_count == 0)
    {
        /*  测试UPP传输的同时操作普通DDR数据
        temp=i;
        i++;
        if(i==1024)
        {
            i=0;
            j++;
        }
        */

       asm(" nop");

       //UARTprintf( "upp_interrupt_count=%d\n",upp_interrupt_count);
    }

    /*检查UPP传输的数据是否正确 (loopback modes only)*/
    //UARTprintf( "i=%d\n",i);
    //UARTprintf( "j=%d\n",j);
    UARTPuts("Data mismatch in buffers.\n",-2);
    if (upp_interrupt_count == 2 && upp_error_count == 0)
    {
        for (i = 0; i<upp_frame_size; i++)
        {
            if (upp_buffer_a != upp_buffer_b)
            {
                upp_error_count++;
            }
        }
    }

    /* 报告通信结果*/
    if(upp_error_count != 0)
        UARTprintf( "upp_error_count=%d\n",upp_error_count);
    else
        UARTPuts("uPP transfers complete!\n",-2);

    UARTPuts("Do you want to print all the data?(y/n)   ",-2);
    UARTGets(ch,2);
    UARTPuts("\n", -2);

    if(ch[0] == 'y')
    {
        /*打印全部读到的数据*/
        for(i=0; i<upp_frame_size; )
        {
            for(j=0; j<5; j++)
            {
                UARTprintf("upp_buffer_a[%d]=%d   ",i,upp_buffer_a);
                i++;
                //if(i >= 4096)
                //    break;

            }
            UARTPuts("\n",-2);
        }
    }

}


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

15

主题

1357

帖子

4579

积分

创龙

Rank: 8Rank: 8

积分
4579
推荐
发表于 2015-8-29 14:31:50 | 只看该作者
fish 发表于 2015-8-28 17:42
您好,请问您提到的 直接在内存管理中将缓存全部配置为内存 具体怎么配置呢? ...


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复 支持 1 反对 0

使用道具 举报

15

主题

1357

帖子

4579

积分

创龙

Rank: 8Rank: 8

积分
4579
29#
发表于 2015-8-30 13:46:55 | 只看该作者
fish 发表于 2015-8-29 20:37
谢谢!
请问在将UPP的例程 从starterware移植到sys/bios上时,upp的EOW中断直接移植过去呢,还是要作为硬 ...

参考视频教程

当然是 HWI
回复 支持 反对

使用道具 举报

1

主题

6

帖子

66

积分

注册会员

Rank: 2

积分
66
28#
发表于 2015-8-29 20:37:48 | 只看该作者

谢谢!
请问在将UPP的例程 从starterware移植到sys/bios上时,upp的EOW中断直接移植过去呢,还是要作为硬件中断HWI?

点评

参考视频教程 导入是 HWI  详情 回复 发表于 2015-8-30 13:46
回复 支持 反对

使用道具 举报

1

主题

6

帖子

66

积分

注册会员

Rank: 2

积分
66
26#
发表于 2015-8-28 17:42:03 | 只看该作者
您好,请问您提到的 直接在内存管理中将缓存全部配置为内存 具体怎么配置呢?

点评

[attachimg]440[/attachimg]  详情 回复 发表于 2015-8-29 14:31
回复 支持 反对

使用道具 举报

15

主题

1357

帖子

4579

积分

创龙

Rank: 8Rank: 8

积分
4579
25#
发表于 2015-4-29 17:23:51 | 只看该作者
cqf00 发表于 2015-4-29 16:13
在这之前,我找了不少的资料了,很大程度上,也认为是缓存一致性的问题。
我也查阅了TI的关于cache方面的 ...

参考 EMIF_AD7606v2 例程

如果你还是不清楚的话 就等待我们发布更新的例程吧
回复 支持 反对

使用道具 举报

2

主题

5

帖子

174

积分

注册会员

Rank: 2

积分
174
24#
发表于 2015-4-29 16:13:44 | 只看该作者
本帖最后由 cqf00 于 2015-4-29 16:15 编辑
希望缄默 发表于 2015-4-29 13:38
用了缓存大部分情况就要维护缓存一致性

在这之前,我找了不少的资料了,很大程度上,也认为是缓存一致性的问题。
我也查阅了TI的关于cache方面的资料,但是,我还是不知道,使用C6748 + Starterware的情况下,具体该如何“对一段使能了L1、L2缓存的DDR2内存数据,实现upp的正确收发”。

点评

参考 EMIF_AD7606v2 例程 如果你还是不清楚的话 就等待我们发布更新的例程吧  详情 回复 发表于 2015-4-29 17:23
回复 支持 反对

使用道具 举报

15

主题

1357

帖子

4579

积分

创龙

Rank: 8Rank: 8

积分
4579
23#
发表于 2015-4-29 13:38:39 | 只看该作者
cqf00 发表于 2015-4-28 08:59
如果跟upp没有关系,那如何对一段使能了L1、L2缓存的DDR2内存数据,实现upp的正确收发。(使用的是C6748评 ...

用了缓存大部分情况就要维护缓存一致性
回复 支持 反对

使用道具 举报

2

主题

5

帖子

174

积分

注册会员

Rank: 2

积分
174
22#
发表于 2015-4-28 08:59:43 | 只看该作者

如果跟upp没有关系,那如何对一段使能了L1、L2缓存的DDR2内存数据,实现upp的正确收发。(使用的是C6748评估板 + Starterware)

点评

用了缓存大部分情况就要维护缓存一致性  详情 回复 发表于 2015-4-29 13:38
回复 支持 反对

使用道具 举报

15

主题

1357

帖子

4579

积分

创龙

Rank: 8Rank: 8

积分
4579
21#
发表于 2015-1-21 20:27:39 | 只看该作者
378087736 发表于 2015-1-21 15:06
syslink下关闭DSP的cache是在config.bld中把l1DMode:"32k", l1PMode:"32k",l2Mode:"32k"这几项去掉么? ...

看 DSP 视频教程 第5章
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|嵌入式开发者社区 ( 粤ICP备15055271号

GMT+8, 2024-5-4 10:30 , Processed in 0.041982 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

快速回复 返回顶部 返回列表