* [PATCH RESEND v5 0/4] OMAP GPMC DT bindings @ 2012-11-28 16:58 Daniel Mack 2012-11-28 16:58 ` [PATCH v5 1/4] mtd: omap-nand: pass device_node in platform data Daniel Mack ` (4 more replies) 0 siblings, 5 replies; 15+ messages in thread From: Daniel Mack @ 2012-11-28 16:58 UTC (permalink / raw) To: linux-arm-kernel Cc: linux-omap, jon-hunter, avinashphilip, x0148406, tony, paul, nsekhar, jacmet, grant.likely, rob.herring, devicetree-discuss, Daniel Mack [Resending +devicetree-discuss, +Rob, +Grant] This is a series of patches to support GPMC peripherals on OMAP boards. Depends on Linus' master + omap-next (branch omap-for-v3.8/cleanup-headers-gpmc) The only supported peripheral for now is NAND, but other types would be easy to add. Version 2 addresses details pointed out by Jon Hunter, Afzal Mohammed and Rob Herring: - add "reg" and "ti,hwmod" properties to Documentation - use generic of_mtd functions and the property names defined by them, namely "nand-bus-width" and "nand-ecc-mode" - reduce the default register space size in the Documentation to 8K, as found in the hwmod code - switch to a DT layout based on ranges and address translation. Although this property is not currently looked at as long as the handling code still uses the runtime calculation methods, we now have these values in the bindings, eventually allowing us to switch the implementation with less pain. Version 3 includes fixes pointed out by Jon Hunter: - better documentation of the 'ranges' property to describe the fact that it's representing the CS lines - GPMC_CS_CONFIGx -> GPMC_CONFIGx in comments - drop interrupt-parent from example bindings - add of_node_put() at the end of the child iteration Version 4 fixes compilation for !CONFIG_MTD_NAND and includes more details from Jon Hunter and Avinash, Philip: - Add "num-cs" and "num-waitpins" properties, which will eventually be used to get rid of GPMC_CS_NUM - Better description of generic nand DT properties - Dropped patch 3/4 as an equivalent fix was already merged - Added ti,nand-ecc-use-elm property Version 5 with regards to Avinash, Philip and Peter Korsgaard: - Re-add accidentially forgotten Documentation/devicetree/bindings/bus/ti-gpmc.txt - Rename "software" ecc mode to "sw" - Initialize gpmc_nand_data->is_elm_used to 'true' rather than 1 - Drop ti,nand-ecc-use-elm binding in favor of a new ecc mode named "bch8-am335xrbl-compatible" - Add two more patches for section mismatch fixups Daniel Mack (4): mtd: omap-nand: pass device_node in platform data ARM: OMAP: gpmc-nand: drop __init annotation ARM: OMAP: gpmc: enable hwecc for AM33xx SoCs ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND Documentation/devicetree/bindings/bus/ti-gpmc.txt | 76 +++++++++ .../devicetree/bindings/mtd/gpmc-nand.txt | 81 +++++++++ arch/arm/mach-omap2/gpmc-nand.c | 15 +- arch/arm/mach-omap2/gpmc.c | 181 ++++++++++++++++++++- drivers/mtd/nand/omap2.c | 4 +- 5 files changed, 348 insertions(+), 9 deletions(-) create mode 100644 Documentation/devicetree/bindings/bus/ti-gpmc.txt create mode 100644 Documentation/devicetree/bindings/mtd/gpmc-nand.txt -- 1.7.11.7 ^ permalink raw reply [flat|nested] 15+ messages in thread
* [PATCH v5 1/4] mtd: omap-nand: pass device_node in platform data 2012-11-28 16:58 [PATCH RESEND v5 0/4] OMAP GPMC DT bindings Daniel Mack @ 2012-11-28 16:58 ` Daniel Mack 2012-11-28 16:58 ` [PATCH v5 2/4] ARM: OMAP: gpmc-nand: drop __init annotation Daniel Mack ` (3 subsequent siblings) 4 siblings, 0 replies; 15+ messages in thread From: Daniel Mack @ 2012-11-28 16:58 UTC (permalink / raw) To: linux-arm-kernel Cc: linux-omap, jon-hunter, avinashphilip, x0148406, tony, paul, nsekhar, jacmet, grant.likely, rob.herring, devicetree-discuss, Daniel Mack 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: Daniel Mack <zonque@gmail.com> --- drivers/mtd/nand/omap2.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/mtd/nand/omap2.c b/drivers/mtd/nand/omap2.c index 3282b15..a733f15 100644 --- a/drivers/mtd/nand/omap2.c +++ b/drivers/mtd/nand/omap2.c @@ -1331,6 +1331,7 @@ static int __devinit omap_nand_probe(struct platform_device *pdev) dma_cap_mask_t mask; unsigned sig; struct resource *res; + struct mtd_part_parser_data ppdata = {}; pdata = pdev->dev.platform_data; if (pdata == NULL) { @@ -1556,7 +1557,8 @@ static int __devinit omap_nand_probe(struct platform_device *pdev) goto out_release_mem_region; } - mtd_device_parse_register(&info->mtd, NULL, NULL, pdata->parts, + ppdata.of_node = pdata->of_node; + mtd_device_parse_register(&info->mtd, NULL, &ppdata, pdata->parts, pdata->nr_parts); platform_set_drvdata(pdev, &info->mtd); -- 1.7.11.7 ^ permalink raw reply related [flat|nested] 15+ messages in thread
* [PATCH v5 2/4] ARM: OMAP: gpmc-nand: drop __init annotation 2012-11-28 16:58 [PATCH RESEND v5 0/4] OMAP GPMC DT bindings Daniel Mack 2012-11-28 16:58 ` [PATCH v5 1/4] mtd: omap-nand: pass device_node in platform data Daniel Mack @ 2012-11-28 16:58 ` Daniel Mack 2012-11-28 16:58 ` [PATCH v5 3/4] ARM: OMAP: gpmc: enable hwecc for AM33xx SoCs Daniel Mack ` (2 subsequent siblings) 4 siblings, 0 replies; 15+ messages in thread From: Daniel Mack @ 2012-11-28 16:58 UTC (permalink / raw) To: linux-arm-kernel Cc: linux-omap, jon-hunter, avinashphilip, x0148406, tony, paul, nsekhar, jacmet, grant.likely, rob.herring, devicetree-discuss, Daniel Mack gpmc_nand_init() will be called from another driver's probe() function, so the easiest way to prevent section mismatches is to drop the annotation here. Signed-off-by: Daniel Mack <zonque@gmail.com> --- arch/arm/mach-omap2/gpmc-nand.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/arch/arm/mach-omap2/gpmc-nand.c b/arch/arm/mach-omap2/gpmc-nand.c index 8607735..f9f23a2 100644 --- a/arch/arm/mach-omap2/gpmc-nand.c +++ b/arch/arm/mach-omap2/gpmc-nand.c @@ -89,7 +89,7 @@ static int omap2_nand_gpmc_retime( return 0; } -static bool __init gpmc_hwecc_bch_capable(enum omap_ecc ecc_opt) +static bool gpmc_hwecc_bch_capable(enum omap_ecc ecc_opt) { /* support only OMAP3 class */ if (!cpu_is_omap34xx()) { @@ -110,8 +110,8 @@ static bool __init gpmc_hwecc_bch_capable(enum omap_ecc ecc_opt) return 1; } -int __init gpmc_nand_init(struct omap_nand_platform_data *gpmc_nand_data, - struct gpmc_timings *gpmc_t) +int gpmc_nand_init(struct omap_nand_platform_data *gpmc_nand_data, + struct gpmc_timings *gpmc_t) { int err = 0; struct device *dev = &gpmc_nand_device.dev; -- 1.7.11.7 ^ permalink raw reply related [flat|nested] 15+ messages in thread
* [PATCH v5 3/4] ARM: OMAP: gpmc: enable hwecc for AM33xx SoCs 2012-11-28 16:58 [PATCH RESEND v5 0/4] OMAP GPMC DT bindings Daniel Mack 2012-11-28 16:58 ` [PATCH v5 1/4] mtd: omap-nand: pass device_node in platform data Daniel Mack 2012-11-28 16:58 ` [PATCH v5 2/4] ARM: OMAP: gpmc-nand: drop __init annotation Daniel Mack @ 2012-11-28 16:58 ` Daniel Mack 2012-11-28 16:58 ` [PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND Daniel Mack [not found] ` <1354121939-11246-1-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 4 siblings, 0 replies; 15+ messages in thread From: Daniel Mack @ 2012-11-28 16:58 UTC (permalink / raw) To: linux-arm-kernel Cc: linux-omap, jon-hunter, avinashphilip, x0148406, tony, paul, nsekhar, jacmet, grant.likely, rob.herring, devicetree-discuss, Daniel Mack The am33xx is capable of handling bch error correction modes, so enable that feature in the driver. Signed-off-by: Daniel Mack <zonque@gmail.com> --- arch/arm/mach-omap2/gpmc-nand.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/arch/arm/mach-omap2/gpmc-nand.c b/arch/arm/mach-omap2/gpmc-nand.c index f9f23a2..c8a72ba 100644 --- a/arch/arm/mach-omap2/gpmc-nand.c +++ b/arch/arm/mach-omap2/gpmc-nand.c @@ -92,17 +92,18 @@ static int omap2_nand_gpmc_retime( static bool gpmc_hwecc_bch_capable(enum omap_ecc ecc_opt) { /* support only OMAP3 class */ - if (!cpu_is_omap34xx()) { + if (!cpu_is_omap34xx() && !soc_is_am33xx()) { pr_err("BCH ecc is not supported on this CPU\n"); return 0; } /* - * For now, assume 4-bit mode is only supported on OMAP3630 ES1.x, x>=1. - * Other chips may be added if confirmed to work. + * For now, assume 4-bit mode is only supported on OMAP3630 ES1.x, x>=1 + * and AM33xx derivates. Other chips may be added if confirmed to work. */ if ((ecc_opt == OMAP_ECC_BCH4_CODE_HW) && - (!cpu_is_omap3630() || (GET_OMAP_REVISION() == 0))) { + (!cpu_is_omap3630() || (GET_OMAP_REVISION() == 0)) && + (!soc_is_am33xx())) { pr_err("BCH 4-bit mode is not supported on this CPU\n"); return 0; } -- 1.7.11.7 ^ permalink raw reply related [flat|nested] 15+ messages in thread
* [PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND 2012-11-28 16:58 [PATCH RESEND v5 0/4] OMAP GPMC DT bindings Daniel Mack ` (2 preceding siblings ...) 2012-11-28 16:58 ` [PATCH v5 3/4] ARM: OMAP: gpmc: enable hwecc for AM33xx SoCs Daniel Mack @ 2012-11-28 16:58 ` Daniel Mack [not found] ` <1354121939-11246-5-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> [not found] ` <1354121939-11246-1-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 4 siblings, 1 reply; 15+ messages in thread From: Daniel Mack @ 2012-11-28 16:58 UTC (permalink / raw) To: linux-arm-kernel Cc: linux-omap, jon-hunter, avinashphilip, x0148406, tony, paul, nsekhar, jacmet, grant.likely, rob.herring, devicetree-discuss, Daniel Mack This patch adds basic DT bindings for OMAP GPMC. The actual peripherals are instantiated from child nodes within the GPMC node, and the only type of device that is currently supported is NAND. Code was added to parse the generic GPMC timing parameters and some documentation with examples on how to use them. Successfully tested on an AM33xx board. Signed-off-by: Daniel Mack <zonque@gmail.com> --- Documentation/devicetree/bindings/bus/ti-gpmc.txt | 76 +++++++++ .../devicetree/bindings/mtd/gpmc-nand.txt | 81 +++++++++ arch/arm/mach-omap2/gpmc.c | 181 ++++++++++++++++++++- 3 files changed, 337 insertions(+), 1 deletion(-) create mode 100644 Documentation/devicetree/bindings/bus/ti-gpmc.txt create mode 100644 Documentation/devicetree/bindings/mtd/gpmc-nand.txt diff --git a/Documentation/devicetree/bindings/bus/ti-gpmc.txt b/Documentation/devicetree/bindings/bus/ti-gpmc.txt new file mode 100644 index 0000000..ba3d6a5 --- /dev/null +++ b/Documentation/devicetree/bindings/bus/ti-gpmc.txt @@ -0,0 +1,76 @@ +Device tree bindings for OMAP general purpose memory controllers (GPMC) + +The actual devices are instantiated from the child nodes of a GPMC node. + +Required properties: + + - compatible: Should be set to "ti,gpmc" + - reg: A resource specifier for the register space + (see the example below) + - ti,hwmods: Should be set to "ti,gpmc" until the DT transition is + completed. + - #address-cells: Must be set to 2 to allow memory address translation + - #size-cells: Must be set to 1 to allow CS address passing + - num-cs: The maximum number of chip-select lines that controller + can support. + - num-waitpins: The maximum number of wait pins that controller can + support. + - ranges: Must be set up to reflect the memory layout with four + integer values for each chip-select line in use: + + <cs-number> 0 <physical address of mapping> <size> + + Note that this property is not currently parsed. + Calculated values derived from the contents of the + per-CS register GPMC_CONFIG7 (as set up by the + bootloader) are used. That will change in the future, + so be sure to fill the correct values here. + +Timing properties for child nodes. All are optional and default to 0. + + - gpmc,sync-clk: Minimum clock period for synchronous mode, in picoseconds + + Chip-select signal timings corresponding to GPMC_CONFIG2: + - gpmc,cs-on: Assertion time + - gpmc,cs-rd-off: Read deassertion time + - gpmc,cs-wr-off: Write deassertion time + + ADV signal timings corresponding to GPMC_CONFIG3: + - gpmc,adv-on: Assertion time + - gpmc,adv-rd-off: Read deassertion time + - gpmc,adv-wr-off: Write deassertion time + + WE signals timings corresponding to GPMC_CONFIG4: + - gpmc,we-on: Assertion time + - gpmc,we-off: Deassertion time + + OE signals timings corresponding to GPMC_CONFIG4: + - gpmc,oe-on: Assertion time + - gpmc,oe-off: Deassertion time + + Access time and cycle time timings corresponding to GPMC_CONFIG5: + - gpmc,page-burst-access: Multiple access word delay + - gpmc,access: Start-cycle to first data valid delay + - gpmc,rd-cycle: Total read cycle time + - gpmc,wr-cycle: Total write cycle time + +The following are only on OMAP3430: + - gpmc,wr-access + - gpmc,wr-data-mux-bus + + +Example for an AM33xx board: + + gpmc: gpmc@50000000 { + compatible = "ti,gpmc"; + ti,hwmods = "gpmc"; + reg = <0x50000000 0x2000>; + interrupts = <100>; + + num-cs = <8>; + #address-cells = <2>; + #size-cells = <1>; + ranges = <0 0 0x08000000 0x10000000>; /* CS0 @addr 0x8000000, size 0x10000000 */ + + /* child nodes go here */ + }; diff --git a/Documentation/devicetree/bindings/mtd/gpmc-nand.txt b/Documentation/devicetree/bindings/mtd/gpmc-nand.txt new file mode 100644 index 0000000..635f550 --- /dev/null +++ b/Documentation/devicetree/bindings/mtd/gpmc-nand.txt @@ -0,0 +1,81 @@ +Device tree bindings for GPMC connected NANDs + +GPMC connected NAND (found on OMAP boards) are represented as child nodes of +the GPMC controller with a name of "nand". + +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 + +For NAND specific properties such as ECC modes or bus width, please refer to +Documentation/devicetree/bindings/mtd/nand.txt + + +Required properties: + + - reg: The CS line the peripheral is connected to + +Optional properties: + + - nand-bus-width: Set this numeric value to 16 if the hardware + is wired that way. If not specified, a bus + width of 8 is assumed. + - ti,nand-ecc-opt: A string setting the ECC layout to use. One of: + + "sw" Software method (default) + "hw" Hardware method + "hw-romcode" gpmc hamming mode method & romcode layout + "bch4" 4-bit BCH ecc code + "bch8" 8-bit BCH ecc code + "bch8-am335xrbl-compatible" + Use an RBL compatible BCH8 ECC mode. + Note that this mode requires the runtime + detection of the error location module (ELM), + which must hence be enabled in the kernel + config. + +For inline partiton table parsing (optional): + + - #address-cells: should be set to 1 + - #size-cells: should be set to 1 + +Example for an AM33xx board: + + gpmc: gpmc@50000000 { + compatible = "ti,gpmc"; + ti,hwmods = "gpmc"; + reg = <0x50000000 0x1000000>; + interrupts = <100>; + num-cs = <8>; + num-waitpins = <8>; + #address-cells = <2>; + #size-cells = <1>; + ranges = <0 0 0x08000000 0x10000000>; /* CS0: NAND */ + + nand@0,0 { + reg = <0 0 0>; /* CS0, offset 0 */ + nand-bus-width = <16>; + ti,nand-ecc-opt = "bch8-am335xrbl-compatible"; + + gpmc,sync-clk = <0>; + gpmc,cs-on = <0>; + gpmc,cs-rd-off = <44>; + gpmc,cs-wr-off = <44>; + gpmc,adv-on = <6>; + gpmc,adv-rd-off = <34>; + gpmc,adv-wr-off = <44>; + gpmc,we-off = <40>; + gpmc,oe-off = <54>; + gpmc,access = <64>; + gpmc,rd-cycle = <82>; + gpmc,wr-cycle = <82>; + gpmc,wr-access = <40>; + gpmc,wr-data-mux-bus = <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 ff869a3..61597ff 100644 --- a/arch/arm/mach-omap2/gpmc.c +++ b/arch/arm/mach-omap2/gpmc.c @@ -25,6 +25,10 @@ #include <linux/module.h> #include <linux/interrupt.h> #include <linux/platform_device.h> +#include <linux/of.h> +#include <linux/of_mtd.h> +#include <linux/of_device.h> +#include <linux/mtd/nand.h> #include <linux/platform_data/mtd-nand-omap2.h> @@ -37,6 +41,7 @@ #include "soc.h" #include "common.h" #include "gpmc.h" +#include "gpmc-nand.h" #define DEVICE_NAME "omap-gpmc" @@ -751,7 +756,172 @@ static int __devinit gpmc_mem_init(void) return 0; } -static __devinit int gpmc_probe(struct platform_device *pdev) +#ifdef CONFIG_OF +static struct of_device_id gpmc_dt_ids[] = { + { .compatible = "ti,gpmc" }, + { } +}; +MODULE_DEVICE_TABLE(of, gpmc_dt_ids); + +static void __maybe_unused gpmc_read_timings_dt(struct device_node *np, + struct gpmc_timings *gpmc_t) +{ + u32 val; + + memset(gpmc_t, 0, sizeof(*gpmc_t)); + + /* minimum clock period for syncronous mode */ + if (!of_property_read_u32(np, "gpmc,sync-clk", &val)) + gpmc_t->sync_clk = val; + + /* chip select timtings */ + if (!of_property_read_u32(np, "gpmc,cs-on", &val)) + gpmc_t->cs_on = val; + + if (!of_property_read_u32(np, "gpmc,cs-rd-off", &val)) + gpmc_t->cs_rd_off = val; + + if (!of_property_read_u32(np, "gpmc,cs-wr-off", &val)) + gpmc_t->cs_wr_off = val; + + /* ADV signal timings */ + if (!of_property_read_u32(np, "gpmc,adv-on", &val)) + gpmc_t->adv_on = val; + + if (!of_property_read_u32(np, "gpmc,adv-rd-off", &val)) + gpmc_t->adv_rd_off = val; + + if (!of_property_read_u32(np, "gpmc,adv-wr-off", &val)) + gpmc_t->adv_wr_off = val; + + /* WE signal timings */ + if (!of_property_read_u32(np, "gpmc,we-on", &val)) + gpmc_t->we_on = val; + + if (!of_property_read_u32(np, "gpmc,we-off", &val)) + gpmc_t->we_off = val; + + /* OE signal timings */ + if (!of_property_read_u32(np, "gpmc,oe-on", &val)) + gpmc_t->oe_on = val; + + if (!of_property_read_u32(np, "gpmc,oe-off", &val)) + gpmc_t->oe_off = val; + + /* access and cycle timings */ + if (!of_property_read_u32(np, "gpmc,page-burst-access", &val)) + gpmc_t->page_burst_access = val; + + if (!of_property_read_u32(np, "gpmc,access", &val)) + gpmc_t->access = val; + + if (!of_property_read_u32(np, "gpmc,rd-cycle", &val)) + gpmc_t->rd_cycle = val; + + if (!of_property_read_u32(np, "gpmc,wr-cycle", &val)) + gpmc_t->wr_cycle = val; + + /* only for OMAP3430 */ + if (!of_property_read_u32(np, "gpmc,wr-access", &val)) + gpmc_t->wr_access = val; + + if (!of_property_read_u32(np, "gpmc,wr-data-mux-bus", &val)) + gpmc_t->wr_data_mux_bus = val; +} + +#ifdef CONFIG_MTD_NAND + +static const char *nand_ecc_opts[] = { + [OMAP_ECC_HAMMING_CODE_DEFAULT] = "sw", + [OMAP_ECC_HAMMING_CODE_HW] = "hw", + [OMAP_ECC_HAMMING_CODE_HW_ROMCODE] = "hw-romcode", + [OMAP_ECC_BCH4_CODE_HW] = "bch4", + [OMAP_ECC_BCH8_CODE_HW] = "bch8", +}; + +static int gpmc_probe_nand_child(struct platform_device *pdev, + struct device_node *child) +{ + u32 val; + const char *s; + struct gpmc_timings gpmc_t; + struct omap_nand_platform_data *gpmc_nand_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_nand_data = devm_kzalloc(&pdev->dev, sizeof(*gpmc_nand_data), + GFP_KERNEL); + if (!gpmc_nand_data) + return -ENOMEM; + + gpmc_nand_data->cs = val; + gpmc_nand_data->of_node = child; + + 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; + } + } + + val = of_get_nand_bus_width(child); + if (val == 16) + gpmc_nand_data->devsize = NAND_BUSWIDTH_16; + + gpmc_read_timings_dt(child, &gpmc_t); + gpmc_nand_init(gpmc_nand_data, &gpmc_t); + + return 0; +} +#else +static int gpmc_probe_nand_child(struct platform_device *pdev, + struct device_node *child) +{ + return 0; +} +#endif + +static int gpmc_probe_dt(struct platform_device *pdev) +{ + int ret; + struct device_node *child; + const struct of_device_id *of_id = + of_match_device(gpmc_dt_ids, &pdev->dev); + + if (!of_id) + return 0; + + for_each_node_by_name(child, "nand") { + ret = gpmc_probe_nand_child(pdev, child); + of_node_put(child); + if (ret < 0) + return ret; + } + + return 0; +} +#else +static int gpmc_probe_dt(struct platform_device *pdev) +{ + return 0; +} +#endif + +static int __devinit gpmc_probe(struct platform_device *pdev) { int rc; u32 l; @@ -804,6 +974,14 @@ static __devinit int gpmc_probe(struct platform_device *pdev) if (IS_ERR_VALUE(gpmc_setup_irq())) dev_warn(gpmc_dev, "gpmc_setup_irq failed\n"); + rc = gpmc_probe_dt(pdev); + if (rc < 0) { + clk_disable_unprepare(gpmc_l3_clk); + clk_put(gpmc_l3_clk); + dev_err(gpmc_dev, "failed to probe DT parameters\n"); + return rc; + } + return 0; } @@ -821,6 +999,7 @@ static struct platform_driver gpmc_driver = { .driver = { .name = DEVICE_NAME, .owner = THIS_MODULE, + .of_match_table = of_match_ptr(gpmc_dt_ids), }, }; -- 1.7.11.7 ^ permalink raw reply related [flat|nested] 15+ messages in thread
[parent not found: <1354121939-11246-5-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* RE: [PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND [not found] ` <1354121939-11246-5-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2012-11-29 12:36 ` Philip, Avinash 2012-11-29 12:41 ` Daniel Mack 0 siblings, 1 reply; 15+ messages in thread From: Philip, Avinash @ 2012-11-29 12:36 UTC (permalink / raw) To: Daniel Mack, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org Cc: Mohammed, Afzal, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, Nori, Sekhar, rob.herring-bsGFqQB8/DxBDgjK7y7TUQ@public.gmane.org, linux-omap-u79uwXL29TY76Z2rM5mHXA@public.gmane.org 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; http://www.spinics.net/lists/arm-kernel/msg210549.html Thanks Avinash > ^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND 2012-11-29 12:36 ` Philip, Avinash @ 2012-11-29 12:41 ` Daniel Mack 2012-11-29 14:59 ` Philip, Avinash 0 siblings, 1 reply; 15+ messages in thread From: Daniel Mack @ 2012-11-29 12:41 UTC (permalink / raw) To: Philip, Avinash Cc: linux-arm-kernel@lists.infradead.org, linux-omap@vger.kernel.org, Hunter, Jon, Mohammed, Afzal, tony@atomide.com, paul@pwsan.com, Nori, Sekhar, jacmet@sunsite.dk, grant.likely@secretlab.ca, rob.herring@calxeda.com, devicetree-discuss@lists.ozlabs.org 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". Which detail am I missing? :) Daniel ^ permalink raw reply [flat|nested] 15+ messages in thread
* RE: [PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND 2012-11-29 12:41 ` Daniel Mack @ 2012-11-29 14:59 ` Philip, Avinash 2012-11-29 15:07 ` Daniel Mack 0 siblings, 1 reply; 15+ messages in thread From: Philip, Avinash @ 2012-11-29 14:59 UTC (permalink / raw) To: Daniel Mack Cc: linux-arm-kernel@lists.infradead.org, linux-omap@vger.kernel.org, Hunter, Jon, Mohammed, Afzal, tony@atomide.com, paul@pwsan.com, Nori, Sekhar, jacmet@sunsite.dk, grant.likely@secretlab.ca, rob.herring@calxeda.com, devicetree-discuss@lists.ozlabs.org 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 > > 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. Thanks Avinash > > > Daniel > > ^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND 2012-11-29 14:59 ` Philip, Avinash @ 2012-11-29 15:07 ` Daniel Mack [not found] ` <50B77A28.8080608-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 0 siblings, 1 reply; 15+ messages in thread From: Daniel Mack @ 2012-11-29 15:07 UTC (permalink / raw) To: Philip, Avinash Cc: linux-arm-kernel@lists.infradead.org, linux-omap@vger.kernel.org, Hunter, Jon, Mohammed, Afzal, tony@atomide.com, paul@pwsan.com, Nori, Sekhar, jacmet@sunsite.dk, grant.likely@secretlab.ca, rob.herring@calxeda.com, devicetree-discuss@lists.ozlabs.org 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 ^ permalink raw reply [flat|nested] 15+ messages in thread
[parent not found: <50B77A28.8080608-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* RE: [PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND [not found] ` <50B77A28.8080608-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2012-11-29 15:24 ` Philip, Avinash 0 siblings, 0 replies; 15+ messages in thread From: Philip, Avinash @ 2012-11-29 15:24 UTC (permalink / raw) To: Daniel Mack Cc: Mohammed, Afzal, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, Nori, Sekhar, rob.herring-bsGFqQB8/DxBDgjK7y7TUQ@public.gmane.org, linux-omap-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org On Thu, Nov 29, 2012 at 20:37:20, Daniel Mack wrote: > 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. I believe it should go through the OMAP trees. Thanks Avinash > > >> 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 > > ^ permalink raw reply [flat|nested] 15+ messages in thread
[parent not found: <1354121939-11246-1-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* RE: [PATCH RESEND v5 0/4] OMAP GPMC DT bindings [not found] ` <1354121939-11246-1-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2012-11-29 5:24 ` Philip, Avinash 2012-11-29 11:58 ` Daniel Mack 0 siblings, 1 reply; 15+ messages in thread From: Philip, Avinash @ 2012-11-29 5:24 UTC (permalink / raw) To: Daniel Mack, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org Cc: Mohammed, Afzal, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, Nori, Sekhar, rob.herring-bsGFqQB8/DxBDgjK7y7TUQ@public.gmane.org, linux-omap-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Wed, Nov 28, 2012 at 22:28:55, Daniel Mack wrote: > [Resending +devicetree-discuss, +Rob, +Grant] > > > This is a series of patches to support GPMC peripherals on OMAP boards. > > Depends on Linus' master + > omap-next (branch omap-for-v3.8/cleanup-headers-gpmc) Can you resend this series on top of linux_next? Some of the missing items I seen 1. Of_node not populated in omap_nand_platform_data structure. 2. Remove platform device creation from hwmod as GPMC DT is populating. Currently GPMC device creaing from DT & HWMOD. Also can you address how this patch series depends on mtd: nand: OMAP: ELM error correction support for BCH ecc Thanks Avinash > > The only supported peripheral for now is NAND, but other types would be > easy to add. > > Version 2 addresses details pointed out by Jon Hunter, Afzal Mohammed > and Rob Herring: > > - add "reg" and "ti,hwmod" properties to Documentation > - use generic of_mtd functions and the property names defined by them, > namely "nand-bus-width" and "nand-ecc-mode" > - reduce the default register space size in the Documentation to 8K, > as found in the hwmod code > - switch to a DT layout based on ranges and address translation. > Although this property is not currently looked at as long as the > handling code still uses the runtime calculation methods, we now > have these values in the bindings, eventually allowing us to > switch the implementation with less pain. > > Version 3 includes fixes pointed out by Jon Hunter: > > - better documentation of the 'ranges' property to describe the > fact that it's representing the CS lines > - GPMC_CS_CONFIGx -> GPMC_CONFIGx in comments > - drop interrupt-parent from example bindings > - add of_node_put() at the end of the child iteration > > Version 4 fixes compilation for !CONFIG_MTD_NAND and includes more > details from Jon Hunter and Avinash, Philip: > > - Add "num-cs" and "num-waitpins" properties, which will eventually > be used to get rid of GPMC_CS_NUM > - Better description of generic nand DT properties > - Dropped patch 3/4 as an equivalent fix was already merged > - Added ti,nand-ecc-use-elm property > > Version 5 with regards to Avinash, Philip and Peter Korsgaard: > > - Re-add accidentially forgotten > Documentation/devicetree/bindings/bus/ti-gpmc.txt > - Rename "software" ecc mode to "sw" > - Initialize gpmc_nand_data->is_elm_used to 'true' rather than 1 > - Drop ti,nand-ecc-use-elm binding in favor of a new ecc mode > named "bch8-am335xrbl-compatible" > - Add two more patches for section mismatch fixups > > Daniel Mack (4): > mtd: omap-nand: pass device_node in platform data > ARM: OMAP: gpmc-nand: drop __init annotation > ARM: OMAP: gpmc: enable hwecc for AM33xx SoCs > ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND > > Documentation/devicetree/bindings/bus/ti-gpmc.txt | 76 +++++++++ > .../devicetree/bindings/mtd/gpmc-nand.txt | 81 +++++++++ > arch/arm/mach-omap2/gpmc-nand.c | 15 +- > arch/arm/mach-omap2/gpmc.c | 181 ++++++++++++++++++++- > drivers/mtd/nand/omap2.c | 4 +- > 5 files changed, 348 insertions(+), 9 deletions(-) > create mode 100644 Documentation/devicetree/bindings/bus/ti-gpmc.txt > create mode 100644 Documentation/devicetree/bindings/mtd/gpmc-nand.txt > > -- > 1.7.11.7 > > ^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH RESEND v5 0/4] OMAP GPMC DT bindings 2012-11-29 5:24 ` [PATCH RESEND v5 0/4] OMAP GPMC DT bindings Philip, Avinash @ 2012-11-29 11:58 ` Daniel Mack [not found] ` <50B74DCC.5060808-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 0 siblings, 1 reply; 15+ messages in thread From: Daniel Mack @ 2012-11-29 11:58 UTC (permalink / raw) To: Philip, Avinash Cc: linux-arm-kernel@lists.infradead.org, linux-omap@vger.kernel.org, Hunter, Jon, Mohammed, Afzal, tony@atomide.com, paul@pwsan.com, Nori, Sekhar, jacmet@sunsite.dk, grant.likely@secretlab.ca, rob.herring@calxeda.com, devicetree-discuss@lists.ozlabs.org Hi Avinash, On 29.11.2012 06:24, Philip, Avinash wrote: > On Wed, Nov 28, 2012 at 22:28:55, Daniel Mack wrote: >> [Resending +devicetree-discuss, +Rob, +Grant] >> >> >> This is a series of patches to support GPMC peripherals on OMAP boards. >> >> Depends on Linus' master + >> omap-next (branch omap-for-v3.8/cleanup-headers-gpmc) > > Can you resend this series on top of linux_next? The only branch these patches depend on is the "omap-for-v3.8/cleanup-headers-gpmc" branch from omap_next. Are you actually seeing any merge conflicts with my series? If so, which branch are you referring to exactly? > Some of the missing items I seen > 1. Of_node not populated in omap_nand_platform_data structure. Hmm - gpmc_probe_nand_child() from 4/4 adds gpmc_nand_data->of_node = child; Do I miss anything? > 2. Remove platform device creation from hwmod as GPMC DT is populating. > Currently GPMC device creaing from DT & HWMOD. This is already addressed in cd00b0530 ("ARM: OMAP2+: gpmc: Fix kernel BUG for DT boot mode") by Vaibhav Hiremath, which I got via Afzal's USB branch: https://gitorious.org/x0148406-public/linux-kernel/commit/cd00b053082a5cabbb1a35e072b0c044e17e8ec2/diffs As that fix is on the way, I dropped my version which did the same thing. > Also can you address how this patch series depends on > mtd: nand: OMAP: ELM error correction support for BCH ecc I have your ELM patches on top of mine, and they apply cleanly. But I believe it shouldn't be an issue if you base mine on top of yours. Let me know if you want me to rebase anything again. The best solution probably if I make sure the series applies cleanly to whatever tree it will be merged trough - but I don't know which that would be eventually. Thanks for the continuing feedback, Daniel >> >> The only supported peripheral for now is NAND, but other types would be >> easy to add. >> >> Version 2 addresses details pointed out by Jon Hunter, Afzal Mohammed >> and Rob Herring: >> >> - add "reg" and "ti,hwmod" properties to Documentation >> - use generic of_mtd functions and the property names defined by them, >> namely "nand-bus-width" and "nand-ecc-mode" >> - reduce the default register space size in the Documentation to 8K, >> as found in the hwmod code >> - switch to a DT layout based on ranges and address translation. >> Although this property is not currently looked at as long as the >> handling code still uses the runtime calculation methods, we now >> have these values in the bindings, eventually allowing us to >> switch the implementation with less pain. >> >> Version 3 includes fixes pointed out by Jon Hunter: >> >> - better documentation of the 'ranges' property to describe the >> fact that it's representing the CS lines >> - GPMC_CS_CONFIGx -> GPMC_CONFIGx in comments >> - drop interrupt-parent from example bindings >> - add of_node_put() at the end of the child iteration >> >> Version 4 fixes compilation for !CONFIG_MTD_NAND and includes more >> details from Jon Hunter and Avinash, Philip: >> >> - Add "num-cs" and "num-waitpins" properties, which will eventually >> be used to get rid of GPMC_CS_NUM >> - Better description of generic nand DT properties >> - Dropped patch 3/4 as an equivalent fix was already merged >> - Added ti,nand-ecc-use-elm property >> >> Version 5 with regards to Avinash, Philip and Peter Korsgaard: >> >> - Re-add accidentially forgotten >> Documentation/devicetree/bindings/bus/ti-gpmc.txt >> - Rename "software" ecc mode to "sw" >> - Initialize gpmc_nand_data->is_elm_used to 'true' rather than 1 >> - Drop ti,nand-ecc-use-elm binding in favor of a new ecc mode >> named "bch8-am335xrbl-compatible" >> - Add two more patches for section mismatch fixups >> >> Daniel Mack (4): >> mtd: omap-nand: pass device_node in platform data >> ARM: OMAP: gpmc-nand: drop __init annotation >> ARM: OMAP: gpmc: enable hwecc for AM33xx SoCs >> ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND >> >> Documentation/devicetree/bindings/bus/ti-gpmc.txt | 76 +++++++++ >> .../devicetree/bindings/mtd/gpmc-nand.txt | 81 +++++++++ >> arch/arm/mach-omap2/gpmc-nand.c | 15 +- >> arch/arm/mach-omap2/gpmc.c | 181 ++++++++++++++++++++- >> drivers/mtd/nand/omap2.c | 4 +- >> 5 files changed, 348 insertions(+), 9 deletions(-) >> create mode 100644 Documentation/devicetree/bindings/bus/ti-gpmc.txt >> create mode 100644 Documentation/devicetree/bindings/mtd/gpmc-nand.txt >> >> -- >> 1.7.11.7 >> >> > ^ permalink raw reply [flat|nested] 15+ messages in thread
[parent not found: <50B74DCC.5060808-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* RE: [PATCH RESEND v5 0/4] OMAP GPMC DT bindings [not found] ` <50B74DCC.5060808-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2012-11-29 15:08 ` Philip, Avinash 2012-11-29 15:23 ` Daniel Mack 0 siblings, 1 reply; 15+ messages in thread From: Philip, Avinash @ 2012-11-29 15:08 UTC (permalink / raw) To: Daniel Mack Cc: Mohammed, Afzal, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, Nori, Sekhar, rob.herring-bsGFqQB8/DxBDgjK7y7TUQ@public.gmane.org, linux-omap-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org On Thu, Nov 29, 2012 at 17:28:04, Daniel Mack wrote: > Hi Avinash, > > On 29.11.2012 06:24, Philip, Avinash wrote: > > On Wed, Nov 28, 2012 at 22:28:55, Daniel Mack wrote: > >> [Resending +devicetree-discuss, +Rob, +Grant] > >> > >> > >> This is a series of patches to support GPMC peripherals on OMAP boards. > >> > >> Depends on Linus' master + > >> omap-next (branch omap-for-v3.8/cleanup-headers-gpmc) > > > > Can you resend this series on top of linux_next? > > The only branch these patches depend on is the > "omap-for-v3.8/cleanup-headers-gpmc" branch from omap_next. Are you > actually seeing any merge conflicts with my series? If so, which branch > are you referring to exactly? > > > Some of the missing items I seen > > 1. Of_node not populated in omap_nand_platform_data structure. > > Hmm - gpmc_probe_nand_child() from 4/4 adds > > gpmc_nand_data->of_node = child; > > Do I miss anything? I didn't found definition for of_node member in omap_nand_platform_data structure. This also might be missing in liniux-next? > > > 2. Remove platform device creation from hwmod as GPMC DT is populating. > > Currently GPMC device creaing from DT & HWMOD. > > This is already addressed in cd00b0530 ("ARM: OMAP2+: gpmc: Fix kernel > BUG for DT boot mode") by Vaibhav Hiremath, which I got via Afzal's USB > branch: Purpose of VH's patch was to get beagle bone booting, but Jon sent another patch that made beagle bone boot and it has reached mainline by v3.7-rc2, hence the patch you are referring to is currently not going upstream. Still to have GPMC DT work, we need that patch as other wise there would be two GPMC devices. In earlier versions of your series, you had a similar patch, it is required, can you please add it to your series as otherwise with your series GPMC DT won't work. > > > https://gitorious.org/x0148406-public/linux-kernel/commit/cd00b053082a5cabbb1a35e072b0c044e17e8ec2/diffs > > As that fix is on the way, I dropped my version which did the same thing. > > > Also can you address how this patch series depends on > > mtd: nand: OMAP: ELM error correction support for BCH ecc > > I have your ELM patches on top of mine, and they apply cleanly. But I > believe it shouldn't be an issue if you base mine on top of yours. Yes they are independent. So go ahead and submit GPMC DT binding support. > > Let me know if you want me to rebase anything again. The best solution > probably if I make sure the series applies cleanly to whatever tree it > will be merged trough - but I don't know which that would be eventually. My intention was just to tell you to test on linux-next not to resend (mistake). Thanks Avinash > > > Thanks for the continuing feedback, > Daniel > > > >> > >> The only supported peripheral for now is NAND, but other types would be > >> easy to add. > >> > >> Version 2 addresses details pointed out by Jon Hunter, Afzal Mohammed > >> and Rob Herring: > >> > >> - add "reg" and "ti,hwmod" properties to Documentation > >> - use generic of_mtd functions and the property names defined by them, > >> namely "nand-bus-width" and "nand-ecc-mode" > >> - reduce the default register space size in the Documentation to 8K, > >> as found in the hwmod code > >> - switch to a DT layout based on ranges and address translation. > >> Although this property is not currently looked at as long as the > >> handling code still uses the runtime calculation methods, we now > >> have these values in the bindings, eventually allowing us to > >> switch the implementation with less pain. > >> > >> Version 3 includes fixes pointed out by Jon Hunter: > >> > >> - better documentation of the 'ranges' property to describe the > >> fact that it's representing the CS lines > >> - GPMC_CS_CONFIGx -> GPMC_CONFIGx in comments > >> - drop interrupt-parent from example bindings > >> - add of_node_put() at the end of the child iteration > >> > >> Version 4 fixes compilation for !CONFIG_MTD_NAND and includes more > >> details from Jon Hunter and Avinash, Philip: > >> > >> - Add "num-cs" and "num-waitpins" properties, which will eventually > >> be used to get rid of GPMC_CS_NUM > >> - Better description of generic nand DT properties > >> - Dropped patch 3/4 as an equivalent fix was already merged > >> - Added ti,nand-ecc-use-elm property > >> > >> Version 5 with regards to Avinash, Philip and Peter Korsgaard: > >> > >> - Re-add accidentially forgotten > >> Documentation/devicetree/bindings/bus/ti-gpmc.txt > >> - Rename "software" ecc mode to "sw" > >> - Initialize gpmc_nand_data->is_elm_used to 'true' rather than 1 > >> - Drop ti,nand-ecc-use-elm binding in favor of a new ecc mode > >> named "bch8-am335xrbl-compatible" > >> - Add two more patches for section mismatch fixups > >> > >> Daniel Mack (4): > >> mtd: omap-nand: pass device_node in platform data > >> ARM: OMAP: gpmc-nand: drop __init annotation > >> ARM: OMAP: gpmc: enable hwecc for AM33xx SoCs > >> ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND > >> > >> Documentation/devicetree/bindings/bus/ti-gpmc.txt | 76 +++++++++ > >> .../devicetree/bindings/mtd/gpmc-nand.txt | 81 +++++++++ > >> arch/arm/mach-omap2/gpmc-nand.c | 15 +- > >> arch/arm/mach-omap2/gpmc.c | 181 ++++++++++++++++++++- > >> drivers/mtd/nand/omap2.c | 4 +- > >> 5 files changed, 348 insertions(+), 9 deletions(-) > >> create mode 100644 Documentation/devicetree/bindings/bus/ti-gpmc.txt > >> create mode 100644 Documentation/devicetree/bindings/mtd/gpmc-nand.txt > >> > >> -- > >> 1.7.11.7 > >> > >> > > > > ^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH RESEND v5 0/4] OMAP GPMC DT bindings 2012-11-29 15:08 ` Philip, Avinash @ 2012-11-29 15:23 ` Daniel Mack [not found] ` <50B77DD5.4090001-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 0 siblings, 1 reply; 15+ messages in thread From: Daniel Mack @ 2012-11-29 15:23 UTC (permalink / raw) To: Philip, Avinash Cc: linux-arm-kernel@lists.infradead.org, linux-omap@vger.kernel.org, Hunter, Jon, Mohammed, Afzal, tony@atomide.com, paul@pwsan.com, Nori, Sekhar, jacmet@sunsite.dk, grant.likely@secretlab.ca, rob.herring@calxeda.com, devicetree-discuss@lists.ozlabs.org On 29.11.2012 16:08, Philip, Avinash wrote: > On Thu, Nov 29, 2012 at 17:28:04, Daniel Mack wrote: >> Hi Avinash, >> >> On 29.11.2012 06:24, Philip, Avinash wrote: >>> On Wed, Nov 28, 2012 at 22:28:55, Daniel Mack wrote: >>>> [Resending +devicetree-discuss, +Rob, +Grant] >>>> >>>> >>>> This is a series of patches to support GPMC peripherals on OMAP boards. >>>> >>>> Depends on Linus' master + >>>> omap-next (branch omap-for-v3.8/cleanup-headers-gpmc) >>> >>> Can you resend this series on top of linux_next? >> >> The only branch these patches depend on is the >> "omap-for-v3.8/cleanup-headers-gpmc" branch from omap_next. Are you >> actually seeing any merge conflicts with my series? If so, which branch >> are you referring to exactly? >> >>> Some of the missing items I seen >>> 1. Of_node not populated in omap_nand_platform_data structure. >> >> Hmm - gpmc_probe_nand_child() from 4/4 adds >> >> gpmc_nand_data->of_node = child; >> >> Do I miss anything? > > I didn't found definition for of_node member in omap_nand_platform_data > structure. This also might be missing in liniux-next? Ah, right. I got that entry from your patch ("mtd: nand: omap2: Support for hardware BCH error correction"). But you're right, it should be part of my series. Will add that when resending, but note that your ELM series will then cause a (trivial) merge conflict. >>> 2. Remove platform device creation from hwmod as GPMC DT is populating. >>> Currently GPMC device creaing from DT & HWMOD. >> >> This is already addressed in cd00b0530 ("ARM: OMAP2+: gpmc: Fix kernel >> BUG for DT boot mode") by Vaibhav Hiremath, which I got via Afzal's USB >> branch: > > Purpose of VH's patch was to get beagle bone booting, but Jon sent another > patch that made beagle bone boot and it has reached mainline by v3.7-rc2, > hence the patch you are referring to is currently not going upstream. Still to > have GPMC DT work, we need that patch as other wise there would be two GPMC > devices. In earlier versions of your series, you had a similar patch, it is > required, can you please add it to your series as otherwise with your series > GPMC DT won't work. Ok, fine. Will do. Daniel ^ permalink raw reply [flat|nested] 15+ messages in thread
[parent not found: <50B77DD5.4090001-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* Re: [PATCH RESEND v5 0/4] OMAP GPMC DT bindings [not found] ` <50B77DD5.4090001-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2012-11-30 5:53 ` Vaibhav Hiremath 0 siblings, 0 replies; 15+ messages in thread From: Vaibhav Hiremath @ 2012-11-30 5:53 UTC (permalink / raw) To: Daniel Mack Cc: Mohammed, Afzal, devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, Nori, Sekhar, rob.herring-bsGFqQB8/DxBDgjK7y7TUQ@public.gmane.org, Philip, Avinash, linux-omap-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org On 11/29/2012 8:53 PM, Daniel Mack wrote: > On 29.11.2012 16:08, Philip, Avinash wrote: >> On Thu, Nov 29, 2012 at 17:28:04, Daniel Mack wrote: >>> Hi Avinash, >>> >>> On 29.11.2012 06:24, Philip, Avinash wrote: >>>> On Wed, Nov 28, 2012 at 22:28:55, Daniel Mack wrote: >>>>> [Resending +devicetree-discuss, +Rob, +Grant] >>>>> >>>>> >>>>> This is a series of patches to support GPMC peripherals on OMAP boards. >>>>> >>>>> Depends on Linus' master + >>>>> omap-next (branch omap-for-v3.8/cleanup-headers-gpmc) >>>> >>>> Can you resend this series on top of linux_next? >>> >>> The only branch these patches depend on is the >>> "omap-for-v3.8/cleanup-headers-gpmc" branch from omap_next. Are you >>> actually seeing any merge conflicts with my series? If so, which branch >>> are you referring to exactly? >>> >>>> Some of the missing items I seen >>>> 1. Of_node not populated in omap_nand_platform_data structure. >>> >>> Hmm - gpmc_probe_nand_child() from 4/4 adds >>> >>> gpmc_nand_data->of_node = child; >>> >>> Do I miss anything? >> >> I didn't found definition for of_node member in omap_nand_platform_data >> structure. This also might be missing in liniux-next? > > Ah, right. I got that entry from your patch ("mtd: nand: omap2: Support > for hardware BCH error correction"). But you're right, it should be part > of my series. Will add that when resending, but note that your ELM > series will then cause a (trivial) merge conflict. > >>>> 2. Remove platform device creation from hwmod as GPMC DT is populating. >>>> Currently GPMC device creaing from DT & HWMOD. >>> >>> This is already addressed in cd00b0530 ("ARM: OMAP2+: gpmc: Fix kernel >>> BUG for DT boot mode") by Vaibhav Hiremath, which I got via Afzal's USB >>> branch: >> >> Purpose of VH's patch was to get beagle bone booting, but Jon sent another >> patch that made beagle bone boot and it has reached mainline by v3.7-rc2, >> hence the patch you are referring to is currently not going upstream. Still to >> have GPMC DT work, we need that patch as other wise there would be two GPMC >> devices. In earlier versions of your series, you had a similar patch, it is >> required, can you please add it to your series as otherwise with your series >> GPMC DT won't work. > > Ok, fine. Will do. > Feel free to take that patch forward, merge into your series. Thanks, Vaibhav > > Daniel > > -- > To unsubscribe from this list: send the line "unsubscribe linux-omap" in > the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org > More majordomo info at http://vger.kernel.org/majordomo-info.html > ^ permalink raw reply [flat|nested] 15+ messages in thread
end of thread, other threads:[~2012-11-30 5:53 UTC | newest] Thread overview: 15+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2012-11-28 16:58 [PATCH RESEND v5 0/4] OMAP GPMC DT bindings Daniel Mack 2012-11-28 16:58 ` [PATCH v5 1/4] mtd: omap-nand: pass device_node in platform data Daniel Mack 2012-11-28 16:58 ` [PATCH v5 2/4] ARM: OMAP: gpmc-nand: drop __init annotation Daniel Mack 2012-11-28 16:58 ` [PATCH v5 3/4] ARM: OMAP: gpmc: enable hwecc for AM33xx SoCs Daniel Mack 2012-11-28 16:58 ` [PATCH v5 4/4] ARM: OMAP: gpmc: add DT bindings for GPMC timings and NAND Daniel Mack [not found] ` <1354121939-11246-5-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2012-11-29 12:36 ` Philip, Avinash 2012-11-29 12:41 ` Daniel Mack 2012-11-29 14:59 ` Philip, Avinash 2012-11-29 15:07 ` Daniel Mack [not found] ` <50B77A28.8080608-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2012-11-29 15:24 ` Philip, Avinash [not found] ` <1354121939-11246-1-git-send-email-zonque-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2012-11-29 5:24 ` [PATCH RESEND v5 0/4] OMAP GPMC DT bindings Philip, Avinash 2012-11-29 11:58 ` Daniel Mack [not found] ` <50B74DCC.5060808-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2012-11-29 15:08 ` Philip, Avinash 2012-11-29 15:23 ` Daniel Mack [not found] ` <50B77DD5.4090001-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2012-11-30 5:53 ` Vaibhav Hiremath
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).