[PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND

Daniel Mack zonque at gmail.com
Fri Nov 30 02:07:20 EST 2012


On 29.11.2012 15:59, Philip, Avinash wrote:
> On Thu, Nov 29, 2012 at 18:11:42, Daniel Mack wrote:
>> On 29.11.2012 13:36, Philip, Avinash wrote:
>>> On Wed, Nov 28, 2012 at 22:28:59, Daniel Mack wrote:
>>> [...]
>>>> +	if (!of_property_read_string(child, "ti,nand-ecc-opt", &s)) {
>>>> +		for (val = 0; val < ARRAY_SIZE(nand_ecc_opts); val++)
>>>> +			if (!strcasecmp(s, nand_ecc_opts[val])) {
>>>> +				gpmc_nand_data->ecc_opt = val;
>>>> +				break;
>>>> +			}
>>>> +
>>>> +		/*
>>>> +		 *  AM335x RBL compatibility mode - dependns on runtime
>>>> +		 * detection of the error location module.
>>>> +		 */
>>>> +		if (!strcasecmp(s, "bch8-am335xrbl-compatible")) {
>>>> +			gpmc_nand_data->ecc_opt = OMAP_ECC_BCH8_CODE_HW;
>>>> +			gpmc_nand_data->is_elm_used = true;
>>>
>>> Remove is_elm_used from struct omap_nand_platform_data. Now this data
>>> populated as part of run time detection of elm module. So please remove
>>> The usage of is_elm_used;
>>
>> So why do we need "bch8-am335xrbl-compatible" as special case then?
>>
>> I thought the whole idea here is to tell the driver we want bch8 *and*
>> the usage of the elm, instead of falling back to the (incompatible)
>> software mode? If I remove that assignment, "bch8-am335xrbl-compatible"
>> is the same than "bch8".
>>
> 
> Here we have different problems present. 
> 1. GPMC-NAND DT binding support.
> 2. Compatible ECC layout between kernel, boot loader.
> 3. Support for hardware accelerator, i.e ELM for error correction.
> 
> So priority should go for GPMC DT binding support. 
> Can you please proceed with GPMC-NAND DT bindings without considering
> ELM so that driver features existing can be obtained with DT.
> 
> I will take care of ECC layout (or RBL) compatibility along with ELM
> series. I will make ELM series on top of your changes. This way we can
> avoid circular dependency

Ok, fair enough. I'll drop "bch8-am335xrbl-compatible" from the list
again and only care for those that are present in the enum.

Before I send the patches again, could you quickly state which
repository they will go through? I'll make sure there are no conflicts
when applying.

>> Which detail am I missing? :)
> 
> I think what you need is NAND ECC layout to be common across Kernel and
> boot loader. Strictly speaking ELM is not a necessity for it. The common
> layout can be obtained even without presence of ELM, ELM is only a hardware
> accelerator for error correction. If ELM is not used, we can rely on software
> error correction, at least theoretically. But the way software error correction
> is handled currently in omap nand driver will not help us as ecc layout assumed
> is different.

Yes, understood, hence I need some workaround for now, which I can
happily keep in my local branch.


Thanks,
Daniel



More information about the devicetree-discuss mailing list