// 参阅
#include “linux/module.h”
#include “linux/types.h”
#include “linux/init.h”
#include “linux/kernel.h”
#include “linux/string.h”
#include “linux/ioport.h”
#include “linux/platform_device.h
#include “linux/delay.h”
#include “linux/err.h”
#include “linux/slab.h”
#include “linux/clk.h”
#include “linux/mtd/mtd.h”
#include “linux/mtd/nand.h”
#include “linux/mtd/nand_ecc.h”
#include “linux/mtd/partitions.h”
#include “asm/io.h”
#include “asm/arch/regs-nand.h”
#include “asm/arch/nand.h”
struct s3c_nand_regs {
};
static struct nand_chip *s3c_nand;
static struct mtd_info *s3c_mtd;
static struct s3c_nand_regs *s3c_nand_regs;
static struct mtd_partition s3c_nand_parts[] = {
};
static void s3c2440_select_chip(struct mtd_info *mtd, int chipnr)
{
}
static void s3c2440_cmd_ctrl(struct mtd_info *mtd, int dat, unsigned int ctrl)
{
}
static int s3c2440_dev_ready(struct mtd_info *mtd)
{
}
static int s3c_nand_init(void)
{
/ 设置nand_chip是给nand_scan函数运用的, 假如不知道怎样设置, 先看nand_scan怎样运用
/ 它应该供给:选中,发指令,发地址,发数据,读数据,判别状况的功用
// 使能NAND FLASH控制器的时钟
* TACLS: 宣布CLE/ALE之后多长时刻才宣布nWE信号, 从NAND手册可知CLE/ALE与nWE能够一起宣布,所以TACLS=0
* TWRPH0: nWE的脉冲宽度, HCLK x ( TWRPH0 + 1 ), 从NAND手册可知它要>=12ns, 所以TWRPH0>=1
* TWRPH1: nWE变为高电平后多长时刻CLE/ALE才干变为低电平, 从NAND手册可知它要>=5ns, 所以TWRPH1>=0
//
#define TACLS 0
#define TWRPH0 1
#define TWRPH1 0
* BIT1-设为1, 撤销片选
* BIT0-设为1, 使能NAND FLASH控制器
//
}
static void s3c_nand_exit(void)
{
}
module_init(s3c_nand_init);
module_exit(s3c_nand_exit);
MODULE_LICENSE(“GPL”);
=================================================================
NAND FLASH是一个存储芯片
那么: 这样的操作很合理”读地址A的数据,把数据B写到地址A”
问1. 原理图上NAND FLASH和S3C2440之间只要数据线,
答1.在DATA0~DATA7上既传输数据,又传输地址
问2. 从NAND FLASH芯片手册可知,要操作NAND FLASH需求先宣布指令
答2.在DATA0~DATA7上既传输数据,又传输地址,也传输指令
问3. 数据线既接到NAND FLASH,也接到NOR FLASH,还接到SDRAM、DM9000等等
答3. 这些设备,要拜访之有必要”选中”,
问4. 假定烧写NAND FLASH,把指令、地址、数据发给它之后,
答4. 经过状况引脚RnB来判别:它为高电平表明安排妥当,它为低电平表明正忙
问5. 怎样操作NAND FLASH呢?
答5. 依据NAND FLASH的芯片手册,一般的进程是:
发指令 选中芯片
发地址 选中芯片 NFADDR=地址值
发数据 选中芯片 NFDATA=数据值
读数据 选中芯片 val=NFDATA
用UBOOT来体会NAND FLASH的操作:
1. 读ID
选中 NFCONT的bit1设为0 md.l 0x4E000004 1; mw.l 0x4E000004 1
宣布指令0x90 NFCMMD=0x90 mw.b 0x4E000008 0x90
宣布地址0x00 NFADDR=0x00 mw.b 0x4E00000C 0x00
读数据得到0xEC val=NFDATA md.b 0x4E000010 1
读数据得到device code val=NFDATA md.b 0x4E000010 1
退出读ID的状况 NFCMMD=0xff mw.b 0x4E000008 0xff
2. 读内容: 读0地址的数据
运用UBOOT指令:
nand dump 0
Page 00000000 dump:
选中 NFCONT的bit1设为0 md.l 0x4E000004 1; mw.l 0x4E000004 1
宣布指令0x00 NFCMMD=0x00 mw.b 0x4E000008 0x00
宣布地址0x00 NFADDR=0x00 mw.b 0x4E00000C 0x00
宣布地址0x00 NFADDR=0x00 mw.b 0x4E00000C 0x00
宣布地址0x00 NFADDR=0x00 mw.b 0x4E00000C 0x00
宣布地址0x00 NFADDR=0x00 mw.b 0x4E00000C 0x00
宣布地址0x00 NFADDR=0x00 mw.b 0x4E00000C 0x00
宣布指令0x30 NFCMMD=0x30 mw.b 0x4E000008 0x30
读数据得到0x17 val=NFDATA md.b 0x4E000010 1
读数据得到0x00 val=NFDATA md.b 0x4E000010 1
读数据得到0x00 val=NFDATA md.b 0x4E000010 1
读数据得到0xea val=NFDATA md.b 0x4E000010 1
退出读状况 NFCMMD=0xff mw.b 0x4E000008 0xff
NAND FLASH驱动程序层次
看内核发动信息
S3C24XX NAND Driver, (c) 2004 Simtec Electronics
s3c2440-nand s3c2440-nand: Tacls=3, 30ns Twrph0=7 70ns, Twrph1=3 30ns
NAND device: Manufacturer ID: 0xec, Chip ID: 0xda (Samsung NAND 256MiB 3,3V 8-bit)
Scanning device for bad blocks
Bad eraseblock 256 at 0x02000000
Bad eraseblock 257 at 0x02020000
Bad eraseblock 319 at 0x027e0000
Bad eraseblock 606 at 0x04bc0000
Bad eraseblock 608 at 0x04c00000
Creating 4 MTD partitions on “NAND 256MiB 3,3V 8-bit”:
0x00000000-0x00040000 : “bootloader”
0x00040000-0x00060000 : “params”
0x00060000-0x00260000 : “kernel”
0x00260000-0x10000000 : “root”
搜”S3C24XX NAND Driver”
S3c2410.c (drivers\mtd\nand)
s3c2410_nand_inithw
s3c2410_nand_init_chip
nand_scan // drivers/mtd/nand/nand_base.c 依据nand_chip的底层操作函数辨认NAND FLASH,结构mtd_info
if (!chip->select_chip)
chip->select_chip = nand_select_chip; // 默认值不适用
if (chip->cmdfunc == NULL)
chip->cmdfunc = nand_command;
chip->cmd_ctrl(mtd, command, ctrl);
if (!chip->read_byte)
chip->read_byte = nand_read_byte;
readb(chip->IO_ADDR_R);
if (chip->waitfunc == NULL)
chip->waitfunc = nand_wait;
chip->dev_ready
s3c2410_nand_add_partition
测验4th:
1. make menuconfig去掉内核自带的NAND FLASH驱动
-> Device Drivers
2. make uImage
3. insmod s3c_nand.ko
4. 格局化 (参阅下面编译东西)
5. 挂接
6. 在/mnt目录下建文件
编译东西:
1. tar xjf mtd-utils-05.07.23.tar.bz2
2. cd mtd-utils-05.07.23/util
修正Makefile:
#CROSS=arm-linux-
改为
CROSS=arm-linux-
3. make
4. cp flash_erase flash_eraseall /work/nfs_root/first_fs/bin/