[PATCH v8 0/3] add the GPMI controller driver for IMX23/IMX28

Koen Beel koen.beel.barco at gmail.com
Thu Jul 28 05:38:43 EDT 2011


Hi,

I have test on mx23evk board. Still see the same issues.

On Wed, Jul 27, 2011 at 3:53 AM, Huang Shijie <b32955 at freescale.com> wrote:
> Hi,
>
> Thanks for your test.
>
>> Hi,
>>
>> It's not really working for me.
>> I've applied all gpmi-nand driver patches and the dma driver patches.
>>
>> I have added following kernel parameters:
>> mtdparts=gpmi-nand:20m(boot),-(user) ubi.mtd=1 root=ubi0:rootfs0
>> rootfstype=ubifs gpmi_debug_init
>>
>> During boot I get already get DMA timeout:
>> [    2.560000] [ start_dma_without_bch_irq : 392 ] DMA timeout, last DMA
>> :1
>> [    3.560000] [ start_dma_with_bch_irq : 427 ] bch timeout!!!
>> ...
>> (see log file in attach line 89)

I still see this DMA timeout when booting.
What kernel parameters do you use? I still use same as above.

>>
>> When trying flash_erraseall /dev/mtd1 I get:
>> Erasing 128 Kibyte @ 20000 --  0 % complete [   16.700000] [
>> gpmi_read_data : 832 ] step 1 error
>> [   16.700000] [ gpmi_send_command : 749 ] step 1 error
>> [   16.700000] [ mil_cmd_ctrl : 894 ] Chip: 0, Error -1
>> [   16.700000] [ gpmi_send_command : 749 ] step 1 error
>> [   16.700000] [ mil_cmd_ctrl : 894 ] Chip: 0, Error -1
>> [   16.700000] [ gpmi_send_command : 749 ] step 1 error
>> [   16.700000] [ mil_cmd_ctrl : 894 ] Chip: 0, Error -1
>> [   16.700000] [ gpmi_read_data : 832 ] step 1 error
>> libmtd: error!: MEMERA[   16.740000] [ gpmi_send_command : 749 ] step 1
>> error
>> SE64 ioctl failed for eraseblock[   16.750000] [ mil_cmd_ctrl : 894 ]
>> Chip: 0, Error -1
>>  1 (mtd1)
>>         error 5 (Input/output error)
>> flash_erase: error!: /dev/mtd1: MTD Erase failure
>>              error 5 (Input/output error)
>> ...
>> (see log file in attach line 128 and further)

Also still same issue here.

>>
>> Environment:
>> - patches on a 2.6.39.1 kernel (needed to modify the patch a little
>> for changed mtd add/del interface).
>
> Please test the driver on :
>  git://git.linaro.org/people/shawnguo/linux-2.6.git mxs-gpmi

I have used this branch.

>
> or on
>
>  git://git.pengutronix.de/git/imx/linux-2.6.git  imx-for-3.1
>
>
>
> I found the .config may influence the DMA.
> I guess there is some module which has impact to the DMA.
> So You should use the right .config first, you can get the right
> .config by two ways:
> [1] use the 'make mxs_defconfig' in the imx-for-3.1 branch of
>  tree: git://git.pengutronix.de/git/imx/linux-2.6.git
>
> [2] use the attachment which is tested by me.

I have used this config file. Only thing changed to the config file is
(uboot savenv not working):
CONFIG_CMDLINE="console=ttyAMA0,115200
mtdparts=gpmi-nand:20m(boot),-(user) ubi.mtd=1 root=ubi0:rootfs0
rootfstype=ubifs gpmi_debug_init"
CONFIG_CMDLINE_FORCE=y


br,
Koen

>
> Best Regards
> Huang Shijie
>
>
>
>> - using this on our own mx23 based board, so also added some board
>> init code for that.
>>
>>
>> On Fri, Jul 22, 2011 at 10:07 AM, Huang Shijie<b32955 at freescale.com>
>>  wrote:
>>>
>>> Hi Wolfram:
>>>>
>>>> On Fri, Jul 22, 2011 at 11:30:41AM +0800, Huang Shijie wrote:
>>>>>
>>>>> Hi,
>>>>>>>
>>>>>>> The general-purpose media interface(GPMI) controller is a flexible
>>>>>>> interface
>>>>>>> to up to several NAND flashs.
>>>>>>
>>>>>> ...
>>>>>>>
>>>>>>> To Walfram&    Artem:
>>>>>>>     About how to disable the JFFS2 to use the OOB:
>>>>>>>     I read the code, and I still have no idea about how to use the
>>>>>>> ecclayout
>>>>>>>     to do the job. Could you give me some hint? thanks.
>>>>>>
>>>>>> Have you checked mxc_nand.c for example? There is
>>>>>>
>>>>>> static struct nand_ecclayout nandv1_hw_eccoob_smallpage = {
>>>>>>         .eccbytes = 5,
>>>>>>         .eccpos = {6, 7, 8, 9, 10},
>>>>>>         .oobfree = {{0, 5}, {12, 4}, }
>>>>>> }
>>>>>>
>>>>>> defined as one layout. Now, you could define one where oobfree is
>>>>>> empty
>>>>>> and
>>>>>> eccbytes as big as the oob-area.
>>>>>>
>>>>> thanks. I will check the code.
>>>>>>>
>>>>>>> The driver depends on another GPMI-NAND device patch set, you can
>>>>>>> find
>>>>>>> them at :
>>>>>>>        [1]
>>>>>>> http://lists.infradead.org/pipermail/linux-mtd/2011-July/037033.html
>>>>>>>        [2]
>>>>>>> http://lists.infradead.org/pipermail/linux-mtd/2011-July/037031.html
>>>>>>>        [3]
>>>>>>> http://lists.infradead.org/pipermail/linux-mtd/2011-July/037032.html
>>>>>>>        [4]
>>>>>>> http://lists.infradead.org/pipermail/linux-mtd/2011-July/037034.html
>>>>>>>
>>>>>>> The driver also depends on another DMA patch by Shawn:
>>>>>>>        [0]
>>>>>>> http://lists.infradead.org/pipermail/linux-mtd/2011-June/036820.html
>>>>>>
>>>>>> This makes it difficult for testers/reviewers. Please try to get a
>>>>>> git-branch
>>>>>> from Freescale or Linaro.
>>>>>>
>>>>> Shawn will merge my patches to his Linaro branch.
>>
>> I don't see the DMA patch in the git?
>>
>>>> git://git.linaro.org/people/shawnguo/linux-2.6.git mxs-gpmi
>>>
>>> Please test the GPMI driver based this git tree.
>>
>> I will try that on an mx23evk board.
>>
>>> I tested, and the DMA-timeout does not occur any more.
>>>
>>> I notice that Shawn added two more patched to
>>> /arch/arm/config/mxs_defconfig:
>>> [1] ARM: mxs_defconfig: Add mx23evk and mx28evk build
>>> [2] ARM: mxs_defconfig: Change CONFIG_RTC_CLASS 'm' to 'y'
>>>
>>> Please check it. Maybe your kernel code misses them.
>>
>> I don't see any of this in the git?
>>
>>> Of course, you can use the my_config (i sent you last mail) for .config.
>>>
>>> Best Regards
>>> Huang Shijie
>>>
>>>
>>>> Shijie, please check and test it.  I only did a build test.
>>>>
>>>
>>>
>>> _______________________________________________
>>> linux-arm-kernel mailing list
>>> linux-arm-kernel at lists.infradead.org
>>> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
>>>
>
>



More information about the linux-mtd mailing list