[PATCH] MTD Maps driver for Sharp LH7a40x
Thomas Gleixner
tglx at linutronix.de
Sat Jun 19 04:19:09 EDT 2004
On Saturday 19 June 2004 02:38, Marc Singer wrote:
> > The common case can just be solved by using the physmap driver and the
> > command line partition parser. Maybe we should think about an extension
> > to physmap so the board support code can supply an appropriate
> > partitioning scheme along with the chip description.
> >
> > I was thinking about simliar support for the NAND driver too, but there
> > it turns out that the anomalities are given per design, although it
> > should not be an unsolvable problem.
>
> I've chatted with Russell King about this, too. I think we agree that
> board-specific code would be a bad idea. The better solution appears
> to be something on the command line. I'm going to look into it. For
> now, consider this PATCH discarded.
Yes, for the common case where we dont have special functions neccecary the
commandline resp. ATAG (unfortunately only for ARM) is the right place.
This works if the only information which is neccecary is
base address, size and buswidth.
Russell, can you please give define two ATAG numbers for this purpose ?
ATAG_MTD_PHYSMAP and
ATAG_MTD_PARTITION
I would be happy to provide the data structures and parsers to make this work.
BUT,
For chips which need Vpp setting for programming and erasing this is rather
impossible. Same applies to NAND drivers, as the NAND interface can hardly be
specified board independent on the commandline.
For general purpose boards (PCI, PC104 whatever) drivers/mtd/ is surely the
right place. For embedded boards I'm not sure if it makes sense to have all
this code in the mtd subsystem or if it would be better to have this in the
board specific code in arch/xxx/boards/myboard.c which is there anyway.
Another possiblity would be to include a hardware related header file in the
physmap driver and the to be written counterpart for NAND.
#define BOARD_SPECIFIC_MTD_FUNCTIONS
#include <asm/hardware.h>
asm/hardware.h includes board_hardware.h if available.
Inside board_hardware.h then we would have
#ifdef BOARD_SPECIFIC_MTD_FUNCTIONS
board_mtd_functionA(){}
board_mtd_functionB(){}
(nand)pyhsmap chip = {
.address = xxxx;
.....
.functionA = board_mtd_functionA;
.functionA = board_mtd_functionB;
}
#endif
Not all arch's provide a hardware.h file but this should be a solvable
problem. For ARM this should work right out of the box.
I know it looks weird in the first place, but it could be one of the possible
solutions to solve the board support mess. Russell uses a similar approach
for the timer init and interrupt handler for the various subarchs of ARM
since long.
Any thoughts ?
--
Thomas
_____________________________________________________________________
From slash dot org
"When customers are visiting, engineers are not allowed to wear ties.
That way the customer can tell who is the engineer and who is the
salesman (and therefore whom to believe.). Ties cut off blood flow
to the brain, making it easier for the salesmen to do their jobs."
_____________________________________________________________________
linutronix - competence in embedded & realtime linux
http://www.linutronix.de
mail: tglx at linutronix.de
More information about the linux-mtd
mailing list