nand driver help

Mike Rapoport mike at compulab.co.il
Wed Apr 1 11:19:44 EDT 2009



bzachar at direkt-kfki.hu wrote:
>>
>> 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;
>>         }
>>
> 
> Firstly, many thanks for your help!
> 
> I modified your code to this (the modification based on the orig (2.6.16)
> driver):
>         if (ctrl & NAND_CTRL_CHANGE) {
>                 if ( ctrl & NAND_ALE )
>                         chip->IO_ADDR_W = bdevelb_ALE_io_base;
>                 else
>                 if ( ctrl & NAND_CLE )
>                         chip->IO_ADDR_W = bdevelb_CLE_io_base;
>                 else
>                         chip->IO_ADDR_W = bdevelb_io_base;
> 
> For the first look, it works, but I will make a complete test at tomarrow...
> What do you think about this code?

seems Ok.

> regars,
> Balazs Zachar
> 
> 
>>> }
>>>
>>> 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.
>>
>>
> 
> 
> 

-- 
Sincerely yours,
Mike.




More information about the linux-mtd mailing list