[PATCH 01/42] state: Make pointing to the backend using a phandle the only supported method
Jan Remmet
J.Remmet at phytec.de
Mon May 15 02:18:00 PDT 2017
On Fri, Mar 31, 2017 at 09:03:05AM +0200, Sascha Hauer wrote:
> All other methods are broken for some time already: When starting the
> kernel the state code rewrites the state node in the device tree and
> replaced the "backend" property with a phandle - even when the target
> can't be described as a phandle. Since using phandles is the nicest way
> to point to the storage device anyway remove the other methods.
Is there a way to use block devices as storage? On eMMC we use mtd style
partitios inside the sd/mmc host node to access barebox and
barebox-environment. But using this barebox-state didn't find the backend
path.
Jan
>
> Signed-off-by: Sascha Hauer <s.hauer at pengutronix.de>
> ---
> .../devicetree/bindings/barebox/barebox,state.rst | 27 ++++++++++++++++------
> common/state/state.c | 21 ++++++++---------
> 2 files changed, 29 insertions(+), 19 deletions(-)
>
> diff --git a/Documentation/devicetree/bindings/barebox/barebox,state.rst b/Documentation/devicetree/bindings/barebox/barebox,state.rst
> index 438cc434a2..e9daa65f1a 100644
> --- a/Documentation/devicetree/bindings/barebox/barebox,state.rst
> +++ b/Documentation/devicetree/bindings/barebox/barebox,state.rst
> @@ -29,7 +29,8 @@ Required properties:
>
> * ``compatible``: should be ``barebox,state``;
> * ``magic``: A 32bit number used as a magic to identify the state
> -* ``backend``: describes where the data for this state is stored
> +* ``backend``: contains a phandle to the device/partition which holds the
> + actual state data.
> * ``backend-type``: should be ``raw`` or ``dtb``.
>
> Optional properties:
> @@ -77,19 +78,31 @@ Example::
> magic = <0x27031977>;
> compatible = "barebox,state";
> backend-type = "raw";
> - backend = &eeprom, "partname:state";
> + backend = &state_part;
>
> foo {
> - reg = <0x00 0x4>;
> - type = "uint32";
> + reg = <0x00 0x4>;
> + type = "uint32";
> default = <0x0>;
> };
>
> bar {
> - reg = <0x10 0x4>;
> - type = "enum32";
> + reg = <0x10 0x4>;
> + type = "enum32";
> names = "baz", "qux";
> - default = <1>;
> + default = <1>;
> + };
> + };
> +
> + &nand_flash {
> + partitions {
> + compatible = "fixed-partitions";
> + #address-cells = <1>;
> + #size-cells = <1>;
> + state_part: state at 10000 {
> + label = "state";
> + reg = <0x10000 0x10000>;
> + };
> };
> };
>
> diff --git a/common/state/state.c b/common/state/state.c
> index 02bb1bb24a..6e6b3a6f08 100644
> --- a/common/state/state.c
> +++ b/common/state/state.c
> @@ -452,19 +452,16 @@ struct state *state_new_from_node(struct device_node *node, char *path,
> }
>
> if (!path) {
> - /* guess if of_path is a path, not a phandle */
> - if (of_path[0] == '/' && len > 1) {
> - ret = of_find_path(node, "backend", &path, 0);
> - } else {
> - struct device_node *partition_node;
> -
> - partition_node = of_parse_phandle(node, "backend", 0);
> - if (!partition_node)
> - goto out_release_state;
> -
> - of_path = partition_node->full_name;
> - ret = of_find_path_by_node(partition_node, &path, 0);
> + struct device_node *partition_node;
> +
> + partition_node = of_parse_phandle(node, "backend", 0);
> + if (!partition_node) {
> + dev_err(&state->dev, "Cannot resolve \"backend\" phandle\n");
> + goto out_release_state;
> }
> +
> + of_path = partition_node->full_name;
> + ret = of_find_path_by_node(partition_node, &path, 0);
> if (ret) {
> if (ret != -EPROBE_DEFER)
> dev_err(&state->dev, "state failed to parse path to backend: %s\n",
> --
> 2.11.0
>
>
> _______________________________________________
> barebox mailing list
> barebox at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/barebox
More information about the barebox
mailing list