Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
3c146e8d
Commit
3c146e8d
authored
Jun 08, 2004
by
David Woodhouse
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add WindRiver PowerQUICC II flash map driver
parent
fe5d106d
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
176 additions
and
0 deletions
+176
-0
drivers/mtd/maps/Kconfig
drivers/mtd/maps/Kconfig
+8
-0
drivers/mtd/maps/Makefile
drivers/mtd/maps/Makefile
+1
-0
drivers/mtd/maps/wr_sbc82xx_flash.c
drivers/mtd/maps/wr_sbc82xx_flash.c
+167
-0
No files found.
drivers/mtd/maps/Kconfig
View file @
3c146e8d
...
@@ -489,5 +489,13 @@ config MTD_UCLINUX
...
@@ -489,5 +489,13 @@ config MTD_UCLINUX
help
help
Map driver to support image based filesystems for uClinux.
Map driver to support image based filesystems for uClinux.
config MTD_WRSBC8260
tristate "Map driver for WindRiver PowerQUICC II MPC82xx board"
depends on MTD_PARTITIONS && SBC82xx
help
Map driver for WindRiver PowerQUICC II MPC82xx board. Drives
all three flash regions on CS0, CS1 and CS6 if they are configured
correctly by the boot loader.
endmenu
endmenu
drivers/mtd/maps/Makefile
View file @
3c146e8d
...
@@ -56,3 +56,4 @@ obj-$(CONFIG_MTD_BEECH) += beech-mtd.o
...
@@ -56,3 +56,4 @@ obj-$(CONFIG_MTD_BEECH) += beech-mtd.o
obj-$(CONFIG_MTD_ARCTIC)
+=
arctic-mtd.o
obj-$(CONFIG_MTD_ARCTIC)
+=
arctic-mtd.o
obj-$(CONFIG_MTD_H720X)
+=
h720x-flash.o
obj-$(CONFIG_MTD_H720X)
+=
h720x-flash.o
obj-$(CONFIG_MTD_IXP4XX)
+=
ixp4xx.o
obj-$(CONFIG_MTD_IXP4XX)
+=
ixp4xx.o
obj-$(CONFIG_MTD_WRSBC8260)
+=
wr_sbc82xx_flash.o
drivers/mtd/maps/wr_sbc82xx_flash.c
0 → 100644
View file @
3c146e8d
/*
* $Id: wr_sbc82xx_flash.c,v 1.1 2004/06/07 10:21:32 dwmw2 Exp $
*
* Map for flash chips on Wind River PowerQUICC II SBC82xx board.
*
* Copyright (C) 2004 Red Hat, Inc.
*
* Author: David Woodhouse <dwmw2@infradead.org>
*
*/
#include <linux/module.h>
#include <linux/types.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/slab.h>
#include <asm/io.h>
#include <linux/mtd/mtd.h>
#include <linux/mtd/map.h>
#include <linux/config.h>
#include <linux/mtd/partitions.h>
#include <asm/immap_8260.h>
static
struct
mtd_info
*
sbcmtd
[
3
];
static
struct
mtd_partition
*
sbcmtd_parts
[
3
];
struct
map_info
sbc82xx_flash_map
[
3
]
=
{
{.
name
=
"Boot flash"
},
{.
name
=
"Alternate boot flash"
},
{.
name
=
"User flash"
}
};
static
struct
mtd_partition
smallflash_parts
[]
=
{
{
.
name
=
"space"
,
.
size
=
0x100000
,
.
offset
=
0
,
},
{
.
name
=
"bootloader"
,
.
size
=
MTDPART_SIZ_FULL
,
.
offset
=
MTDPART_OFS_APPEND
,
}
};
static
struct
mtd_partition
bigflash_parts
[]
=
{
{
.
name
=
"bootloader"
,
.
size
=
0x80000
,
.
offset
=
0
,
},
{
.
name
=
"file system"
,
.
size
=
MTDPART_SIZ_FULL
,
.
offset
=
MTDPART_OFS_APPEND
,
}
};
static
const
char
*
part_probes
[]
__initdata
=
{
"cmdlinepart"
,
"RedBoot"
,
NULL
};
int
__init
init_sbc82xx_flash
(
void
)
{
volatile
memctl8260_t
*
mc
=
&
immr
->
im_memctl
;
int
bigflash
;
int
i
;
/* First, register the boot flash, whichever we're booting from */
if
((
mc
->
memc_br0
&
0x00001800
)
==
0x00001800
)
{
bigflash
=
0
;
}
else
if
((
mc
->
memc_br0
&
0x00001800
)
==
0x00000800
)
{
bigflash
=
1
;
}
else
{
printk
(
KERN_WARNING
"Bus Controller register BR0 is %08x. Cannot determine flash configuration
\n
"
,
mc
->
memc_br0
);
return
1
;
}
/* Set parameters for the big flash chip (CS6 or CS0) */
sbc82xx_flash_map
[
bigflash
].
buswidth
=
4
;
sbc82xx_flash_map
[
bigflash
].
size
=
0x4000000
;
/* Set parameters for the small flash chip (CS0 or CS6) */
sbc82xx_flash_map
[
!
bigflash
].
buswidth
=
1
;
sbc82xx_flash_map
[
!
bigflash
].
size
=
0x200000
;
/* Set parameters for the user flash chip (CS1) */
sbc82xx_flash_map
[
2
].
buswidth
=
4
;
sbc82xx_flash_map
[
2
].
size
=
0x4000000
;
sbc82xx_flash_map
[
0
].
phys
=
mc
->
memc_br0
&
0xffff8000
;
sbc82xx_flash_map
[
1
].
phys
=
mc
->
memc_br6
&
0xffff8000
;
sbc82xx_flash_map
[
2
].
phys
=
mc
->
memc_br1
&
0xffff8000
;
for
(
i
=
0
;
i
<
3
;
i
++
)
{
int8_t
flashcs
[
3
]
=
{
0
,
6
,
1
};
int
nr_parts
;
printk
(
KERN_NOTICE
"PowerQUICC II %s (%ld MiB on CS%d"
,
sbc82xx_flash_map
[
i
].
name
,
sbc82xx_flash_map
[
i
].
size
>>
20
,
flashcs
[
i
]);
if
(
!
sbc82xx_flash_map
[
i
].
phys
)
{
/* We know it can't be at zero. */
printk
(
"): disabled by bootloader.
\n
"
);
continue
;
}
printk
(
" at %08lx)
\n
"
,
sbc82xx_flash_map
[
i
].
phys
);
sbc82xx_flash_map
[
i
].
virt
=
(
unsigned
long
)
ioremap
(
sbc82xx_flash_map
[
i
].
phys
,
sbc82xx_flash_map
[
i
].
size
);
if
(
!
sbc82xx_flash_map
[
i
].
virt
)
{
printk
(
"Failed to ioremap
\n
"
);
continue
;
}
simple_map_init
(
&
sbc82xx_flash_map
[
i
]);
sbcmtd
[
i
]
=
do_map_probe
(
"cfi_probe"
,
&
sbc82xx_flash_map
[
i
]);
if
(
!
sbcmtd
[
i
])
continue
;
sbcmtd
[
i
]
->
owner
=
THIS_MODULE
;
nr_parts
=
parse_mtd_partitions
(
sbcmtd
[
i
],
part_probes
,
&
sbcmtd_parts
[
i
],
0
);
if
(
nr_parts
>
0
)
{
add_mtd_partitions
(
sbcmtd
[
i
],
sbcmtd_parts
[
i
],
nr_parts
);
continue
;
}
/* No partitioning detected. Use default */
if
(
i
==
2
)
{
add_mtd_device
(
sbcmtd
[
i
]);
}
else
if
(
i
==
bigflash
)
{
add_mtd_partitions
(
sbcmtd
[
i
],
bigflash_parts
,
ARRAY_SIZE
(
bigflash_parts
));
}
else
{
add_mtd_partitions
(
sbcmtd
[
i
],
smallflash_parts
,
ARRAY_SIZE
(
smallflash_parts
));
}
}
return
0
;
}
static
void
__exit
cleanup_sbc82xx_flash
(
void
)
{
int
i
;
for
(
i
=
0
;
i
<
3
;
i
++
)
{
if
(
!
sbcmtd
[
i
])
continue
;
if
(
i
<
2
||
sbcmtd_parts
[
i
])
del_mtd_partitions
(
sbcmtd
[
i
]);
else
del_mtd_device
(
sbcmtd
[
i
]);
kfree
(
sbcmtd_parts
[
i
]);
map_destroy
(
sbcmtd
[
i
]);
iounmap
((
void
*
)
sbc82xx_flash_map
[
i
].
virt
);
sbc82xx_flash_map
[
i
].
virt
=
0
;
}
}
module_init
(
init_sbc82xx_flash
);
module_exit
(
cleanup_sbc82xx_flash
);
MODULE_LICENSE
(
"GPL"
);
MODULE_AUTHOR
(
"David Woodhouse <dwmw2@infradead.org>"
);
MODULE_DESCRIPTION
(
"Flash map driver for WindRiver PowerQUICC II"
);
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment