From: Stephen Warren <swarren-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
To: Hiroshi Doyu <hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
Cc: "grant.likely-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org"
<grant.likely-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>,
"thierry.reding-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org"
<thierry.reding-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>,
"robherring2-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org"
<robherring2-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>,
"joro-zLv9SwRftAIdnm+yROfE0A@public.gmane.org"
<joro-zLv9SwRftAIdnm+yROfE0A@public.gmane.org>,
Stephen Warren <swarren-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>,
"will.deacon-5wv7dgnIgG8@public.gmane.org"
<will.deacon-5wv7dgnIgG8@public.gmane.org>,
"mark.rutland-5wv7dgnIgG8@public.gmane.org"
<mark.rutland-5wv7dgnIgG8@public.gmane.org>,
"devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org"
<devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>,
"iommu-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org"
<iommu-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org>,
"linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org"
<linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>,
"linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org"
<linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org>,
"lorenzo.pieralisi-5wv7dgnIgG8@public.gmane.org"
<lorenzo.pieralisi-5wv7dgnIgG8@public.gmane.org>,
"galak-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org"
<galak-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org>,
"linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org"
<linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>
Subject: Re: [RFC][PATCHv6+++ 01/13] of: introduce of_property_for_earch_phandle_with_args()
Date: Sun, 01 Dec 2013 12:00:09 -0700 [thread overview]
Message-ID: <529B8739.60701@wwwdotorg.org> (raw)
In-Reply-To: <20131129.134625.431945240074254704.hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
On 11/29/2013 04:46 AM, Hiroshi Doyu wrote:
...
> Iterating over a property containing a list of phandles with arguments
> is a common operation for device drivers. This patch adds a new
> of_property_for_each_phandle_with_args() macro to make the iteration
> simpler.
>
> Introduced a new struct "of_phandle_iter" to keep the state when
> iterating over the list.
>
> Signed-off-by: Hiroshi Doyu <hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
> ---
> v6+++:
Surely that's v9; "+++" is rather unusual.
> diff --git a/drivers/of/base.c b/drivers/of/base.c
> +void of_phandle_iter_next(struct of_phandle_iter *iter,
> + struct of_phandle_args *out_args)
> +{
> + phandle phandle;
> + struct device_node *dn;
> + int i, count = iter->cell_count;
> +
> + iter->err = -EINVAL;
> + if (!iter->cells_name && !iter->cell_count)
> + return;
Wasn't that already checked in _start()?
Why not set err = -EINVAL inside the if, rather than setting it to an
error value here by default, then having to over-write it at the end of
the function?
> +static void __of_phandle_iter_set(struct of_phandle_iter *iter,
This is only used in one place; why not simply inline this into
of_phandle_iter_start()? It would make the code simpler.
> +void of_phandle_iter_start(struct of_phandle_iter *iter,
> + iter->cells_name = cells_name;
> + iter->cell_count = cell_count;
Why not pass these values into of_phandle_iter_next() instead? There's
no need to pass them just to _start() so they can be read by _next()
instead.
> diff --git a/include/linux/of.h b/include/linux/of.h
> +/*
> + * keep the state at iterating a list of phandles with variable number
> + * of args
> + */
> +struct of_phandle_iter {
> + int err;
> + const __be32 *cur; /* current phandle */
> + const __be32 *end; /* end of the last phandle */
Can't you detect an error case by e.g. (cur == NULL) and thus avoid
requiring an explicit err field?
Together with removing:
> + const char *cells_name;
> + int cell_count;
... then you'd only be left with cur/end, so I think you could get away
without a struct at all, but simply "cur" as the iterator variable, plus
"end" as the one temp variable.
WARNING: multiple messages have this Message-ID (diff)
From: swarren@wwwdotorg.org (Stephen Warren)
To: linux-arm-kernel@lists.infradead.org
Subject: [RFC][PATCHv6+++ 01/13] of: introduce of_property_for_earch_phandle_with_args()
Date: Sun, 01 Dec 2013 12:00:09 -0700 [thread overview]
Message-ID: <529B8739.60701@wwwdotorg.org> (raw)
In-Reply-To: <20131129.134625.431945240074254704.hdoyu@nvidia.com>
On 11/29/2013 04:46 AM, Hiroshi Doyu wrote:
...
> Iterating over a property containing a list of phandles with arguments
> is a common operation for device drivers. This patch adds a new
> of_property_for_each_phandle_with_args() macro to make the iteration
> simpler.
>
> Introduced a new struct "of_phandle_iter" to keep the state when
> iterating over the list.
>
> Signed-off-by: Hiroshi Doyu <hdoyu@nvidia.com>
> ---
> v6+++:
Surely that's v9; "+++" is rather unusual.
> diff --git a/drivers/of/base.c b/drivers/of/base.c
> +void of_phandle_iter_next(struct of_phandle_iter *iter,
> + struct of_phandle_args *out_args)
> +{
> + phandle phandle;
> + struct device_node *dn;
> + int i, count = iter->cell_count;
> +
> + iter->err = -EINVAL;
> + if (!iter->cells_name && !iter->cell_count)
> + return;
Wasn't that already checked in _start()?
Why not set err = -EINVAL inside the if, rather than setting it to an
error value here by default, then having to over-write it at the end of
the function?
> +static void __of_phandle_iter_set(struct of_phandle_iter *iter,
This is only used in one place; why not simply inline this into
of_phandle_iter_start()? It would make the code simpler.
> +void of_phandle_iter_start(struct of_phandle_iter *iter,
> + iter->cells_name = cells_name;
> + iter->cell_count = cell_count;
Why not pass these values into of_phandle_iter_next() instead? There's
no need to pass them just to _start() so they can be read by _next()
instead.
> diff --git a/include/linux/of.h b/include/linux/of.h
> +/*
> + * keep the state at iterating a list of phandles with variable number
> + * of args
> + */
> +struct of_phandle_iter {
> + int err;
> + const __be32 *cur; /* current phandle */
> + const __be32 *end; /* end of the last phandle */
Can't you detect an error case by e.g. (cur == NULL) and thus avoid
requiring an explicit err field?
Together with removing:
> + const char *cells_name;
> + int cell_count;
... then you'd only be left with cur/end, so I think you could get away
without a struct at all, but simply "cur" as the iterator variable, plus
"end" as the one temp variable.
WARNING: multiple messages have this Message-ID (diff)
From: Stephen Warren <swarren@wwwdotorg.org>
To: Hiroshi Doyu <hdoyu@nvidia.com>
Cc: "grant.likely@linaro.org" <grant.likely@linaro.org>,
"thierry.reding@gmail.com" <thierry.reding@gmail.com>,
"robherring2@gmail.com" <robherring2@gmail.com>,
"joro@8bytes.org" <joro@8bytes.org>,
Stephen Warren <swarren@nvidia.com>,
"will.deacon@arm.com" <will.deacon@arm.com>,
"mark.rutland@arm.com" <mark.rutland@arm.com>,
"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>,
"iommu@lists.linux-foundation.org"
<iommu@lists.linux-foundation.org>,
"linux-tegra@vger.kernel.org" <linux-tegra@vger.kernel.org>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"lorenzo.pieralisi@arm.com" <lorenzo.pieralisi@arm.com>,
"galak@codeaurora.org" <galak@codeaurora.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [RFC][PATCHv6+++ 01/13] of: introduce of_property_for_earch_phandle_with_args()
Date: Sun, 01 Dec 2013 12:00:09 -0700 [thread overview]
Message-ID: <529B8739.60701@wwwdotorg.org> (raw)
In-Reply-To: <20131129.134625.431945240074254704.hdoyu@nvidia.com>
On 11/29/2013 04:46 AM, Hiroshi Doyu wrote:
...
> Iterating over a property containing a list of phandles with arguments
> is a common operation for device drivers. This patch adds a new
> of_property_for_each_phandle_with_args() macro to make the iteration
> simpler.
>
> Introduced a new struct "of_phandle_iter" to keep the state when
> iterating over the list.
>
> Signed-off-by: Hiroshi Doyu <hdoyu@nvidia.com>
> ---
> v6+++:
Surely that's v9; "+++" is rather unusual.
> diff --git a/drivers/of/base.c b/drivers/of/base.c
> +void of_phandle_iter_next(struct of_phandle_iter *iter,
> + struct of_phandle_args *out_args)
> +{
> + phandle phandle;
> + struct device_node *dn;
> + int i, count = iter->cell_count;
> +
> + iter->err = -EINVAL;
> + if (!iter->cells_name && !iter->cell_count)
> + return;
Wasn't that already checked in _start()?
Why not set err = -EINVAL inside the if, rather than setting it to an
error value here by default, then having to over-write it at the end of
the function?
> +static void __of_phandle_iter_set(struct of_phandle_iter *iter,
This is only used in one place; why not simply inline this into
of_phandle_iter_start()? It would make the code simpler.
> +void of_phandle_iter_start(struct of_phandle_iter *iter,
> + iter->cells_name = cells_name;
> + iter->cell_count = cell_count;
Why not pass these values into of_phandle_iter_next() instead? There's
no need to pass them just to _start() so they can be read by _next()
instead.
> diff --git a/include/linux/of.h b/include/linux/of.h
> +/*
> + * keep the state at iterating a list of phandles with variable number
> + * of args
> + */
> +struct of_phandle_iter {
> + int err;
> + const __be32 *cur; /* current phandle */
> + const __be32 *end; /* end of the last phandle */
Can't you detect an error case by e.g. (cur == NULL) and thus avoid
requiring an explicit err field?
Together with removing:
> + const char *cells_name;
> + int cell_count;
... then you'd only be left with cur/end, so I think you could get away
without a struct at all, but simply "cur" as the iterator variable, plus
"end" as the one temp variable.
next prev parent reply other threads:[~2013-12-01 19:00 UTC|newest]
Thread overview: 100+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-11-21 13:40 [PATCHv6 00/13] Unifying SMMU driver among Tegra SoCs Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
[not found] ` < 1385041249-7705-2-git-send-email-hdoyu@nvidia.com>
2013-11-21 13:40 ` [PATCHv6 01/13] of: introduce of_property_for_earch_phandle_with_args() Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
[not found] ` <1385041249-7705-2-git-send-email-hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-11-21 17:17 ` [PATCHv6+ " Hiroshi Doyu
2013-11-21 17:17 ` Hiroshi Doyu
2013-11-21 17:17 ` Hiroshi Doyu
[not found] ` <20131121.191720.1487772262083864095.hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-11-21 18:57 ` Stephen Warren
2013-11-21 18:57 ` Stephen Warren
2013-11-21 18:57 ` Stephen Warren
[not found] ` <528E577C.2050506-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
2013-11-28 12:58 ` [RFC][PATCHv6++ " Hiroshi Doyu
2013-11-28 12:58 ` Hiroshi Doyu
2013-11-28 12:58 ` Hiroshi Doyu
[not found] ` <20131128.145818.1345100874304396564.hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-11-29 11:46 ` [RFC][PATCHv6+++ " Hiroshi Doyu
2013-11-29 11:46 ` Hiroshi Doyu
2013-11-29 11:46 ` Hiroshi Doyu
[not found] ` <20131129.134625.431945240074254704.hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-12-01 19:00 ` Stephen Warren [this message]
2013-12-01 19:00 ` Stephen Warren
2013-12-01 19:00 ` Stephen Warren
[not found] ` <529B8739.60701-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
2013-12-02 11:02 ` Hiroshi Doyu
2013-12-02 11:02 ` Hiroshi Doyu
2013-12-02 11:02 ` Hiroshi Doyu
[not found] ` <20131202.130220.1404999403649937134.hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-12-02 14:39 ` Rob Herring
2013-12-02 14:39 ` Rob Herring
2013-12-02 14:39 ` Rob Herring
[not found] ` <CAL_JsqKDokswB1jJN7ZT-Us0h=uTf5qHLZFUJfGFkXBjdO5XjA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2013-12-03 6:46 ` Hiroshi Doyu
2013-12-03 6:46 ` Hiroshi Doyu
2013-12-03 6:46 ` Hiroshi Doyu
2013-12-03 20:14 ` Stephen Warren
2013-12-03 20:14 ` Stephen Warren
2013-12-03 20:14 ` Stephen Warren
2013-12-11 13:28 ` [PATCHv6+ " Grant Likely
2013-12-11 13:28 ` Grant Likely
2013-12-11 13:28 ` Grant Likely
[not found] ` <20131211132845.5461FC4061A-WNowdnHR2B42iJbIjFUEsiwD8/FfD2ys@public.gmane.org>
2013-12-11 13:33 ` Hiroshi Doyu
2013-12-11 13:33 ` Hiroshi Doyu
2013-12-11 13:33 ` Hiroshi Doyu
2013-12-11 13:33 ` Hiroshi Doyu
[not found] ` < 20131211.153338.2186623380643957232.hdoyu@nvidia.com>
[not found] ` <20131211.153338.2186623380643957232.hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-12-12 11:34 ` Grant Likely
2013-12-12 11:34 ` Grant Likely
2013-12-12 11:34 ` Grant Likely
[not found] ` <20131212113417.BDCD0C40637-WNowdnHR2B42iJbIjFUEsiwD8/FfD2ys@public.gmane.org>
2013-12-12 12:14 ` Hiroshi Doyu
2013-12-12 12:14 ` Hiroshi Doyu
2013-12-12 12:14 ` Hiroshi Doyu
[not found] ` <20131212.141404.684884000513445038.hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-12-14 15:51 ` Hiroshi Doyu
2013-12-14 15:51 ` Hiroshi Doyu
2013-12-14 15:51 ` Hiroshi Doyu
[not found] ` <20131214.175115.1251935659998248370.hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-12-16 17:14 ` Stephen Warren
2013-12-16 17:14 ` Stephen Warren
2013-12-16 17:14 ` Stephen Warren
2013-12-11 13:27 ` Grant Likely
2013-12-11 13:27 ` Grant Likely
2013-12-11 13:27 ` Grant Likely
[not found] ` <1385041249-7705-1-git-send-email-hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-11-21 13:40 ` [PATCHv6 02/13] iommu/of: introduce a global iommu device list Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 03/13] iommu/of: check if dependee iommu is ready or not Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 04/13] driver/core: populate devices in order for IOMMUs Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 05/13] iommu/core: add ops->{bound,unbind}_driver() Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
[not found] ` <1385041249-7705-6-git-send-email-hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-11-25 13:49 ` Hiroshi Doyu
2013-11-25 13:49 ` Hiroshi Doyu
2013-11-25 13:49 ` Hiroshi Doyu
[not found] ` <20131125154937.d6dbe9aedc16aab335d92f99-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-12-04 7:40 ` Hiroshi Doyu
2013-12-04 7:40 ` Hiroshi Doyu
2013-12-04 7:40 ` Hiroshi Doyu
[not found] ` <20131204094027.dad1288aec14551ec42f3743-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2013-12-04 10:01 ` Will Deacon
2013-12-04 10:01 ` Will Deacon
2013-12-04 10:01 ` Will Deacon
2013-11-21 13:40 ` [PATCHv6 06/13] ARM: tegra: create a DT header defining SWGROUP ID Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 07/13] iommu/tegra: smmu: register device to iommu dynamically Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 08/13] iommu/tegra: smmu: calculate ASID register offset by ID Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 09/13] iommu/tegra: smmu: get swgroups from DT "iommus=" Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 10/13] iommu/tegra: smmu: allow duplicate ASID wirte Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 11/13] iommu/tegra: smmu: Rename hwgrp -> swgroups Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 12/13] iommu/tegra: smmu: add SMMU to an global iommu list Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` [PATCHv6 13/13] [FOR TEST] ARM: dt: tegra30: add "iommus" binding Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
2013-11-21 13:40 ` Hiroshi Doyu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=529B8739.60701@wwwdotorg.org \
--to=swarren-3lzwwm7+weoh9zmkesr00q@public.gmane.org \
--cc=devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=galak-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org \
--cc=grant.likely-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org \
--cc=hdoyu-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org \
--cc=iommu-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org \
--cc=joro-zLv9SwRftAIdnm+yROfE0A@public.gmane.org \
--cc=linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org \
--cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=lorenzo.pieralisi-5wv7dgnIgG8@public.gmane.org \
--cc=mark.rutland-5wv7dgnIgG8@public.gmane.org \
--cc=robherring2-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
--cc=swarren-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org \
--cc=thierry.reding-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
--cc=will.deacon-5wv7dgnIgG8@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.