Re: [PATCH v4 3/5] w1: core: match sub-nodes of bus masters in devicetree

From: Sebastian Reichel
Date: Fri Jul 06 2018 - 09:52:15 EST


Hi Greg & Evgeniy,

I suggest, that I take this patch and the DT bindings together
with the power-supply changes, once the bindings have been
reviewed by Rob (Herring). I will prepare an immutable branch,
that can be pulled into w1 as needed. Are you fine with this?

-- Sebastian

On Fri, Jul 06, 2018 at 07:35:50AM +0200, Daniel Mack wrote:
> Once a new slave device is detected, match it against all sub-nodes of the
> master bus controller. If a match is found, set the slave device's of_node
> pointer.
>
> Signed-off-by: Daniel Mack <daniel@xxxxxxxxxx>
> ---
> drivers/w1/w1.c | 3 +++
> include/linux/w1.h | 2 ++
> 2 files changed, 5 insertions(+)
>
> diff --git a/drivers/w1/w1.c b/drivers/w1/w1.c
> index caef0e0fd817..890c038c25f8 100644
> --- a/drivers/w1/w1.c
> +++ b/drivers/w1/w1.c
> @@ -26,6 +26,7 @@
> #include <linux/kthread.h>
> #include <linux/freezer.h>
> #include <linux/hwmon.h>
> +#include <linux/of.h>
>
> #include <linux/atomic.h>
>
> @@ -686,6 +687,8 @@ static int __w1_attach_slave_device(struct w1_slave *sl)
> sl->dev.bus = &w1_bus_type;
> sl->dev.release = &w1_slave_release;
> sl->dev.groups = w1_slave_groups;
> + sl->dev.of_node = of_find_matching_node(sl->master->dev.of_node,
> + sl->family->of_match_table);
>
> dev_set_name(&sl->dev, "%02x-%012llx",
> (unsigned int) sl->reg_num.family,
> diff --git a/include/linux/w1.h b/include/linux/w1.h
> index 694101f744c7..3111585c371f 100644
> --- a/include/linux/w1.h
> +++ b/include/linux/w1.h
> @@ -274,6 +274,8 @@ struct w1_family {
>
> struct w1_family_ops *fops;
>
> + const struct of_device_id *of_match_table;
> +
> atomic_t refcnt;
> };
>
> --
> 2.17.1
>

Attachment: signature.asc
Description: PGP signature