* [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data
@ 2012-12-24 0:01 Ezequiel Garcia
2012-12-24 0:01 ` [PATCH 2/3] arm: omap2: gpmc-onenand: drop __init annotation Ezequiel Garcia
` (2 more replies)
0 siblings, 3 replies; 6+ messages in thread
From: Ezequiel Garcia @ 2012-12-24 0:01 UTC (permalink / raw)
To: linux-omap, linux-arm-kernel, linux-mtd
Cc: Thomas Petazzoni, martinez.javier, zonque, grant.likely,
eballetbo, matthias.bgg, jon-hunter, b-cousson, Ezequiel Garcia
Pass an optional device_node pointer in the platform data,
which in turn will be put into a mtd_part_parser_data.
This way, code that sets up the platform devices can pass
along the node from DT so that the partitions can be parsed.
For non-DT boards, this change has no effect.
Signed-off-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com>
---
drivers/mtd/onenand/omap2.c | 4 +++-
include/linux/platform_data/mtd-onenand-omap2.h | 3 +++
2 files changed, 6 insertions(+), 1 deletions(-)
diff --git a/drivers/mtd/onenand/omap2.c b/drivers/mtd/onenand/omap2.c
index 065f3fe..eec2aed 100644
--- a/drivers/mtd/onenand/omap2.c
+++ b/drivers/mtd/onenand/omap2.c
@@ -637,6 +637,7 @@ static int omap2_onenand_probe(struct platform_device *pdev)
struct onenand_chip *this;
int r;
struct resource *res;
+ struct mtd_part_parser_data ppdata = {};
pdata = pdev->dev.platform_data;
if (pdata == NULL) {
@@ -767,7 +768,8 @@ static int omap2_onenand_probe(struct platform_device *pdev)
if ((r = onenand_scan(&c->mtd, 1)) < 0)
goto err_release_regulator;
- r = mtd_device_parse_register(&c->mtd, NULL, NULL,
+ ppdata.of_node = pdata->of_node;
+ r = mtd_device_parse_register(&c->mtd, NULL, &ppdata,
pdata ? pdata->parts : NULL,
pdata ? pdata->nr_parts : 0);
if (r)
diff --git a/include/linux/platform_data/mtd-onenand-omap2.h b/include/linux/platform_data/mtd-onenand-omap2.h
index 685af7e..e9a9fb1 100644
--- a/include/linux/platform_data/mtd-onenand-omap2.h
+++ b/include/linux/platform_data/mtd-onenand-omap2.h
@@ -29,5 +29,8 @@ struct omap_onenand_platform_data {
u8 flags;
u8 regulator_can_sleep;
u8 skip_initial_unlocking;
+
+ /* for passing the partitions */
+ struct device_node *of_node;
};
#endif
--
1.7.8.6
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH 2/3] arm: omap2: gpmc-onenand: drop __init annotation
2012-12-24 0:01 [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data Ezequiel Garcia
@ 2012-12-24 0:01 ` Ezequiel Garcia
2012-12-24 0:01 ` [PATCH 3/3] arm: omap2: gpmc: add DT bindings for OneNAND Ezequiel Garcia
2013-01-15 22:48 ` [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data Ezequiel Garcia
2 siblings, 0 replies; 6+ messages in thread
From: Ezequiel Garcia @ 2012-12-24 0:01 UTC (permalink / raw)
To: linux-omap, linux-arm-kernel, linux-mtd
Cc: Thomas Petazzoni, martinez.javier, zonque, grant.likely,
eballetbo, matthias.bgg, jon-hunter, b-cousson, Ezequiel Garcia
gpmc_onenand_init() will be called from another driver's probe() function,
so drop the __init annotation, in order to prevent section mismatches.
Signed-off-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com>
---
arch/arm/mach-omap2/gpmc-onenand.c | 2 +-
1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/arch/arm/mach-omap2/gpmc-onenand.c b/arch/arm/mach-omap2/gpmc-onenand.c
index 94a349e..fadd8743 100644
--- a/arch/arm/mach-omap2/gpmc-onenand.c
+++ b/arch/arm/mach-omap2/gpmc-onenand.c
@@ -356,7 +356,7 @@ static int gpmc_onenand_setup(void __iomem *onenand_base, int *freq_ptr)
return ret;
}
-void __init gpmc_onenand_init(struct omap_onenand_platform_data *_onenand_data)
+void gpmc_onenand_init(struct omap_onenand_platform_data *_onenand_data)
{
int err;
--
1.7.8.6
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH 3/3] arm: omap2: gpmc: add DT bindings for OneNAND
2012-12-24 0:01 [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data Ezequiel Garcia
2012-12-24 0:01 ` [PATCH 2/3] arm: omap2: gpmc-onenand: drop __init annotation Ezequiel Garcia
@ 2012-12-24 0:01 ` Ezequiel Garcia
2012-12-24 0:50 ` Ezequiel Garcia
2013-01-15 22:48 ` [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data Ezequiel Garcia
2 siblings, 1 reply; 6+ messages in thread
From: Ezequiel Garcia @ 2012-12-24 0:01 UTC (permalink / raw)
To: linux-omap, linux-arm-kernel, linux-mtd
Cc: Thomas Petazzoni, martinez.javier, zonque, grant.likely,
eballetbo, matthias.bgg, jon-hunter, b-cousson, Ezequiel Garcia
This patch adds device tree bindings for OMAP OneNAND devices.
Tested on an OMAP3 3430 IGEPv2 board.
Signed-off-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com>
---
.../devicetree/bindings/mtd/gpmc-onenand.txt | 44 ++++++++++++++++++++
arch/arm/mach-omap2/gpmc.c | 44 ++++++++++++++++++++
2 files changed, 88 insertions(+), 0 deletions(-)
create mode 100644 Documentation/devicetree/bindings/mtd/gpmc-onenand.txt
diff --git a/Documentation/devicetree/bindings/mtd/gpmc-onenand.txt b/Documentation/devicetree/bindings/mtd/gpmc-onenand.txt
new file mode 100644
index 0000000..4108f18
--- /dev/null
+++ b/Documentation/devicetree/bindings/mtd/gpmc-onenand.txt
@@ -0,0 +1,44 @@
+Device tree bindings for GPMC connected OneNANDs
+
+GPMC connected OneNAND (found on OMAP boards) are represented as child nodes of
+the GPMC controller with a name of "onenand".
+
+All timing relevant properties as well as generic gpmc child properties are
+explained in a separate documents - please refer to
+Documentation/devicetree/bindings/bus/ti-gpmc.txt
+
+Required properties:
+
+ - reg: The CS line the peripheral is connected to
+
+Optional properties:
+
+ - dma-channel: DMA Channel index
+
+For inline partiton table parsing (optional):
+
+ - #address-cells: should be set to 1
+ - #size-cells: should be set to 1
+
+Example for an OMAP3430 board:
+
+ gpmc: gpmc@6e000000 {
+ compatible = "ti,omap3430-gpmc";
+ ti,hwmods = "gpmc";
+ reg = <0x6e000000 0x1000000>;
+ interrupts = <20>;
+ gpmc,num-cs = <8>;
+ gpmc,num-waitpins = <4>;
+ #address-cells = <2>;
+ #size-cells = <1>;
+
+ onenand@0 {
+ reg = <0>;
+
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ /* partitions go here */
+ };
+ };
+
diff --git a/arch/arm/mach-omap2/gpmc.c b/arch/arm/mach-omap2/gpmc.c
index 08d580a..b1f0f0b 100644
--- a/arch/arm/mach-omap2/gpmc.c
+++ b/arch/arm/mach-omap2/gpmc.c
@@ -39,6 +39,7 @@
#include "omap_device.h"
#include "gpmc.h"
#include "gpmc-nand.h"
+#include "gpmc-onenand.h"
#define DEVICE_NAME "omap-gpmc"
@@ -1259,6 +1260,43 @@ static int gpmc_probe_nand_child(struct platform_device *pdev,
}
#endif
+#ifdef CONFIG_MTD_ONENAND
+static int gpmc_probe_onenand_child(struct platform_device *pdev,
+ struct device_node *child)
+{
+ u32 val;
+ struct omap_onenand_platform_data *gpmc_onenand_data;
+
+ if (of_property_read_u32(child, "reg", &val) < 0) {
+ dev_err(&pdev->dev, "%s has no 'reg' property\n",
+ child->full_name);
+ return -ENODEV;
+ }
+
+ gpmc_onenand_data = devm_kzalloc(&pdev->dev, sizeof(*gpmc_onenand_data),
+ GFP_KERNEL);
+ if (!gpmc_onenand_data)
+ return -ENOMEM;
+
+ gpmc_onenand_data->cs = val;
+ gpmc_onenand_data->of_node = child;
+ gpmc_onenand_data->dma_channel = -1;
+
+ if (!of_property_read_u32(child, "dma-channel", &val))
+ gpmc_onenand_data->dma_channel = val;
+
+ gpmc_onenand_init(gpmc_onenand_data);
+
+ return 0;
+}
+#else
+static int gpmc_probe_onenand_child(struct platform_device *pdev,
+ struct device_node *child)
+{
+ return 0;
+}
+#endif
+
static int gpmc_probe_dt(struct platform_device *pdev)
{
int ret;
@@ -1276,6 +1314,12 @@ static int gpmc_probe_dt(struct platform_device *pdev)
return ret;
}
+ for_each_node_by_name(child, "onenand") {
+ ret = gpmc_probe_onenand_child(pdev, child);
+ of_node_put(child);
+ if (ret < 0)
+ return ret;
+ }
return 0;
}
#else
--
1.7.8.6
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH 3/3] arm: omap2: gpmc: add DT bindings for OneNAND
2012-12-24 0:01 ` [PATCH 3/3] arm: omap2: gpmc: add DT bindings for OneNAND Ezequiel Garcia
@ 2012-12-24 0:50 ` Ezequiel Garcia
0 siblings, 0 replies; 6+ messages in thread
From: Ezequiel Garcia @ 2012-12-24 0:50 UTC (permalink / raw)
To: linux-omap
Cc: linux-arm-kernel, linux-mtd, Thomas Petazzoni, martinez.javier,
zonque, grant.likely, eballetbo, matthias.bgg, jon-hunter,
b-cousson, Ezequiel Garcia
On Sun, Dec 23, 2012 at 9:01 PM, Ezequiel Garcia
<ezequiel.garcia@free-electrons.com> wrote:
> This patch adds device tree bindings for OMAP OneNAND devices.
> Tested on an OMAP3 3430 IGEPv2 board.
>
> Signed-off-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com>
> ---
> .../devicetree/bindings/mtd/gpmc-onenand.txt | 44 ++++++++++++++++++++
> arch/arm/mach-omap2/gpmc.c | 44 ++++++++++++++++++++
> 2 files changed, 88 insertions(+), 0 deletions(-)
> create mode 100644 Documentation/devicetree/bindings/mtd/gpmc-onenand.txt
>
> diff --git a/Documentation/devicetree/bindings/mtd/gpmc-onenand.txt b/Documentation/devicetree/bindings/mtd/gpmc-onenand.txt
> new file mode 100644
> index 0000000..4108f18
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/mtd/gpmc-onenand.txt
> @@ -0,0 +1,44 @@
> +Device tree bindings for GPMC connected OneNANDs
> +
> +GPMC connected OneNAND (found on OMAP boards) are represented as child nodes of
> +the GPMC controller with a name of "onenand".
> +
> +All timing relevant properties as well as generic gpmc child properties are
> +explained in a separate documents - please refer to
> +Documentation/devicetree/bindings/bus/ti-gpmc.txt
> +
> +Required properties:
> +
> + - reg: The CS line the peripheral is connected to
> +
> +Optional properties:
> +
> + - dma-channel: DMA Channel index
> +
> +For inline partiton table parsing (optional):
> +
> + - #address-cells: should be set to 1
> + - #size-cells: should be set to 1
> +
> +Example for an OMAP3430 board:
> +
> + gpmc: gpmc@6e000000 {
> + compatible = "ti,omap3430-gpmc";
> + ti,hwmods = "gpmc";
> + reg = <0x6e000000 0x1000000>;
> + interrupts = <20>;
> + gpmc,num-cs = <8>;
> + gpmc,num-waitpins = <4>;
> + #address-cells = <2>;
> + #size-cells = <1>;
> +
Before anyone complains, this is wrong:
> + onenand@0 {
> + reg = <0>;
> +
It should be "reg = <0 0 0>" of course.
Also, IMHO, I don't like the node to be matched by his name.
Shouldn't we add a "compatible" tag instead?
That way we could describe the device like
flash@xxx {
compatible = "nand";
}
or
flash@xxx {
compatible = "onenand";
}
Does this make sense?
Regards,
Ezequiel
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data
2012-12-24 0:01 [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data Ezequiel Garcia
2012-12-24 0:01 ` [PATCH 2/3] arm: omap2: gpmc-onenand: drop __init annotation Ezequiel Garcia
2012-12-24 0:01 ` [PATCH 3/3] arm: omap2: gpmc: add DT bindings for OneNAND Ezequiel Garcia
@ 2013-01-15 22:48 ` Ezequiel Garcia
2013-01-17 11:47 ` Artem Bityutskiy
2 siblings, 1 reply; 6+ messages in thread
From: Ezequiel Garcia @ 2013-01-15 22:48 UTC (permalink / raw)
To: Artem Bityutskiy
Cc: linux-omap, linux-arm-kernel, linux-mtd, Thomas Petazzoni,
martinez.javier, zonque, grant.likely, eballetbo, matthias.bgg,
jon-hunter, b-cousson, Tony Lindgren, Ezequiel Garcia
Artem,
On Sun, Dec 23, 2012 at 9:01 PM, Ezequiel Garcia
<ezequiel.garcia@free-electrons.com> wrote:
> Pass an optional device_node pointer in the platform data,
> which in turn will be put into a mtd_part_parser_data.
> This way, code that sets up the platform devices can pass
> along the node from DT so that the partitions can be parsed.
>
> For non-DT boards, this change has no effect.
>
> Signed-off-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com>
> ---
> drivers/mtd/onenand/omap2.c | 4 +++-
> include/linux/platform_data/mtd-onenand-omap2.h | 3 +++
> 2 files changed, 6 insertions(+), 1 deletions(-)
>
> diff --git a/drivers/mtd/onenand/omap2.c b/drivers/mtd/onenand/omap2.c
> index 065f3fe..eec2aed 100644
> --- a/drivers/mtd/onenand/omap2.c
> +++ b/drivers/mtd/onenand/omap2.c
> @@ -637,6 +637,7 @@ static int omap2_onenand_probe(struct platform_device *pdev)
> struct onenand_chip *this;
> int r;
> struct resource *res;
> + struct mtd_part_parser_data ppdata = {};
>
> pdata = pdev->dev.platform_data;
> if (pdata == NULL) {
> @@ -767,7 +768,8 @@ static int omap2_onenand_probe(struct platform_device *pdev)
> if ((r = onenand_scan(&c->mtd, 1)) < 0)
> goto err_release_regulator;
>
> - r = mtd_device_parse_register(&c->mtd, NULL, NULL,
> + ppdata.of_node = pdata->of_node;
> + r = mtd_device_parse_register(&c->mtd, NULL, &ppdata,
> pdata ? pdata->parts : NULL,
> pdata ? pdata->nr_parts : 0);
> if (r)
> diff --git a/include/linux/platform_data/mtd-onenand-omap2.h b/include/linux/platform_data/mtd-onenand-omap2.h
> index 685af7e..e9a9fb1 100644
> --- a/include/linux/platform_data/mtd-onenand-omap2.h
> +++ b/include/linux/platform_data/mtd-onenand-omap2.h
> @@ -29,5 +29,8 @@ struct omap_onenand_platform_data {
> u8 flags;
> u8 regulator_can_sleep;
> u8 skip_initial_unlocking;
> +
> + /* for passing the partitions */
> + struct device_node *of_node;
> };
> #endif
> --
> 1.7.8.6
>
I saw you have acked the gpmc patch on nand.
Can I add your Acked-by on this one, when I send the rebased patch set?
Thanks,
--
Ezequiel
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data
2013-01-15 22:48 ` [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data Ezequiel Garcia
@ 2013-01-17 11:47 ` Artem Bityutskiy
0 siblings, 0 replies; 6+ messages in thread
From: Artem Bityutskiy @ 2013-01-17 11:47 UTC (permalink / raw)
To: Ezequiel Garcia
Cc: linux-omap, linux-arm-kernel, linux-mtd, Thomas Petazzoni,
martinez.javier, zonque, grant.likely, eballetbo, matthias.bgg,
jon-hunter, b-cousson, Tony Lindgren, Ezequiel Garcia
[-- Attachment #1: Type: text/plain, Size: 378 bytes --]
On Tue, 2013-01-15 at 19:48 -0300, Ezequiel Garcia wrote:
> I saw you have acked the gpmc patch on nand.
> Can I add your Acked-by on this one, when I send the rebased patch set?
Yes, I saw this series which depends on Daniel Mack's work. It looks
good. You can add
Acked-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
--
Best Regards,
Artem Bityutskiy
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 836 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2013-01-17 11:46 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-12-24 0:01 [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data Ezequiel Garcia
2012-12-24 0:01 ` [PATCH 2/3] arm: omap2: gpmc-onenand: drop __init annotation Ezequiel Garcia
2012-12-24 0:01 ` [PATCH 3/3] arm: omap2: gpmc: add DT bindings for OneNAND Ezequiel Garcia
2012-12-24 0:50 ` Ezequiel Garcia
2013-01-15 22:48 ` [PATCH 1/3] mtd: omap-onenand: pass device_node in platform data Ezequiel Garcia
2013-01-17 11:47 ` Artem Bityutskiy
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).