当前位置:首页 > 单片机 > 单片机
[导读] 大家好,又到了天嵌【嵌入式分享】的时间,相对于前几期【嵌入式分享】做的主要是TQ335X开发板的技术分享,本期决定做同是cortex-a8系列的TQ210开发板的技术分享。本期是关于TQ210开发板的Nand flash驱动编写,可能

 大家好,又到了天嵌【嵌入式分享】的时间,相对于前几期【嵌入式分享】做的主要是TQ335X开发板的技术分享,本期决定做同是cortex-a8系列的TQ210开发板的技术分享。本期是关于TQ210开发板的Nand flash驱动编写,可能源码部分会比较多,本文由博主girlkoo编写,感谢他的分享。

跟裸机程序一样,S5PV210(TQ210)的Nand flash模块跟S3C2440(TQ2440)的Nand flash模块非常相似,如果不引入ECC,驱动程序的编写也非常简单,我是使用的Linux-3.8.6(Linux-3.8.3也一样)内核,驱动的API函数有些变化,不过原理是相通的,稍微看一下内核源码并参考下其他平台的相关代码就可以自己写出Nand flash驱动了,下面是Nand flash驱动的源码,没有启用ECC,当然,你也可以改成软件ECC,但是我的觉得既然软件ECC不如HWECC快,我就采用硬件ECC吧。

#include

#include

#include

#include

#include

#include

#include

#include

struct s5p_nand_regs{

unsigned long nfconf;

unsigned long nfcont;

unsigned long nfcmmd;

unsigned long nfaddr;

unsigned long nfdata;

unsigned long nfmeccd0;

unsigned long nfmeccd1;

unsigned long nfseccd;

unsigned long nfsblk;

unsigned long nfeblk;

unsigned long nfstat;

unsigned long nfeccerr0;

unsigned long nfeccerr1;

unsigned long nfmecc0;

unsigned long nfmecc1;

unsigned long nfsecc;

unsigned long nfmlcbitpt;

};

struct s5p_nand_ecc{

unsigned long nfeccconf;

unsigned long nfecccont;

unsigned long nfeccstat;

unsigned long nfeccsecstat;

unsigned long nfeccprgecc0;

unsigned long nfeccprgecc1;

unsigned long nfeccprgecc2;

unsigned long nfeccprgecc3;

unsigned long nfeccprgecc4;

unsigned long nfeccprgecc5;

unsigned long nfeccprgecc6;

unsigned long nfeccerl0;

unsigned long nfeccerl1;

unsigned long nfeccerl2;

unsigned long nfeccerl3;

unsigned long nfeccerl4;

unsigned long nfeccerl5;

unsigned long nfeccerl6;

unsigned long nfeccerl7;

unsigned long nfeccerp0;

unsigned long nfeccerp1;

unsigned long nfeccerp2;

unsigned long nfeccerp3;

unsigned long nfeccconecc0;

unsigned long nfeccconecc1;

unsigned long nfeccconecc2;

unsigned long nfeccconecc3;

unsigned long nfeccconecc4;

unsigned long nfeccconecc5;

unsigned long nfeccconecc6;

};

static struct nand_chip *nand_chip;

static struct mtd_info *s5p_mtd_info;

static struct s5p_nand_regs *s5p_nand_regs;

static struct s5p_nand_ecc *s5p_nand_ecc;

static struct clk *s5p_nand_clk;

static struct mtd_partition s5p_nand_partions[] = {

[0] = {

.name = "bootloader",

.offset = 0,

.size = SZ_1M,

},

[1] = {

.name = "kernel",

.offset = MTDPART_OFS_APPEND,

.size = 5*SZ_1M,

},

[2] = {

.name = "rootfs",

.offset = MTDPART_OFS_APPEND,

.size = MTDPART_SIZ_FULL,

},

};

static void s5p_nand_select_chip(struct mtd_info *mtd, int chipnr){

if(chipnr == -1){

s5p_nand_regs->nfcont |= (1<<1);

}

else{

s5p_nand_regs->nfcont &= ~(1<<1);

}

}

static void s5p_nand_cmd_ctrl(struct mtd_info *mtd, int cmd, unsigned int ctrl)

{

if (ctrl & NAND_CLE){

s5p_nand_regs->nfcmmd = cmd;

}

else{

s5p_nand_regs->nfaddr = cmd;

}

}

