20150312 NorFlash驱动

20150312 NorFlash驱动

2015-03-12 李海沿

以下知识点是根据韦老大的教程所做的笔记,板子是S3C2410。

About NorFlash and NandFlash

 

NOR

NAND

接口

RAM-like,引脚多

引脚少,复用

容量

小,1M,2M,32M

大,128M,256M,1G

简单

复杂

发出特定指令,复杂

复杂

价格

便宜

质量

几乎没有坏块

可能有坏块,发生位反转

1.读数据

md.b 0

2.读ID NOR手册上

往地址555H写入AAH        

往地址2AAH写入55H 解锁完成

往地址555H写入90H

读0地址得到厂家ID: C2H

读1地址得到设备ID:22DAH 或 225BH

退出读ID状态 往任意地址写入F0

 

如果芯片的接口是A1接到NOR的A0,那么发出的命令要左移一位,NOR才能接收到555这个地址

例如:555H<<1

 

U-BOOT操作:

往地址AAAH写AAH

mw.w aaa aa

往地址554H写55H    

mw.w 554 55

往地址AAAH写90H    

mw.w aaa 90

读0地址得到厂家ID: C2H

md.w 0 1

读2地址得到设备ID: 22DAH 或 225BH

md.w 2 1

退出读ID状态 往任意地址写入F0

mw.w 0 f0

 

3.规范

MOR有两种规范 :

①JEDEC:通过发出命令来读写ID,发送命令,与内核的数组(jedec_table包含nor的各种信息)进行比较一下,发送数据,老式

②CFI:本身就包含了nor容量规格等信息

进入CFI模式

往55H写入98H

读数据

读10H得到0051

读11H得到0052

读12H得到0059

读27H得到容量 (该值的2^n就是容量)

退出CFI模式

往任意地址写入F0

如果芯片的接口是A1接到NOR的A0,那么发出的命令要左移一位,NOR才能接收到555这个地址

例如:555H<<1

 

U-BOOT操作:

进入CFI模式

往AAH写入98H

mw.w aa 98

读数据

读20H得到0051

读22H得到0052

读24H得到0059

读41H得到容量 (该值的2^n就是容量)

md.w 20 1

md.w 22 1

md.w 24 1

md.w 41 1

 

退出CFI模式,往任意地址写入F0

Mw.w 0 f0

 

 

4.写数据

2410读数据uboot操作

往地址AAAH写AAH

mw.w aaa aa

往地址554H写55H    

mw.w 554 55

往地址AAAH写90H    

mw.w aaa 90

读0地址得到厂家ID: C2H

md.w 0 1

读2地址得到设备ID: 22DAH 或 225BH

md.w 2 1

退出读ID状态 往任意地址写入F0

mw.w 0 f0

 

 

 

以下是imx257的nand读写数据的操作,

 

转载于:https://www.cnblogs.com/lihaiyan/p/4333275.html

