pengxihan 发表于 2009-04-26 10:51

板子上做内存测试的代码,大家看看有什么问题

我们做的板子上怀疑内存不稳定,所以要在bootloader里对整个内存进行一次完整的读写测试,我们用的botloader是uboot,uboot在初始化内存后立刻调用我的内存测试程序进行测试。
<code>
int test_dram(uint *start, uint *end)
{
volatile uint *p;
p = start;
while(p < end) {
      *p = 0x55555555;
       if (*p != 0x55555555)
                              return -1; /* fail*/
       p++;
}
return 0;/*sucess*/

}

变量p指针我用了volatile关键字,请问这样是否可以消除CPU cache的影响?我的目标是每次都能让CPU都能真的去内存去读数据,而不是从cache中。

[ 本帖最后由 pengxihan 于 2009-4-26 11:23 编辑 ]

zimang 发表于 2009-04-27 18:40

回复 #1 pengxihan 的帖子

volatile貌似是告诉编译器不优化相关代码,以后每次取值都从其所在位置读取

ivorhuang 发表于 2009-04-27 21:26

回复 #1 pengxihan 的帖子

应该有问题吧,你用了栈空间.

yidou 发表于 2009-04-28 08:57

回复 #1 pengxihan 的帖子

想消除cache的影响, 请disable/enabledata/Instruction cache.
另, 测试mem有常见的参考代码. 如pattern为55, AA, shift, etc. LZ不必自己写.

rrccffmm 发表于 2009-04-29 00:26

http://www.netrino.com/Embedded-Systems/How-To/Memory-Test-Suite-C

pengxihan 发表于 2009-04-29 11:34

回复 #3 ivorhuang 的帖子

不好意思,忘记说了,这时候堆栈用的是CPU里的SRAM

pengxihan 发表于 2009-04-29 11:35

回复 #4 yidou 的帖子

用volatile是否也可以达到disable data cache的功能??

pengxihan 发表于 2009-04-29 11:40

回复 #5 rrccffmm 的帖子

这个程序不错,它检测内存数据线和地址线是否有短路、拉高或者拉底的错误,但是存在这样一个问题:
因为我们板子上连接的是DDRII的内存颗粒,是按照行列地址线那样链接的,如果程序检测出A10有短路,那么如何判断A10对应到板子上的哪一根线呢?因为程序中是按照A0~A31这样来的。

rrccffmm 发表于 2009-04-29 22:36

回复 #8 pengxihan 的帖子

uboot里有dcache_disable函数,不过不同平台实现不一样,比如mips上就是改变CP0 CONFIG寄存器中某位的值。用volatile不能达到disable data cache的功能,它对程序的影响你可以反汇编看一下编译的结果,对比不加volatile的程序看有什么区别。

内存行列地址线复用,也就那么几根,只要发现有短路的问题,一根一根的去查也花不了多少时间。

gqwang2005 发表于 2009-05-05 16:42

回复 #5 rrccffmm 的帖子

好东西啊,学习了
页: [1] 2
查看完整版本: 板子上做内存测试的代码,大家看看有什么问题