int main (void)
{
u16 j=0;
u32 i=0;
u8 temp=0,sval=0;
delay_init(); //延时函数初始化
NVIC_Configuration(); //设置NVIC中断分组2:2位抢占优先级,2位响应优先级
uart_init(9600); //串口初始化为9600
LED_Init(); //LED端口初始化
FSMC_SRAM_Init();
while(1)
{
//每隔4K字节,写入一个数据,总共写入256个数据,刚好是1M字节
j++;
if(j==1)
{
printf("\n Data is being written.....\n\r");
for(i=0;i<1024*1024;i+=4096)
{
fsmc_sram_test_write(0XFA,i);
delay_us(1);
}
for(i=1024*1024;i<2*1024*1024;i+=4096)
{
fsmc_sram_test_write(0X54,i);
delay_us(1);
}
//依次读出之前写入的数据,进行校验
}
if(j==100)
{
for(i=0;i<3*1024*1024;i+=4096)
{
sval=fsmc_sram_test_read(i);
printf("\n %d\n",i/4096);
printf("\n %2X\n",sval);
printf("\r\r");
}
j=0;
}
if(j%10==0)
{
LED3=!LED3;
delay_ms(400);
}
}
}
外部静态存储器测试,芯片是2MB的,即2X1024X1024个地址,
代码的意思是,
向存储器写:
每4KB写一个数,1024X1024以前的写0XFA;
1024X1024到1024X1024*2的写0X54;
向存储器读:
每4KB读一个数,总计是512个,想看看地址溢出的部分读出的数据是什么,
所以3*1024*1024;i
结果发现每次最后一次写的数都会覆盖前面的,实验结果应该是前256个数为0XFA;
后256个数是0X54;最后256个数不定;
结果如下:
Data is being written.....
|