Hi Pekon,

On 05/20/2014 09:24 AM, Pekon Gupta wrote:
> This patch enables 'wait-pin' monitoring in NAND driver if following 
> properties
> are present under NAND DT node
>   gpmc,wait-pin = <wait-pin number>
>   gpmc,wait-on-read
>   gpmc,wait-on-write
> As NAND generic framework uses common path nand_chip->dev_ready() for 
> monitoring
> completion of Read and Write status, so wait-pin monitoring is enabled only 
> when
> *both* 'gpmc,wait-on-read' and 'gpmc,wait-on-write' are specified.
> 
> CC: [email protected]
> Signed-off-by: Pekon Gupta <[email protected]>
> ---
>  Documentation/devicetree/bindings/mtd/gpmc-nand.txt | 8 ++++++++
>  arch/arm/mach-omap2/gpmc-nand.c                     | 8 +++++---
>  2 files changed, 13 insertions(+), 3 deletions(-)
> 
> diff --git a/Documentation/devicetree/bindings/mtd/gpmc-nand.txt 
> b/Documentation/devicetree/bindings/mtd/gpmc-nand.txt
> index eb81435..4039032 100644
> --- a/Documentation/devicetree/bindings/mtd/gpmc-nand.txt
> +++ b/Documentation/devicetree/bindings/mtd/gpmc-nand.txt
> @@ -45,6 +45,14 @@ Optional properties:
>               ELM hardware engines should specify this device node in .dtsi
>               Using ELM for ECC error correction frees some CPU cycles.
>  
> + - gpmc,wait-pin=<pin number>        Specifies GPMC wait-pin number to 
> monitor
> + - gpmc,wait-on-read         Enable wait-pin monitoring for Read accesses
> + - gpmc,wait-on-write                Enable wait-pin monitoring for Write 
> accesses
> +             As NAND generic framework uses single common function
> +             nand_chip->dev_ready() for polling wait-pin both for Read and
> +             Write accesses. So for NAND devices both 'gpmc,wait-on-read' and
> +             'gpmc,wait-on-write' need to be specified together.
> +
>  For inline partiton table parsing (optional):
>  


>   - #address-cells: should be set to 1
> diff --git a/arch/arm/mach-omap2/gpmc-nand.c b/arch/arm/mach-omap2/gpmc-nand.c
> index 17cd393..62bc3de 100644
> --- a/arch/arm/mach-omap2/gpmc-nand.c
> +++ b/arch/arm/mach-omap2/gpmc-nand.c
> @@ -123,11 +123,13 @@ int gpmc_nand_init(struct omap_nand_platform_data 
> *gpmc_nand_data,
>               }
>       }
>  
> -     if (gpmc_nand_data->of_node)
> +     if (gpmc_nand_data->of_node) {
>               gpmc_read_settings_dt(gpmc_nand_data->of_node, &s);
> -     else
> +             if (s.wait_on_read && s.wait_on_write)
> +                     gpmc_nand_data->dev_ready = true;
> +     } else {
>               gpmc_set_legacy(gpmc_nand_data, &s);
> -
> +     }
>       s.device_nand = true;

NACK.

For NAND, we only need the wait-pin property. The wait-on-read/wait-on-write 
flags are meaningless.
Also, the wait-pin number needs to be communicated to the NAND driver and 
omap_dev_ready() function updated so that it checks for the right wait pin 
status.

>  
>       err = gpmc_cs_program_settings(gpmc_nand_data->cs, &s);
> 

cheers,
-roger
--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to