Linux 下 Nand Flash 驱动说明

注册 driver_register

通过 module_init(s3c2410_nand_init);注册 Nand Flash 驱动. 在 s3c2410_nand_init ()中通过 driver_register()注册

s3c2410_nand_driver 驱动程序,如下所示:

static struct device_driver s3c2410_nand_driver = {

.name          = "s3c2410-nand",

.bus           = &platform_bus_type, /* 在 drivers/base/platform.c 中定义 */

.probe         = s3c2410_nand_probe,

.remove        = s3c2410_nand_remove,

};

探测设备 probe

在注册的 Nand Flash 驱动程序中, probe 方法为 s3c2410_nand_probe(). s3c2410_nand_probe()再调用 s3c24xx_nand_probe(). 在该函数中, 把*info 作为 Nand Flash 驱动的私有数据结构, 并通过 dev_set_drvdata(dev, info)把*info 保存在*device 的*driver_data 字段中.然后通过 clk_get(dev, "nand")获取 Nand Flash 的时钟资 源, clk_use(info->clk)增加时钟资源的使用计数, clk_enable(info->clk)开启资源.填写*info 的其它字段, 其中包括:

  1. 通过 request_mem_region()为 Nand Flash 寄存器区申请 I/O 内存地址空间区,并通过 ioremap()把它映射到虚 拟地址空间.

    1. 调用 s3c2410_nand_inithw()初始化 Nand Flash 控制器. 3.  为 mtd 设备分配设备信息的存储空间.

4. 对当前 mtd 设备,调用 s3c2410_nand_init_chip()进行初始化.

5. 对当前 mtd 设备, 调用 nand_scan()检测 Nand Flash 芯片, nand_scan()函数在 drivers/mtd/nand/nand_base.c 中 定义.该函数的作用是初始化 struct nand_chip 中一些方法, 并从 Nand Flash 中读取芯片 ID, 并初始化 struct mtd_info 中的方法.

6.  对当前 mtd 设备,加入其分区信息.

7. 如果还有更多 mtd 设备,到 4 执行.

  初始化 Nand Flash 控制器

s3c2410_nand_inithw()函数会初始化 Nand Flash 控制器, 通过设置 Nand Flash 控制寄存器(S3C2410_NFCONF)来

完成, 这里最重要的是根据 S3C2410 的 PCLK 计算出 tacls, twrph0 以及 twrph1 值.

移除设备

s3c2410_nand_remove()当设备被移除时,被 device 核心驱动调用.它完成的主要工作如下:

  1. 把*device 的*driver_data 字段置空.

2. 释放 mtd 设备信息. 3. 释放 clk 资源.

4. 通过 iounmap()取消映地址空间. 5. 释放申请的 I/O 内存资源.

6. 释放设备私有数据*info 的空间.

    Nand Flash 芯片初始化

s3c2410_nand_init_chip()初始化 struct nand_chip 中的一些主要字段以及方法.其中主要包括的方法有:

  1. s3c2410_nand_hwcontrol(); 硬件控制

2. s3c2410_nand_devready(); 设备是否准备好

  1. s3c2410_nand_write_buf(); 写一个 buffer 到 nand flash
  2. s3c2410_nand_read_buf(); 读一个 buffer 到 nand flash 5. s3c2410_nand_select_chip(); 选择操作芯片

如果支持 ECC 硬件校验,还设置如下方法:

  1. s3c2410_nand_correct_data();
    通过 ECC 码校正数据
  2. s3c2410_nand_enable_hwecc();
    开启硬件 ECC 检查
  3. s3c2410_nand_calculate_ecc();
    计算 ECC 码

Nand
Flash

当对 nand flash 的设备文件(nand flash 在/dev 下对应的文件)执行系统调用 read(),或在某个文件系统中对该 设备进行读操作时. 会调用
struct mtd_info 中的 read 方法,他们缺省调用函数为 nand_read(),在 drivers/mtd/nand/nand_base.c
中定义.nand_read()调用 nand_do_read_ecc(),执行读操作. 在 nand_do_read_ecc()函数中,主要完成如下几项工作:

  1. 会调用在
    nand flash 驱动中对
    struct nand_chip 重载的 select_chip 方法,即 s3c2410_nand_select_chip()选择要操作的 MTD 芯片.
  2. 会调用在
    struct nand_chip 中系统缺省的方法 cmdfunc 发送读命令到 nand flash.
  3. 会调用在 nand
    flash 驱动中对 struct
    nand_chip 重载的 read_buf(),即 s3c2410_nand_read_buf() 从 Nand Flash
    的控制器的数据寄存器中读出数据.
  4. 如果有必要的话,会调用在 nand
    flash 驱动中对 struct
    nand_chip 重载的
    enable_hwecc,correct_data 以及 calculate_ecc 方法,进行数据 ECC 校验。

写 Nand Flash

