nand flash 移植

2019-07-20 04:22发布

本帖最后由 hpdell 于 2016-12-19 14:11 编辑

最近把历程的 nand flash 程序移植到 MT29F32G08CBACA 这个芯片上,出现如下问题,

如果单独使用如下函数进行测试是是正常的,

  FTL_Init() ;

  NAND_EraseBlock(4000);

    uint32_t RWDataSize = 8192 * 4;
  uint8_t  * nand_F_tx_buff =  (uint8_t  *)mymalloc(SRAMEX, RWDataSize );        
  uint8_t  * nand_F_rx_buff =  (uint8_t  *)mymalloc(SRAMEX, RWDataSize );        
  uint8_t i=0;
  for(cc=0; cc < RWDataSize; cc++)
  {
    nand_F_tx_buff[cc] = i * 2 ;
    nand_F_rx_buff[cc] = 0;
    i ++;
  }  

  NAND_WritePage( 4000, 6, &nand_F_tx_buff[0], 512);
  NAND_ReadPage(4000, 6, &nand_F_rx_buff[0], 512);   

  if( Buffercmp_8(&nand_F_tx_buff[0], &nand_F_rx_buff[0], 512) == 0)
    printf("NAND Data Read Write 8192 * 4 Test OK     ...  DD ");
  else
    printf("NAND Data Read Write 8192 * 4 Test Error  ...  EE ");   


  myfree(SRAMEX, nand_F_tx_buff);
  myfree(SRAMEX, nand_F_rx_buff);

上述测试是OK的

但是如果使用LUT功能建立分区表 就出错,格式化也是出错,也就是如下函数
u8 FTL_CreateLUT(u8 mode)

另外  hnand1.Init.ECCPageSize = FMC_NAND_ECC_PAGE_SIZE_1024BYTE;       //ECC页大小为1024字节 这个我配置是1024字节,根据资料介绍是1024字节,还有

还有#define NAND_ECC_SECTOR_SIZE                1024                        //执行ECC计算的单元大小,默认1024字节 我也改成了1024,

不知道其他的是否还需要修改啊 ???

mt29f32g08cbaca芯片的ecc资料介绍:
mt29f32g08-ecc.png

mt29f4g08abada芯片的ecc资料介绍:
mt29f4g08abada-ecc.png
还有这个地方的 i = nand_dev.page_mainsize + 0X10 + eccstart * 4;        //计算写入ECC的spare区地址   0X10是怎么得来的啊   ???????





友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
19条回答
正点原子
1楼-- · 2019-07-21 02:19
是我们开发板?还是你自己设计的硬件?
hbyue
2楼-- · 2019-07-21 04:49
 精彩回答 2  元偷偷看……
hpdell
3楼-- · 2019-07-21 08:17
正点原子 发表于 2016-12-17 16:40
是我们开发板?还是你自己设计的硬件?

我是吧你们的历程 程序移植到到我的工程上,

我现在的的芯片时 MT29F32G08, 不过这个芯片 的 spare 是 1024,不知道 除了上述我提到的地方外,还有哪些需要修改的啊 ??
hpdell
4楼-- · 2019-07-21 13:47
 精彩回答 2  元偷偷看……
正点原子
5楼-- · 2019-07-21 16:58
 精彩回答 2  元偷偷看……
hpdell
6楼-- · 2019-07-21 17:16
正点原子 发表于 2016-12-26 01:01
spare区不影响的

你好,目前我这个 nand flash 芯片是MLC的,不知道 stm是否支持啊,但是看stm资料貌似只支持 SLC 的nand flash
我现在如果不使用 ecc 功能的话,读写完全没有问题,但是使用 ecc spare 功能就不行了

一周热门 更多>