All of lore.kernel.org
 help / color / mirror / Atom feed
From: Govindraj <govindraj.ti@gmail.com>
To: Vimal Singh <vimal.newwork@gmail.com>
Cc: linux-omap@vger.kernel.org, Tony Lindgren <tony@atomide.com>,
	Linux MTD <linux-mtd@lists.infradead.org>
Subject: Re: [PATCH 2/2]: Introducing 'gpmc-nand.c' for GPMC specific NAND init
Date: Fri, 4 Dec 2009 19:00:48 +0530	[thread overview]
Message-ID: <d6a0f7aa0912040530o72d16979m4c785c2f9cda150c@mail.gmail.com> (raw)
In-Reply-To: <ce9ab5790912040514n238fd080g722f42b426bb6b1b@mail.gmail.com>

This patch got line wrapped.

-- 
---
Regards,
Govindraj.R


On Fri, Dec 4, 2009 at 6:44 PM, Vimal Singh <vimal.newwork@gmail.com> wrote:
> Ahh.. this is my bad.
>
> [...]
>> +       err = gpmc_nand_setup((void __iomem *)
>> +                                       &gpmc_nand_data->gpmc_cs_baseaddr);
> we just do not need casting here.
>
> Apologies for making noise and confusion.
> Please take this one.
>
> -vimal
>
> From e024a2e6aa2051259ad904daff13bdac73b3b1b8 Mon Sep 17 00:00:00 2001
> From: Vimal Singh <vimalsingh@ti.com>
> Date: Wed, 25 Nov 2009 18:23:15 +0530
> Subject: [PATCH] Introducing 'gpmc-nand.c' for GPMC specific NAND init
>
> Introducing 'gpmc-nand.c' for GPMC specific NAND init.
> For example: GPMC timing parameters and all.
> This patch also migrates gpmc related calls from 'nand/omap2.c'
> to 'gpmc-nand.c'.
>
> Signed-off-by: Vimal Singh <vimalsingh@ti.com>
> ---
>  arch/arm/mach-omap2/Makefile           |    3 +
>  arch/arm/mach-omap2/gpmc-nand.c        |  141 ++++++++++++++++++++++++++++++++
>  arch/arm/plat-omap/include/plat/nand.h |    6 ++
>  drivers/mtd/nand/omap2.c               |   26 +-----
>  4 files changed, 153 insertions(+), 23 deletions(-)
>  create mode 100644 arch/arm/mach-omap2/gpmc-nand.c
>
> diff --git a/arch/arm/mach-omap2/Makefile b/arch/arm/mach-omap2/Makefile
> index 59b0ccc..0dfe27a 100644
> --- a/arch/arm/mach-omap2/Makefile
> +++ b/arch/arm/mach-omap2/Makefile
> @@ -103,5 +103,8 @@ obj-y                                       += usb-ehci.o
>  onenand-$(CONFIG_MTD_ONENAND_OMAP2)    := gpmc-onenand.o
>  obj-y                                  += $(onenand-m) $(onenand-y)
>
> +nand-$(CONFIG_MTD_NAND_OMAP2)          := gpmc-nand.o
> +obj-y                                  += $(nand-m) $(nand-y)
> +
>  smc91x-$(CONFIG_SMC91X)                        := gpmc-smc91x.o
>  obj-y                                  += $(smc91x-m) $(smc91x-y)
> diff --git a/arch/arm/mach-omap2/gpmc-nand.c b/arch/arm/mach-omap2/gpmc-nand.c
> new file mode 100644
> index 0000000..0621e39
> --- /dev/null
> +++ b/arch/arm/mach-omap2/gpmc-nand.c
> @@ -0,0 +1,141 @@
> +/*
> + * gpmc-nand.c
> + *
> + * Copyright (C) 2009 Texas Instruments
> + * Vimal Singh <vimalsingh@ti.com>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License version 2 as
> + * published by the Free Software Foundation.
> + */
> +
> +#include <linux/kernel.h>
> +#include <linux/platform_device.h>
> +#include <linux/io.h>
> +
> +#include <asm/mach/flash.h>
> +
> +#include <plat/nand.h>
> +#include <plat/board.h>
> +#include <plat/gpmc.h>
> +
> +#define WR_RD_PIN_MONITORING   0x00600000
> +
> +static struct omap_nand_platform_data *gpmc_nand_data;
> +
> +static struct resource gpmc_nand_resource = {
> +       .flags          = IORESOURCE_MEM,
> +};
> +
> +static struct platform_device gpmc_nand_device = {
> +       .name           = "omap2-nand",
> +       .id             = 0,
> +       .num_resources  = 1,
> +       .resource       = &gpmc_nand_resource,
> +};
> +
> +static int omap2_nand_gpmc_config(int cs, void __iomem *nand_base)
> +{
> +       struct gpmc_timings t;
> +       int err;
> +
> +       const int cs_rd_off = 36;
> +       const int cs_wr_off = 36;
> +       const int adv_on = 6;
> +       const int adv_rd_off = 24;
> +       const int adv_wr_off = 36;
> +       const int oe_off = 48;
> +       const int we_off = 30;
> +       const int rd_cycle = 72;
> +       const int wr_cycle = 72;
> +       const int access = 54;
> +       const int wr_data_mux_bus = 8;
> +       const int wr_access = 30;
> +
> +       memset(&t, 0, sizeof(t));
> +       t.sync_clk = 0;
> +       t.cs_on = 0;
> +       t.adv_on = gpmc_round_ns_to_ticks(adv_on);
> +
> +       /* Read */
> +       t.adv_rd_off = gpmc_round_ns_to_ticks(adv_rd_off);
> +       t.oe_on  = t.adv_on;
> +       t.access = gpmc_round_ns_to_ticks(access);
> +       t.oe_off = gpmc_round_ns_to_ticks(oe_off);
> +       t.cs_rd_off = gpmc_round_ns_to_ticks(cs_rd_off);
> +       t.rd_cycle  = gpmc_round_ns_to_ticks(rd_cycle);
> +
> +       /* Write */
> +       t.adv_wr_off = gpmc_round_ns_to_ticks(adv_wr_off);
> +       t.we_on  = t.oe_on;
> +       if (cpu_is_omap34xx()) {
> +               t.wr_data_mux_bus = gpmc_round_ns_to_ticks(wr_data_mux_bus);
> +               t.wr_access = gpmc_round_ns_to_ticks(wr_access);
> +       }
> +       t.we_off = gpmc_round_ns_to_ticks(we_off);
> +       t.cs_wr_off = gpmc_round_ns_to_ticks(cs_wr_off);
> +       t.wr_cycle  = gpmc_round_ns_to_ticks(wr_cycle);
> +
> +       /* Configure GPMC */
> +       gpmc_cs_write_reg(cs, GPMC_CS_CONFIG1,
> +                       GPMC_CONFIG1_DEVICESIZE(gpmc_nand_data->devsize) |
> +                       GPMC_CONFIG1_DEVICETYPE_NAND);
> +
> +       err = gpmc_cs_set_timings(cs, &t);
> +       if (err)
> +               return err;
> +
> +       return 0;
> +}
> +
> +static int gpmc_nand_setup(void __iomem *nand_base)
> +{
> +       struct device *dev = &gpmc_nand_device.dev;
> +
> +       /* Set timings in GPMC */
> +       if (omap2_nand_gpmc_config(gpmc_nand_data->cs, nand_base) < 0) {
> +               dev_err(dev, "Unable to set gpmc timings\n");
> +               return -EINVAL;
> +       }
> +
> +       return 0;
> +}
> +
> +int __init gpmc_nand_init(struct omap_nand_platform_data *_nand_data)
> +{
> +       unsigned int val;
> +       int err = 0;
> +       struct device *dev = &gpmc_nand_device.dev;
> +
> +       gpmc_nand_data = _nand_data;
> +       gpmc_nand_data->nand_setup = gpmc_nand_setup;
> +       gpmc_nand_device.dev.platform_data = gpmc_nand_data;
> +
> +       err = gpmc_nand_setup(gpmc_nand_data->gpmc_cs_baseaddr);
> +       if (err < 0) {
> +               dev_err(dev, "NAND platform setup failed: %d\n", err);
> +               return err;
> +       }
> +
> +       /* Enable RD PIN Monitoring Reg */
> +       if (gpmc_nand_data->dev_ready) {
> +               val  = gpmc_cs_read_reg(gpmc_nand_data->cs,
> +                                                GPMC_CS_CONFIG1);
> +               val |= WR_RD_PIN_MONITORING;
> +               gpmc_cs_write_reg(gpmc_nand_data->cs,
> +                                               GPMC_CS_CONFIG1, val);
> +       }
> +
> +       val  = gpmc_cs_read_reg(gpmc_nand_data->cs, GPMC_CS_CONFIG7);
> +       val &= ~(0xf << 8);
> +       val |=  (0xc & 0xf) << 8;
> +       gpmc_cs_write_reg(gpmc_nand_data->cs, GPMC_CS_CONFIG7, val);
> +
> +       err = platform_device_register(&gpmc_nand_device);
> +       if (err < 0) {
> +               dev_err(dev, "Unable to register NAND device\n");
> +               return err;
> +       }
> +
> +       return 0;
> +}
> diff --git a/arch/arm/plat-omap/include/plat/nand.h
> b/arch/arm/plat-omap/include/plat/nand.h
> index 631a7be..2ba9842 100644
> --- a/arch/arm/plat-omap/include/plat/nand.h
> +++ b/arch/arm/plat-omap/include/plat/nand.h
> @@ -21,4 +21,10 @@ struct omap_nand_platform_data {
>        int                     dma_channel;
>        void __iomem            *gpmc_cs_baseaddr;
>        void __iomem            *gpmc_baseaddr;
> +       int                     devsize;
>  };
> +
> +/* size (4 KiB) for IO mapping */
> +#define        NAND_IO_SIZE    SZ_4K
> +
> +extern int gpmc_nand_init(struct omap_nand_platform_data *d);
> diff --git a/drivers/mtd/nand/omap2.c b/drivers/mtd/nand/omap2.c
> index 1bb799f..aaef170 100644
> --- a/drivers/mtd/nand/omap2.c
> +++ b/drivers/mtd/nand/omap2.c
> @@ -30,12 +30,8 @@
>
>  #define        DRIVER_NAME     "omap2-nand"
>
> -/* size (4 KiB) for IO mapping */
> -#define        NAND_IO_SIZE    SZ_4K
> -
>  #define        NAND_WP_OFF     0
>  #define NAND_WP_BIT    0x00000010
> -#define WR_RD_PIN_MONITORING   0x00600000
>
>  #define        GPMC_BUF_FULL   0x00000001
>  #define        GPMC_BUF_EMPTY  0x00000000
> @@ -882,8 +878,6 @@ static int __devinit omap_nand_probe(struct
> platform_device *pdev)
>        struct omap_nand_info           *info;
>        struct omap_nand_platform_data  *pdata;
>        int                             err;
> -       unsigned long                   val;
> -
>
>        pdata = pdev->dev.platform_data;
>        if (pdata == NULL) {
> @@ -910,24 +904,15 @@ static int __devinit omap_nand_probe(struct
> platform_device *pdev)
>        info->mtd.name          = dev_name(&pdev->dev);
>        info->mtd.owner         = THIS_MODULE;
>
> +       info->nand.options      |= pdata->devsize ? NAND_BUSWIDTH_16 : 0;
> +       info->nand.options      |= NAND_SKIP_BBTSCAN;
> +
>        err = gpmc_cs_request(info->gpmc_cs, NAND_IO_SIZE, &info->phys_base);
>        if (err < 0) {
>                dev_err(&pdev->dev, "Cannot request GPMC CS\n");
>                goto out_free_info;
>        }
>
> -       /* Enable RD PIN Monitoring Reg */
> -       if (pdata->dev_ready) {
> -               val  = gpmc_cs_read_reg(info->gpmc_cs, GPMC_CS_CONFIG1);
> -               val |= WR_RD_PIN_MONITORING;
> -               gpmc_cs_write_reg(info->gpmc_cs, GPMC_CS_CONFIG1, val);
> -       }
> -
> -       val  = gpmc_cs_read_reg(info->gpmc_cs, GPMC_CS_CONFIG7);
> -       val &= ~(0xf << 8);
> -       val |=  (0xc & 0xf) << 8;
> -       gpmc_cs_write_reg(info->gpmc_cs, GPMC_CS_CONFIG7, val);
> -
>        /* NAND write protect off */
>        omap_nand_wp(&info->mtd, NAND_WP_OFF);
>
> @@ -963,11 +948,6 @@ static int __devinit omap_nand_probe(struct
> platform_device *pdev)
>                info->nand.chip_delay = 50;
>        }
>
> -       info->nand.options  |= NAND_SKIP_BBTSCAN;
> -       if ((gpmc_cs_read_reg(info->gpmc_cs, GPMC_CS_CONFIG1) & 0x3000)
> -                                                               == 0x1000)
> -               info->nand.options  |= NAND_BUSWIDTH_16;
> -
>        if (use_prefetch) {
>                /* copy the virtual address of nand base for fifo access */
>                info->nand_pref_fifo_add = info->nand.IO_ADDR_R;
> --
> 1.5.5
> --
> To unsubscribe from this list: send the line "unsubscribe linux-omap" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>
--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

WARNING: multiple messages have this Message-ID (diff)
From: Govindraj <govindraj.ti@gmail.com>
To: Vimal Singh <vimal.newwork@gmail.com>
Cc: Tony Lindgren <tony@atomide.com>,
	linux-omap@vger.kernel.org,
	Linux MTD <linux-mtd@lists.infradead.org>
Subject: Re: [PATCH 2/2]: Introducing 'gpmc-nand.c' for GPMC specific NAND init
Date: Fri, 4 Dec 2009 19:00:48 +0530	[thread overview]
Message-ID: <d6a0f7aa0912040530o72d16979m4c785c2f9cda150c@mail.gmail.com> (raw)
In-Reply-To: <ce9ab5790912040514n238fd080g722f42b426bb6b1b@mail.gmail.com>

This patch got line wrapped.

-- 
---
Regards,
Govindraj.R


On Fri, Dec 4, 2009 at 6:44 PM, Vimal Singh <vimal.newwork@gmail.com> wrote:
> Ahh.. this is my bad.
>
> [...]
>> +       err = gpmc_nand_setup((void __iomem *)
>> +                                       &gpmc_nand_data->gpmc_cs_baseaddr);
> we just do not need casting here.
>
> Apologies for making noise and confusion.
> Please take this one.
>
> -vimal
>
> From e024a2e6aa2051259ad904daff13bdac73b3b1b8 Mon Sep 17 00:00:00 2001
> From: Vimal Singh <vimalsingh@ti.com>
> Date: Wed, 25 Nov 2009 18:23:15 +0530
> Subject: [PATCH] Introducing 'gpmc-nand.c' for GPMC specific NAND init
>
> Introducing 'gpmc-nand.c' for GPMC specific NAND init.
> For example: GPMC timing parameters and all.
> This patch also migrates gpmc related calls from 'nand/omap2.c'
> to 'gpmc-nand.c'.
>
> Signed-off-by: Vimal Singh <vimalsingh@ti.com>
> ---
>  arch/arm/mach-omap2/Makefile           |    3 +
>  arch/arm/mach-omap2/gpmc-nand.c        |  141 ++++++++++++++++++++++++++++++++
>  arch/arm/plat-omap/include/plat/nand.h |    6 ++
>  drivers/mtd/nand/omap2.c               |   26 +-----
>  4 files changed, 153 insertions(+), 23 deletions(-)
>  create mode 100644 arch/arm/mach-omap2/gpmc-nand.c
>
> diff --git a/arch/arm/mach-omap2/Makefile b/arch/arm/mach-omap2/Makefile
> index 59b0ccc..0dfe27a 100644
> --- a/arch/arm/mach-omap2/Makefile
> +++ b/arch/arm/mach-omap2/Makefile
> @@ -103,5 +103,8 @@ obj-y                                       += usb-ehci.o
>  onenand-$(CONFIG_MTD_ONENAND_OMAP2)    := gpmc-onenand.o
>  obj-y                                  += $(onenand-m) $(onenand-y)
>
> +nand-$(CONFIG_MTD_NAND_OMAP2)          := gpmc-nand.o
> +obj-y                                  += $(nand-m) $(nand-y)
> +
>  smc91x-$(CONFIG_SMC91X)                        := gpmc-smc91x.o
>  obj-y                                  += $(smc91x-m) $(smc91x-y)
> diff --git a/arch/arm/mach-omap2/gpmc-nand.c b/arch/arm/mach-omap2/gpmc-nand.c
> new file mode 100644
> index 0000000..0621e39
> --- /dev/null
> +++ b/arch/arm/mach-omap2/gpmc-nand.c
> @@ -0,0 +1,141 @@
> +/*
> + * gpmc-nand.c
> + *
> + * Copyright (C) 2009 Texas Instruments
> + * Vimal Singh <vimalsingh@ti.com>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License version 2 as
> + * published by the Free Software Foundation.
> + */
> +
> +#include <linux/kernel.h>
> +#include <linux/platform_device.h>
> +#include <linux/io.h>
> +
> +#include <asm/mach/flash.h>
> +
> +#include <plat/nand.h>
> +#include <plat/board.h>
> +#include <plat/gpmc.h>
> +
> +#define WR_RD_PIN_MONITORING   0x00600000
> +
> +static struct omap_nand_platform_data *gpmc_nand_data;
> +
> +static struct resource gpmc_nand_resource = {
> +       .flags          = IORESOURCE_MEM,
> +};
> +
> +static struct platform_device gpmc_nand_device = {
> +       .name           = "omap2-nand",
> +       .id             = 0,
> +       .num_resources  = 1,
> +       .resource       = &gpmc_nand_resource,
> +};
> +
> +static int omap2_nand_gpmc_config(int cs, void __iomem *nand_base)
> +{
> +       struct gpmc_timings t;
> +       int err;
> +
> +       const int cs_rd_off = 36;
> +       const int cs_wr_off = 36;
> +       const int adv_on = 6;
> +       const int adv_rd_off = 24;
> +       const int adv_wr_off = 36;
> +       const int oe_off = 48;
> +       const int we_off = 30;
> +       const int rd_cycle = 72;
> +       const int wr_cycle = 72;
> +       const int access = 54;
> +       const int wr_data_mux_bus = 8;
> +       const int wr_access = 30;
> +
> +       memset(&t, 0, sizeof(t));
> +       t.sync_clk = 0;
> +       t.cs_on = 0;
> +       t.adv_on = gpmc_round_ns_to_ticks(adv_on);
> +
> +       /* Read */
> +       t.adv_rd_off = gpmc_round_ns_to_ticks(adv_rd_off);
> +       t.oe_on  = t.adv_on;
> +       t.access = gpmc_round_ns_to_ticks(access);
> +       t.oe_off = gpmc_round_ns_to_ticks(oe_off);
> +       t.cs_rd_off = gpmc_round_ns_to_ticks(cs_rd_off);
> +       t.rd_cycle  = gpmc_round_ns_to_ticks(rd_cycle);
> +
> +       /* Write */
> +       t.adv_wr_off = gpmc_round_ns_to_ticks(adv_wr_off);
> +       t.we_on  = t.oe_on;
> +       if (cpu_is_omap34xx()) {
> +               t.wr_data_mux_bus = gpmc_round_ns_to_ticks(wr_data_mux_bus);
> +               t.wr_access = gpmc_round_ns_to_ticks(wr_access);
> +       }
> +       t.we_off = gpmc_round_ns_to_ticks(we_off);
> +       t.cs_wr_off = gpmc_round_ns_to_ticks(cs_wr_off);
> +       t.wr_cycle  = gpmc_round_ns_to_ticks(wr_cycle);
> +
> +       /* Configure GPMC */
> +       gpmc_cs_write_reg(cs, GPMC_CS_CONFIG1,
> +                       GPMC_CONFIG1_DEVICESIZE(gpmc_nand_data->devsize) |
> +                       GPMC_CONFIG1_DEVICETYPE_NAND);
> +
> +       err = gpmc_cs_set_timings(cs, &t);
> +       if (err)
> +               return err;
> +
> +       return 0;
> +}
> +
> +static int gpmc_nand_setup(void __iomem *nand_base)
> +{
> +       struct device *dev = &gpmc_nand_device.dev;
> +
> +       /* Set timings in GPMC */
> +       if (omap2_nand_gpmc_config(gpmc_nand_data->cs, nand_base) < 0) {
> +               dev_err(dev, "Unable to set gpmc timings\n");
> +               return -EINVAL;
> +       }
> +
> +       return 0;
> +}
> +
> +int __init gpmc_nand_init(struct omap_nand_platform_data *_nand_data)
> +{
> +       unsigned int val;
> +       int err = 0;
> +       struct device *dev = &gpmc_nand_device.dev;
> +
> +       gpmc_nand_data = _nand_data;
> +       gpmc_nand_data->nand_setup = gpmc_nand_setup;
> +       gpmc_nand_device.dev.platform_data = gpmc_nand_data;
> +
> +       err = gpmc_nand_setup(gpmc_nand_data->gpmc_cs_baseaddr);
> +       if (err < 0) {
> +               dev_err(dev, "NAND platform setup failed: %d\n", err);
> +               return err;
> +       }
> +
> +       /* Enable RD PIN Monitoring Reg */
> +       if (gpmc_nand_data->dev_ready) {
> +               val  = gpmc_cs_read_reg(gpmc_nand_data->cs,
> +                                                GPMC_CS_CONFIG1);
> +               val |= WR_RD_PIN_MONITORING;
> +               gpmc_cs_write_reg(gpmc_nand_data->cs,
> +                                               GPMC_CS_CONFIG1, val);
> +       }
> +
> +       val  = gpmc_cs_read_reg(gpmc_nand_data->cs, GPMC_CS_CONFIG7);
> +       val &= ~(0xf << 8);
> +       val |=  (0xc & 0xf) << 8;
> +       gpmc_cs_write_reg(gpmc_nand_data->cs, GPMC_CS_CONFIG7, val);
> +
> +       err = platform_device_register(&gpmc_nand_device);
> +       if (err < 0) {
> +               dev_err(dev, "Unable to register NAND device\n");
> +               return err;
> +       }
> +
> +       return 0;
> +}
> diff --git a/arch/arm/plat-omap/include/plat/nand.h
> b/arch/arm/plat-omap/include/plat/nand.h
> index 631a7be..2ba9842 100644
> --- a/arch/arm/plat-omap/include/plat/nand.h
> +++ b/arch/arm/plat-omap/include/plat/nand.h
> @@ -21,4 +21,10 @@ struct omap_nand_platform_data {
>        int                     dma_channel;
>        void __iomem            *gpmc_cs_baseaddr;
>        void __iomem            *gpmc_baseaddr;
> +       int                     devsize;
>  };
> +
> +/* size (4 KiB) for IO mapping */
> +#define        NAND_IO_SIZE    SZ_4K
> +
> +extern int gpmc_nand_init(struct omap_nand_platform_data *d);
> diff --git a/drivers/mtd/nand/omap2.c b/drivers/mtd/nand/omap2.c
> index 1bb799f..aaef170 100644
> --- a/drivers/mtd/nand/omap2.c
> +++ b/drivers/mtd/nand/omap2.c
> @@ -30,12 +30,8 @@
>
>  #define        DRIVER_NAME     "omap2-nand"
>
> -/* size (4 KiB) for IO mapping */
> -#define        NAND_IO_SIZE    SZ_4K
> -
>  #define        NAND_WP_OFF     0
>  #define NAND_WP_BIT    0x00000010
> -#define WR_RD_PIN_MONITORING   0x00600000
>
>  #define        GPMC_BUF_FULL   0x00000001
>  #define        GPMC_BUF_EMPTY  0x00000000
> @@ -882,8 +878,6 @@ static int __devinit omap_nand_probe(struct
> platform_device *pdev)
>        struct omap_nand_info           *info;
>        struct omap_nand_platform_data  *pdata;
>        int                             err;
> -       unsigned long                   val;
> -
>
>        pdata = pdev->dev.platform_data;
>        if (pdata == NULL) {
> @@ -910,24 +904,15 @@ static int __devinit omap_nand_probe(struct
> platform_device *pdev)
>        info->mtd.name          = dev_name(&pdev->dev);
>        info->mtd.owner         = THIS_MODULE;
>
> +       info->nand.options      |= pdata->devsize ? NAND_BUSWIDTH_16 : 0;
> +       info->nand.options      |= NAND_SKIP_BBTSCAN;
> +
>        err = gpmc_cs_request(info->gpmc_cs, NAND_IO_SIZE, &info->phys_base);
>        if (err < 0) {
>                dev_err(&pdev->dev, "Cannot request GPMC CS\n");
>                goto out_free_info;
>        }
>
> -       /* Enable RD PIN Monitoring Reg */
> -       if (pdata->dev_ready) {
> -               val  = gpmc_cs_read_reg(info->gpmc_cs, GPMC_CS_CONFIG1);
> -               val |= WR_RD_PIN_MONITORING;
> -               gpmc_cs_write_reg(info->gpmc_cs, GPMC_CS_CONFIG1, val);
> -       }
> -
> -       val  = gpmc_cs_read_reg(info->gpmc_cs, GPMC_CS_CONFIG7);
> -       val &= ~(0xf << 8);
> -       val |=  (0xc & 0xf) << 8;
> -       gpmc_cs_write_reg(info->gpmc_cs, GPMC_CS_CONFIG7, val);
> -
>        /* NAND write protect off */
>        omap_nand_wp(&info->mtd, NAND_WP_OFF);
>
> @@ -963,11 +948,6 @@ static int __devinit omap_nand_probe(struct
> platform_device *pdev)
>                info->nand.chip_delay = 50;
>        }
>
> -       info->nand.options  |= NAND_SKIP_BBTSCAN;
> -       if ((gpmc_cs_read_reg(info->gpmc_cs, GPMC_CS_CONFIG1) & 0x3000)
> -                                                               == 0x1000)
> -               info->nand.options  |= NAND_BUSWIDTH_16;
> -
>        if (use_prefetch) {
>                /* copy the virtual address of nand base for fifo access */
>                info->nand_pref_fifo_add = info->nand.IO_ADDR_R;
> --
> 1.5.5
> --
> To unsubscribe from this list: send the line "unsubscribe linux-omap" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>

  reply	other threads:[~2009-12-04 13:30 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-12-03 14:06 [PATCH 2/2]: Introducing 'gpmc-nand.c' for GPMC specific NAND init Vimal Singh
2009-12-04 13:04 ` Vimal Singh
2009-12-04 13:14   ` Vimal Singh
2009-12-04 13:14     ` Vimal Singh
2009-12-04 13:30     ` Govindraj [this message]
2009-12-04 13:30       ` Govindraj
2009-12-04 13:38 Govindraj.R
2009-12-04 22:01 ` Tony Lindgren
2009-12-07  6:29   ` Vimal Singh
2009-12-07 13:29     ` Vimal Singh
2009-12-07 17:56       ` Tony Lindgren
2009-12-08 23:57         ` Tony Lindgren
2009-12-14  6:26           ` Vimal Singh

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=d6a0f7aa0912040530o72d16979m4c785c2f9cda150c@mail.gmail.com \
    --to=govindraj.ti@gmail.com \
    --cc=linux-mtd@lists.infradead.org \
    --cc=linux-omap@vger.kernel.org \
    --cc=tony@atomide.com \
    --cc=vimal.newwork@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.