NandFlash驱动框架

1.首先和前面的几个驱动程序相似,需要分配一个nand_chip结构体

  s3c_nand = kzalloc(sizeof(struct nand_chip), GFP_KERNEL);

然后填充该结构体

 

/* 2. 设置nand_chip */
/* 设置nand_chip是给nand_scan函数使用的, 如果不知道怎么设置, 先看nand_scan怎么使用
* 它应该提供:选中,发命令,发地址,发数据,读数据,判断状态的功能
*/

  s3c_nand->select_chip = s3c2440_select_chip;//片选函数
    s3c_nand->cmd_ctrl    = s3c2440_cmd_ctrl;//发送指令函数
    s3c_nand->IO_ADDR_R   = &s3c_nand_regs->nfdata;//
    s3c_nand->IO_ADDR_W   = &s3c_nand_regs->nfdata;//
    s3c_nand->dev_ready   = s3c2440_dev_ready;//状态识别
    s3c_nand->ecc.mode    = NAND_ECC_SOFT;//使用ecc校验

 

2.在设置硬件之前先使能nandflash时钟:

  struct clk *clk;

  clk = clkget(NULL, "nand");

  clk_enable(clk);

3.接着进行硬件寄存器的配置,nandflash寄存器较多且是连续的,这里可以用一个nand_regs结构体实现ioremap 

 

struct s3c_nand_regs {
    unsigned long nfconf  ;
    unsigned long nfcont  ;
    unsigned long nfcmd   ;
    unsigned long nfaddr  ;
    unsigned long nfdata  ;
    unsigned long nfeccd0 ;
    unsigned long nfeccd1 ;
    unsigned long nfeccd  ;
    unsigned long nfstat  ;
    unsigned long nfestat0;
    unsigned long nfestat1;
    unsigned long nfmecc0 ;
    unsigned long nfmecc1 ;
    unsigned long nfsecc  ;
    unsigned long nfsblk  ;
    unsigned long nfeblk  ;
};

4.使用nand_scan 

  s3c_mtd = kzalloc(sizeof(struct mtd_info), GFP_KERNEL);
  s3c_mtd->owner = THIS_MODULE;
  s3c_mtd->priv = s3c_nand;

  nand_scan(s3c_mtd, 1);//识别NANDFLASH,构造mtd_info

 5.增加mtd分区

  add_mtd_partitions(s3c_mtd, s3c_nand_parts, 4);

你可能感兴趣的:(NandFlash驱动框架)