[PATCH] mtd/maps: add mtd-ram support to physmap_of

Grant Likely grant.likely at secretlab.ca
Sat Aug 8 15:43:32 EST 2009


On Fri, Jul 17, 2009 at 6:39 AM, Wolfram Sang<w.sang at pengutronix.de> wrote:
> Use physmap_of to access RAMs as mtd and add documenation for it. This approach
> is a lot less intrusive as adding an of-wrapper around plat-ram.c. As most
> extensions of plat-ram.c (e.g. custom map-functions) can't be mapped to the
> device tree anyhow, extending physmap_of seems to be the cleanest approach.
>
> Tested with a phyCORE-MPC5121e.
>
> Signed-off-by: Wolfram Sang <w.sang at pengutronix.de>

Looks good to me.

Acked-by: Grant Likely <grant.likely at secretlab.ca>

> Cc: Vitaly Wool <vwool at ru.mvista.com>
> Cc: Artem Bityutskiy <dedekind at infradead.org>
> Cc: David Woodhouse <dwmw2 at infradead.org>
> Cc: Ken MacLeod <ken at bitsko.slc.ut.us>
> Cc: Albrecht Dreß <albrecht.dress at arcor.de>
> ---
>  Documentation/powerpc/dts-bindings/mtd-physmap.txt |   42 ++++++++++++-------
>  drivers/mtd/maps/physmap_of.c                      |    4 ++
>  2 files changed, 30 insertions(+), 16 deletions(-)
>
> diff --git a/Documentation/powerpc/dts-bindings/mtd-physmap.txt b/Documentation/powerpc/dts-bindings/mtd-physmap.txt
> index 667c9bd..80152cb 100644
> --- a/Documentation/powerpc/dts-bindings/mtd-physmap.txt
> +++ b/Documentation/powerpc/dts-bindings/mtd-physmap.txt
> @@ -1,18 +1,19 @@
> -CFI or JEDEC memory-mapped NOR flash
> +CFI or JEDEC memory-mapped NOR flash, MTD-RAM (NVRAM...)
>
>  Flash chips (Memory Technology Devices) are often used for solid state
>  file systems on embedded devices.
>
> - - compatible : should contain the specific model of flash chip(s)
> -   used, if known, followed by either "cfi-flash" or "jedec-flash"
> - - reg : Address range(s) of the flash chip(s)
> + - compatible : should contain the specific model of mtd chip(s)
> +   used, if known, followed by either "cfi-flash", "jedec-flash"
> +   or "mtd-ram".
> + - reg : Address range(s) of the mtd chip(s)
>    It's possible to (optionally) define multiple "reg" tuples so that
> -   non-identical NOR chips can be described in one flash node.
> - - bank-width : Width (in bytes) of the flash bank.  Equal to the
> +   non-identical chips can be described in one node.
> + - bank-width : Width (in bytes) of the bank.  Equal to the
>    device width times the number of interleaved chips.
> - - device-width : (optional) Width of a single flash chip.  If
> + - device-width : (optional) Width of a single mtd chip.  If
>    omitted, assumed to be equal to 'bank-width'.
> - - #address-cells, #size-cells : Must be present if the flash has
> + - #address-cells, #size-cells : Must be present if the device has
>    sub-nodes representing partitions (see below).  In this case
>    both #address-cells and #size-cells must be equal to 1.
>
> @@ -22,24 +23,24 @@ are defined:
>  - vendor-id : Contains the flash chip's vendor id (1 byte).
>  - device-id : Contains the flash chip's device id (1 byte).
>
> -In addition to the information on the flash bank itself, the
> +In addition to the information on the mtd bank itself, the
>  device tree may optionally contain additional information
> -describing partitions of the flash address space.  This can be
> +describing partitions of the address space.  This can be
>  used on platforms which have strong conventions about which
> -portions of the flash are used for what purposes, but which don't
> +portions of a flash are used for what purposes, but which don't
>  use an on-flash partition table such as RedBoot.
>
> -Each partition is represented as a sub-node of the flash device.
> +Each partition is represented as a sub-node of the mtd device.
>  Each node's name represents the name of the corresponding
> -partition of the flash device.
> +partition of the mtd device.
>
>  Flash partitions
> - - reg : The partition's offset and size within the flash bank.
> - - label : (optional) The label / name for this flash partition.
> + - reg : The partition's offset and size within the mtd bank.
> + - label : (optional) The label / name for this partition.
>    If omitted, the label is taken from the node name (excluding
>    the unit address).
>  - read-only : (optional) This parameter, if present, is a hint to
> -   Linux that this flash partition should only be mounted
> +   Linux that this partition should only be mounted
>    read-only.  This is usually used for flash partitions
>    containing early-boot firmware images or data which should not
>    be clobbered.
> @@ -78,3 +79,12 @@ Here an example with multiple "reg" tuples:
>                        reg = <0 0x04000000>;
>                };
>        };
> +
> +An example using SRAM:
> +
> +       sram at 2,0 {
> +               compatible = "samsung,k6f1616u6a", "mtd-ram";
> +               reg = <2 0 0x00200000>;
> +               bank-width = <2>;
> +       };
> +
> diff --git a/drivers/mtd/maps/physmap_of.c b/drivers/mtd/maps/physmap_of.c
> index 39d357b..45eee20 100644
> --- a/drivers/mtd/maps/physmap_of.c
> +++ b/drivers/mtd/maps/physmap_of.c
> @@ -360,6 +360,10 @@ static struct of_device_id of_flash_match[] = {
>                .data           = (void *)"jedec_probe",
>        },
>        {
> +               .compatible     = "mtd-ram",
> +               .data           = (void *)"map_ram",
> +       },
> +       {
>                .type           = "rom",
>                .compatible     = "direct-mapped"
>        },
> --
> 1.6.3.1
>
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev at lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/linuxppc-dev



-- 
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.


More information about the Linuxppc-dev mailing list