S5PV210之Nand flash驱动编写

发布者:SparklingMelody最新更新时间:2014-12-16 关键字:S5PV210之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;[page]

//硬件部分初始化

mem = platform_get_resource(pdev, IORESOURCE_MEM, 0);

if (!mem) {

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

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 ");

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 ");

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 ");

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 ");

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 ");

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 ");

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开发板

关键字:S5PV210之Nand  flash  驱动编写 引用地址:S5PV210之Nand flash驱动编写

上一篇:单片机的设计方案和单片机提供商
下一篇:msp430 io口的配置和使用

推荐阅读最新更新时间:2024-03-16 13:48

应用材料:2011年NAND Flash厂资本支出将大幅成长
针对2011年半导体资本支出的趋势,设备大厂应用材料(Applied Materials)指出,2011年NAND Flash厂资本支出将大幅成长,幅度将胜过DRAM产业,晶圆代工也仍然相当强劲,预估整体半导体设备市场将有持平至5%的成长幅度。 应材在前段晶圆设备(WFE)与先进封装市场具有领先地位,为持续超越竞争对手,也宣布推出最新矽蚀刻系统Applied Centris,在新产品助阵下,应材预估旗下硅系统部门(Silicon System Group)全球市占率将自2011年起有连3年的成长。 应材在前段晶圆设备位居市场龙头地位,不过业界也指出,近年来,应材在蚀刻设备方面,表现欠佳。 对此,应用材
[半导体设计/制造]
MSP430flash封装读写函数
封装好读写函数,输入地址可写入和读出,都是long数据类型 void flash_w(int add,long value) { Flash_ptrD = (unsigned long *) add; // 初始化Flash pointer FCTL3 = FWKEY; // FWKEY为写入密码 FCTL1 = FWKEY+ERASE; // FWKEY为写入密码,ERASE为段擦除 *Flash_ptrD = 0; // 擦除 FCTL1 = FWKEY+BLKWRT; // FWKEY为写入密码,BLKWRT为lon
[单片机]
2440的flash、linux、bootloader
开始拿到2440板的时候不知道norflash ,nandflash等等干什么的,还有SDRAM有是什么,还有linux系统装在哪里,怎么装,supervivi有是什么等等很多的问题,今天大概简单的理清楚这里关系。 首先分开flash与SDRAM,这俩个其实我们都使用过,flash,U盘就是一块flash,主要是掉电不易失,至于norflash和nandflash都是flash只是工艺,读写速度,性能,造价等等不同,一般说nandflash可以做的很大,现在大的可以有几G了,好多开发板上面都是1G的了,而且造价便宜,但是nandflash容易产生坏块。而norflash一般比较小,几M,造价比较贵,但是不容易产生坏块,性能较好
[单片机]
飞思卡尔 i.MX 平台支持 Flash Player 10.1
使用飞思卡尔半导体的 i.MX 处理器制造智能移动设备的制造商不久便能够支持 Adobe® Flash® Player 10.1 软件,提供包括视频播放、动画、游戏及欣赏其它丰富 web 内容的极佳体验。通过与 Adobe 和 Movial 的紧密合作,飞思卡尔将把 Adobe Flash Player 10.1 引入其 i.MX 平台,支持运行 Linux® 或 Android™ 操作系统并提供卓越的视频和图形功能的消费产品开发。 从飞思卡尔 i.MX51 系列处理器着手,这几家公司将携手加快 Flash Player 10.1 的速度(Flash Player 10.1计划将于 2010 年上半年发布)。基于 i
[嵌入式]
FLASH存储器接口电路图(Altera FPGA开发板)
FLASH存储器接口电路图(Altera FPGA开发板)
[模拟电子]
<font color='red'>FLASH</font>存储器接口电路图(Altera FPGA开发板)
如何将MSP430单片机中的long数据烧写至Flash中去
从RAM地址0x0200中读取一个long数据,并烧写至地址为0x1800的Flash中。 代码: #include“io430.h” void main(void) { //初始化RAM信息段的指针 unsigned long * RAM_ptr = (unsigned long *) 0x0200; //初始化Flash信息段的指针 unsigned long * Flash_ptr = (unsigned long *) 0x1800; //存放数据的变量 unsigned long value; WDTCTL = WDTPW + WDTHOLD; //关闭看门狗 P4DIR |= BIT2; //设置P4.2为输出
[单片机]
如何将MSP430单片机中的long数据烧写至<font color='red'>Flash</font>中去
单片机 MSP430G2553 FLASH 操作
//FLASH操作 写入 void write_SegC(char value , char lenChar) { char *Flash_ptr; // Flash pointer char i; Flash_ptr = (char *) 0x1040; // Initialize Flash pointer FCTL1 = FWKEY + ERASE; // Set Erase bit FCTL3 = FWKEY; // Clear Lock bit *Flash_ptr = 0; // Dum
[单片机]
单片机的FLASH引导装载系统设计
  前言   DSP系统的引导装载是指在系统加电时,由DSP将一段存储在外部非易失性存储器中的代码移植到内部高速存储器单元并执行的过程。 FLASH 是一种高密度、非易失性的电可擦写存储器,而且单位存储比特的价格比传统EPROM要低。为此,本文介绍了TMS320C6713浮点DSP芯片和SST公司提供的SST39VF400A FLASH存储器的基本特点,给出了使用该FLASH存储器设计和实现完整的TMS320C6713 DSP引导装载系统的具体方法。   1 硬件设计   1.1 主要芯片介绍   DSP自动引导装载系统主要使用DSP芯片(TMS320C6713)和外扩存储器(SST39VF400A)两种芯片来实现。其
[单片机]
单片机的<font color='red'>FLASH</font>引导装载系统设计
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved