DAT_copy 产生的问题
来源:互联网 发布:与淘宝相似的软件 编辑:程序博客网 时间:2024/05/16 12:33
http://blog.csdn.net/adrianfeng/article/details/5894584
//这个转载的东西,经我实验没有发现错误。就当学习了吧。
//我分析应该不会出错,因为编译器有一套维护cache的机制,否则不累死程序员了
#include <csl.h>
#include <csl_cache.h>
#include <csl_dat.h>
#include <stdio.h>
#pragma DATA_SECTION(external, "quickdata")
char external[352*416]; // 片外
#pragma DATA_SECTION(internal, "quickdata")
char internal[16 * 352]; // 片内
void main()
{
int i, j, id;
char x = 0;
CSL_init();
CACHE_clean(CACHE_L2ALL, 0, 0);
CACHE_setL2Mode(CACHE_128KCACHE);
CACHE_enableCaching(CACHE_EMIFA_CE00);
CACHE_enableCaching(CACHE_EMIFA_CE01);
for(i = 0; i < 352 * 416;++i)
{
external[i] = (i & 0xff);
}
DAT_open(DAT_CHAANY, DAT_PRI_LOW, DAT_OPEN_2D);
id = DAT_copy2d(DAT_2D1D, &external[0], internal, 352, 16, 416);
DAT_wait(id);
for(i = 0; i < 16; ++i) // 检查搬移是否正确
{
if(memcmp(&external[i * 416], &internal[i * 352], 352) != 0)
{
fprintf(stderr, "error/n");
}
}
fprintf(stderr, "end/n");
}
测试运行失败。DMA传输后片内与片外数据不一致。经分析后确认是因为程序开始打开了L2Cache,并且允许对片外存储器进行缓存,因此开始对external的初始化实际上实在L2Cache中做的,并未实时更新到片外external,故DMA不正确,解决办法是在external初始化之后调用下面的语句请求二级缓存立刻刷新数据:
CACHE_wbInvL2(external, 352*416, CACHE_WAIT);
则测试正确,注意这个函数的第二个参数有最大为65536*4的限制,如果要刷新的数据大小超过了这个值,则应该分为几块分别调用该函数。
###############################################################################
The DATA_SECTION pragma allocates space for the symbol in a section called section name.
The syntax for the pragma in C is:
#pragma DATA_SECTION (symbol, "section name");
我个人的理解是:
定义一个数据段:
段名为: "section name"
段的内容在: symbol 里
在CCS编程中,如果我们不指定变量的存放位置,编译器会自动的给变量分配一个位置,但是如果有的时候需要把变量放在一个特定的空间内,我们应该如何操作呢,CCS提供了如下的两个指令
#pragma CODE_SECTION
#pragma DATA_SECTION
其中data_section是针对数据空间的,code_section是针对程序空间的,具体的使用办法是
#pragma DATA_SECTION(bufferB, ”my_sect”)
char bufferB[512];
在.cmd文件中建立对应的section就可以使用了。
注意:在使用#pragma DATA_SECTION时,应该先开辟一个空间,即:#pragma DATA_SECTION(bufferB, ”my_sect”),然后再定义该空间的大小:char bufferB[512];
- DAT_copy 产生的问题
- DAT_copy 产生的问题
- DAT_copy 产生的问题
- DAT_copy 产生的问题
- DAT_copy 产生的问题 .
- hive 终端产生的问题
- 随机数据产生的问题
- DWR异步产生的问题
- 由问题产生的感悟
- 启动 hadoop的产生问题
- 继承产生两义性的问题
- 临界区问题的产生
- CLGeocoder单列产生的问题
- 修改lower_case_table_names产生的问题
- 清除浮动产生的问题
- Keil的代码优化产生的问题
- Keil的代码优化产生的问题
- Keil的代码优化产生的问题
- 开通了博客
- GDI+学习笔记(三)绘制一张简单的图片
- 分享一下个人的Vim配置文件
- 安卓基础学习2
- ant笔记-6.项目构建之清理,初始化,编译
- DAT_copy 产生的问题
- 分布式系统时钟同步(未完)
- C++ class实例的内存结构
- 般若波多密心经读书心得(一)
- 在win7上安装 SQL serve 2000
- POJ - 2362 Square
- BOW和LSH的一点理解
- 7 lessons I wish I learned before starting my first game internship
- C语言--关于二维数组