[PATCH 04/11] mtd: ofpart: do not fail probe when no partitions exist
Brian Norris
computersforpeace at gmail.com
Tue Jun 23 11:26:33 PDT 2015
On Wed, Jun 03, 2015 at 09:26:40PM -0000, Michal Suchanek wrote:
> On Exynos it is necessary to set SPI controller parameters that apply to
> a SPI slave in a DT subnode of the slave device. The ofpart code returns
> an error when there are subnodes of the SPI flash but no partitions are
> found. Change this condition to a warning so that flash without
> partitions can be accessed on Exynos.
So judging by the subsequent discussion, you're looking at handling
nodes like this:
flash at ... {
compatible = "m25p80";
...
controller-data {
samsung,spi-feedback-delay = <0>;
};
};
Now, I'm not a real fan of this controller-data node in the first place
(did that binding get reviewed?). But this is especially bad since
we now have collisions on what to do with subnodes that don't have a
compatible property. By legacy, ofpart has already claimed ownership of
subnodes of an MTD node, where the subnode does not have a compatible
property. See Documentation/devicetree/bindings/mtd/partition.txt:
"NOTE: if the sub-node has a compatible string, then it is not a
partition."
So it seems the natural solution is to just define a proper
compatibile property for this subnode, and ofpart.c will naturally
handle this. See:
commit e79265ba6bdb31437bd4c3e7911950f9d1262a07
Author: Josh Wu <josh.wu at atmel.com>
Date: Mon Aug 5 19:14:38 2013 +0800
mtd: ofpart: add compatible check for child nodes
Brian
> Signed-off-by: Michal Suchanek <hramrach at gmail.com>
> ---
> drivers/mtd/ofpart.c | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/mtd/ofpart.c b/drivers/mtd/ofpart.c
> index aa26c32..a29d29f 100644
> --- a/drivers/mtd/ofpart.c
> +++ b/drivers/mtd/ofpart.c
> @@ -94,10 +94,10 @@ static int parse_ofpart_partitions(struct mtd_info *master,
>
> if (!i) {
> of_node_put(pp);
> - pr_err("No valid partition found on %s\n", node->full_name);
> + pr_warn("No valid partition found on %s\n", node->full_name);
> kfree(*pparts);
> *pparts = NULL;
> - return -EINVAL;
> + return 0;
> }
>
> return nr_parts;
> --
> 2.1.4
>
More information about the linux-mtd
mailing list