linux NAND驱动之五:NAND驱动中probe和nand_chip结构
来源:互联网 发布:java零基础视频 编辑:程序博客网 时间:2024/04/28 13:24
在基于MTD 的NAND driver 的probe 函数中,主要可以分为两部分内容,其一是与很多外设driver 类似的一些工作,如申请地址,中断,DMA 等资源,kzalloc 及初始化一些结构体,分配DMA 用的内存等等;其二就是与MTD 相关的一些特定的工作,在这里我们将只描述第二部分内容。
(1)probe 函数中与MTD 相关的结构体
unsigned int options :与具体的NAND 芯片相关的一些选项,如NAND_BUSWIDTH_16 等,可以参考<linux/mtd/nand.h>
int page_shift :用位表示的NAND 芯片的page 大小,如某片NAND 芯片的一个page 有512 个字节,那么page_shift 就是9 ;
int phys_erase_shift :用位表示的NAND 芯片的每次可擦除的大小,如某片NAND 芯片每次可擦除16K 字节( 通常就是一个block 的大小) ,那么phys_erase_shift 就是14 ;
int bbt_erase_shift :用位表示的bad block table 的大小,通常一个bbt 占用一个block ,所以bbt_erase_shift 通常与phys_erase_shift 相等;
int
unsigned long chipsize :NAND 芯片的大小;
int
int
int
C.
(2)对NAND 芯片进行实际操作的函数
}
IO_ADDR_R 和IO_ADDR_W :8 位NAND 芯片的读写地址,如果你的NAND controller 是用PIO 模式与NAND 芯片交互,那么只要把这两个值赋上合适的地址,就完全可以使用MTD 提供的default 的读写函数来操作NAND 芯片了。所以这两个变量视具体的NAND controller 而定,不一定用得着;
read_byte 和read_word :从NAND 芯片读一个字节或一个字,通常MTD 会在读取NAND 芯片的ID ,STATUS 和OOB 中的坏块信息时调用这两个函数,具体是这样的流程,首先MTD 调用cmdfunc 函数,发起相应的命令,NAND 芯片收到命令后就会做好准备,最后MTD 就会调用read_byte 或read_word 函数从NAND 芯片中读取芯片的ID ,STATUS 或者OOB ;
read_buf 、write_buf 和verify_buf:分别是从NAND 芯片读取数据到buffer、把buffer 中的数据写入到NAND 芯片、和从NAND 芯片中读取数据并验证。调用read_buf 时的流程与read_byte 和read_word 类似,MTD 也是先调用cmdfunc 函数发起读命令( 如NAND_CMD_READ0 命令) ,接着NAND 芯片收到命令后做好准备,最后MTD 再调用read_buf 函数把NAND 芯片中的数据读取到buffer 中。调用write_buf 函数的流程与read_buf 相似;
select_chip :因为系统中可能有不止一片NAND 芯片,所以在对NAND 芯片进行操作前,需要这个函数来指定一片NAND 芯片;
cmdfunc :向NAND 芯片发起命令;
waitfunc :NAND 芯片在接收到命令后,并不一定能立即响应NAND controller 的下一步动作,对有些命令,比如erase ,program 等命令,NAND 芯片需要一定的时间来完成,所以就需要这个waitfunc 来等待NAND 芯片完成命令,并再次进入准备好状态;
write_page :把一个page 的数据写入NAND 芯片,这个函数一般不需我们实现,因为它会调用struct nand_ecc_ctrl 中的write_page_raw 或者write_page 函数,关于这两个函数将在稍后介绍。
(3)最后,struct nand_chip 结构体中还包含了一个很重要的结构体,即struct
struct nand_ecc_ctrl {
} ;
hwctl :这个函数用来控制硬件产生ecc ,其实它主要的工作就是控制NAND controller 向NAND 芯片发出NAND_ECC_READ 、NAND_ECC_WRITE 和NAND_ECC_READSYN 等命令,与struct nand_chip 结构体中的cmdfunc 类似,只不过发起的命令是ECC 相关的罢了;
calculate :根据data 计算ecc 值;
correct :根据ecc 值,判断读写数据时是否有错误发生,若有错,则立即试着纠正,纠正失败则返回错误;
read_page_raw 和write_page_raw :从NAND 芯片中读取一个page 的原始数据和向NAND 芯片写入一个page 的原始数据,所谓的原始数据,即不对读写的数据做ecc 处理,该读写什么值就读写什么值。另外,这两个函数会读写整个page 中的所有内容,即不但会读写一个page 中MAIN 部分,还会读写OOB 部分。
read_page 和write_page :与read_page_raw 和write_page_raw 类似,但不同的是,read_page 和write_page 在读写过程中会加入ecc 的计算,校验,和纠正等处理。
read_oob 和write_oob :读写oob 中的内容,不包括MAIN 部分。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhandoushi1982/archive/2010/03/24/5410938.aspx
来源:http://blog.sina.com.cn/s/blog_55465b470100iwkt.html
- linux NAND驱动之五:NAND驱动中probe和nand_chip结构体
- linux NAND驱动之五:NAND驱动中probe和nand_chip结构体
- linux NAND驱动之五:NAND驱动中probe和nand_chip结构
- linux NAND驱动之五:NAND驱动中probe和nand_chip结构体
- linux NAND驱动之六:NAND驱动的probe流程
- linux NAND驱动之六:NAND驱动的probe流程
- linux NAND驱动之六:NAND驱动的probe流程
- inux NAND驱动之六:NAND驱动的probe流程
- linux nand 驱动
- linux NAND驱动之二:NAND存储原理
- linux NAND驱动之二:NAND存储原理
- linux NAND驱动之二:NAND存储原理
- Linux块设备驱动之NAND FLASH
- Nand flash linux 驱动研究
- linux NAND驱动之三:6410平台上的NAND驱动加载
- linux NAND驱动之三:6410平台上的NAND驱动加载
- linux NAND驱动之三:6410平台上的NAND驱动加载
- linux NAND驱动之三:6410平台上的NAND驱动加载
- shell--所有行前加序号
- 使用可重入函数进行更安全的信号处理
- Linux下可以替换运行中的程序么?
- sed 学习笔记(转)
- Awk学习笔记
- linux NAND驱动之五:NAND驱动中probe和nand_chip结构
- shell字符串操作集
- MySQL删除小写记录
- TPL: 一个新的C++正则表达式(regex)库
- http://www.regexlab.com/zh/regref.htm
- LINUX同步软件rsync原理
- Linux下select调用引发的血案
- LinuxThread VS NPTL
- Linux 线程模型的比较:LinuxThreads 和 NPTL