linuxdriver_code_tool |-- 03 | `-- 2.6内核升级工具 | |-- device-mapper-1.00.19-2.i386.rpm | |-- lvm2-2.00.25-1.01.i386.rpm | |-- mkinitrd-4.2.0.3.tar.tar | |-- module-init-tools-3.2.2.tar.bz2 | `-- modutils-2.4.5-1.src.rpm |-- 04 | |-- 内核模块参数范例 | | `-- book.c | |-- 内核模块导出符号 | | `-- export_symb.c | `-- 最简单的内核模块 | `-- hello.c |-- 05 | `-- udev源代码 | `-- udev-114.tar.gz |-- 06 | |-- globalmem驱动 | | `-- globalmem.c | `-- 包含2个globalmem设备的驱动 | `-- globalmem_two.c |-- 07 | `-- 含并发控制的globalmem驱动 | `-- globalmem_lock.c |-- 08 | |-- globalfifo驱动 | | `-- globalfifo.c | `-- poll应用程序范例 | `-- pollmonitor.c |-- 09 | |-- 异步通知应用程序范例 | | `-- asyncmonitor.c | `-- 支持异步通知的globalfifo | `-- globalfifo_async.c |-- 10 | |-- S3C2410实时钟驱动 | | `-- s3c2410-rtc.c | `-- 秒设备驱动与应用程序 | |-- second.c | `-- second_test.c |-- 11 | |-- DMA范例 | | |-- 3c505.c | | |-- 3c505.h | | `-- dma.h | `-- 静态映射范例 | `-- mach-smdk2440.c |-- 12 | |-- NVRAM驱动 | | `-- generic_nvram.c | |-- 触摸屏驱动 | | |-- 作为input设备 | | | |-- s3c2410_ts.c | | | `-- s3c2410_ts.h | | `-- 作为普通字符设备 | | `-- s3c2410-ts.c | |-- 看门狗驱动 | | `-- s3c2410_wdt.c | `-- 平台设备 | `-- devs.c |-- 13 | |-- IDE驱动 | | |-- ide-disk.c | | `-- ide-h8300.c | `-- RAMDISK驱动 | `-- rd.c |-- 14 | |-- S3C2410串口驱动 | | |-- regs-gpio.h | | |-- regs-serial.h | | `-- s3c2410.c | `-- 串口核心层 | |-- serial_core.c | `-- serial_core.h |-- 15 | |-- S3C2410 I2C主机驱动 | | |-- i2c-s3c2410.c | | |-- iic.h | | |-- regs-gpio.h | | `-- regs-iic.h | `-- SAA711x I2C设备驱动 | `-- saa711x.c |-- 16 | `-- CS8900以太网设备驱动 | |-- cs89x0.c | `-- cs89x0.h |-- 17 | |-- ALSA工具及库 | | |-- alsa-driver-1.0.15.tar.bz2 | | |-- alsa-firmware-1.0.15.tar.bz2 | | |-- alsa-lib-1.0.15.tar.bz2 | | |-- alsa-oss-1.0.15.tar.bz2 | | |-- alsa-tools-1.0.15.tar.bz2 | | |-- alsa-utils-1.0.13.tar.bz2 | | `-- pyalsa-1.0.15.tar.bz2 | |-- ALSA驱动范例 | | |-- sa11xx-uda1341.c | | `-- uda1341.h | |-- ALSA应用程序范例 | | |-- pcm.c | | `-- pcm_min.c | |-- OSS驱动范例 | | `-- s3c2410-uda1341.c | `-- OSS应用程序范例 | |-- mixer.c | `-- sound.c |-- 18 | |-- FRAMEBUFFER应用程序范例 | | `-- fb_display | | |-- fb_display.c | | |-- fb_display.h | | |-- Makefile | | |-- README | | `-- test.c | `-- S3C2410 LCD驱动 | |-- s3c2410fb.c | `-- s3c2410fb.h |-- 19 | |-- busybox源代码 | | `-- busybox-1.2.1.tar.bz2 | |-- MTD工具 | | `-- mtd-utils-1.0.0.tar.gz | |-- nand驱动范例 | | `-- s3c2410.c | |-- nor驱动范例 | | `-- s3c2410nor.c | `-- yaffs&yaffs2源代码 | |-- yaffs.tar.gz | `-- yaffs2.tar.gz |-- 20 | |-- USB串口驱动 | | |-- usb-serial.c | | `-- usb-serial.h | |-- USB工具 | | `-- usbview-1.0.tar.tar | |-- USB骨架程序 | | `-- usb-skeleton.c | |-- USB键盘驱动 | | |-- input.h | | |-- usb_input.h | | `-- usbkbd.c | `-- usb主机控制器驱动范例 | |-- ohci-s3c2410.c | `-- usb-control.h |-- 21 | |-- PCI骨架程序 | | `-- pci-skeleton.c | `-- PCI驱动范例 | `-- i810_audio.c `-- 22 |-- 范例代码 | |-- oops范例 | | |-- oops_example.asm | | `-- oops_example.c | `-- proc范例 | `-- sim_proc.c `-- 内核调试工具 |-- ddd-3.3.11.tar.gz |-- gdbmod-2.4.bz2 |-- kdb-v4.4-2.6.15-rc5-common-1.bz2 |-- kdb-v4.4-2.6.15-rc5-common-2.bz2 |-- kdb-v4.4-2.6.15-rc5-i386-1.bz2 `-- linux-2.6.15.5-kgdb-2.4.tar.tar 73 directories, 91 files
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值