Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
61b03bd7
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
61b03bd7
编写于
11月 07, 2005
作者:
T
Thomas Gleixner
提交者:
Thomas Gleixner
11月 07, 2005
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[MTD] NAND: Clean up trailing white spaces
Signed-off-by:
N
Thomas Gleixner
<
tglx@linutronix.de
>
上级
e5580fbe
变更
17
展开全部
隐藏空白更改
内联
并排
Showing
17 changed file
with
695 addition
and
695 deletion
+695
-695
drivers/mtd/nand/Kconfig
drivers/mtd/nand/Kconfig
+5
-5
drivers/mtd/nand/au1550nd.c
drivers/mtd/nand/au1550nd.c
+29
-29
drivers/mtd/nand/autcpu12.c
drivers/mtd/nand/autcpu12.c
+11
-11
drivers/mtd/nand/diskonchip.c
drivers/mtd/nand/diskonchip.c
+50
-50
drivers/mtd/nand/edb7312.c
drivers/mtd/nand/edb7312.c
+24
-24
drivers/mtd/nand/h1910.c
drivers/mtd/nand/h1910.c
+24
-24
drivers/mtd/nand/nand_base.c
drivers/mtd/nand/nand_base.c
+239
-239
drivers/mtd/nand/nand_bbt.c
drivers/mtd/nand/nand_bbt.c
+124
-124
drivers/mtd/nand/nand_ecc.c
drivers/mtd/nand/nand_ecc.c
+22
-22
drivers/mtd/nand/nand_ids.c
drivers/mtd/nand/nand_ids.c
+15
-15
drivers/mtd/nand/nandsim.c
drivers/mtd/nand/nandsim.c
+81
-81
drivers/mtd/nand/ppchameleonevb.c
drivers/mtd/nand/ppchameleonevb.c
+3
-3
drivers/mtd/nand/rtc_from4.c
drivers/mtd/nand/rtc_from4.c
+29
-29
drivers/mtd/nand/s3c2410.c
drivers/mtd/nand/s3c2410.c
+15
-15
drivers/mtd/nand/sharpsl.c
drivers/mtd/nand/sharpsl.c
+11
-11
drivers/mtd/nand/spia.c
drivers/mtd/nand/spia.c
+3
-3
drivers/mtd/nand/toto.c
drivers/mtd/nand/toto.c
+10
-10
未找到文件。
drivers/mtd/nand/Kconfig
浏览文件 @
61b03bd7
# drivers/mtd/nand/Kconfig
# $Id: Kconfig,v 1.3
4 2005/09/23 01:44:55 ppopov
Exp $
# $Id: Kconfig,v 1.3
5 2005/11/07 11:14:30 gleixner
Exp $
menu "NAND Flash Device Drivers"
depends on MTD!=n
...
...
@@ -27,14 +27,14 @@ config MTD_NAND_AUTCPU12
tristate "SmartMediaCard on autronix autcpu12 board"
depends on MTD_NAND && ARCH_AUTCPU12
help
This enables the driver for the autronix autcpu12 board to
This enables the driver for the autronix autcpu12 board to
access the SmartMediaCard.
config MTD_NAND_EDB7312
tristate "Support for Cirrus Logic EBD7312 evaluation board"
depends on MTD_NAND && ARCH_EDB7312
help
This enables the driver for the Cirrus Logic EBD7312 evaluation
This enables the driver for the Cirrus Logic EBD7312 evaluation
board to access the onboard NAND Flash.
config MTD_NAND_H1900
...
...
@@ -71,7 +71,7 @@ config MTD_NAND_RTC_FROM4
select REED_SOLOMON
select REED_SOLOMON_DEC8
help
This enables the driver for the Renesas Technology AG-AND
This enables the driver for the Renesas Technology AG-AND
flash interface board (FROM_BOARD4)
config MTD_NAND_PPCHAMELEONEVB
...
...
@@ -88,7 +88,7 @@ config MTD_NAND_S3C2410
SoCs
No board specfic support is done by this driver, each board
must advertise a platform_device for the driver to attach.
must advertise a platform_device for the driver to attach.
config MTD_NAND_S3C2410_DEBUG
bool "S3C2410 NAND driver debug"
...
...
drivers/mtd/nand/au1550nd.c
浏览文件 @
61b03bd7
...
...
@@ -3,7 +3,7 @@
*
* Copyright (C) 2004 Embedded Edge, LLC
*
* $Id: au1550nd.c,v 1.1
2 2005/09/23 01:44:55 ppopov
Exp $
* $Id: au1550nd.c,v 1.1
3 2005/11/07 11:14:30 gleixner
Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
...
...
@@ -25,10 +25,10 @@
#else
#include <asm/au1000.h>
#ifdef CONFIG_MIPS_PB1550
#include <asm/pb1550.h>
#include <asm/pb1550.h>
#endif
#ifdef CONFIG_MIPS_DB1550
#include <asm/db1x00.h>
#include <asm/db1x00.h>
#endif
#endif
...
...
@@ -43,12 +43,12 @@ static int nand_width = 1; /* default x8*/
* Define partitions for flash device
*/
const
static
struct
mtd_partition
partition_info
[]
=
{
{
{
.
name
=
"NAND FS 0"
,
.
offset
=
0
,
.
size
=
8
*
1024
*
1024
.
size
=
8
*
1024
*
1024
},
{
{
.
name
=
"NAND FS 1"
,
.
offset
=
MTDPART_OFS_APPEND
,
.
size
=
MTDPART_SIZ_FULL
...
...
@@ -89,7 +89,7 @@ static void au_write_byte(struct mtd_info *mtd, u_char byte)
* au_read_byte16 - read one byte endianess aware from the chip
* @mtd: MTD device structure
*
* read function for 16bit buswith with
* read function for 16bit buswith with
* endianess conversion
*/
static
u_char
au_read_byte16
(
struct
mtd_info
*
mtd
)
...
...
@@ -119,7 +119,7 @@ static void au_write_byte16(struct mtd_info *mtd, u_char byte)
* au_read_word - read one word from the chip
* @mtd: MTD device structure
*
* read function for 16bit buswith without
* read function for 16bit buswith without
* endianess conversion
*/
static
u16
au_read_word
(
struct
mtd_info
*
mtd
)
...
...
@@ -135,7 +135,7 @@ static u16 au_read_word(struct mtd_info *mtd)
* @mtd: MTD device structure
* @word: data word to write
*
* write function for 16bit buswith without
* write function for 16bit buswith without
* endianess conversion
*/
static
void
au_write_word
(
struct
mtd_info
*
mtd
,
u16
word
)
...
...
@@ -165,7 +165,7 @@ static void au_write_buf(struct mtd_info *mtd, const u_char *buf, int len)
}
/**
* au_read_buf - read chip data into buffer
* au_read_buf - read chip data into buffer
* @mtd: MTD device structure
* @buf: buffer to store date
* @len: number of bytes to read
...
...
@@ -179,12 +179,12 @@ static void au_read_buf(struct mtd_info *mtd, u_char *buf, int len)
for
(
i
=
0
;
i
<
len
;
i
++
)
{
buf
[
i
]
=
readb
(
this
->
IO_ADDR_R
);
au_sync
();
au_sync
();
}
}
/**
* au_verify_buf - Verify chip data against buffer
* au_verify_buf - Verify chip data against buffer
* @mtd: MTD device structure
* @buf: buffer containing the data to compare
* @len: number of bytes to compare
...
...
@@ -219,16 +219,16 @@ static void au_write_buf16(struct mtd_info *mtd, const u_char *buf, int len)
struct
nand_chip
*
this
=
mtd
->
priv
;
u16
*
p
=
(
u16
*
)
buf
;
len
>>=
1
;
for
(
i
=
0
;
i
<
len
;
i
++
)
{
writew
(
p
[
i
],
this
->
IO_ADDR_W
);
au_sync
();
}
}
/**
* au_read_buf16 - read chip data into buffer
* au_read_buf16 - read chip data into buffer
* @mtd: MTD device structure
* @buf: buffer to store date
* @len: number of bytes to read
...
...
@@ -249,7 +249,7 @@ static void au_read_buf16(struct mtd_info *mtd, u_char *buf, int len)
}
/**
* au_verify_buf16 - Verify chip data against buffer
* au_verify_buf16 - Verify chip data against buffer
* @mtd: MTD device structure
* @buf: buffer containing the data to compare
* @len: number of bytes to compare
...
...
@@ -282,26 +282,26 @@ static void au1550_hwcontrol(struct mtd_info *mtd, int cmd)
case
NAND_CTL_CLRCLE
:
this
->
IO_ADDR_W
=
p_nand
+
MEM_STNAND_DATA
;
break
;
case
NAND_CTL_SETALE
:
this
->
IO_ADDR_W
=
p_nand
+
MEM_STNAND_ADDR
;
break
;
case
NAND_CTL_CLRALE
:
this
->
IO_ADDR_W
=
p_nand
+
MEM_STNAND_DATA
;
/* FIXME: Nobody knows why this is neccecary,
case
NAND_CTL_CLRALE
:
this
->
IO_ADDR_W
=
p_nand
+
MEM_STNAND_DATA
;
/* FIXME: Nobody knows why this is neccecary,
* but it works only that way */
udelay
(
1
);
udelay
(
1
);
break
;
case
NAND_CTL_SETNCE
:
case
NAND_CTL_SETNCE
:
/* assert (force assert) chip enable */
au_writel
((
1
<<
(
4
+
NAND_CS
))
,
MEM_STNDCTL
);
break
;
break
;
case
NAND_CTL_CLRNCE
:
case
NAND_CTL_CLRNCE
:
/* deassert chip enable */
au_writel
(
0
,
MEM_STNDCTL
);
break
;
break
;
}
this
->
IO_ADDR_R
=
this
->
IO_ADDR_W
;
/* Drain the writebuffer */
au_sync
();
}
...
...
@@ -325,7 +325,7 @@ int __init au1xxx_nand_init (void)
u32
nand_phys
;
/* Allocate memory for MTD device structure and private data */
au1550_mtd
=
kmalloc
(
sizeof
(
struct
mtd_info
)
+
au1550_mtd
=
kmalloc
(
sizeof
(
struct
mtd_info
)
+
sizeof
(
struct
nand_chip
),
GFP_KERNEL
);
if
(
!
au1550_mtd
)
{
printk
(
"Unable to allocate NAND MTD dev structure.
\n
"
);
...
...
@@ -345,7 +345,7 @@ int __init au1xxx_nand_init (void)
/* disable interrupts */
au_writel
(
au_readl
(
MEM_STNDCTL
)
&
~
(
1
<<
8
),
MEM_STNDCTL
);
/* disable NAND boot */
au_writel
(
au_readl
(
MEM_STNDCTL
)
&
~
(
1
<<
0
),
MEM_STNDCTL
);
...
...
@@ -353,7 +353,7 @@ int __init au1xxx_nand_init (void)
/* set gpio206 high */
au_writel
(
au_readl
(
GPIO2_DIR
)
&
~
(
1
<<
6
),
GPIO2_DIR
);
boot_swapboot
=
(
au_readl
(
MEM_STSTAT
)
&
(
0x7
<<
1
))
|
boot_swapboot
=
(
au_readl
(
MEM_STSTAT
)
&
(
0x7
<<
1
))
|
((
bcsr
->
status
>>
6
)
&
0x1
);
switch
(
boot_swapboot
)
{
case
0
:
...
...
@@ -402,7 +402,7 @@ int __init au1xxx_nand_init (void)
au_writel
(
NAND_STADDR
,
MEM_STADDR3
);
}
#endif
/* Locate NAND chip-select in order to determine NAND phys address */
mem_staddr
=
0x00000000
;
if
(((
au_readl
(
MEM_STCFG0
)
&
0x7
)
==
0x5
)
&&
(
NAND_CS
==
0
))
...
...
@@ -438,7 +438,7 @@ int __init au1xxx_nand_init (void)
this
->
hwcontrol
=
au1550_hwcontrol
;
this
->
dev_ready
=
au1550_device_ready
;
/* 30 us command delay time */
this
->
chip_delay
=
30
;
this
->
chip_delay
=
30
;
this
->
eccmode
=
NAND_ECC_SOFT
;
this
->
options
=
NAND_NO_AUTOINCR
;
...
...
@@ -467,7 +467,7 @@ int __init au1xxx_nand_init (void)
outio:
iounmap
((
void
*
)
p_nand
);
outmem:
kfree
(
au1550_mtd
);
return
retval
;
...
...
drivers/mtd/nand/autcpu12.c
浏览文件 @
61b03bd7
...
...
@@ -5,8 +5,8 @@
*
* Derived from drivers/mtd/spia.c
* Copyright (C) 2000 Steven J. Hill (sjhill@realitydiluted.com)
*
* $Id: autcpu12.c,v 1.2
2 2004/11/04 12:53:1
0 gleixner Exp $
*
* $Id: autcpu12.c,v 1.2
3 2005/11/07 11:14:3
0 gleixner Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
...
...
@@ -14,7 +14,7 @@
*
* Overview:
* This is a device driver for the NAND flash device found on the
* autronix autcpu12 board, which is a SmartMediaCard. It supports
* autronix autcpu12 board, which is a SmartMediaCard. It supports
* 16MiB, 32MiB and 64MiB cards.
*
*
...
...
@@ -93,7 +93,7 @@ static struct mtd_partition partition_info128k[] = {
#define NUM_PARTITIONS32K 2
#define NUM_PARTITIONS64K 2
#define NUM_PARTITIONS128K 2
/*
/*
* hardware specific access to control-lines
*/
static
void
autcpu12_hwcontrol
(
struct
mtd_info
*
mtd
,
int
cmd
)
...
...
@@ -163,7 +163,7 @@ int __init autcpu12_init (void)
this
->
hwcontrol
=
autcpu12_hwcontrol
;
this
->
dev_ready
=
autcpu12_device_ready
;
/* 20 us command delay time */
this
->
chip_delay
=
20
;
this
->
chip_delay
=
20
;
this
->
eccmode
=
NAND_ECC_SOFT
;
/* Enable the following for a flash based bad block table */
...
...
@@ -171,21 +171,21 @@ int __init autcpu12_init (void)
this->options = NAND_USE_FLASH_BBT;
*/
this
->
options
=
NAND_USE_FLASH_BBT
;
/* Scan to find existance of the device */
if
(
nand_scan
(
autcpu12_mtd
,
1
))
{
err
=
-
ENXIO
;
goto
out_ior
;
}
/* Register the partitions */
switch
(
autcpu12_mtd
->
size
){
case
SZ_16M
:
add_mtd_partitions
(
autcpu12_mtd
,
partition_info16k
,
NUM_PARTITIONS16K
);
break
;
case
SZ_32M
:
add_mtd_partitions
(
autcpu12_mtd
,
partition_info32k
,
NUM_PARTITIONS32K
);
break
;
case
SZ_64M
:
add_mtd_partitions
(
autcpu12_mtd
,
partition_info64k
,
NUM_PARTITIONS64K
);
break
;
case
SZ_128M
:
add_mtd_partitions
(
autcpu12_mtd
,
partition_info128k
,
NUM_PARTITIONS128K
);
break
;
case
SZ_64M
:
add_mtd_partitions
(
autcpu12_mtd
,
partition_info64k
,
NUM_PARTITIONS64K
);
break
;
case
SZ_128M
:
add_mtd_partitions
(
autcpu12_mtd
,
partition_info128k
,
NUM_PARTITIONS128K
);
break
;
default:
{
printk
(
"Unsupported SmartMedia device
\n
"
);
printk
(
"Unsupported SmartMedia device
\n
"
);
err
=
-
ENXIO
;
goto
out_ior
;
}
...
...
@@ -213,7 +213,7 @@ static void __exit autcpu12_cleanup (void)
/* unmap physical adress */
iounmap
((
void
*
)
autcpu12_fio_base
);
/* Free the MTD device structure */
kfree
(
autcpu12_mtd
);
}
...
...
drivers/mtd/nand/diskonchip.c
浏览文件 @
61b03bd7
/*
/*
* drivers/mtd/nand/diskonchip.c
*
* (C) 2003 Red Hat, Inc.
...
...
@@ -8,15 +8,15 @@
* Author: David Woodhouse <dwmw2@infradead.org>
* Additional Diskonchip 2000 and Millennium support by Dan Brown <dan_brown@ieee.org>
* Diskonchip Millennium Plus support by Kalev Lember <kalev@smartlink.ee>
*
*
* Error correction code lifted from the old docecc code
* Author: Fabrice Bellard (fabrice.bellard@netgem.com)
* Author: Fabrice Bellard (fabrice.bellard@netgem.com)
* Copyright (C) 2000 Netgem S.A.
* converted to the generic Reed-Solomon library by Thomas Gleixner <tglx@linutronix.de>
*
*
* Interface to generic NAND code for M-Systems DiskOnChip devices
*
* $Id: diskonchip.c,v 1.5
4 2005/04/07 14:22:55 dbrown
Exp $
* $Id: diskonchip.c,v 1.5
5 2005/11/07 11:14:30 gleixner
Exp $
*/
#include <linux/kernel.h>
...
...
@@ -42,16 +42,16 @@
static
unsigned
long
__initdata
doc_locations
[]
=
{
#if defined (__alpha__) || defined(__i386__) || defined(__x86_64__)
#ifdef CONFIG_MTD_NAND_DISKONCHIP_PROBE_HIGH
0xfffc8000
,
0xfffca000
,
0xfffcc000
,
0xfffce000
,
0xfffc8000
,
0xfffca000
,
0xfffcc000
,
0xfffce000
,
0xfffd0000
,
0xfffd2000
,
0xfffd4000
,
0xfffd6000
,
0xfffd8000
,
0xfffda000
,
0xfffdc000
,
0xfffde000
,
0xfffe0000
,
0xfffe2000
,
0xfffe4000
,
0xfffe6000
,
0xfffd8000
,
0xfffda000
,
0xfffdc000
,
0xfffde000
,
0xfffe0000
,
0xfffe2000
,
0xfffe4000
,
0xfffe6000
,
0xfffe8000
,
0xfffea000
,
0xfffec000
,
0xfffee000
,
#else
/* CONFIG_MTD_DOCPROBE_HIGH */
0xc8000
,
0xca000
,
0xcc000
,
0xce000
,
0xc8000
,
0xca000
,
0xcc000
,
0xce000
,
0xd0000
,
0xd2000
,
0xd4000
,
0xd6000
,
0xd8000
,
0xda000
,
0xdc000
,
0xde000
,
0xe0000
,
0xe2000
,
0xe4000
,
0xe6000
,
0xd8000
,
0xda000
,
0xdc000
,
0xde000
,
0xe0000
,
0xe2000
,
0xe4000
,
0xe6000
,
0xe8000
,
0xea000
,
0xec000
,
0xee000
,
#endif
/* CONFIG_MTD_DOCPROBE_HIGH */
#elif defined(__PPC__)
...
...
@@ -138,7 +138,7 @@ MODULE_PARM_DESC(doc_config_location, "Physical memory address at which to probe
/* the Reed Solomon control structure */
static
struct
rs_control
*
rs_decoder
;
/*
/*
* The HW decoder in the DoC ASIC's provides us a error syndrome,
* which we must convert to a standard syndrom usable by the generic
* Reed-Solomon library code.
...
...
@@ -163,8 +163,8 @@ static int doc_ecc_decode (struct rs_control *rs, uint8_t *data, uint8_t *ecc)
/* Initialize the syndrom buffer */
for
(
i
=
0
;
i
<
NROOTS
;
i
++
)
s
[
i
]
=
ds
[
0
];
/*
* Evaluate
/*
* Evaluate
* s[i] = ds[3]x^3 + ds[2]x^2 + ds[1]x^1 + ds[0]
* where x = alpha^(FCR + i)
*/
...
...
@@ -188,7 +188,7 @@ static int doc_ecc_decode (struct rs_control *rs, uint8_t *data, uint8_t *ecc)
if
(
nerr
<
0
)
return
nerr
;
/*
/*
* Correct the errors. The bitpositions are a bit of magic,
* but they are given by the design of the de/encoder circuit
* in the DoC ASIC's.
...
...
@@ -205,7 +205,7 @@ static int doc_ecc_decode (struct rs_control *rs, uint8_t *data, uint8_t *ecc)
can be modified since pos is even */
index
=
(
pos
>>
3
)
^
1
;
bitpos
=
pos
&
7
;
if
((
index
>=
0
&&
index
<
SECTOR_SIZE
)
||
if
((
index
>=
0
&&
index
<
SECTOR_SIZE
)
||
index
==
(
SECTOR_SIZE
+
1
))
{
val
=
(
uint8_t
)
(
errval
[
i
]
>>
(
2
+
bitpos
));
parity
^=
val
;
...
...
@@ -216,7 +216,7 @@ static int doc_ecc_decode (struct rs_control *rs, uint8_t *data, uint8_t *ecc)
bitpos
=
(
bitpos
+
10
)
&
7
;
if
(
bitpos
==
0
)
bitpos
=
8
;
if
((
index
>=
0
&&
index
<
SECTOR_SIZE
)
||
if
((
index
>=
0
&&
index
<
SECTOR_SIZE
)
||
index
==
(
SECTOR_SIZE
+
1
))
{
val
=
(
uint8_t
)(
errval
[
i
]
<<
(
8
-
bitpos
));
parity
^=
val
;
...
...
@@ -233,7 +233,7 @@ static void DoC_Delay(struct doc_priv *doc, unsigned short cycles)
{
volatile
char
dummy
;
int
i
;
for
(
i
=
0
;
i
<
cycles
;
i
++
)
{
if
(
DoC_is_Millennium
(
doc
))
dummy
=
ReadDOC
(
doc
->
virtadr
,
NOP
);
...
...
@@ -242,7 +242,7 @@ static void DoC_Delay(struct doc_priv *doc, unsigned short cycles)
else
dummy
=
ReadDOC
(
doc
->
virtadr
,
DOCStatus
);
}
}
#define CDSN_CTRL_FR_B_MASK (CDSN_CTRL_FR_B0 | CDSN_CTRL_FR_B1)
...
...
@@ -327,7 +327,7 @@ static u_char doc2000_read_byte(struct mtd_info *mtd)
return
ret
;
}
static
void
doc2000_writebuf
(
struct
mtd_info
*
mtd
,
static
void
doc2000_writebuf
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -343,7 +343,7 @@ static void doc2000_writebuf(struct mtd_info *mtd,
if
(
debug
)
printk
(
"
\n
"
);
}
static
void
doc2000_readbuf
(
struct
mtd_info
*
mtd
,
static
void
doc2000_readbuf
(
struct
mtd_info
*
mtd
,
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -358,7 +358,7 @@ static void doc2000_readbuf(struct mtd_info *mtd,
}
}
static
void
doc2000_readbuf_dword
(
struct
mtd_info
*
mtd
,
static
void
doc2000_readbuf_dword
(
struct
mtd_info
*
mtd
,
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -379,7 +379,7 @@ static void doc2000_readbuf_dword(struct mtd_info *mtd,
}
}
static
int
doc2000_verifybuf
(
struct
mtd_info
*
mtd
,
static
int
doc2000_verifybuf
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -406,12 +406,12 @@ static uint16_t __init doc200x_ident_chip(struct mtd_info *mtd, int nr)
doc200x_hwcontrol
(
mtd
,
NAND_CTL_SETALE
);
this
->
write_byte
(
mtd
,
0
);
doc200x_hwcontrol
(
mtd
,
NAND_CTL_CLRALE
);
/* We cant' use dev_ready here, but at least we wait for the
* command to complete
* command to complete
*/
udelay
(
50
);
ret
=
this
->
read_byte
(
mtd
)
<<
8
;
ret
|=
this
->
read_byte
(
mtd
);
...
...
@@ -438,7 +438,7 @@ static uint16_t __init doc200x_ident_chip(struct mtd_info *mtd, int nr)
this
->
read_buf
=
&
doc2000_readbuf_dword
;
}
}
return
ret
;
}
...
...
@@ -469,7 +469,7 @@ static int doc200x_wait(struct mtd_info *mtd, struct nand_chip *this, int state)
struct
doc_priv
*
doc
=
this
->
priv
;
int
status
;
DoC_WaitReady
(
doc
);
this
->
cmdfunc
(
mtd
,
NAND_CMD_STATUS
,
-
1
,
-
1
);
DoC_WaitReady
(
doc
);
...
...
@@ -503,7 +503,7 @@ static u_char doc2001_read_byte(struct mtd_info *mtd)
return
ReadDOC
(
docptr
,
LastDataRead
);
}
static
void
doc2001_writebuf
(
struct
mtd_info
*
mtd
,
static
void
doc2001_writebuf
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -517,7 +517,7 @@ static void doc2001_writebuf(struct mtd_info *mtd,
WriteDOC
(
0x00
,
docptr
,
WritePipeTerm
);
}
static
void
doc2001_readbuf
(
struct
mtd_info
*
mtd
,
static
void
doc2001_readbuf
(
struct
mtd_info
*
mtd
,
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -535,7 +535,7 @@ static void doc2001_readbuf(struct mtd_info *mtd,
buf
[
i
]
=
ReadDOC
(
docptr
,
LastDataRead
);
}
static
int
doc2001_verifybuf
(
struct
mtd_info
*
mtd
,
static
int
doc2001_verifybuf
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -570,7 +570,7 @@ static u_char doc2001plus_read_byte(struct mtd_info *mtd)
return
ret
;
}
static
void
doc2001plus_writebuf
(
struct
mtd_info
*
mtd
,
static
void
doc2001plus_writebuf
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -587,7 +587,7 @@ static void doc2001plus_writebuf(struct mtd_info *mtd,
if
(
debug
)
printk
(
"
\n
"
);
}
static
void
doc2001plus_readbuf
(
struct
mtd_info
*
mtd
,
static
void
doc2001plus_readbuf
(
struct
mtd_info
*
mtd
,
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -617,7 +617,7 @@ static void doc2001plus_readbuf(struct mtd_info *mtd,
if
(
debug
)
printk
(
"
\n
"
);
}
static
int
doc2001plus_verifybuf
(
struct
mtd_info
*
mtd
,
static
int
doc2001plus_verifybuf
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
)
{
struct
nand_chip
*
this
=
mtd
->
priv
;
...
...
@@ -797,7 +797,7 @@ static void doc2001plus_command (struct mtd_info *mtd, unsigned command, int col
WriteDOC
(
0
,
docptr
,
Mplus_FlashControl
);
}
/*
/*
* program and erase have their own busy handlers
* status and sequential in needs no delay
*/
...
...
@@ -822,7 +822,7 @@ static void doc2001plus_command (struct mtd_info *mtd, unsigned command, int col
/* This applies to read commands */
default:
/*
/*
* If we don't have access to the busy pin, we apply the given
* command delay
*/
...
...
@@ -945,7 +945,7 @@ static int doc200x_calculate_ecc(struct mtd_info *mtd, const u_char *dat,
for
(
i
=
0
;
i
<
6
;
i
++
)
{
if
(
DoC_is_MillenniumPlus
(
doc
))
ecc_code
[
i
]
=
ReadDOC_
(
docptr
,
DoC_Mplus_ECCSyndrome0
+
i
);
else
else
ecc_code
[
i
]
=
ReadDOC_
(
docptr
,
DoC_ECCSyndrome0
+
i
);
if
(
ecc_code
[
i
]
!=
empty_write_ecc
[
i
])
emptymatch
=
0
;
...
...
@@ -982,7 +982,7 @@ static int doc200x_correct_data(struct mtd_info *mtd, u_char *dat, u_char *read_
void
__iomem
*
docptr
=
doc
->
virtadr
;
volatile
u_char
dummy
;
int
emptymatch
=
1
;
/* flush the pipeline */
if
(
DoC_is_2000
(
doc
))
{
dummy
=
ReadDOC
(
docptr
,
2
k_ECCStatus
);
...
...
@@ -997,7 +997,7 @@ static int doc200x_correct_data(struct mtd_info *mtd, u_char *dat, u_char *read_
dummy
=
ReadDOC
(
docptr
,
ECCConf
);
dummy
=
ReadDOC
(
docptr
,
ECCConf
);
}
/* Error occured ? */
if
(
dummy
&
0x80
)
{
for
(
i
=
0
;
i
<
6
;
i
++
)
{
...
...
@@ -1035,7 +1035,7 @@ static int doc200x_correct_data(struct mtd_info *mtd, u_char *dat, u_char *read_
if
(
!
emptymatch
)
ret
=
doc_ecc_decode
(
rs_decoder
,
dat
,
calc_ecc
);
if
(
ret
>
0
)
printk
(
KERN_ERR
"doc200x_correct_data corrected %d errors
\n
"
,
ret
);
}
}
if
(
DoC_is_MillenniumPlus
(
doc
))
WriteDOC
(
DOC_ECC_DIS
,
docptr
,
Mplus_ECCConf
);
else
...
...
@@ -1046,7 +1046,7 @@ static int doc200x_correct_data(struct mtd_info *mtd, u_char *dat, u_char *read_
}
return
ret
;
}
//u_char mydatabuf[528];
/* The strange out-of-order .oobfree list below is a (possibly unneeded)
...
...
@@ -1065,7 +1065,7 @@ static struct nand_oobinfo doc200x_oobinfo = {
.
eccpos
=
{
0
,
1
,
2
,
3
,
4
,
5
},
.
oobfree
=
{
{
8
,
8
},
{
6
,
2
}
}
};
/* Find the (I)NFTL Media Header, and optionally also the mirror media header.
On sucessful return, buf will contain a copy of the media header for
further processing. id is the string to scan for, and will presumably be
...
...
@@ -1251,7 +1251,7 @@ static inline int __init inftl_partscan(struct mtd_info *mtd,
mh
->
BlockMultiplierBits
=
le32_to_cpu
(
mh
->
BlockMultiplierBits
);
mh
->
FormatFlags
=
le32_to_cpu
(
mh
->
FormatFlags
);
mh
->
PercentUsed
=
le32_to_cpu
(
mh
->
PercentUsed
);
printk
(
KERN_INFO
" bootRecordID = %s
\n
"
" NoOfBootImageBlocks = %d
\n
"
" NoOfBinaryPartitions = %d
\n
"
...
...
@@ -1468,7 +1468,7 @@ static inline int __init doc2001_init(struct mtd_info *mtd)
ReadDOC
(
doc
->
virtadr
,
ChipID
);
if
(
ReadDOC
(
doc
->
virtadr
,
ChipID
)
!=
DOC_ChipID_DocMil
)
{
/* It's not a Millennium; it's one of the newer
DiskOnChip 2000 units with a similar ASIC.
DiskOnChip 2000 units with a similar ASIC.
Treat it like a Millennium, except that it
can have multiple chips. */
doc2000_count_chips
(
mtd
);
...
...
@@ -1530,20 +1530,20 @@ static inline int __init doc_probe(unsigned long physadr)
* to the DOCControl register. So we store the current contents
* of the DOCControl register's location, in case we later decide
* that it's not a DiskOnChip, and want to put it back how we
* found it.
* found it.
*/
save_control
=
ReadDOC
(
virtadr
,
DOCControl
);
/* Reset the DiskOnChip ASIC */
WriteDOC
(
DOC_MODE_CLR_ERR
|
DOC_MODE_MDWREN
|
DOC_MODE_RESET
,
WriteDOC
(
DOC_MODE_CLR_ERR
|
DOC_MODE_MDWREN
|
DOC_MODE_RESET
,
virtadr
,
DOCControl
);
WriteDOC
(
DOC_MODE_CLR_ERR
|
DOC_MODE_MDWREN
|
DOC_MODE_RESET
,
WriteDOC
(
DOC_MODE_CLR_ERR
|
DOC_MODE_MDWREN
|
DOC_MODE_RESET
,
virtadr
,
DOCControl
);
/* Enable the DiskOnChip ASIC */
WriteDOC
(
DOC_MODE_CLR_ERR
|
DOC_MODE_MDWREN
|
DOC_MODE_NORMAL
,
WriteDOC
(
DOC_MODE_CLR_ERR
|
DOC_MODE_MDWREN
|
DOC_MODE_NORMAL
,
virtadr
,
DOCControl
);
WriteDOC
(
DOC_MODE_CLR_ERR
|
DOC_MODE_MDWREN
|
DOC_MODE_NORMAL
,
WriteDOC
(
DOC_MODE_CLR_ERR
|
DOC_MODE_MDWREN
|
DOC_MODE_NORMAL
,
virtadr
,
DOCControl
);
ChipID
=
ReadDOC
(
virtadr
,
ChipID
);
...
...
@@ -1738,7 +1738,7 @@ static int __init init_nanddoc(void)
int
i
,
ret
=
0
;
/* We could create the decoder on demand, if memory is a concern.
* This way we have it handy, if an error happens
* This way we have it handy, if an error happens
*
* Symbolsize is 10 (bits)
* Primitve polynomial is x^10+x^3+1
...
...
drivers/mtd/nand/edb7312.c
浏览文件 @
61b03bd7
...
...
@@ -6,7 +6,7 @@
* Derived from drivers/mtd/nand/autcpu12.c
* Copyright (c) 2001 Thomas Gleixner (gleixner@autronix.de)
*
* $Id: edb7312.c,v 1.1
1 2004/11/04 12:53:1
0 gleixner Exp $
* $Id: edb7312.c,v 1.1
2 2005/11/07 11:14:3
0 gleixner Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
...
...
@@ -71,27 +71,27 @@ static struct mtd_partition partition_info[] = {
#endif
/*
/*
* hardware specific access to control-lines
*/
static
void
ep7312_hwcontrol
(
struct
mtd_info
*
mtd
,
int
cmd
)
static
void
ep7312_hwcontrol
(
struct
mtd_info
*
mtd
,
int
cmd
)
{
switch
(
cmd
)
{
case
NAND_CTL_SETCLE
:
clps_writeb
(
clps_readb
(
ep7312_pxdr
)
|
0x10
,
ep7312_pxdr
);
case
NAND_CTL_SETCLE
:
clps_writeb
(
clps_readb
(
ep7312_pxdr
)
|
0x10
,
ep7312_pxdr
);
break
;
case
NAND_CTL_CLRCLE
:
case
NAND_CTL_CLRCLE
:
clps_writeb
(
clps_readb
(
ep7312_pxdr
)
&
~
0x10
,
ep7312_pxdr
);
break
;
case
NAND_CTL_SETALE
:
clps_writeb
(
clps_readb
(
ep7312_pxdr
)
|
0x20
,
ep7312_pxdr
);
break
;
case
NAND_CTL_CLRALE
:
clps_writeb
(
clps_readb
(
ep7312_pxdr
)
&
~
0x20
,
ep7312_pxdr
);
break
;
case
NAND_CTL_SETNCE
:
clps_writeb
((
clps_readb
(
ep7312_pxdr
)
|
0x80
)
&
~
0x40
,
ep7312_pxdr
);
break
;
...
...
@@ -122,16 +122,16 @@ static int __init ep7312_init (void)
int
mtd_parts_nb
=
0
;
struct
mtd_partition
*
mtd_parts
=
0
;
void
__iomem
*
ep7312_fio_base
;
/* Allocate memory for MTD device structure and private data */
ep7312_mtd
=
kmalloc
(
sizeof
(
struct
mtd_info
)
+
ep7312_mtd
=
kmalloc
(
sizeof
(
struct
mtd_info
)
+
sizeof
(
struct
nand_chip
),
GFP_KERNEL
);
if
(
!
ep7312_mtd
)
{
printk
(
"Unable to allocate EDB7312 NAND MTD device structure.
\n
"
);
return
-
ENOMEM
;
}
/* map physical adress */
ep7312_fio_base
=
ioremap
(
ep7312_fio_pbase
,
SZ_1K
);
if
(
!
ep7312_fio_base
)
{
...
...
@@ -139,23 +139,23 @@ static int __init ep7312_init (void)
kfree
(
ep7312_mtd
);
return
-
EIO
;
}
/* Get pointer to private data */
this
=
(
struct
nand_chip
*
)
(
&
ep7312_mtd
[
1
]);
/* Initialize structures */
memset
((
char
*
)
ep7312_mtd
,
0
,
sizeof
(
struct
mtd_info
));
memset
((
char
*
)
this
,
0
,
sizeof
(
struct
nand_chip
));
/* Link the private data with the MTD structure */
ep7312_mtd
->
priv
=
this
;
/*
* Set GPIO Port B control register so that the pins are configured
* to be outputs for controlling the NAND flash.
*/
clps_writeb
(
0xf0
,
ep7312_pxddr
);
/* insert callbacks */
this
->
IO_ADDR_R
=
ep7312_fio_base
;
this
->
IO_ADDR_W
=
ep7312_fio_base
;
...
...
@@ -163,14 +163,14 @@ static int __init ep7312_init (void)
this
->
dev_ready
=
ep7312_device_ready
;
/* 15 us command delay time */
this
->
chip_delay
=
15
;
/* Scan to find existence of the device */
if
(
nand_scan
(
ep7312_mtd
,
1
))
{
iounmap
((
void
*
)
ep7312_fio_base
);
kfree
(
ep7312_mtd
);
return
-
ENXIO
;
}
#ifdef CONFIG_MTD_PARTITIONS
ep7312_mtd
->
name
=
"edb7312-nand"
;
mtd_parts_nb
=
parse_mtd_partitions
(
ep7312_mtd
,
part_probes
,
...
...
@@ -185,11 +185,11 @@ static int __init ep7312_init (void)
mtd_parts_nb
=
NUM_PARTITIONS
;
part_type
=
"static"
;
}
/* Register the partitions */
printk
(
KERN_NOTICE
"Using %s partition definition
\n
"
,
part_type
);
add_mtd_partitions
(
ep7312_mtd
,
mtd_parts
,
mtd_parts_nb
);
/* Return happy */
return
0
;
}
...
...
@@ -201,13 +201,13 @@ module_init(ep7312_init);
static
void
__exit
ep7312_cleanup
(
void
)
{
struct
nand_chip
*
this
=
(
struct
nand_chip
*
)
&
ep7312_mtd
[
1
];
/* Release resources, unregister device */
nand_release
(
ap7312_mtd
);
/* Free internal data buffer */
kfree
(
this
->
data_buf
);
/* Free the MTD device structure */
kfree
(
ep7312_mtd
);
}
...
...
drivers/mtd/nand/h1910.c
浏览文件 @
61b03bd7
...
...
@@ -7,7 +7,7 @@
* Copyright (C) 2002 Marius Grger (mag@sysgo.de)
* Copyright (c) 2001 Thomas Gleixner (gleixner@autronix.de)
*
* $Id: h1910.c,v 1.
5 2004/11/04 12:53:1
0 gleixner Exp $
* $Id: h1910.c,v 1.
6 2005/11/07 11:14:3
0 gleixner Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
...
...
@@ -54,24 +54,24 @@ static struct mtd_partition partition_info[] = {
#endif
/*
/*
* hardware specific access to control-lines
*/
static
void
h1910_hwcontrol
(
struct
mtd_info
*
mtd
,
int
cmd
)
static
void
h1910_hwcontrol
(
struct
mtd_info
*
mtd
,
int
cmd
)
{
struct
nand_chip
*
this
=
(
struct
nand_chip
*
)
(
mtd
->
priv
);
switch
(
cmd
)
{
case
NAND_CTL_SETCLE
:
case
NAND_CTL_SETCLE
:
this
->
IO_ADDR_R
|=
(
1
<<
2
);
this
->
IO_ADDR_W
|=
(
1
<<
2
);
break
;
case
NAND_CTL_CLRCLE
:
case
NAND_CTL_CLRCLE
:
this
->
IO_ADDR_R
&=
~
(
1
<<
2
);
this
->
IO_ADDR_W
&=
~
(
1
<<
2
);
break
;
case
NAND_CTL_SETALE
:
this
->
IO_ADDR_R
|=
(
1
<<
3
);
this
->
IO_ADDR_W
|=
(
1
<<
3
);
...
...
@@ -80,7 +80,7 @@ static void h1910_hwcontrol(struct mtd_info *mtd, int cmd)
this
->
IO_ADDR_R
&=
~
(
1
<<
3
);
this
->
IO_ADDR_W
&=
~
(
1
<<
3
);
break
;
case
NAND_CTL_SETNCE
:
break
;
case
NAND_CTL_CLRNCE
:
...
...
@@ -108,18 +108,18 @@ static int __init h1910_init (void)
int
mtd_parts_nb
=
0
;
struct
mtd_partition
*
mtd_parts
=
0
;
void
__iomem
*
nandaddr
;
if
(
!
machine_is_h1900
())
return
-
ENODEV
;
nandaddr
=
__ioremap
(
0x08000000
,
0x1000
,
0
,
1
);
if
(
!
nandaddr
)
{
printk
(
"Failed to ioremap nand flash.
\n
"
);
return
-
ENOMEM
;
}
/* Allocate memory for MTD device structure and private data */
h1910_nand_mtd
=
kmalloc
(
sizeof
(
struct
mtd_info
)
+
h1910_nand_mtd
=
kmalloc
(
sizeof
(
struct
mtd_info
)
+
sizeof
(
struct
nand_chip
),
GFP_KERNEL
);
if
(
!
h1910_nand_mtd
)
{
...
...
@@ -127,22 +127,22 @@ static int __init h1910_init (void)
iounmap
((
void
*
)
nandaddr
);
return
-
ENOMEM
;
}
/* Get pointer to private data */
this
=
(
struct
nand_chip
*
)
(
&
h1910_nand_mtd
[
1
]);
/* Initialize structures */
memset
((
char
*
)
h1910_nand_mtd
,
0
,
sizeof
(
struct
mtd_info
));
memset
((
char
*
)
this
,
0
,
sizeof
(
struct
nand_chip
));
/* Link the private data with the MTD structure */
h1910_nand_mtd
->
priv
=
this
;
/*
* Enable VPEN
*/
GPSR
(
37
)
=
GPIO_bit
(
37
);
/* insert callbacks */
this
->
IO_ADDR_R
=
nandaddr
;
this
->
IO_ADDR_W
=
nandaddr
;
...
...
@@ -152,7 +152,7 @@ static int __init h1910_init (void)
this
->
chip_delay
=
50
;
this
->
eccmode
=
NAND_ECC_SOFT
;
this
->
options
=
NAND_NO_AUTOINCR
;
/* Scan to find existence of the device */
if
(
nand_scan
(
h1910_nand_mtd
,
1
))
{
printk
(
KERN_NOTICE
"No NAND device - returning -ENXIO
\n
"
);
...
...
@@ -160,9 +160,9 @@ static int __init h1910_init (void)
iounmap
((
void
*
)
nandaddr
);
return
-
ENXIO
;
}
#ifdef CONFIG_MTD_CMDLINE_PARTS
mtd_parts_nb
=
parse_cmdline_partitions
(
h1910_nand_mtd
,
&
mtd_parts
,
mtd_parts_nb
=
parse_cmdline_partitions
(
h1910_nand_mtd
,
&
mtd_parts
,
"h1910-nand"
);
if
(
mtd_parts_nb
>
0
)
part_type
=
"command line"
;
...
...
@@ -175,11 +175,11 @@ static int __init h1910_init (void)
mtd_parts_nb
=
NUM_PARTITIONS
;
part_type
=
"static"
;
}
/* Register the partitions */
printk
(
KERN_NOTICE
"Using %s partition definition
\n
"
,
part_type
);
add_mtd_partitions
(
h1910_nand_mtd
,
mtd_parts
,
mtd_parts_nb
);
/* Return happy */
return
0
;
}
...
...
@@ -191,7 +191,7 @@ module_init(h1910_init);
static
void
__exit
h1910_cleanup
(
void
)
{
struct
nand_chip
*
this
=
(
struct
nand_chip
*
)
&
h1910_nand_mtd
[
1
];
/* Release resources, unregister device */
nand_release
(
h1910_nand_mtd
);
...
...
drivers/mtd/nand/nand_base.c
浏览文件 @
61b03bd7
此差异已折叠。
点击以展开。
drivers/mtd/nand/nand_bbt.c
浏览文件 @
61b03bd7
此差异已折叠。
点击以展开。
drivers/mtd/nand/nand_ecc.c
浏览文件 @
61b03bd7
...
...
@@ -7,22 +7,22 @@
* Copyright (C) 2000-2004 Steven J. Hill (sjhill@realitydiluted.com)
* Toshiba America Electronics Components, Inc.
*
* $Id: nand_ecc.c,v 1.1
4 2004/06/16 15:34:37
gleixner Exp $
* $Id: nand_ecc.c,v 1.1
5 2005/11/07 11:14:30
gleixner Exp $
*
* This file is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2 or (at your option) any
* later version.
*
*
* This file is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* for more details.
*
*
* You should have received a copy of the GNU General Public License along
* with this file; if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*
*
* As a special exception, if other files instantiate templates or use
* macros or inline functions from these files, or you compile these
* files and link them with other works to produce a work based on these
...
...
@@ -30,7 +30,7 @@
* covered by the GNU General Public License. However the source code for
* these files must still be made available in accordance with section (3)
* of the GNU General Public License.
*
*
* This exception does not invalidate any other reasons why a work based on
* this file might be covered by the GNU General Public License.
*/
...
...
@@ -67,7 +67,7 @@ static const u_char nand_ecc_precalc_table[] = {
* nand_trans_result - [GENERIC] create non-inverted ECC
* @reg2: line parity reg 2
* @reg3: line parity reg 3
* @ecc_code: ecc
* @ecc_code: ecc
*
* Creates non-inverted ECC code from line parity
*/
...
...
@@ -75,11 +75,11 @@ static void nand_trans_result(u_char reg2, u_char reg3,
u_char
*
ecc_code
)
{
u_char
a
,
b
,
i
,
tmp1
,
tmp2
;
/* Initialize variables */
a
=
b
=
0x80
;
tmp1
=
tmp2
=
0
;
/* Calculate first ECC byte */
for
(
i
=
0
;
i
<
4
;
i
++
)
{
if
(
reg3
&
a
)
/* LP15,13,11,9 --> ecc_code[0] */
...
...
@@ -90,7 +90,7 @@ static void nand_trans_result(u_char reg2, u_char reg3,
b
>>=
1
;
a
>>=
1
;
}
/* Calculate second ECC byte */
b
=
0x80
;
for
(
i
=
0
;
i
<
4
;
i
++
)
{
...
...
@@ -102,7 +102,7 @@ static void nand_trans_result(u_char reg2, u_char reg3,
b
>>=
1
;
a
>>=
1
;
}
/* Store two of the ECC bytes */
ecc_code
[
0
]
=
tmp1
;
ecc_code
[
1
]
=
tmp2
;
...
...
@@ -118,28 +118,28 @@ int nand_calculate_ecc(struct mtd_info *mtd, const u_char *dat, u_char *ecc_code
{
u_char
idx
,
reg1
,
reg2
,
reg3
;
int
j
;
/* Initialize variables */
reg1
=
reg2
=
reg3
=
0
;
ecc_code
[
0
]
=
ecc_code
[
1
]
=
ecc_code
[
2
]
=
0
;
/* Build up column parity */
/* Build up column parity */
for
(
j
=
0
;
j
<
256
;
j
++
)
{
/* Get CP0 - CP5 from table */
idx
=
nand_ecc_precalc_table
[
dat
[
j
]];
reg1
^=
(
idx
&
0x3f
);
/* All bit XOR = 1 ? */
if
(
idx
&
0x40
)
{
reg3
^=
(
u_char
)
j
;
reg2
^=
~
((
u_char
)
j
);
}
}
/* Create non-inverted ECC code from line parity */
nand_trans_result
(
reg2
,
reg3
,
ecc_code
);
/* Calculate final ECC code */
ecc_code
[
0
]
=
~
ecc_code
[
0
];
ecc_code
[
1
]
=
~
ecc_code
[
1
];
...
...
@@ -159,12 +159,12 @@ int nand_calculate_ecc(struct mtd_info *mtd, const u_char *dat, u_char *ecc_code
int
nand_correct_data
(
struct
mtd_info
*
mtd
,
u_char
*
dat
,
u_char
*
read_ecc
,
u_char
*
calc_ecc
)
{
u_char
a
,
b
,
c
,
d1
,
d2
,
d3
,
add
,
bit
,
i
;
/* Do error detection */
/* Do error detection */
d1
=
calc_ecc
[
0
]
^
read_ecc
[
0
];
d2
=
calc_ecc
[
1
]
^
read_ecc
[
1
];
d3
=
calc_ecc
[
2
]
^
read_ecc
[
2
];
if
((
d1
|
d2
|
d3
)
==
0
)
{
/* No errors */
return
0
;
...
...
@@ -173,7 +173,7 @@ int nand_correct_data(struct mtd_info *mtd, u_char *dat, u_char *read_ecc, u_cha
a
=
(
d1
^
(
d1
>>
1
))
&
0x55
;
b
=
(
d2
^
(
d2
>>
1
))
&
0x55
;
c
=
(
d3
^
(
d3
>>
1
))
&
0x54
;
/* Found and will correct single bit error in the data */
if
((
a
==
0x55
)
&&
(
b
==
0x55
)
&&
(
c
==
0x54
))
{
c
=
0x80
;
...
...
@@ -237,7 +237,7 @@ int nand_correct_data(struct mtd_info *mtd, u_char *dat, u_char *read_ecc, u_cha
}
}
}
/* Should never happen */
return
-
1
;
}
...
...
drivers/mtd/nand/nand_ids.c
浏览文件 @
61b03bd7
...
...
@@ -3,7 +3,7 @@
*
* Copyright (C) 2002 Thomas Gleixner (tglx@linutronix.de)
*
* $Id: nand_ids.c,v 1.1
4 2005/06/23 09:38:50
gleixner Exp $
* $Id: nand_ids.c,v 1.1
6 2005/11/07 11:14:31
gleixner Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
...
...
@@ -14,14 +14,14 @@
#include <linux/mtd/nand.h>
/*
* Chip ID list
*
*
* Name. ID code, pagesize, chipsize in MegaByte, eraseblock size,
* options
*
*
* Pagesize; 0, 256, 512
* 0 get this information from the extended chip ID
+ 256 256 Byte page size
* 512 512 Byte page size
* 512 512 Byte page size
*/
struct
nand_flash_dev
nand_flash_ids
[]
=
{
{
"NAND 1MiB 5V 8-bit"
,
0x6e
,
256
,
1
,
0x1000
,
0
},
...
...
@@ -34,27 +34,27 @@ struct nand_flash_dev nand_flash_ids[] = {
{
"NAND 4MiB 3,3V 8-bit"
,
0xe3
,
512
,
4
,
0x2000
,
0
},
{
"NAND 4MiB 3,3V 8-bit"
,
0xe5
,
512
,
4
,
0x2000
,
0
},
{
"NAND 8MiB 3,3V 8-bit"
,
0xd6
,
512
,
8
,
0x2000
,
0
},
{
"NAND 8MiB 1,8V 8-bit"
,
0x39
,
512
,
8
,
0x2000
,
0
},
{
"NAND 8MiB 3,3V 8-bit"
,
0xe6
,
512
,
8
,
0x2000
,
0
},
{
"NAND 8MiB 1,8V 16-bit"
,
0x49
,
512
,
8
,
0x2000
,
NAND_BUSWIDTH_16
},
{
"NAND 8MiB 3,3V 16-bit"
,
0x59
,
512
,
8
,
0x2000
,
NAND_BUSWIDTH_16
},
{
"NAND 16MiB 1,8V 8-bit"
,
0x33
,
512
,
16
,
0x4000
,
0
},
{
"NAND 16MiB 3,3V 8-bit"
,
0x73
,
512
,
16
,
0x4000
,
0
},
{
"NAND 16MiB 1,8V 16-bit"
,
0x43
,
512
,
16
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 16MiB 3,3V 16-bit"
,
0x53
,
512
,
16
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 32MiB 1,8V 8-bit"
,
0x35
,
512
,
32
,
0x4000
,
0
},
{
"NAND 32MiB 3,3V 8-bit"
,
0x75
,
512
,
32
,
0x4000
,
0
},
{
"NAND 32MiB 1,8V 16-bit"
,
0x45
,
512
,
32
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 32MiB 3,3V 16-bit"
,
0x55
,
512
,
32
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 64MiB 1,8V 8-bit"
,
0x36
,
512
,
64
,
0x4000
,
0
},
{
"NAND 64MiB 3,3V 8-bit"
,
0x76
,
512
,
64
,
0x4000
,
0
},
{
"NAND 64MiB 1,8V 16-bit"
,
0x46
,
512
,
64
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 64MiB 3,3V 16-bit"
,
0x56
,
512
,
64
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 128MiB 1,8V 8-bit"
,
0x78
,
512
,
128
,
0x4000
,
0
},
{
"NAND 128MiB 1,8V 8-bit"
,
0x39
,
512
,
128
,
0x4000
,
0
},
{
"NAND 128MiB 3,3V 8-bit"
,
0x79
,
512
,
128
,
0x4000
,
0
},
...
...
@@ -62,7 +62,7 @@ struct nand_flash_dev nand_flash_ids[] = {
{
"NAND 128MiB 1,8V 16-bit"
,
0x49
,
512
,
128
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 128MiB 3,3V 16-bit"
,
0x74
,
512
,
128
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 128MiB 3,3V 16-bit"
,
0x59
,
512
,
128
,
0x4000
,
NAND_BUSWIDTH_16
},
{
"NAND 256MiB 3,3V 8-bit"
,
0x71
,
512
,
256
,
0x4000
,
0
},
/* These are the new chips with large page size. The pagesize
...
...
@@ -73,7 +73,7 @@ struct nand_flash_dev nand_flash_ids[] = {
{
"NAND 64MiB 3,3V 8-bit"
,
0xF2
,
0
,
64
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_NO_AUTOINCR
},
{
"NAND 64MiB 1,8V 16-bit"
,
0xB2
,
0
,
64
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_BUSWIDTH_16
|
NAND_NO_AUTOINCR
},
{
"NAND 64MiB 3,3V 16-bit"
,
0xC2
,
0
,
64
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_BUSWIDTH_16
|
NAND_NO_AUTOINCR
},
/* 1 Gigabit */
{
"NAND 128MiB 1,8V 8-bit"
,
0xA1
,
0
,
128
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_NO_AUTOINCR
},
{
"NAND 128MiB 3,3V 8-bit"
,
0xF1
,
0
,
128
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_NO_AUTOINCR
},
...
...
@@ -85,13 +85,13 @@ struct nand_flash_dev nand_flash_ids[] = {
{
"NAND 256MiB 3,3V 8-bit"
,
0xDA
,
0
,
256
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_NO_AUTOINCR
},
{
"NAND 256MiB 1,8V 16-bit"
,
0xBA
,
0
,
256
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_BUSWIDTH_16
|
NAND_NO_AUTOINCR
},
{
"NAND 256MiB 3,3V 16-bit"
,
0xCA
,
0
,
256
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_BUSWIDTH_16
|
NAND_NO_AUTOINCR
},
/* 4 Gigabit */
{
"NAND 512MiB 1,8V 8-bit"
,
0xAC
,
0
,
512
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_NO_AUTOINCR
},
{
"NAND 512MiB 3,3V 8-bit"
,
0xDC
,
0
,
512
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_NO_AUTOINCR
},
{
"NAND 512MiB 1,8V 16-bit"
,
0xBC
,
0
,
512
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_BUSWIDTH_16
|
NAND_NO_AUTOINCR
},
{
"NAND 512MiB 3,3V 16-bit"
,
0xCC
,
0
,
512
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_BUSWIDTH_16
|
NAND_NO_AUTOINCR
},
/* 8 Gigabit */
{
"NAND 1GiB 1,8V 8-bit"
,
0xA3
,
0
,
1024
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_NO_AUTOINCR
},
{
"NAND 1GiB 3,3V 8-bit"
,
0xD3
,
0
,
1024
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_NO_AUTOINCR
},
...
...
@@ -104,11 +104,11 @@ struct nand_flash_dev nand_flash_ids[] = {
{
"NAND 2GiB 1,8V 16-bit"
,
0xB5
,
0
,
2048
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_BUSWIDTH_16
|
NAND_NO_AUTOINCR
},
{
"NAND 2GiB 3,3V 16-bit"
,
0xC5
,
0
,
2048
,
0
,
NAND_SAMSUNG_LP_OPTIONS
|
NAND_BUSWIDTH_16
|
NAND_NO_AUTOINCR
},
/* Renesas AND 1 Gigabit. Those chips do not support extended id and have a strange page/block layout !
/* Renesas AND 1 Gigabit. Those chips do not support extended id and have a strange page/block layout !
* The chosen minimum erasesize is 4 * 2 * 2048 = 16384 Byte, as those chips have an array of 4 page planes
* 1 block = 2 pages, but due to plane arrangement the blocks 0-3 consists of page 0 + 4,1 + 5, 2 + 6, 3 + 7
* Anyway JFFS2 would increase the eraseblock size so we chose a combined one which can be erased in one go
* There are more speed improvements for reads and writes possible, but not implemented now
* There are more speed improvements for reads and writes possible, but not implemented now
*/
{
"AND 128MiB 3,3V 8-bit"
,
0x01
,
2048
,
128
,
0x4000
,
NAND_IS_AND
|
NAND_NO_AUTOINCR
|
NAND_4PAGE_ARRAY
|
BBT_AUTO_REFRESH
},
...
...
drivers/mtd/nand/nandsim.c
浏览文件 @
61b03bd7
...
...
@@ -3,7 +3,7 @@
*
* Author: Artem B. Bityuckiy <dedekind@oktetlabs.ru>, <dedekind@infradead.org>
*
* Copyright (C) 2004 Nokia Corporation
* Copyright (C) 2004 Nokia Corporation
*
* Note: NS means "NAND Simulator".
* Note: Input means input TO flash chip, output means output FROM chip.
...
...
@@ -126,7 +126,7 @@ MODULE_PARM_DESC(dbg, "Output debug information if not zero");
/* The largest possible page size */
#define NS_LARGEST_PAGE_SIZE 2048
/* The prefix for simulator output */
#define NS_OUTPUT_PREFIX "[nandsim]"
...
...
@@ -145,7 +145,7 @@ MODULE_PARM_DESC(dbg, "Output debug information if not zero");
do { if (do_delays) udelay(us); } while(0)
#define NS_MDELAY(us) \
do { if (do_delays) mdelay(us); } while(0)
/* Is the nandsim structure initialized ? */
#define NS_IS_INITIALIZED(ns) ((ns)->geom.totsz != 0)
...
...
@@ -153,12 +153,12 @@ MODULE_PARM_DESC(dbg, "Output debug information if not zero");
#define NS_STATUS_OK(ns) (NAND_STATUS_READY | (NAND_STATUS_WP * ((ns)->lines.wp == 0)))
/* Operation failed completion status */
#define NS_STATUS_FAILED(ns) (NAND_STATUS_FAIL | NS_STATUS_OK(ns))
#define NS_STATUS_FAILED(ns) (NAND_STATUS_FAIL | NS_STATUS_OK(ns))
/* Calculate the page offset in flash RAM image by (row, column) address */
#define NS_RAW_OFFSET(ns) \
(((ns)->regs.row << (ns)->geom.pgshift) + ((ns)->regs.row * (ns)->geom.oobsz) + (ns)->regs.column)
/* Calculate the OOB offset in flash RAM image by (row, column) address */
#define NS_RAW_OFFSET_OOB(ns) (NS_RAW_OFFSET(ns) + ns->geom.pgsz)
...
...
@@ -223,15 +223,15 @@ MODULE_PARM_DESC(dbg, "Output debug information if not zero");
/* Remove action bits ftom state */
#define NS_STATE(x) ((x) & ~ACTION_MASK)
/*
/*
* Maximum previous states which need to be saved. Currently saving is
* only needed for page programm operation with preceeded read command
* (which is only valid for 512-byte pages).
*/
#define NS_MAX_PREVSTATES 1
/*
/*
* The structure which describes all the internal simulator data.
*/
struct
nandsim
{
...
...
@@ -242,7 +242,7 @@ struct nandsim {
uint32_t
options
;
/* chip's characteristic bits */
uint32_t
state
;
/* current chip state */
uint32_t
nxstate
;
/* next expected state */
uint32_t
*
op
;
/* current operation, NULL operations isn't known yet */
uint32_t
pstates
[
NS_MAX_PREVSTATES
];
/* previous states */
uint16_t
npstates
;
/* number of previous states saved */
...
...
@@ -413,7 +413,7 @@ init_nandsim(struct mtd_info *mtd)
ns
->
geom
.
secaddrbytes
=
3
;
}
}
/* Detect how many ID bytes the NAND chip outputs */
for
(
i
=
0
;
nand_flash_ids
[
i
].
name
!=
NULL
;
i
++
)
{
if
(
second_id_byte
!=
nand_flash_ids
[
i
].
id
)
...
...
@@ -444,7 +444,7 @@ init_nandsim(struct mtd_info *mtd)
#ifdef CONFIG_NS_ABS_POS
ns
->
mem
.
byte
=
ioremap
(
CONFIG_NS_ABS_POS
,
ns
->
geom
.
totszoob
);
if
(
!
ns
->
mem
.
byte
)
{
NS_ERR
(
"init_nandsim: failed to map the NAND flash image at address %p
\n
"
,
NS_ERR
(
"init_nandsim: failed to map the NAND flash image at address %p
\n
"
,
(
void
*
)
CONFIG_NS_ABS_POS
);
return
-
ENOMEM
;
}
...
...
@@ -567,7 +567,7 @@ static int
check_command
(
int
cmd
)
{
switch
(
cmd
)
{
case
NAND_CMD_READ0
:
case
NAND_CMD_READSTART
:
case
NAND_CMD_PAGEPROG
:
...
...
@@ -580,7 +580,7 @@ check_command(int cmd)
case
NAND_CMD_RESET
:
case
NAND_CMD_READ1
:
return
0
;
case
NAND_CMD_STATUS_MULTI
:
default:
return
1
;
...
...
@@ -631,7 +631,7 @@ static inline void
accept_addr_byte
(
struct
nandsim
*
ns
,
u_char
bt
)
{
uint
byte
=
(
uint
)
bt
;
if
(
ns
->
regs
.
count
<
(
ns
->
geom
.
pgaddrbytes
-
ns
->
geom
.
secaddrbytes
))
ns
->
regs
.
column
|=
(
byte
<<
8
*
ns
->
regs
.
count
);
else
{
...
...
@@ -642,11 +642,11 @@ accept_addr_byte(struct nandsim *ns, u_char bt)
return
;
}
/*
* Switch to STATE_READY state.
*/
static
inline
void
static
inline
void
switch_to_ready_state
(
struct
nandsim
*
ns
,
u_char
status
)
{
NS_DBG
(
"switch_to_ready_state: switch to %s state
\n
"
,
get_state_name
(
STATE_READY
));
...
...
@@ -675,7 +675,7 @@ switch_to_ready_state(struct nandsim *ns, u_char status)
* (for example program from the second half and read from the
* second half operations both begin with the READ1 command). In this
* case the ns->pstates[] array contains previous states.
*
*
* Thus, the function tries to find operation containing the following
* states (if the 'flag' parameter is 0):
* ns->pstates[0], ... ns->pstates[ns->npstates], ns->state
...
...
@@ -683,7 +683,7 @@ switch_to_ready_state(struct nandsim *ns, u_char status)
* If (one and only one) matching operation is found, it is accepted (
* ns->ops, ns->state, ns->nxstate are initialized, ns->npstate is
* zeroed).
*
*
* If there are several maches, the current state is pushed to the
* ns->pstates.
*
...
...
@@ -692,7 +692,7 @@ switch_to_ready_state(struct nandsim *ns, u_char status)
* In such situation the function is called with 'flag' != 0, and the
* operation is searched using the following pattern:
* ns->pstates[0], ... ns->pstates[ns->npstates], <address input>
*
*
* It is supposed that this pattern must either match one operation on
* none. There can't be ambiguity in that case.
*
...
...
@@ -711,15 +711,15 @@ find_operation(struct nandsim *ns, uint32_t flag)
{
int
opsfound
=
0
;
int
i
,
j
,
idx
=
0
;
for
(
i
=
0
;
i
<
NS_OPER_NUM
;
i
++
)
{
int
found
=
1
;
if
(
!
(
ns
->
options
&
ops
[
i
].
reqopts
))
/* Ignore operations we can't perform */
continue
;
if
(
flag
)
{
if
(
!
(
ops
[
i
].
states
[
ns
->
npstates
]
&
STATE_ADDR_MASK
))
continue
;
...
...
@@ -728,7 +728,7 @@ find_operation(struct nandsim *ns, uint32_t flag)
continue
;
}
for
(
j
=
0
;
j
<
ns
->
npstates
;
j
++
)
for
(
j
=
0
;
j
<
ns
->
npstates
;
j
++
)
if
(
NS_STATE
(
ops
[
i
].
states
[
j
])
!=
NS_STATE
(
ns
->
pstates
[
j
])
&&
(
ns
->
options
&
ops
[
idx
].
reqopts
))
{
found
=
0
;
...
...
@@ -745,7 +745,7 @@ find_operation(struct nandsim *ns, uint32_t flag)
/* Exact match */
ns
->
op
=
&
ops
[
idx
].
states
[
0
];
if
(
flag
)
{
/*
/*
* In this case the find_operation function was
* called when address has just began input. But it isn't
* yet fully input and the current state must
...
...
@@ -763,7 +763,7 @@ find_operation(struct nandsim *ns, uint32_t flag)
idx
,
get_state_name
(
ns
->
state
),
get_state_name
(
ns
->
nxstate
));
return
0
;
}
if
(
opsfound
==
0
)
{
/* Nothing was found. Try to ignore previous commands (if any) and search again */
if
(
ns
->
npstates
!=
0
)
{
...
...
@@ -777,13 +777,13 @@ find_operation(struct nandsim *ns, uint32_t flag)
switch_to_ready_state
(
ns
,
NS_STATUS_FAILED
(
ns
));
return
-
2
;
}
if
(
flag
)
{
/* This shouldn't happen */
NS_DBG
(
"find_operation: BUG, operation must be known if address is input
\n
"
);
return
-
2
;
}
NS_DBG
(
"find_operation: there is still ambiguity
\n
"
);
ns
->
pstates
[
ns
->
npstates
++
]
=
ns
->
state
;
...
...
@@ -803,7 +803,7 @@ do_state_action(struct nandsim *ns, uint32_t action)
int
busdiv
=
ns
->
busw
==
8
?
1
:
2
;
action
&=
ACTION_MASK
;
/* Check that page address input is correct */
if
(
action
!=
ACTION_SECERASE
&&
ns
->
regs
.
row
>=
ns
->
geom
.
pgnum
)
{
NS_WARN
(
"do_state_action: wrong page number (%#x)
\n
"
,
ns
->
regs
.
row
);
...
...
@@ -827,14 +827,14 @@ do_state_action(struct nandsim *ns, uint32_t action)
NS_DBG
(
"do_state_action: (ACTION_CPY:) copy %d bytes to int buf, raw offset %d
\n
"
,
num
,
NS_RAW_OFFSET
(
ns
)
+
ns
->
regs
.
off
);
if
(
ns
->
regs
.
off
==
0
)
NS_LOG
(
"read page %d
\n
"
,
ns
->
regs
.
row
);
else
if
(
ns
->
regs
.
off
<
ns
->
geom
.
pgsz
)
NS_LOG
(
"read page %d (second half)
\n
"
,
ns
->
regs
.
row
);
else
NS_LOG
(
"read OOB of page %d
\n
"
,
ns
->
regs
.
row
);
NS_UDELAY
(
access_delay
);
NS_UDELAY
(
input_cycle
*
ns
->
geom
.
pgsz
/
1000
/
busdiv
);
...
...
@@ -844,30 +844,30 @@ do_state_action(struct nandsim *ns, uint32_t action)
/*
* Erase sector.
*/
if
(
ns
->
lines
.
wp
)
{
NS_ERR
(
"do_state_action: device is write-protected, ignore sector erase
\n
"
);
return
-
1
;
}
if
(
ns
->
regs
.
row
>=
ns
->
geom
.
pgnum
-
ns
->
geom
.
pgsec
||
(
ns
->
regs
.
row
&
~
(
ns
->
geom
.
secsz
-
1
)))
{
NS_ERR
(
"do_state_action: wrong sector address (%#x)
\n
"
,
ns
->
regs
.
row
);
return
-
1
;
}
ns
->
regs
.
row
=
(
ns
->
regs
.
row
<<
8
*
(
ns
->
geom
.
pgaddrbytes
-
ns
->
geom
.
secaddrbytes
))
|
ns
->
regs
.
column
;
ns
->
regs
.
column
=
0
;
NS_DBG
(
"do_state_action: erase sector at address %#x, off = %d
\n
"
,
ns
->
regs
.
row
,
NS_RAW_OFFSET
(
ns
));
NS_LOG
(
"erase sector %d
\n
"
,
ns
->
regs
.
row
>>
(
ns
->
geom
.
secshift
-
ns
->
geom
.
pgshift
));
memset
(
ns
->
mem
.
byte
+
NS_RAW_OFFSET
(
ns
),
0xFF
,
ns
->
geom
.
secszoob
);
NS_MDELAY
(
erase_delay
);
break
;
case
ACTION_PRGPAGE
:
...
...
@@ -893,12 +893,12 @@ do_state_action(struct nandsim *ns, uint32_t action)
NS_DBG
(
"do_state_action: copy %d bytes from int buf to (%#x, %#x), raw off = %d
\n
"
,
num
,
ns
->
regs
.
row
,
ns
->
regs
.
column
,
NS_RAW_OFFSET
(
ns
)
+
ns
->
regs
.
off
);
NS_LOG
(
"programm page %d
\n
"
,
ns
->
regs
.
row
);
NS_UDELAY
(
programm_delay
);
NS_UDELAY
(
output_cycle
*
ns
->
geom
.
pgsz
/
1000
/
busdiv
);
break
;
case
ACTION_ZEROOFF
:
NS_DBG
(
"do_state_action: set internal offset to 0
\n
"
);
ns
->
regs
.
off
=
0
;
...
...
@@ -918,7 +918,7 @@ do_state_action(struct nandsim *ns, uint32_t action)
NS_DBG
(
"do_state_action: set internal offset to %d
\n
"
,
ns
->
geom
.
pgsz
);
ns
->
regs
.
off
=
ns
->
geom
.
pgsz
;
break
;
default:
NS_DBG
(
"do_state_action: BUG! unknown action
\n
"
);
}
...
...
@@ -937,7 +937,7 @@ switch_state(struct nandsim *ns)
* The current operation have already been identified.
* Just follow the states chain.
*/
ns
->
stateidx
+=
1
;
ns
->
state
=
ns
->
nxstate
;
ns
->
nxstate
=
ns
->
op
[
ns
->
stateidx
+
1
];
...
...
@@ -951,14 +951,14 @@ switch_state(struct nandsim *ns)
switch_to_ready_state
(
ns
,
NS_STATUS_FAILED
(
ns
));
return
;
}
}
else
{
/*
* We don't yet know which operation we perform.
* Try to identify it.
*/
/*
/*
* The only event causing the switch_state function to
* be called with yet unknown operation is new command.
*/
...
...
@@ -987,7 +987,7 @@ switch_state(struct nandsim *ns)
*/
u_char
status
=
NS_STATUS_OK
(
ns
);
/* In case of data states, see if all bytes were input/output */
if
((
ns
->
state
&
(
STATE_DATAIN_MASK
|
STATE_DATAOUT_MASK
))
&&
ns
->
regs
.
count
!=
ns
->
regs
.
num
)
{
...
...
@@ -995,17 +995,17 @@ switch_state(struct nandsim *ns)
ns
->
regs
.
num
-
ns
->
regs
.
count
);
status
=
NS_STATUS_FAILED
(
ns
);
}
NS_DBG
(
"switch_state: operation complete, switch to STATE_READY state
\n
"
);
switch_to_ready_state
(
ns
,
status
);
return
;
}
else
if
(
ns
->
nxstate
&
(
STATE_DATAIN_MASK
|
STATE_DATAOUT_MASK
))
{
/*
/*
* If the next state is data input/output, switch to it now
*/
ns
->
state
=
ns
->
nxstate
;
ns
->
nxstate
=
ns
->
op
[
++
ns
->
stateidx
+
1
];
ns
->
regs
.
num
=
ns
->
regs
.
count
=
0
;
...
...
@@ -1023,16 +1023,16 @@ switch_state(struct nandsim *ns)
case
STATE_DATAOUT
:
ns
->
regs
.
num
=
ns
->
geom
.
pgszoob
-
ns
->
regs
.
off
-
ns
->
regs
.
column
;
break
;
case
STATE_DATAOUT_ID
:
ns
->
regs
.
num
=
ns
->
geom
.
idbytes
;
break
;
case
STATE_DATAOUT_STATUS
:
case
STATE_DATAOUT_STATUS_M
:
ns
->
regs
.
count
=
ns
->
regs
.
num
=
0
;
break
;
default:
NS_ERR
(
"switch_state: BUG! unknown data state
\n
"
);
}
...
...
@@ -1044,16 +1044,16 @@ switch_state(struct nandsim *ns)
*/
ns
->
regs
.
count
=
0
;
switch
(
NS_STATE
(
ns
->
nxstate
))
{
case
STATE_ADDR_PAGE
:
ns
->
regs
.
num
=
ns
->
geom
.
pgaddrbytes
;
break
;
case
STATE_ADDR_SEC
:
ns
->
regs
.
num
=
ns
->
geom
.
secaddrbytes
;
break
;
case
STATE_ADDR_ZERO
:
ns
->
regs
.
num
=
1
;
break
;
...
...
@@ -1062,7 +1062,7 @@ switch_state(struct nandsim *ns)
NS_ERR
(
"switch_state: BUG! unknown address state
\n
"
);
}
}
else
{
/*
/*
* Just reset internal counters.
*/
...
...
@@ -1184,7 +1184,7 @@ ns_nand_read_byte(struct mtd_info *mtd)
default:
BUG
();
}
if
(
ns
->
regs
.
count
==
ns
->
regs
.
num
)
{
NS_DBG
(
"read_byte: all bytes were read
\n
"
);
...
...
@@ -1201,9 +1201,9 @@ ns_nand_read_byte(struct mtd_info *mtd)
}
else
if
(
NS_STATE
(
ns
->
nxstate
)
==
STATE_READY
)
switch_state
(
ns
);
}
return
outb
;
}
...
...
@@ -1211,7 +1211,7 @@ static void
ns_nand_write_byte
(
struct
mtd_info
*
mtd
,
u_char
byte
)
{
struct
nandsim
*
ns
=
(
struct
nandsim
*
)((
struct
nand_chip
*
)
mtd
->
priv
)
->
priv
;
/* Sanity and correctness checks */
if
(
!
ns
->
lines
.
ce
)
{
NS_ERR
(
"write_byte: chip is disabled, ignore write
\n
"
);
...
...
@@ -1221,7 +1221,7 @@ ns_nand_write_byte(struct mtd_info *mtd, u_char byte)
NS_ERR
(
"write_byte: ALE and CLE pins are high simultaneously, ignore write
\n
"
);
return
;
}
if
(
ns
->
lines
.
cle
==
1
)
{
/*
* The byte written is a command.
...
...
@@ -1233,7 +1233,7 @@ ns_nand_write_byte(struct mtd_info *mtd, u_char byte)
return
;
}
/*
/*
* Chip might still be in STATE_DATAOUT
* (if OPT_AUTOINCR feature is supported), STATE_DATAOUT_STATUS or
* STATE_DATAOUT_STATUS_M state. If so, switch state.
...
...
@@ -1254,13 +1254,13 @@ ns_nand_write_byte(struct mtd_info *mtd, u_char byte)
"ignore previous states
\n
"
,
(
uint
)
byte
,
get_state_name
(
ns
->
nxstate
));
switch_to_ready_state
(
ns
,
NS_STATUS_FAILED
(
ns
));
}
/* Check that the command byte is correct */
if
(
check_command
(
byte
))
{
NS_ERR
(
"write_byte: unknown command %#x
\n
"
,
(
uint
)
byte
);
return
;
}
NS_DBG
(
"command byte corresponding to %s state accepted
\n
"
,
get_state_name
(
get_state_by_command
(
byte
)));
ns
->
regs
.
command
=
byte
;
...
...
@@ -1277,12 +1277,12 @@ ns_nand_write_byte(struct mtd_info *mtd, u_char byte)
if
(
find_operation
(
ns
,
1
)
<
0
)
return
;
if
((
ns
->
state
&
ACTION_MASK
)
&&
do_state_action
(
ns
,
ns
->
state
)
<
0
)
{
switch_to_ready_state
(
ns
,
NS_STATUS_FAILED
(
ns
));
return
;
}
ns
->
regs
.
count
=
0
;
switch
(
NS_STATE
(
ns
->
nxstate
))
{
case
STATE_ADDR_PAGE
:
...
...
@@ -1306,7 +1306,7 @@ ns_nand_write_byte(struct mtd_info *mtd, u_char byte)
switch_to_ready_state
(
ns
,
NS_STATUS_FAILED
(
ns
));
return
;
}
/* Check if this is expected byte */
if
(
ns
->
regs
.
count
==
ns
->
regs
.
num
)
{
NS_ERR
(
"write_byte: no more address bytes expected
\n
"
);
...
...
@@ -1325,12 +1325,12 @@ ns_nand_write_byte(struct mtd_info *mtd, u_char byte)
NS_DBG
(
"address (%#x, %#x) is accepted
\n
"
,
ns
->
regs
.
row
,
ns
->
regs
.
column
);
switch_state
(
ns
);
}
}
else
{
/*
* The byte written is an input data.
*/
/* Check that chip is expecting data input */
if
(
!
(
ns
->
state
&
STATE_DATAIN_MASK
))
{
NS_ERR
(
"write_byte: data input (%#x) isn't expected, state is %s, "
...
...
@@ -1372,7 +1372,7 @@ ns_nand_read_word(struct mtd_info *mtd)
struct
nand_chip
*
chip
=
(
struct
nand_chip
*
)
mtd
->
priv
;
NS_DBG
(
"read_word
\n
"
);
return
chip
->
read_byte
(
mtd
)
|
(
chip
->
read_byte
(
mtd
)
<<
8
);
}
...
...
@@ -1380,14 +1380,14 @@ static void
ns_nand_write_word
(
struct
mtd_info
*
mtd
,
uint16_t
word
)
{
struct
nand_chip
*
chip
=
(
struct
nand_chip
*
)
mtd
->
priv
;
NS_DBG
(
"write_word
\n
"
);
chip
->
write_byte
(
mtd
,
word
&
0xFF
);
chip
->
write_byte
(
mtd
,
word
>>
8
);
}
static
void
static
void
ns_nand_write_buf
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
)
{
struct
nandsim
*
ns
=
(
struct
nandsim
*
)((
struct
nand_chip
*
)
mtd
->
priv
)
->
priv
;
...
...
@@ -1409,13 +1409,13 @@ ns_nand_write_buf(struct mtd_info *mtd, const u_char *buf, int len)
memcpy
(
ns
->
buf
.
byte
+
ns
->
regs
.
count
,
buf
,
len
);
ns
->
regs
.
count
+=
len
;
if
(
ns
->
regs
.
count
==
ns
->
regs
.
num
)
{
NS_DBG
(
"write_buf: %d bytes were written
\n
"
,
ns
->
regs
.
count
);
}
}
static
void
static
void
ns_nand_read_buf
(
struct
mtd_info
*
mtd
,
u_char
*
buf
,
int
len
)
{
struct
nandsim
*
ns
=
(
struct
nandsim
*
)((
struct
nand_chip
*
)
mtd
->
priv
)
->
priv
;
...
...
@@ -1453,7 +1453,7 @@ ns_nand_read_buf(struct mtd_info *mtd, u_char *buf, int len)
memcpy
(
buf
,
ns
->
buf
.
byte
+
ns
->
regs
.
count
,
len
);
ns
->
regs
.
count
+=
len
;
if
(
ns
->
regs
.
count
==
ns
->
regs
.
num
)
{
if
((
ns
->
options
&
OPT_AUTOINCR
)
&&
NS_STATE
(
ns
->
state
)
==
STATE_DATAOUT
)
{
ns
->
regs
.
count
=
0
;
...
...
@@ -1465,11 +1465,11 @@ ns_nand_read_buf(struct mtd_info *mtd, u_char *buf, int len)
else
if
(
NS_STATE
(
ns
->
nxstate
)
==
STATE_READY
)
switch_state
(
ns
);
}
return
;
}
static
int
static
int
ns_nand_verify_buf
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
)
{
ns_nand_read_buf
(
mtd
,
(
u_char
*
)
&
ns_verify_buf
[
0
],
len
);
...
...
@@ -1496,7 +1496,7 @@ int __init ns_init_module(void)
NS_ERR
(
"wrong bus width (%d), use only 8 or 16
\n
"
,
bus_width
);
return
-
EINVAL
;
}
/* Allocate and initialize mtd_info, nand_chip and nandsim structures */
nsmtd
=
kmalloc
(
sizeof
(
struct
mtd_info
)
+
sizeof
(
struct
nand_chip
)
+
sizeof
(
struct
nandsim
),
GFP_KERNEL
);
...
...
@@ -1509,7 +1509,7 @@ int __init ns_init_module(void)
chip
=
(
struct
nand_chip
*
)(
nsmtd
+
1
);
nsmtd
->
priv
=
(
void
*
)
chip
;
nand
=
(
struct
nandsim
*
)(
chip
+
1
);
chip
->
priv
=
(
void
*
)
nand
;
chip
->
priv
=
(
void
*
)
nand
;
/*
* Register simulator's callbacks.
...
...
@@ -1526,9 +1526,9 @@ int __init ns_init_module(void)
chip
->
eccmode
=
NAND_ECC_SOFT
;
chip
->
options
|=
NAND_SKIP_BBTSCAN
;
/*
/*
* Perform minimum nandsim structure initialization to handle
* the initial ID read command correctly
* the initial ID read command correctly
*/
if
(
third_id_byte
!=
0xFF
||
fourth_id_byte
!=
0xFF
)
nand
->
geom
.
idbytes
=
4
;
...
...
@@ -1557,7 +1557,7 @@ int __init ns_init_module(void)
NS_ERR
(
"scan_bbt: can't initialize the nandsim structure
\n
"
);
goto
error
;
}
if
((
retval
=
nand_default_bbt
(
nsmtd
))
!=
0
)
{
free_nandsim
(
nand
);
goto
error
;
...
...
drivers/mtd/nand/ppchameleonevb.c
浏览文件 @
61b03bd7
...
...
@@ -6,7 +6,7 @@
* Derived from drivers/mtd/nand/edb7312.c
*
*
* $Id: ppchameleonevb.c,v 1.
6 2004/11/05 16:07:16 kalev
Exp $
* $Id: ppchameleonevb.c,v 1.
7 2005/11/07 11:14:31 gleixner
Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
...
...
@@ -338,7 +338,7 @@ static int __init ppchameleonevb_init (void)
out_be32
((
volatile
unsigned
*
)
GPIO0_TSRH
,
in_be32
((
volatile
unsigned
*
)
GPIO0_TSRH
)
&
0xFFFFFFF0
);
out_be32
((
volatile
unsigned
*
)
GPIO0_TSRL
,
in_be32
((
volatile
unsigned
*
)
GPIO0_TSRL
)
&
0x3FFFFFFF
);
/* enable output driver */
out_be32
((
volatile
unsigned
*
)
GPIO0_TCR
,
in_be32
((
volatile
unsigned
*
)
GPIO0_TCR
)
|
NAND_EVB_nCE_GPIO_PIN
|
out_be32
((
volatile
unsigned
*
)
GPIO0_TCR
,
in_be32
((
volatile
unsigned
*
)
GPIO0_TCR
)
|
NAND_EVB_nCE_GPIO_PIN
|
NAND_EVB_CLE_GPIO_PIN
|
NAND_EVB_ALE_GPIO_PIN
);
#ifdef USE_READY_BUSY_PIN
/* three-state select */
...
...
@@ -402,7 +402,7 @@ static void __exit ppchameleonevb_cleanup (void)
/* Release resources, unregister device(s) */
nand_release
(
ppchameleon_mtd
);
nand_release
(
ppchameleonevb_mtd
);
/* Release iomaps */
this
=
(
struct
nand_chip
*
)
&
ppchameleon_mtd
[
1
];
iounmap
((
void
*
)
this
->
IO_ADDR_R
;
...
...
drivers/mtd/nand/rtc_from4.c
浏览文件 @
61b03bd7
...
...
@@ -2,11 +2,11 @@
* drivers/mtd/nand/rtc_from4.c
*
* Copyright (C) 2004 Red Hat, Inc.
*
*
* Derived from drivers/mtd/nand/spia.c
* Copyright (C) 2000 Steven J. Hill (sjhill@realitydiluted.com)
*
* $Id: rtc_from4.c,v 1.
9 2005/01/24 20:40:11 dmarlin
Exp $
* $Id: rtc_from4.c,v 1.
10 2005/11/07 11:14:31 gleixner
Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
...
...
@@ -14,8 +14,8 @@
*
* Overview:
* This is a device driver for the AG-AND flash device found on the
* Renesas Technology Corp. Flash ROM 4-slot interface board (FROM_BOARD4),
* which utilizes the Renesas HN29V1G91T-30 part.
* Renesas Technology Corp. Flash ROM 4-slot interface board (FROM_BOARD4),
* which utilizes the Renesas HN29V1G91T-30 part.
* This chip is a 1 GBibit (128MiB x 8 bits) AG-AND flash device.
*/
...
...
@@ -105,9 +105,9 @@ const static struct mtd_partition partition_info[] = {
};
#define NUM_PARTITIONS 1
/*
/*
* hardware specific flash bbt decriptors
* Note: this is to allow debugging by disabling
* Note: this is to allow debugging by disabling
* NAND_BBT_CREATE and/or NAND_BBT_WRITE
*
*/
...
...
@@ -141,7 +141,7 @@ static struct nand_bbt_descr rtc_from4_bbt_mirror_descr = {
/* the Reed Solomon control structure */
static
struct
rs_control
*
rs_decoder
;
/*
/*
* hardware specific Out Of Band information
*/
static
struct
nand_oobinfo
rtc_from4_nand_oobinfo
=
{
...
...
@@ -200,38 +200,38 @@ static uint8_t revbits[256] = {
/*
/*
* rtc_from4_hwcontrol - hardware specific access to control-lines
* @mtd: MTD device structure
* @cmd: hardware control command
*
* Address lines (A5 and A4) are used to control Command and Address Latch
* Address lines (A5 and A4) are used to control Command and Address Latch
* Enable on this board, so set the read/write address appropriately.
*
* Chip Enable is also controlled by the Chip Select (CS5) and
* Chip Enable is also controlled by the Chip Select (CS5) and
* Address lines (A24-A22), so no action is required here.
*
*/
static
void
rtc_from4_hwcontrol
(
struct
mtd_info
*
mtd
,
int
cmd
)
{
struct
nand_chip
*
this
=
(
struct
nand_chip
*
)
(
mtd
->
priv
);
switch
(
cmd
)
{
case
NAND_CTL_SETCLE
:
case
NAND_CTL_SETCLE
:
this
->
IO_ADDR_W
=
(
void
__iomem
*
)((
unsigned
long
)
this
->
IO_ADDR_W
|
RTC_FROM4_CLE
);
break
;
case
NAND_CTL_CLRCLE
:
case
NAND_CTL_CLRCLE
:
this
->
IO_ADDR_W
=
(
void
__iomem
*
)((
unsigned
long
)
this
->
IO_ADDR_W
&
~
RTC_FROM4_CLE
);
break
;
case
NAND_CTL_SETALE
:
this
->
IO_ADDR_W
=
(
void
__iomem
*
)((
unsigned
long
)
this
->
IO_ADDR_W
|
RTC_FROM4_ALE
);
break
;
case
NAND_CTL_CLRALE
:
this
->
IO_ADDR_W
=
(
void
__iomem
*
)((
unsigned
long
)
this
->
IO_ADDR_W
&
~
RTC_FROM4_ALE
);
break
;
case
NAND_CTL_SETNCE
:
break
;
case
NAND_CTL_CLRNCE
:
...
...
@@ -296,7 +296,7 @@ static int rtc_from4_nand_device_ready(struct mtd_info *mtd)
* @mtd: MTD device structure
* @chip: Chip to select (0 == slot 3, 1 == slot 4)
*
* If there was a sudden loss of power during an erase operation, a
* If there was a sudden loss of power during an erase operation, a
* "device recovery" operation must be performed when power is restored
* to ensure correct operation. This routine performs the required steps
* for the requested chip.
...
...
@@ -312,7 +312,7 @@ static void deplete(struct mtd_info *mtd, int chip)
while
(
!
this
->
dev_ready
(
mtd
));
this
->
select_chip
(
mtd
,
chip
);
/* Send the commands for device recovery, phase 1 */
this
->
cmdfunc
(
mtd
,
NAND_CMD_DEPLETE1
,
0x0000
,
0x0000
);
this
->
cmdfunc
(
mtd
,
NAND_CMD_DEPLETE2
,
-
1
,
-
1
);
...
...
@@ -330,7 +330,7 @@ static void deplete(struct mtd_info *mtd, int chip)
* @mtd: MTD device structure
* @mode: I/O mode; read or write
*
* enable hardware ECC for data read or write
* enable hardware ECC for data read or write
*
*/
static
void
rtc_from4_enable_hwecc
(
struct
mtd_info
*
mtd
,
int
mode
)
...
...
@@ -340,7 +340,7 @@ static void rtc_from4_enable_hwecc(struct mtd_info *mtd, int mode)
switch
(
mode
)
{
case
NAND_ECC_READ
:
status
=
RTC_FROM4_RS_ECC_CTL_CLR
status
=
RTC_FROM4_RS_ECC_CTL_CLR
|
RTC_FROM4_RS_ECC_CTL_FD_E
;
*
rs_ecc_ctl
=
status
;
...
...
@@ -353,8 +353,8 @@ static void rtc_from4_enable_hwecc(struct mtd_info *mtd, int mode)
break
;
case
NAND_ECC_WRITE
:
status
=
RTC_FROM4_RS_ECC_CTL_CLR
|
RTC_FROM4_RS_ECC_CTL_GEN
status
=
RTC_FROM4_RS_ECC_CTL_CLR
|
RTC_FROM4_RS_ECC_CTL_GEN
|
RTC_FROM4_RS_ECC_CTL_FD_E
;
*
rs_ecc_ctl
=
status
;
...
...
@@ -411,7 +411,7 @@ static void rtc_from4_calculate_ecc(struct mtd_info *mtd, const u_char *dat, u_c
static
int
rtc_from4_correct_data
(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
u_char
*
ecc1
,
u_char
*
ecc2
)
{
int
i
,
j
,
res
;
unsigned
short
status
;
unsigned
short
status
;
uint16_t
par
[
6
],
syn
[
6
];
uint8_t
ecc
[
8
];
volatile
unsigned
short
*
rs_ecc
;
...
...
@@ -430,7 +430,7 @@ static int rtc_from4_correct_data(struct mtd_info *mtd, const u_char *buf, u_cha
}
/* convert into 6 10bit syndrome fields */
par
[
5
]
=
rs_decoder
->
index_of
[(((
uint16_t
)
ecc
[
0
]
>>
0
)
&
0x0ff
)
|
par
[
5
]
=
rs_decoder
->
index_of
[(((
uint16_t
)
ecc
[
0
]
>>
0
)
&
0x0ff
)
|
(((
uint16_t
)
ecc
[
1
]
<<
8
)
&
0x300
)];
par
[
4
]
=
rs_decoder
->
index_of
[(((
uint16_t
)
ecc
[
1
]
>>
2
)
&
0x03f
)
|
(((
uint16_t
)
ecc
[
2
]
<<
6
)
&
0x3c0
)];
...
...
@@ -456,7 +456,7 @@ static int rtc_from4_correct_data(struct mtd_info *mtd, const u_char *buf, u_cha
/* Let the library code do its magic.*/
res
=
decode_rs8
(
rs_decoder
,
(
uint8_t
*
)
buf
,
par
,
512
,
syn
,
0
,
NULL
,
0xff
,
NULL
);
if
(
res
>
0
)
{
DEBUG
(
MTD_DEBUG_LEVEL0
,
"rtc_from4_correct_data: "
DEBUG
(
MTD_DEBUG_LEVEL0
,
"rtc_from4_correct_data: "
"ECC corrected %d errors on read
\n
"
,
res
);
}
return
res
;
...
...
@@ -470,9 +470,9 @@ static int rtc_from4_correct_data(struct mtd_info *mtd, const u_char *buf, u_cha
* @state: state or the operation
* @status: status code returned from read status
* @page: startpage inside the chip, must be called with (page & this->pagemask)
*
* Perform additional error status checks on erase and write failures
* to determine if errors are correctable. For this device, correctable
*
* Perform additional error status checks on erase and write failures
* to determine if errors are correctable. For this device, correctable
* 1-bit errors on erase and write are considered acceptable.
*
* note: see pages 34..37 of data sheet for details.
...
...
@@ -633,7 +633,7 @@ int __init rtc_from4_init (void)
#ifdef RTC_FROM4_HWECC
/* We could create the decoder on demand, if memory is a concern.
* This way we have it handy, if an error happens
* This way we have it handy, if an error happens
*
* Symbolsize is 10 (bits)
* Primitve polynomial is x^10+x^3+1
...
...
drivers/mtd/nand/s3c2410.c
浏览文件 @
61b03bd7
...
...
@@ -19,7 +19,7 @@
* 08-Jul-2005 BJD Fix OOPS when no platform data supplied
* 20-Oct-2005 BJD Fix timing calculation bug
*
* $Id: s3c2410.c,v 1.
18 2005/10/20 21:22:55 bjd
Exp $
* $Id: s3c2410.c,v 1.
20 2005/11/07 11:14:31 gleixner
Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
...
...
@@ -164,7 +164,7 @@ static int s3c2410_nand_calc_rate(int wanted, unsigned long clk, int max)
/* controller setup */
static
int
s3c2410_nand_inithw
(
struct
s3c2410_nand_info
*
info
,
static
int
s3c2410_nand_inithw
(
struct
s3c2410_nand_info
*
info
,
struct
device
*
dev
)
{
struct
s3c2410_platform_nand
*
plat
=
to_nand_plat
(
dev
);
...
...
@@ -186,7 +186,7 @@ static int s3c2410_nand_inithw(struct s3c2410_nand_info *info,
twrph0
=
8
;
twrph1
=
8
;
}
if
(
tacls
<
0
||
twrph0
<
0
||
twrph1
<
0
)
{
printk
(
KERN_ERR
PFX
"cannot get timings suitable for board
\n
"
);
return
-
EINVAL
;
...
...
@@ -194,7 +194,7 @@ static int s3c2410_nand_inithw(struct s3c2410_nand_info *info,
printk
(
KERN_INFO
PFX
"Tacls=%d, %dns Twrph0=%d %dns, Twrph1=%d %dns
\n
"
,
tacls
,
to_ns
(
tacls
,
clkrate
),
twrph0
,
to_ns
(
twrph0
,
clkrate
),
twrph0
,
to_ns
(
twrph0
,
clkrate
),
twrph1
,
to_ns
(
twrph1
,
clkrate
));
if
(
!
info
->
is_s3c2440
)
{
...
...
@@ -219,7 +219,7 @@ static int s3c2410_nand_inithw(struct s3c2410_nand_info *info,
static
void
s3c2410_nand_select_chip
(
struct
mtd_info
*
mtd
,
int
chip
)
{
struct
s3c2410_nand_info
*
info
;
struct
s3c2410_nand_mtd
*
nmtd
;
struct
s3c2410_nand_mtd
*
nmtd
;
struct
nand_chip
*
this
=
mtd
->
priv
;
void
__iomem
*
reg
;
unsigned
long
cur
;
...
...
@@ -252,7 +252,7 @@ static void s3c2410_nand_select_chip(struct mtd_info *mtd, int chip)
writel
(
cur
,
reg
);
}
/* command and control functions
/* command and control functions
*
* Note, these all use tglx's method of changing the IO_ADDR_W field
* to make the code simpler, and use the nand layer's code to issue the
...
...
@@ -324,7 +324,7 @@ static void s3c2440_nand_hwcontrol(struct mtd_info *mtd, int cmd)
static
int
s3c2410_nand_devready
(
struct
mtd_info
*
mtd
)
{
struct
s3c2410_nand_info
*
info
=
s3c2410_nand_mtd_toinfo
(
mtd
);
if
(
info
->
is_s3c2440
)
return
readb
(
info
->
regs
+
S3C2440_NFSTAT
)
&
S3C2440_NFSTAT_READY
;
return
readb
(
info
->
regs
+
S3C2410_NFSTAT
)
&
S3C2410_NFSTAT_BUSY
;
...
...
@@ -345,7 +345,7 @@ static int s3c2410_nand_correct_data(struct mtd_info *mtd, u_char *dat,
if
(
read_ecc
[
0
]
==
calc_ecc
[
0
]
&&
read_ecc
[
1
]
==
calc_ecc
[
1
]
&&
read_ecc
[
2
]
==
calc_ecc
[
2
])
read_ecc
[
2
]
==
calc_ecc
[
2
])
return
0
;
/* we curently have no method for correcting the error */
...
...
@@ -436,14 +436,14 @@ static int s3c2410_nand_remove(struct device *dev)
dev_set_drvdata
(
dev
,
NULL
);
if
(
info
==
NULL
)
if
(
info
==
NULL
)
return
0
;
/* first thing we need to do is release all our mtds
* and their partitions, then go through freeing the
* resources used
* resources used
*/
if
(
info
->
mtds
!=
NULL
)
{
struct
s3c2410_nand_mtd
*
ptr
=
info
->
mtds
;
int
mtdno
;
...
...
@@ -507,7 +507,7 @@ static int s3c2410_nand_add_partition(struct s3c2410_nand_info *info,
/* s3c2410_nand_init_chip
*
* init a single instance of an chip
* init a single instance of an chip
*/
static
void
s3c2410_nand_init_chip
(
struct
s3c2410_nand_info
*
info
,
...
...
@@ -625,7 +625,7 @@ static int s3c24xx_nand_probe(struct device *dev, int is_s3c2440)
dev_err
(
dev
,
"cannot reserve register region
\n
"
);
err
=
-
EIO
;
goto
exit_error
;
}
}
dev_dbg
(
dev
,
"mapped registers at %p
\n
"
,
info
->
regs
);
...
...
@@ -659,7 +659,7 @@ static int s3c24xx_nand_probe(struct device *dev, int is_s3c2440)
for
(
setno
=
0
;
setno
<
nr_sets
;
setno
++
,
nmtd
++
)
{
pr_debug
(
"initialising set %d (%p, info %p)
\n
"
,
setno
,
nmtd
,
info
);
s3c2410_nand_init_chip
(
info
,
nmtd
,
sets
);
nmtd
->
scan_res
=
nand_scan
(
&
nmtd
->
mtd
,
...
...
@@ -672,7 +672,7 @@ static int s3c24xx_nand_probe(struct device *dev, int is_s3c2440)
if
(
sets
!=
NULL
)
sets
++
;
}
pr_debug
(
"initialised ok
\n
"
);
return
0
;
...
...
drivers/mtd/nand/sharpsl.c
浏览文件 @
61b03bd7
...
...
@@ -3,7 +3,7 @@
*
* Copyright (C) 2004 Richard Purdie
*
* $Id: sharpsl.c,v 1.
6 2005/11/03 11:36:42 rpurdie
Exp $
* $Id: sharpsl.c,v 1.
7 2005/11/07 11:14:31 gleixner
Exp $
*
* Based on Sharp's NAND driver sharp_sl.c
*
...
...
@@ -76,14 +76,14 @@ static struct mtd_partition sharpsl_nand_default_partition_info[] = {
},
};
/*
/*
* hardware specific access to control-lines
*/
static
void
sharpsl_nand_hwcontrol
(
struct
mtd_info
*
mtd
,
int
cmd
)
{
switch
(
cmd
)
{
case
NAND_CTL_SETCLE
:
case
NAND_CTL_SETCLE
:
writeb
(
readb
(
FLASHCTL
)
|
FLCLE
,
FLASHCTL
);
break
;
case
NAND_CTL_CLRCLE
:
...
...
@@ -97,10 +97,10 @@ sharpsl_nand_hwcontrol(struct mtd_info* mtd, int cmd)
writeb
(
readb
(
FLASHCTL
)
&
~
FLALE
,
FLASHCTL
);
break
;
case
NAND_CTL_SETNCE
:
case
NAND_CTL_SETNCE
:
writeb
(
readb
(
FLASHCTL
)
&
~
(
FLCE0
|
FLCE1
),
FLASHCTL
);
break
;
case
NAND_CTL_CLRNCE
:
case
NAND_CTL_CLRNCE
:
writeb
(
readb
(
FLASHCTL
)
|
(
FLCE0
|
FLCE1
),
FLASHCTL
);
break
;
}
...
...
@@ -126,8 +126,8 @@ static struct nand_oobinfo akita_oobinfo = {
.
useecc
=
MTD_NANDECC_AUTOPLACE
,
.
eccbytes
=
24
,
.
eccpos
=
{
0x5
,
0x1
,
0x2
,
0x3
,
0x6
,
0x7
,
0x15
,
0x11
,
0x12
,
0x13
,
0x16
,
0x17
,
0x25
,
0x21
,
0x22
,
0x23
,
0x5
,
0x1
,
0x2
,
0x3
,
0x6
,
0x7
,
0x15
,
0x11
,
0x12
,
0x13
,
0x16
,
0x17
,
0x25
,
0x21
,
0x22
,
0x23
,
0x26
,
0x27
,
0x35
,
0x31
,
0x32
,
0x33
,
0x36
,
0x37
},
.
oobfree
=
{
{
0x08
,
0x09
}
}
};
...
...
@@ -177,7 +177,7 @@ sharpsl_nand_init(void)
printk
(
"Unable to allocate SharpSL NAND MTD device structure.
\n
"
);
return
-
ENOMEM
;
}
/* map physical adress */
sharpsl_io_base
=
ioremap
(
sharpsl_phys_base
,
0x1000
);
if
(
!
sharpsl_io_base
){
...
...
@@ -185,7 +185,7 @@ sharpsl_nand_init(void)
kfree
(
sharpsl_mtd
);
return
-
EIO
;
}
/* Get pointer to private data */
this
=
(
struct
nand_chip
*
)
(
&
sharpsl_mtd
[
1
]);
...
...
@@ -211,7 +211,7 @@ sharpsl_nand_init(void)
this
->
chip_delay
=
15
;
/* set eccmode using hardware ECC */
this
->
eccmode
=
NAND_ECC_HW3_256
;
this
->
badblock_pattern
=
&
sharpsl_bbt
;
this
->
badblock_pattern
=
&
sharpsl_bbt
;
if
(
machine_is_akita
()
||
machine_is_borzoi
())
{
this
->
badblock_pattern
=
&
sharpsl_akita_bbt
;
this
->
autooob
=
&
akita_oobinfo
;
...
...
@@ -232,7 +232,7 @@ sharpsl_nand_init(void)
sharpsl_mtd
->
name
=
"sharpsl-nand"
;
nr_partitions
=
parse_mtd_partitions
(
sharpsl_mtd
,
part_probes
,
&
sharpsl_partition_info
,
0
);
if
(
nr_partitions
<=
0
)
{
nr_partitions
=
DEFAULT_NUM_PARTITIONS
;
sharpsl_partition_info
=
sharpsl_nand_default_partition_info
;
...
...
drivers/mtd/nand/spia.c
浏览文件 @
61b03bd7
...
...
@@ -8,7 +8,7 @@
* to controllines (due to change in nand.c)
* page_cache added
*
* $Id: spia.c,v 1.2
4 2004/11/04 12:53:10
gleixner Exp $
* $Id: spia.c,v 1.2
5 2005/11/07 11:14:31
gleixner Exp $
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
...
...
@@ -82,7 +82,7 @@ const static struct mtd_partition partition_info[] = {
#define NUM_PARTITIONS 2
/*
/*
* hardware specific access to control-lines
*/
static
void
spia_hwcontrol
(
struct
mtd_info
*
mtd
,
int
cmd
){
...
...
@@ -137,7 +137,7 @@ int __init spia_init (void)
/* Set address of hardware control function */
this
->
hwcontrol
=
spia_hwcontrol
;
/* 15 us command delay time */
this
->
chip_delay
=
15
;
this
->
chip_delay
=
15
;
/* Scan to find existence of the device */
if
(
nand_scan
(
spia_mtd
,
1
))
{
...
...
drivers/mtd/nand/toto.c
浏览文件 @
61b03bd7
...
...
@@ -15,7 +15,7 @@
* This is a device driver for the NAND flash device found on the
* TI fido board. It supports 32MiB and 64MiB cards
*
* $Id: toto.c,v 1.
4 2004/10/05 13:50:20
gleixner Exp $
* $Id: toto.c,v 1.
5 2005/11/07 11:14:31
gleixner Exp $
*/
#include <linux/slab.h>
...
...
@@ -57,7 +57,7 @@ static unsigned long toto_io_base = OMAP_FLASH_1_BASE;
#endif
#define T_NAND_CTL_SETNCE(iob) gpiosetout(NAND_NCE, 0)
#define T_NAND_CTL_CLRNCE(iob) gpiosetout(NAND_NCE, NAND_NCE)
/*
* Define partitions for flash devices
*/
...
...
@@ -91,7 +91,7 @@ static struct mtd_partition partition_info32M[] = {
#define NUM_PARTITIONS32M 3
#define NUM_PARTITIONS64M 4
/*
/*
* hardware specific access to control-lines
*/
...
...
@@ -146,7 +146,7 @@ int __init toto_init (void)
this
->
hwcontrol
=
toto_hwcontrol
;
this
->
dev_ready
=
NULL
;
/* 25 us command delay time */
this
->
chip_delay
=
30
;
this
->
chip_delay
=
30
;
this
->
eccmode
=
NAND_ECC_SOFT
;
/* Scan to find existance of the device */
...
...
@@ -157,10 +157,10 @@ int __init toto_init (void)
/* Register the partitions */
switch
(
toto_mtd
->
size
){
case
SZ_64M
:
add_mtd_partitions
(
toto_mtd
,
partition_info64M
,
NUM_PARTITIONS64M
);
break
;
case
SZ_32M
:
add_mtd_partitions
(
toto_mtd
,
partition_info32M
,
NUM_PARTITIONS32M
);
break
;
case
SZ_64M
:
add_mtd_partitions
(
toto_mtd
,
partition_info64M
,
NUM_PARTITIONS64M
);
break
;
case
SZ_32M
:
add_mtd_partitions
(
toto_mtd
,
partition_info32M
,
NUM_PARTITIONS32M
);
break
;
default:
{
printk
(
KERN_WARNING
"Unsupported Nand device
\n
"
);
printk
(
KERN_WARNING
"Unsupported Nand device
\n
"
);
err
=
-
ENXIO
;
goto
out_buf
;
}
...
...
@@ -170,9 +170,9 @@ int __init toto_init (void)
archflashwp
(
0
,
0
);
/* open up flash for writing */
goto
out
;
out_buf:
kfree
(
this
->
data_buf
);
kfree
(
this
->
data_buf
);
out_mtd:
kfree
(
toto_mtd
);
out:
...
...
@@ -194,7 +194,7 @@ static void __exit toto_cleanup (void)
/* stop flash writes */
archflashwp
(
0
,
1
);
/* release gpios to system */
gpiorelease
(
NAND_MASK
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录