s3c2440裸机-内存控制器(三-4、norflash编程之实现)

2023-08-09  

1.识别norflash

我们知道要识别norflash属性,要让norflash进入cfi模式,然后按照手册上的表格发送一系列的命令就能获取norflash属性。


1)发送命令


那么我们需要实现一个cpu向nor发命令的一个函数nor_cmd()。我们的norflash是16bit位宽的,所以访问nor是以16位为单位访问的。


#define NOR_FLASH_BASE  0  /* jz2440, nor-->cs0, base addr = 0 */

/* 比如:   55H 98 

** 本意是: 往(0 + (0x55)<<1)写入0x98

*/

void nor_write_word(unsigned int base, unsigned int offset, unsigned int val)

{

volatile unsigned short *p = (volatile unsigned short *)(base + (offset << 1));

*p = val;

}


void nor_cmd(unsigned int offset, unsigned int cmd)

{

nor_write_word(NOR_FLASH_BASE, offset, cmd);

}

我们通过调用nor_cmd就可以向flash的指定地址写入命令。


2)

unsigned int nor_read_word(unsigned int base, unsigned int offset)

{

volatile unsigned short *p = (volatile unsigned short *)(base + (offset << 1));

return *p;

}


unsigned int nor_dat(unsigned int offset)

{

return nor_read_word(NOR_FLASH_BASE, offset);

}

这样我们调用nor_dat(addr)就可以获得norflash中addr地址处的数据,返回的数据是16bit(1 word)。

3)识别函数

那么现在有了发命令函数nor_cmd和读数据函数nor_dat,那么就就可以参考nor芯片手册的命令表进行操作norflash了。

/* 进入NOR FLASH的CFI模式

 * 读取flash属性

 */

void do_scan_nor_flash(void)

{

char str[4];

unsigned int size;

int regions, i;

int region_info_base = 0x2d; //第0块region的基地址2d,第1块region的基地址31,第2块region的基地址35......(参考手册表4-3)

int block_addr=0, blocks, block_size, j;

int cnt = 0;


int vendor, device;

/* 打印厂家ID、设备ID */

nor_cmd(0x555, 0xaa);    /* 解锁 */

nor_cmd(0x2aa, 0x55); 

nor_cmd(0x555, 0x90);    /* read id */

vendor = nor_dat(0);

device = nor_dat(1);

nor_cmd(0, 0xf0);        /* reset */

nor_cmd(0x55, 0x98);  /* 进入cfi模式 */

str[0] = nor_dat(0x10); //读地址10H得到0051('q')

str[1] = nor_dat(0x11); //读地址11H得到0052('r')

str[2] = nor_dat(0x12); //读地址12H得到0059('y')

str[3] = '

文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。