nand driver help
Mike Rapoport
mike at compulab.co.il
Mon Mar 30 02:35:26 EDT 2009
Zachár Balázs wrote:
> Hi,
>
> I have a pxa270 based board, and I try to create the nand driver for the 2.6.28-7 main kernel... On this board, the nand flash is connected directly to the pxa27x PCMCIA socket's pins... (see this
> pdf: http://pubs.gumstix.org/documents/PXA%20Documentation/PXA270/PXA270%20Connecting%20NAND%20Flash%20%5B28014402%5D.pdf)
>
[ snip ]
>
> On my board the NAND AL signal is connected to MA20 so if I "access" to 0x2010_0000 (PCMCIA0 address: 0x2000_0000) it should decoded as AL=1 operation.
> If I right, if I "access" to the PCMCIA1 address (PCMCIA1 address: 0x3000_0000) it should decoded as a CL=1 operation.
> The R/Bn (ready_notbusy) signal is connected to GPIO55 and the WP signal is connected to GPIO56.
>
> I write this hwcontrol function for my board's cmd_crtl function, but I think it isn't work(bdevelb_ALE_io_base=ioremap(0x20100000, 0x1000),bdevelb_CLE_io_base=ioremap(0x30000000, 0x1000)):
> static void bdevelb_nand_hwcontrol(struct mtd_info *mtd, int cmd, unsigned int ctrl)
> {
> struct nand_chip *chip = mtd->priv;
>
> if (ctrl & NAND_CTRL_CHANGE) {
> if ( ctrl & NAND_ALE )
> writeb(0xff, bdevelb_ALE_io_base);
> if ( ctrl & NAND_CLE )
> writeb(0xff, bdevelb_CLE_io_base);
> }
>
> if (cmd != NAND_CMD_NONE)
> writeb(cmd, chip->IO_ADDR_W);
You should set chip->IO_ADDW_W to either bdevelb_ALE_io_base or
bdevelb_CLE_io_base, depending on the ctrl value:
if (ctrl & NAND_CTRL_CHANGE) {
if ( ctrl & NAND_ALE )
chip->IO_ADDR_W = bdevelb_ALE_io_base;
if ( ctrl & NAND_CLE )
chip->IO_ADDR_W = bdevelb_CLE_io_base;
}
> }
>
> Is this function good for this connection scheme?
> What is it mean "access" to an address? Can be enough a readb funtion?
>
> regards,
> Balazs
>
>
>
> ______________________________________________________
> Linux MTD discussion mailing list
> http://lists.infradead.org/mailman/listinfo/linux-mtd/
>
--
Sincerely yours,
Mike.
More information about the linux-mtd
mailing list