当对 nand flash 的设备文件(nand flash 在/dev 下对应的文件)执行系统调用 write(),或在某个文件系统中对该设备 进行读操作时, 会调用
struct mtd_info 中 write 方法,他们缺省调用函数为 nand_write(),这两个函数在
drivers/mtd/nand/nand_base.c 中定义. nand_write()调用 nand_write_ecc(),执行写操作.在
nand_do_write_ecc()函数中,主要完成如下几项工作:

    1. 会调用在
      nand flash 驱动中对
      struct nand_chip 重载的 select_chip 方法,即 s3c2410_nand_select_chip()选择要操作的 MTD 芯片.
    2. 调用 nand_write_page()写一个页.
    3. 在 nand_write_page()中,会调用在 struct
      nand_chip 中系统缺省的方法 cmdfunc
      发送写命令 到 nand flash.

    4. nand_write_page()中,会调用在 nand flash 驱动中对 struct nand_chip 重载的 write_buf(),即 s3c2410_nand_write_buf()从 Nand
      Flash 的控制器的数据寄存器中写入数据.

    5. nand_write_page()中,会调用在 nand flash
      驱动中对 struct nand_chip 重载 waitfunc 方法, 该方法调用系统缺省函数 nand_wait(),该方法获取操作状态,并等待 nand flash 操作完成.等
      待操作完成,是调用 nand flash 驱动中对 struct nand_chip 中重载的 dev_ready 方法,即
      s3c2410_nand_devready()函数.

原文地址:https://www.cnblogs.com/fanweisheng/p/11106264.html

时间: 2024-10-08 03:51:10

Linux 下 Nand Flash 驱动说明的相关文章

【详解】如何编写Linux下Nand Flash驱动

From: http://www.crifan.com/files/doc/docbook/linux_nand_driver/release/html/linux_nand_driver.html 版本:v2.2 Crifan Li 摘要 本文先解释了Nand Flash相关的一些名词,再从Flash硬件机制开始,介绍到Nand Flash的常见的物理特性,且深入介绍了Nand Flash的一些高级功能,然后开始介绍Linux下面和Nand Flash相关的软件架构MTD的相关知识,最后介绍了

Linux 下 Nand Flash 驱动主要数据结构说明

s3c2410 专有数据结构 s3c2410_nand_set struct s3c2410_nand_set { int                    nr_chips;     /* 芯片的数目 */ int                    nr_partitions; /* 分区的数目 */ char                   *name;          /* 集合名称   */ int                   nr_map;       /* 可选

Linux 下 Nand Flash 调用关系

Nand Flash 设备添加时数据结构包含关系 struct mtd_partition        partition_info[] --> struct s3c2410_nand_set     nandset --> struct s3c2410_platform_nand superlpplatfrom --> struct platform_device      s3c_device_nand 在该数据结构的 name 字段的初始化值"s3c2410-nand&

linux下Pl353 NAND Flash驱动分析

linux的NAND Flash驱动位于drivers/mtd/nand子目录下: nand_base.c-->定义通用的nand flash基本操作函数,如读写page,可自己重写这些函数 nand_bbt.c-->与坏块管理有关的函数和结构体 nand_ids.c-->nand_flash_ids[](芯片ID)和nand_manuf_ids[](厂商ID) nand_ecc.c-->软件ECC代码,若系统支持硬件ECC,则不用理会这个文件 pl353_nand.c-->

MPC8313ERDB在Linux从NAND FLASH读取UBoot环境变量的代码分析

[email protected] 一.故事起因 因为文件系统的增大,已经大大的超出了8MB的NOR FLASH,而不得不把内核,文件系统和设备树文件保存到NAND FLASH上.但是因为使用的是RAMDISK,而无法保存一些个别的配置和参数,最简单的需要就是设置系统的IP了,,, 要使用统一的RAMDISK,而实现LINUX启动之后,设置成不能的参数功能,比较方便的就是从UBOOT把这些参数传递过去,这个得到了大家的认证,我们可以直接添加启动参数,然后在内核里面读出来,这种方法比较方法,唯一不

NAND FLASH 驱动分析

NAND FLASH是一个存储芯片 那么: 这样的操作很合理"读地址A的数据,把数据B写到地址A" 问1. 原理图上NAND FLASH和S3C2440之间只有数据线, 怎么传输地址? 答1.在DATA0-DATA7上既传输数据,又传输地址 当ALE为高电平时传输的是地址, 问2. 从NAND FLASH芯片手册可知,要操作NAND FLASH需要先发出命令 怎么传入命令? 答2.在DATA0-DATA7上既传输数据,又传输地址,也传输命令 当ALE为高电平时传输的是地址, 当CLE为

linux下USB设备驱动

本文以USB鼠标讲解USB设备驱动. 驱动程序中调用usb_register(struct usb_driver *)函数时,先判断USB总线驱动程序是否支持usb_driver里定义的id_table,若支持,调用usb_driver的probe函数. 所以首先要定义并初始化usb_driver结构体: static struct usb_driver usbmouse_as_key_driver = { .name = "usbmouse_as_key", .probe = usb

Linux下hp打印机驱动hplip分析

Hplip分析 版本是2.14,源码位置:http://hplipopensource.com.图的来源:http://hplipopensource.com/node/128. 1.D-Bus初始化流程 D-Bus的初始化同样是在ui4/devmgr5.py开始的. ui4/devmgr5.py 01 class DevMgr5(QMainWindow,  Ui_MainWindow): 02     ...... 03     # TODO: Make sbus init mandatory

【L】小米随身WiFi,Linux下AP热点驱动(开源)

前言 这是作者修改后的Linux下的小米随身WiFi驱动,支持Ap模式,开源,同时支持360随身WiFi二代 注意: 1.这个是Linux下的小米随身WiFi驱动,不是Window和MAC下 2.这个不是STA模式下的可当作无线网卡的驱动,是可当Ap热点模式的驱动 3.这个理论上也是支持360随身WiFi二代..(rtusb_dev_id.c 里面同样有360的id) 原由: 小米随身WiFi很好用,有Widnow和Mac的系统的驱动, 但是可怜不少Linux下的苦逼开发者,没有驱动就是没有..