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);
原文:http://www.cnblogs.com/izhangzhne/p/4937062.html