static int s5p_nand_ready(struct mtd_info *mtd){

return (s5p_nand_regs->nfstat & 0x1);

}

static int s5p_nand_probe(struct platform_device *pdev){

int ret = 0;

struct resource *mem;

//硬件部分初始化

mem = platform_get_resource(pdev, IORESOURCE_MEM, 0);

if (!mem) {

dev_err(&pdev->dev, "can't get I/O resource mem\n");

return -ENXIO;

}

s5p_nand_regs = (struct s5p_nand_regs *)ioremap(mem->start, resource_size(mem));

if (s5p_nand_regs == NULL) {

dev_err(&pdev->dev, "ioremap failed\n");

ret = -EIO;

goto err_exit;

}

s5p_nand_ecc = (struct s5p_nand_ecc *)ioremap(0xB0E20000, sizeof(struct s5p_nand_ecc));

if(s5p_nand_ecc == NULL){

dev_err(&pdev->dev, "ioremap failed\n");

ret = -EIO;

goto err_iounmap;

}

s5p_nand_clk = clk_get(&pdev->dev, "nand");

if(s5p_nand_clk == NULL){

dev_dbg(&pdev->dev, "get clk failed\n");

ret = -ENODEV;

goto err_iounmap;

}

clk_enable(s5p_nand_clk);

s5p_nand_regs->nfconf = (3<<12)|(5<<8)|(3<<4)|(1<<1);

s5p_nand_regs->nfcont |= 3;

//分配驱动相关结构体

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

if(nand_chip == NULL){

dev_err(&pdev->dev, "failed to allocate nand_chip structure\n");

ret = -ENOMEM;

goto err_clk_put;

}

s5p_mtd_info = (struct mtd_info *)kzalloc(sizeof(struct mtd_info), GFP_KERNEL);

if(s5p_mtd_info == NULL){

dev_err(&pdev->dev, "failed to allocate mtd_info structure\n");

ret = -ENOMEM;

goto err_free_chip;

}

//设置驱动相关结构体

nand_chip->select_chip = s5p_nand_select_chip;

nand_chip->cmd_ctrl = s5p_nand_cmd_ctrl;

nand_chip->IO_ADDR_R = &s5p_nand_regs->nfdata;

nand_chip->IO_ADDR_W = &s5p_nand_regs->nfdata;

nand_chip->dev_ready = s5p_nand_ready;

nand_chip->ecc.mode = NAND_ECC_SOFT;

s5p_mtd_info->priv = nand_chip;

s5p_mtd_info->owner = THIS_MODULE;

//扫描Nand flash 设备

if(nand_scan(s5p_mtd_info, 1)){

dev_dbg(&pdev->dev, "nand scan error\n");

goto err_free_info;

}

//添加分区信息

ret = mtd_device_parse_register(s5p_mtd_info, NULL, NULL, s5p_nand_partions, ARRAY_SIZE(s5p_nand_partions));

if(!ret)

return 0;

err_free_info:

kfree(s5p_mtd_info);

err_free_chip:

kfree(nand_chip);

err_clk_put:

clk_disable(s5p_nand_clk);

clk_put(s5p_nand_clk);

err_iounmap:

//if(s5p_nand_ecc == NULL)

// iounmap(s5p_nand_ecc);

if(s5p_nand_regs == NULL)

iounmap(s5p_nand_regs);

err_exit:

return ret;

}

static int s5p_nand_remove(struct platform_device *pdev){

nand_release(s5p_mtd_info);

kfree(s5p_mtd_info);

kfree(nand_chip);

clk_disable(s5p_nand_clk);

clk_put(s5p_nand_clk);

if(s5p_nand_regs == NULL)

iounmap(s5p_nand_regs);

return 0;

}

static struct platform_driver s5p_nand_drv = {

.driver = {

.owner = THIS_MODULE,

.name = "s5p-nand",

},

.probe = s5p_nand_probe,

.remove = s5p_nand_remove,

};

module_platform_driver(s5p_nand_drv);

MODULE_LICENSE("GPL");

上述源码为嵌入式爱好者分享,如有更新,请咨询相关客服与销售人员,以便更新与开发。

操作所使用的硬件:

TQ210V6开发板

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