S3C6410学习——Nand flash陷阱
当系统以Nand方式启动时,硬件将Nand Flash的前8KB拷贝到Steppingstone,然后从0地址开始运行程序,在这8KB以内代码中,我们需要完成必要的硬件初始化,如果代码超过8K,我们还需要将剩余代码的搬移到链接地址处,一般在SDRAM/DDR中。其中,硬件部分需要初始化系统时钟、DDR和NAND Flash三部分。这就是S3C6410以Nand方式启动时的大致流程,看上去跟ARM9(S3C2440)没有差别,但是如果您亲自动手写一下这个启动过程,你会发现ARM9跟ARM11还是存在若干差别的,这里我要说的是Nand裸机驱动的问题。述了S3C6410的Nand方式启动流程,看上去跟ARM9(S3C2440)没有太大差别,但是如果您亲自动手写一下这个启动过程,你会发现ARM9跟ARM11还是存在若干差别的,这里我要说的是Nand裸机驱动的问题。
我的开发板式Tiny6410,配置的Nand flash是K9GAG08U0E,块空间1M,页空间8K。于是可以实现nand_read函数:
void store2nand(unsigned long ddr_start, unsigned long length){unsigned char* src = (unsigned char*)ddr_start;unsigned long rest = length;unsigned long size;unsigned long i;for(i = 0; i != 4; ++i){size = rest>2048?2048:rest;nand_write(PAGE_SIZE*i, src+2048*i, size);rest -= size;if(rest == 0)return;}nand_write(PAGE_SIZE*4, src+2048*4, rest);}store2nand函数可以用来下载程序时写nand用,如果不按照这种方式将程序写入nand,硬件就无法正确加载Nand flash的前8K代码,程序也就无法正常运行。下面是我自己写的Tiny6410裸机程序,arm-linux-gcc环境,如果需要可以下载了看看,代码实现了系统时钟、DDR、Nand flash还有串口的初始化,下面是链接地址,以后还会继续完善:
。。。链接地址刷不出来,等刷出来完善上。。。