Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
61ecfa87
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
61ecfa87
编写于
11月 07, 2005
作者:
T
Thomas Gleixner
提交者:
Thomas Gleixner
11月 07, 2005
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[MTD] includes: Clean up trailing white spaces
Signed-off-by:
N
Thomas Gleixner
<
tglx@linutronix.de
>
上级
03ead842
变更
16
隐藏空白更改
内联
并排
Showing
16 changed file
with
118 addition
and
118 deletion
+118
-118
include/linux/mtd/bbm.h
include/linux/mtd/bbm.h
+1
-1
include/linux/mtd/blktrans.h
include/linux/mtd/blktrans.h
+2
-2
include/linux/mtd/cfi.h
include/linux/mtd/cfi.h
+12
-12
include/linux/mtd/doc2000.h
include/linux/mtd/doc2000.h
+9
-9
include/linux/mtd/flashchip.h
include/linux/mtd/flashchip.h
+7
-7
include/linux/mtd/ftl.h
include/linux/mtd/ftl.h
+3
-3
include/linux/mtd/gen_probe.h
include/linux/mtd/gen_probe.h
+2
-2
include/linux/mtd/jedec.h
include/linux/mtd/jedec.h
+10
-10
include/linux/mtd/map.h
include/linux/mtd/map.h
+7
-7
include/linux/mtd/mtd.h
include/linux/mtd/mtd.h
+12
-12
include/linux/mtd/nand.h
include/linux/mtd/nand.h
+27
-27
include/linux/mtd/onenand.h
include/linux/mtd/onenand.h
+1
-1
include/linux/mtd/partitions.h
include/linux/mtd/partitions.h
+10
-10
include/linux/mtd/physmap.h
include/linux/mtd/physmap.h
+6
-6
include/linux/mtd/pmc551.h
include/linux/mtd/pmc551.h
+6
-6
include/linux/mtd/xip.h
include/linux/mtd/xip.h
+3
-3
未找到文件。
include/linux/mtd/bbm.h
浏览文件 @
61ecfa87
...
...
@@ -29,7 +29,7 @@
* @param version version read from the bbt page during scan
* @param len length of the pattern, if 0 no pattern check is performed
* @param maxblocks maximum number of blocks to search for a bbt. This number of
* blocks is reserved at the end of the device
* blocks is reserved at the end of the device
* where the tables are written.
* @param reserved_block_code if non-0, this pattern denotes a reserved
* (rather than bad) block in the stored bbt
...
...
include/linux/mtd/blktrans.h
浏览文件 @
61ecfa87
/*
* $Id: blktrans.h,v 1.
5 2003/06/23 12:00:08 dwmw2
Exp $
* $Id: blktrans.h,v 1.
6 2005/11/07 11:14:54 gleixner
Exp $
*
* (C) 2003 David Woodhouse <dwmw2@infradead.org>
*
...
...
@@ -67,6 +67,6 @@ extern int register_mtd_blktrans(struct mtd_blktrans_ops *tr);
extern
int
deregister_mtd_blktrans
(
struct
mtd_blktrans_ops
*
tr
);
extern
int
add_mtd_blktrans_dev
(
struct
mtd_blktrans_dev
*
dev
);
extern
int
del_mtd_blktrans_dev
(
struct
mtd_blktrans_dev
*
dev
);
#endif
/* __MTD_TRANS_H__ */
include/linux/mtd/cfi.h
浏览文件 @
61ecfa87
/* Common Flash Interface structures
/* Common Flash Interface structures
* See http://support.intel.com/design/flash/technote/index.htm
* $Id: cfi.h,v 1.5
5 2005/08/06 04:40:42 nico
Exp $
* $Id: cfi.h,v 1.5
6 2005/11/07 11:14:54 gleixner
Exp $
*/
#ifndef __MTD_CFI_H__
...
...
@@ -82,8 +82,8 @@ static inline int cfi_interleave_supported(int i)
}
/* NB: these values must represents the number of bytes needed to meet the
* device type (x8, x16, x32). Eg. a 32 bit device is 4 x 8 bytes.
/* NB: these values must represents the number of bytes needed to meet the
* device type (x8, x16, x32). Eg. a 32 bit device is 4 x 8 bytes.
* These numbers are used in calculations.
*/
#define CFI_DEVICETYPE_X8 (8 / 8)
...
...
@@ -259,7 +259,7 @@ static inline uint32_t cfi_build_cmd_addr(uint32_t cmd_ofs, int interleave, int
/*
* Transforms the CFI command for the given geometry (bus width & interleave).
* It looks too long to be inline, but in the common case it should almost all
* get optimised away.
* get optimised away.
*/
static
inline
map_word
cfi_build_cmd
(
u_long
cmd
,
struct
map_info
*
map
,
struct
cfi_private
*
cfi
)
{
...
...
@@ -268,7 +268,7 @@ static inline map_word cfi_build_cmd(u_long cmd, struct map_info *map, struct cf
unsigned
long
onecmd
;
int
i
;
/* We do it this way to give the compiler a fighting chance
/* We do it this way to give the compiler a fighting chance
of optimising away all the crap for 'bankwidth' larger than
an unsigned long, in the common case where that support is
disabled */
...
...
@@ -279,7 +279,7 @@ static inline map_word cfi_build_cmd(u_long cmd, struct map_info *map, struct cf
wordwidth
=
map_bankwidth
(
map
);
words_per_bus
=
1
;
}
chip_mode
=
map_bankwidth
(
map
)
/
cfi_interleave
(
cfi
);
chips_per_word
=
wordwidth
*
cfi_interleave
(
cfi
)
/
map_bankwidth
(
map
);
...
...
@@ -298,7 +298,7 @@ static inline map_word cfi_build_cmd(u_long cmd, struct map_info *map, struct cf
break
;
}
/* Now replicate it across the size of an unsigned long, or
/* Now replicate it across the size of an unsigned long, or
just to the bus width as appropriate */
switch
(
chips_per_word
)
{
default:
BUG
();
...
...
@@ -314,7 +314,7 @@ static inline map_word cfi_build_cmd(u_long cmd, struct map_info *map, struct cf
;
}
/* And finally, for the multi-word case, replicate it
/* And finally, for the multi-word case, replicate it
in all words in the structure */
for
(
i
=
0
;
i
<
words_per_bus
;
i
++
)
{
val
.
x
[
i
]
=
onecmd
;
...
...
@@ -325,14 +325,14 @@ static inline map_word cfi_build_cmd(u_long cmd, struct map_info *map, struct cf
#define CMD(x) cfi_build_cmd((x), map, cfi)
static
inline
unsigned
long
cfi_merge_status
(
map_word
val
,
struct
map_info
*
map
,
static
inline
unsigned
long
cfi_merge_status
(
map_word
val
,
struct
map_info
*
map
,
struct
cfi_private
*
cfi
)
{
int
wordwidth
,
words_per_bus
,
chip_mode
,
chips_per_word
;
unsigned
long
onestat
,
res
=
0
;
int
i
;
/* We do it this way to give the compiler a fighting chance
/* We do it this way to give the compiler a fighting chance
of optimising away all the crap for 'bankwidth' larger than
an unsigned long, in the common case where that support is
disabled */
...
...
@@ -343,7 +343,7 @@ static inline unsigned long cfi_merge_status(map_word val, struct map_info *map,
wordwidth
=
map_bankwidth
(
map
);
words_per_bus
=
1
;
}
chip_mode
=
map_bankwidth
(
map
)
/
cfi_interleave
(
cfi
);
chips_per_word
=
wordwidth
*
cfi_interleave
(
cfi
)
/
map_bankwidth
(
map
);
...
...
include/linux/mtd/doc2000.h
浏览文件 @
61ecfa87
/*
/*
* Linux driver for Disk-On-Chip devices
*
* Copyright (C) 1999 Machine Vision Holdings, Inc.
* Copyright (C) 1999 Machine Vision Holdings, Inc.
* Copyright (C) 2001-2003 David Woodhouse <dwmw2@infradead.org>
* Copyright (C) 2002-2003 Greg Ungerer <gerg@snapgear.com>
* Copyright (C) 2002-2003 SnapGear Inc
*
* $Id: doc2000.h,v 1.2
4 2005/01/05 12:40:38 dwmw2 Exp $
* $Id: doc2000.h,v 1.2
5 2005/11/07 11:14:54 gleixner Exp $
*
* Released under GPL
*/
...
...
@@ -75,10 +75,10 @@
#define DoC_Mplus_CtrlConfirm 0x1076
#define DoC_Mplus_Power 0x1fff
/* How to access the device?
* On ARM, it'll be mmap'd directly with 32-bit wide accesses.
/* How to access the device?
* On ARM, it'll be mmap'd directly with 32-bit wide accesses.
* On PPC, it's mmap'd and 16-bit wide.
* Others use readb/writeb
* Others use readb/writeb
*/
#if defined(__arm__)
#define ReadDOC_(adr, reg) ((unsigned char)(*(volatile __u32 *)(((unsigned long)adr)+((reg)<<2))))
...
...
@@ -172,7 +172,7 @@ struct DiskOnChip {
unsigned
long
totlen
;
unsigned
char
ChipID
;
/* Type of DiskOnChip */
int
ioreg
;
unsigned
long
mfr
;
/* Flash IDs - only one type of flash per device */
unsigned
long
id
;
int
chipshift
;
...
...
@@ -180,10 +180,10 @@ struct DiskOnChip {
char
pageadrlen
;
char
interleave
;
/* Internal interleaving - Millennium Plus style */
unsigned
long
erasesize
;
int
curfloor
;
int
curchip
;
int
numchips
;
struct
Nand
*
chips
;
struct
mtd_info
*
nextdoc
;
...
...
include/linux/mtd/flashchip.h
浏览文件 @
61ecfa87
/*
/*
* struct flchip definition
*
* Contains information about the location and state of a given flash device
*
* Contains information about the location and state of a given flash device
*
* (C) 2000 Red Hat. GPLd.
*
* $Id: flashchip.h,v 1.1
7 2005/03/14 18:27:15 bjd
Exp $
* $Id: flashchip.h,v 1.1
8 2005/11/07 11:14:54 gleixner
Exp $
*
*/
...
...
@@ -15,11 +15,11 @@
/* For spinlocks. sched.h includes spinlock.h from whichever directory it
* happens to be in - so we don't have to care whether we're on 2.2, which
* has asm/spinlock.h, or 2.4, which has linux/spinlock.h
* has asm/spinlock.h, or 2.4, which has linux/spinlock.h
*/
#include <linux/sched.h>
typedef
enum
{
typedef
enum
{
FL_READY
,
FL_STATUS
,
FL_CFI_QUERY
,
...
...
@@ -45,7 +45,7 @@ typedef enum {
/* NOTE: confusingly, this can be used to refer to more than one chip at a time,
/* NOTE: confusingly, this can be used to refer to more than one chip at a time,
if they're interleaved. This can even refer to individual partitions on
the same physical chip when present. */
...
...
include/linux/mtd/ftl.h
浏览文件 @
61ecfa87
/*
* $Id: ftl.h,v 1.
6 2003/01/24 13:20:04 dwmw2
Exp $
*
* $Id: ftl.h,v 1.
7 2005/11/07 11:14:54 gleixner
Exp $
*
* Derived from (and probably identical to):
* ftl.h 1.7 1999/10/25 20:23:17
*
...
...
@@ -12,7 +12,7 @@
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and
* limitations under the License.
* limitations under the License.
*
* The initial developer of the original code is David A. Hinds
* <dahinds@users.sourceforge.net>. Portions created by David A. Hinds
...
...
include/linux/mtd/gen_probe.h
浏览文件 @
61ecfa87
/*
* (C) 2001, 2001 Red Hat, Inc.
* GPL'd
* $Id: gen_probe.h,v 1.
3 2004/10/20 22:10:33 dwmw2
Exp $
* $Id: gen_probe.h,v 1.
4 2005/11/07 11:14:54 gleixner
Exp $
*/
#ifndef __LINUX_MTD_GEN_PROBE_H__
#define __LINUX_MTD_GEN_PROBE_H__
#include <linux/mtd/flashchip.h>
#include <linux/mtd/map.h>
#include <linux/mtd/map.h>
#include <linux/mtd/cfi.h>
#include <linux/bitops.h>
...
...
include/linux/mtd/jedec.h
浏览文件 @
61ecfa87
/* JEDEC Flash Interface.
* This is an older type of interface for self programming flash. It is
* This is an older type of interface for self programming flash. It is
* commonly use in older AMD chips and is obsolete compared with CFI.
* It is called JEDEC because the JEDEC association distributes the ID codes
* for the chips.
*
* See the AMD flash databook for information on how to operate the interface.
*
* $Id: jedec.h,v 1.
3 2003/05/21 11:51:01 dwmw2
Exp $
* $Id: jedec.h,v 1.
4 2005/11/07 11:14:54 gleixner
Exp $
*/
#ifndef __LINUX_MTD_JEDEC_H__
...
...
@@ -33,16 +33,16 @@ struct jedec_flash_chip
__u16
jedec
;
unsigned
long
size
;
unsigned
long
sectorsize
;
// *(__u8*)(base + (adder << addrshift)) = data << datashift
// Address size = size << addrshift
unsigned
long
base
;
// Byte 0 of the flash, will be unaligned
unsigned
int
datashift
;
// Useful for 32bit/16bit accesses
unsigned
int
addrshift
;
unsigned
long
offset
;
// linerized start. base==offset for unbanked, uninterleaved flash
__u32
capabilities
;
// These markers are filled in by the flash_chip_scan function
unsigned
long
start
;
unsigned
long
length
;
...
...
@@ -51,16 +51,16 @@ struct jedec_flash_chip
struct
jedec_private
{
unsigned
long
size
;
// Total size of all the devices
/* Bank handling. If sum(bank_fill) == size then this is linear flash.
Otherwise the mapping has holes in it. bank_fill may be used to
find the holes, but in the common symetric case
bank_fill[0] == bank_fill[*], thus addresses may be computed
find the holes, but in the common symetric case
bank_fill[0] == bank_fill[*], thus addresses may be computed
mathmatically. bank_fill must be powers of two */
unsigned
is_banked
;
unsigned
long
bank_fill
[
MAX_JEDEC_CHIPS
];
struct
jedec_flash_chip
chips
[
MAX_JEDEC_CHIPS
];
struct
jedec_flash_chip
chips
[
MAX_JEDEC_CHIPS
];
};
#endif
include/linux/mtd/map.h
浏览文件 @
61ecfa87
/* Overhauled routines for dealing with different mmap regions of flash */
/* $Id: map.h,v 1.5
2 2005/05/25 10:29:41
gleixner Exp $ */
/* $Id: map.h,v 1.5
4 2005/11/07 11:14:54
gleixner Exp $ */
#ifndef __LINUX_MTD_MAP_H__
#define __LINUX_MTD_MAP_H__
...
...
@@ -170,14 +170,14 @@ typedef union {
to a chip probe routine -- either JEDEC or CFI probe or both -- via
do_map_probe(). If a chip is recognised, the probe code will invoke the
appropriate chip driver (if present) and return a struct mtd_info.
At which point, you fill in the mtd->module with your own module
At which point, you fill in the mtd->module with your own module
address, and register it with the MTD core code. Or you could partition
it and register the partitions instead, or keep it for your own private
use; whatever.
The mtd->priv field will point to the struct map_info, and any further
private data required by the chip driver is linked from the
mtd->priv->fldrv_priv field. This allows the map driver to get at
private data required by the chip driver is linked from the
mtd->priv->fldrv_priv field. This allows the map driver to get at
the destructor function map->fldrv_destroy() when it's tired
of living.
*/
...
...
@@ -214,7 +214,7 @@ struct map_info {
If there is no cache to care about this can be set to NULL. */
void
(
*
inval_cache
)(
struct
map_info
*
,
unsigned
long
,
ssize_t
);
/* set_vpp() must handle being reentered -- enable, enable, disable
/* set_vpp() must handle being reentered -- enable, enable, disable
must leave it enabled. */
void
(
*
set_vpp
)(
struct
map_info
*
,
int
);
...
...
@@ -353,7 +353,7 @@ static inline map_word map_word_ff(struct map_info *map)
{
map_word
r
;
int
i
;
if
(
map_bankwidth
(
map
)
<
MAP_FF_LIMIT
)
{
int
bw
=
8
*
map_bankwidth
(
map
);
r
.
x
[
0
]
=
(
1
<<
bw
)
-
1
;
...
...
include/linux/mtd/mtd.h
浏览文件 @
61ecfa87
/*
* $Id: mtd.h,v 1.6
0 2005/08/06 04:40:42 nico
Exp $
/*
* $Id: mtd.h,v 1.6
1 2005/11/07 11:14:54 gleixner
Exp $
*
* Copyright (C) 1999-2003 David Woodhouse <dwmw2@infradead.org> et al.
*
...
...
@@ -90,13 +90,13 @@ struct mtd_info {
// oobinfo is a nand_oobinfo structure, which can be set by iotcl (MEMSETOOBINFO)
struct
nand_oobinfo
oobinfo
;
u_int32_t
oobavail
;
// Number of bytes in OOB area available for fs
u_int32_t
oobavail
;
// Number of bytes in OOB area available for fs
/* Data for variable erase regions. If numeraseregions is zero,
* it means that the whole device has erasesize as given above.
* it means that the whole device has erasesize as given above.
*/
int
numeraseregions
;
struct
mtd_erase_region_info
*
eraseregions
;
struct
mtd_erase_region_info
*
eraseregions
;
/* This really shouldn't be here. It can go away in 2.5 */
u_int32_t
bank_size
;
...
...
@@ -119,10 +119,10 @@ struct mtd_info {
int
(
*
read_oob
)
(
struct
mtd_info
*
mtd
,
loff_t
from
,
size_t
len
,
size_t
*
retlen
,
u_char
*
buf
);
int
(
*
write_oob
)
(
struct
mtd_info
*
mtd
,
loff_t
to
,
size_t
len
,
size_t
*
retlen
,
const
u_char
*
buf
);
/*
* Methods to access the protection register area, present in some
/*
* Methods to access the protection register area, present in some
* flash devices. The user data is one time programmable but the
* factory data is read only.
* factory data is read only.
*/
int
(
*
get_fact_prot_info
)
(
struct
mtd_info
*
mtd
,
struct
otp_info
*
buf
,
size_t
len
);
int
(
*
read_fact_prot_reg
)
(
struct
mtd_info
*
mtd
,
loff_t
from
,
size_t
len
,
size_t
*
retlen
,
u_char
*
buf
);
...
...
@@ -133,14 +133,14 @@ struct mtd_info {
/* kvec-based read/write methods. We need these especially for NAND flash,
with its limited number of write cycles per erase.
NB: The 'count' parameter is the number of _vectors_, each of
NB: The 'count' parameter is the number of _vectors_, each of
which contains an (ofs, len) tuple.
*/
int
(
*
readv
)
(
struct
mtd_info
*
mtd
,
struct
kvec
*
vecs
,
unsigned
long
count
,
loff_t
from
,
size_t
*
retlen
);
int
(
*
readv_ecc
)
(
struct
mtd_info
*
mtd
,
struct
kvec
*
vecs
,
unsigned
long
count
,
loff_t
from
,
int
(
*
readv_ecc
)
(
struct
mtd_info
*
mtd
,
struct
kvec
*
vecs
,
unsigned
long
count
,
loff_t
from
,
size_t
*
retlen
,
u_char
*
eccbuf
,
struct
nand_oobinfo
*
oobsel
);
int
(
*
writev
)
(
struct
mtd_info
*
mtd
,
const
struct
kvec
*
vecs
,
unsigned
long
count
,
loff_t
to
,
size_t
*
retlen
);
int
(
*
writev_ecc
)
(
struct
mtd_info
*
mtd
,
const
struct
kvec
*
vecs
,
unsigned
long
count
,
loff_t
to
,
int
(
*
writev_ecc
)
(
struct
mtd_info
*
mtd
,
const
struct
kvec
*
vecs
,
unsigned
long
count
,
loff_t
to
,
size_t
*
retlen
,
u_char
*
eccbuf
,
struct
nand_oobinfo
*
oobsel
);
/* Sync */
...
...
@@ -204,7 +204,7 @@ int default_mtd_readv(struct mtd_info *mtd, struct kvec *vecs,
#define MTD_WRITEECC(mtd, args...) (*(mtd->write_ecc))(mtd, args)
#define MTD_READOOB(mtd, args...) (*(mtd->read_oob))(mtd, args)
#define MTD_WRITEOOB(mtd, args...) (*(mtd->write_oob))(mtd, args)
#define MTD_SYNC(mtd) do { if (mtd->sync) (*(mtd->sync))(mtd); } while (0)
#define MTD_SYNC(mtd) do { if (mtd->sync) (*(mtd->sync))(mtd); } while (0)
#ifdef CONFIG_MTD_PARTITIONS
...
...
include/linux/mtd/nand.h
浏览文件 @
61ecfa87
...
...
@@ -24,7 +24,7 @@
* bat later if I did something naughty.
* 10-11-2000 SJH Added private NAND flash structure for driver
* 10-24-2000 SJH Added prototype for 'nand_scan' function
* 10-29-2001 TG changed nand_chip structure to support
* 10-29-2001 TG changed nand_chip structure to support
* hardwarespecific function for accessing control lines
* 02-21-2002 TG added support for different read/write adress and
* ready/busy line access function
...
...
@@ -36,21 +36,21 @@
* CONFIG_MTD_NAND_ECC_JFFS2 is not set
* 08-10-2002 TG extensions to nand_chip structure to support HW-ECC
*
* 08-29-2002 tglx nand_chip structure: data_poi for selecting
* 08-29-2002 tglx nand_chip structure: data_poi for selecting
* internal / fs-driver buffer
* support for 6byte/512byte hardware ECC
* read_ecc, write_ecc extended for different oob-layout
* oob layout selections: NAND_NONE_OOB, NAND_JFFS2_OOB,
* NAND_YAFFS_OOB
* 11-25-2002 tglx Added Manufacturer code FUJITSU, NATIONAL
* Split manufacturer and device ID structures
* Split manufacturer and device ID structures
*
* 02-08-2004 tglx added option field to nand structure for chip anomalities
* 05-25-2004 tglx added bad block table support, ST-MICRO manufacturer id
* update of nand_chip structure description
* 01-17-2005 dmarlin added extended commands for AG-AND device and added option
* 01-17-2005 dmarlin added extended commands for AG-AND device and added option
* for BBT_AUTO_REFRESH.
* 01-20-2005 dmarlin added optional pointer to hardware specific callback for
* 01-20-2005 dmarlin added optional pointer to hardware specific callback for
* extra error status checks.
*/
#ifndef __LINUX_MTD_NAND_H
...
...
@@ -120,8 +120,8 @@ extern int nand_read_raw (struct mtd_info *mtd, uint8_t *buf, loff_t from, size_
#define NAND_CMD_CACHEDPROG 0x15
/* Extended commands for AG-AND device */
/*
* Note: the command for NAND_CMD_DEPLETE1 is really 0x00 but
/*
* Note: the command for NAND_CMD_DEPLETE1 is really 0x00 but
* there is no way to distinguish that from NAND_CMD_READ0
* until the remaining sequence of commands has been completed
* so add a high order bit and mask it off in the command.
...
...
@@ -145,7 +145,7 @@ extern int nand_read_raw (struct mtd_info *mtd, uint8_t *buf, loff_t from, size_
#define NAND_STATUS_READY 0x40
#define NAND_STATUS_WP 0x80
/*
/*
* Constants for ECC_MODES
*/
...
...
@@ -191,12 +191,12 @@ extern int nand_read_raw (struct mtd_info *mtd, uint8_t *buf, loff_t from, size_
#define NAND_CACHEPRG 0x00000008
/* Chip has copy back function */
#define NAND_COPYBACK 0x00000010
/* AND Chip which has 4 banks and a confusing page / block
/* AND Chip which has 4 banks and a confusing page / block
* assignment. See Renesas datasheet for further information */
#define NAND_IS_AND 0x00000020
/* Chip has a array of 4 pages which can be read without
* additional ready /busy waits */
#define NAND_4PAGE_ARRAY 0x00000040
#define NAND_4PAGE_ARRAY 0x00000040
/* Chip requires that BBT is periodically rewritten to prevent
* bits from adjacent blocks from 'leaking' in altering data.
* This happens with the Renesas AG-AND chips, possibly others. */
...
...
@@ -219,8 +219,8 @@ extern int nand_read_raw (struct mtd_info *mtd, uint8_t *buf, loff_t from, size_
/* Use a flash based bad block table. This option is passed to the
* default bad block table function. */
#define NAND_USE_FLASH_BBT 0x00010000
/* The hw ecc generator provides a syndrome instead a ecc value on read
* This can only work if we have the ecc bytes directly behind the
/* The hw ecc generator provides a syndrome instead a ecc value on read
* This can only work if we have the ecc bytes directly behind the
* data bytes. Applies for DOC and AG-AND Renesas HW Reed Solomon generators */
#define NAND_HWECC_SYNDROME 0x00020000
/* This option skips the bbt scan during initialization. */
...
...
@@ -252,7 +252,7 @@ struct nand_chip;
/**
* struct nand_hw_control - Control structure for hardware controller (e.g ECC generator) shared among independend devices
* @lock: protection lock
* @lock: protection lock
* @active: the mtd device which holds the controller currently
* @wq: wait queue to sleep on if a NAND operation is in progress
* used instead of the per chip wait queue when a hw controller is available
...
...
@@ -265,8 +265,8 @@ struct nand_hw_control {
/**
* struct nand_chip - NAND Private Flash Chip Data
* @IO_ADDR_R: [BOARDSPECIFIC] address to read the 8 I/O lines of the flash device
* @IO_ADDR_W: [BOARDSPECIFIC] address to write the 8 I/O lines of the flash device
* @IO_ADDR_R: [BOARDSPECIFIC] address to read the 8 I/O lines of the flash device
* @IO_ADDR_W: [BOARDSPECIFIC] address to write the 8 I/O lines of the flash device
* @read_byte: [REPLACEABLE] read one byte from the chip
* @write_byte: [REPLACEABLE] write one byte to the chip
* @read_word: [REPLACEABLE] read one word from the chip
...
...
@@ -289,7 +289,7 @@ struct nand_hw_control {
* be provided if a hardware ECC is available
* @erase_cmd: [INTERN] erase command write function, selectable due to AND support
* @scan_bbt: [REPLACEABLE] function to scan bad block table
* @eccmode: [BOARDSPECIFIC] mode of ecc, see defines
* @eccmode: [BOARDSPECIFIC] mode of ecc, see defines
* @eccsize: [INTERN] databytes used per ecc-calculation
* @eccbytes: [INTERN] number of ecc bytes per ecc-calculation step
* @eccsteps: [INTERN] number of ecc calculation steps per page
...
...
@@ -301,7 +301,7 @@ struct nand_hw_control {
* @phys_erase_shift: [INTERN] number of address bits in a physical eraseblock
* @bbt_erase_shift: [INTERN] number of address bits in a bbt entry
* @chip_shift: [INTERN] number of address bits in one chip
* @data_buf: [INTERN] internal buffer for one page + oob
* @data_buf: [INTERN] internal buffer for one page + oob
* @oob_buf: [INTERN] oob buffer for one eraseblock
* @oobdirty: [INTERN] indicates that oob_buf must be reinitialized
* @data_poi: [INTERN] pointer to a data buffer
...
...
@@ -316,22 +316,22 @@ struct nand_hw_control {
* @bbt: [INTERN] bad block table pointer
* @bbt_td: [REPLACEABLE] bad block table descriptor for flash lookup
* @bbt_md: [REPLACEABLE] bad block table mirror descriptor
* @badblock_pattern: [REPLACEABLE] bad block scan pattern used for initial bad block scan
* @badblock_pattern: [REPLACEABLE] bad block scan pattern used for initial bad block scan
* @controller: [OPTIONAL] a pointer to a hardware controller structure which is shared among multiple independend devices
* @priv: [OPTIONAL] pointer to private chip date
* @errstat: [OPTIONAL] hardware specific function to perform additional error status checks
* @errstat: [OPTIONAL] hardware specific function to perform additional error status checks
* (determine if errors are correctable)
*/
struct
nand_chip
{
void
__iomem
*
IO_ADDR_R
;
void
__iomem
*
IO_ADDR_W
;
u_char
(
*
read_byte
)(
struct
mtd_info
*
mtd
);
void
(
*
write_byte
)(
struct
mtd_info
*
mtd
,
u_char
byte
);
u16
(
*
read_word
)(
struct
mtd_info
*
mtd
);
void
(
*
write_word
)(
struct
mtd_info
*
mtd
,
u16
word
);
void
(
*
write_buf
)(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
);
void
(
*
read_buf
)(
struct
mtd_info
*
mtd
,
u_char
*
buf
,
int
len
);
int
(
*
verify_buf
)(
struct
mtd_info
*
mtd
,
const
u_char
*
buf
,
int
len
);
...
...
@@ -396,7 +396,7 @@ struct nand_chip {
* @name: Identify the device type
* @id: device ID code
* @pagesize: Pagesize in bytes. Either 256 or 512 or 0
* If the pagesize is 0, then the real pagesize
* If the pagesize is 0, then the real pagesize
* and the eraseize are determined from the
* extended id bytes in the chip
* @erasesize: Size of an erase block in the flash device.
...
...
@@ -425,7 +425,7 @@ struct nand_manufacturers {
extern
struct
nand_flash_dev
nand_flash_ids
[];
extern
struct
nand_manufacturers
nand_manuf_ids
[];
/**
/**
* struct nand_bbt_descr - bad block table descriptor
* @options: options for this descriptor
* @pages: the page(s) where we find the bbt, used with option BBT_ABSPAGE
...
...
@@ -436,14 +436,14 @@ extern struct nand_manufacturers nand_manuf_ids[];
* @version: version read from the bbt page during scan
* @len: length of the pattern, if 0 no pattern check is performed
* @maxblocks: maximum number of blocks to search for a bbt. This number of
* blocks is reserved at the end of the device where the tables are
* blocks is reserved at the end of the device where the tables are
* written.
* @reserved_block_code: if non-0, this pattern denotes a reserved (rather than
* bad) block in the stored bbt
* @pattern: pattern to identify bad block table or factory marked good /
* @pattern: pattern to identify bad block table or factory marked good /
* bad blocks, can be NULL, if len = 0
*
* Descriptor for the bad block table marker and the descriptor for the
* Descriptor for the bad block table marker and the descriptor for the
* pattern which identifies good and bad blocks. The assumption is made
* that the pattern and the version count are always located in the oob area
* of the first block.
...
...
include/linux/mtd/onenand.h
浏览文件 @
61ecfa87
...
...
@@ -77,7 +77,7 @@ struct onenand_bufferram {
* @param wq [INTERN] wait queue to sleep on if a OneNAND operation is in progress
* @param state [INTERN] the current state of the OneNAND device
* @param autooob [REPLACEABLE] the default (auto)placement scheme
* @param bbm [REPLACEABLE] pointer to Bad Block Management
* @param bbm [REPLACEABLE] pointer to Bad Block Management
* @param priv [OPTIONAL] pointer to private chip date
*/
struct
onenand_chip
{
...
...
include/linux/mtd/partitions.h
浏览文件 @
61ecfa87
...
...
@@ -5,7 +5,7 @@
*
* This code is GPL
*
* $Id: partitions.h,v 1.1
6 2004/11/16 18:34:40 dwmw2
Exp $
* $Id: partitions.h,v 1.1
7 2005/11/07 11:14:55 gleixner
Exp $
*/
#ifndef MTD_PARTITIONS_H
...
...
@@ -16,25 +16,25 @@
/*
* Partition definition structure:
*
*
* An array of struct partition is passed along with a MTD object to
* add_mtd_partitions() to create them.
*
* For each partition, these fields are available:
* name: string that will be used to label the partition's MTD device.
* size: the partition size; if defined as MTDPART_SIZ_FULL, the partition
* size: the partition size; if defined as MTDPART_SIZ_FULL, the partition
* will extend to the end of the master MTD device.
* offset: absolute starting position within the master MTD device; if
* defined as MTDPART_OFS_APPEND, the partition will start where the
* offset: absolute starting position within the master MTD device; if
* defined as MTDPART_OFS_APPEND, the partition will start where the
* previous one ended; if MTDPART_OFS_NXTBLK, at the next erase block.
* mask_flags: contains flags that have to be masked (removed) from the
* mask_flags: contains flags that have to be masked (removed) from the
* master MTD flag set for the corresponding MTD partition.
* For example, to force a read-only partition, simply adding
* For example, to force a read-only partition, simply adding
* MTD_WRITEABLE to the mask_flags will do the trick.
*
* Note: writeable partitions require their size and offset be
* Note: writeable partitions require their size and offset be
* erasesize aligned (e.g. use MTDPART_OFS_NEXTBLK).
*/
*/
struct
mtd_partition
{
char
*
name
;
/* identifier string */
...
...
@@ -66,7 +66,7 @@ struct mtd_part_parser {
extern
int
register_mtd_parser
(
struct
mtd_part_parser
*
parser
);
extern
int
deregister_mtd_parser
(
struct
mtd_part_parser
*
parser
);
extern
int
parse_mtd_partitions
(
struct
mtd_info
*
master
,
const
char
**
types
,
extern
int
parse_mtd_partitions
(
struct
mtd_info
*
master
,
const
char
**
types
,
struct
mtd_partition
**
pparts
,
unsigned
long
origin
);
#define put_partition_parser(p) do { module_put((p)->owner); } while(0)
...
...
include/linux/mtd/physmap.h
浏览文件 @
61ecfa87
/*
* For boards with physically mapped flash and using
* For boards with physically mapped flash and using
* drivers/mtd/maps/physmap.c mapping driver.
*
* $Id: physmap.h,v 1.
3 2004/07/21 00:16:15 jwboy
er Exp $
* $Id: physmap.h,v 1.
4 2005/11/07 11:14:55 gleixn
er Exp $
*
* Copyright (C) 2003 MontaVista Software Inc.
* Author: Jun Sun, jsun@mvista.com or jsun@junsun.net
...
...
@@ -18,7 +18,7 @@
#include <linux/config.h>
#if defined(CONFIG_MTD_PHYSMAP)
#if defined(CONFIG_MTD_PHYSMAP)
#include <linux/mtd/mtd.h>
#include <linux/mtd/map.h>
...
...
@@ -44,12 +44,12 @@ static inline void physmap_configure(unsigned long addr, unsigned long size, int
#if defined(CONFIG_MTD_PARTITIONS)
/*
* Machines that wish to do flash partition may want to call this function in
* their setup routine.
* Machines that wish to do flash partition may want to call this function in
* their setup routine.
*
* physmap_set_partitions(mypartitions, num_parts);
*
* Note that one can always override this hard-coded partition with
* Note that one can always override this hard-coded partition with
* command line partition (you need to enable CONFIG_MTD_CMDLINE_PARTS).
*/
void
physmap_set_partitions
(
struct
mtd_partition
*
parts
,
int
num_parts
);
...
...
include/linux/mtd/pmc551.h
浏览文件 @
61ecfa87
/*
* $Id: pmc551.h,v 1.
5 2003/01/24 16:49:53 dwmw2
Exp $
* $Id: pmc551.h,v 1.
6 2005/11/07 11:14:55 gleixner
Exp $
*
* PMC551 PCI Mezzanine Ram Device
*
...
...
@@ -7,7 +7,7 @@
* Mark Ferrell
* Copyright 1999,2000 Nortel Networks
*
* License:
* License:
* As part of this driver was derrived from the slram.c driver it falls
* under the same license, which is GNU General Public License v2
*/
...
...
@@ -17,7 +17,7 @@
#include <linux/mtd/mtd.h>
#define PMC551_VERSION "$Id: pmc551.h,v 1.
5 2003/01/24 16:49:53 dwmw2
Exp $\n"\
#define PMC551_VERSION "$Id: pmc551.h,v 1.
6 2005/11/07 11:14:55 gleixner
Exp $\n"\
"Ramix PMC551 PCI Mezzanine Ram Driver. (C) 1999,2000 Nortel Networks.\n"
/*
...
...
@@ -30,7 +30,7 @@ struct mypriv {
u32
curr_map0
;
u32
asize
;
struct
mtd_info
*
nextpmc551
;
};
};
/*
* Function Prototypes
...
...
@@ -39,7 +39,7 @@ static int pmc551_erase(struct mtd_info *, struct erase_info *);
static
void
pmc551_unpoint
(
struct
mtd_info
*
,
u_char
*
,
loff_t
,
size_t
);
static
int
pmc551_point
(
struct
mtd_info
*
mtd
,
loff_t
from
,
size_t
len
,
size_t
*
retlen
,
u_char
**
mtdbuf
);
static
int
pmc551_read
(
struct
mtd_info
*
,
loff_t
,
size_t
,
size_t
*
,
u_char
*
);
static
int
pmc551_write
(
struct
mtd_info
*
,
loff_t
,
size_t
,
size_t
*
,
const
u_char
*
);
static
int
pmc551_write
(
struct
mtd_info
*
,
loff_t
,
size_t
,
size_t
*
,
const
u_char
*
);
/*
...
...
@@ -50,7 +50,7 @@ static int pmc551_write(struct mtd_info *, loff_t, size_t, size_t *, const u_cha
#endif
#ifndef PCI_DEVICE_ID_V3_SEMI_V370PDC
#define PCI_DEVICE_ID_V3_SEMI_V370PDC 0x0200
#define PCI_DEVICE_ID_V3_SEMI_V370PDC 0x0200
#endif
...
...
include/linux/mtd/xip.h
浏览文件 @
61ecfa87
...
...
@@ -12,7 +12,7 @@
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* $Id: xip.h,v 1.
4 2005/10/17 21:03:16 nico
Exp $
* $Id: xip.h,v 1.
5 2005/11/07 11:14:55 gleixner
Exp $
*/
#ifndef __LINUX_MTD_XIP_H__
...
...
@@ -60,9 +60,9 @@
* overflowing.
*
* xip_iprefetch()
*
*
* Macro to fill instruction prefetch
* e.g. a series of nops: asm volatile (".rep 8; nop; .endr");
* e.g. a series of nops: asm volatile (".rep 8; nop; .endr");
*/
#include <asm/mtd-xip.h>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录