From: Ben Dooks <ben-linux@fluff.org>
To: Magnus Damm <magnus.damm@gmail.com>
Cc: Ben Dooks <ben-linux@fluff.org>,
linux-sh@vger.kernel.org, gregkh@suse.de,
linux-kernel@vger.kernel.org, lethal@linux-sh.org,
i2c@lm-sensors.org, akpm@linux-foundation.org,
RMK <rmk@arm.linux.org.uk>
Subject: Re: [i2c] [PATCH 04/05] i2c-sh_mobile: IORESOURCE_CLK support
Date: Wed, 13 Aug 2008 06:54:53 +0100 [thread overview]
Message-ID: <20080813055452.GG2716@fluff.org.uk> (raw)
In-Reply-To: <aec7e5c30807180218y1911d3d3h2e80f5a097a79a14@mail.gmail.com>
On Fri, Jul 18, 2008 at 06:18:06PM +0900, Magnus Damm wrote:
> On Fri, Jul 18, 2008 at 5:04 PM, Ben Dooks <ben-linux@fluff.org> wrote:
> > On Fri, Jul 18, 2008 at 04:40:36PM +0900, Magnus Damm wrote:
> >> From: Magnus Damm <damm@igel.co.jp>
> >>
> >> This patch makes the i2c-sh_mobile driver get the clock name from the
> >> struct resource with type IORESOURCE_CLK provided by the platform data.
> >>
> >> Signed-off-by: Magnus Damm <damm@igel.co.jp>
> >> ---
> >>
> >> drivers/i2c/busses/i2c-sh_mobile.c | 8 +++++++-
> >> 1 file changed, 7 insertions(+), 1 deletion(-)
> >>
> >> --- 0001/drivers/i2c/busses/i2c-sh_mobile.c
> >> +++ work/drivers/i2c/busses/i2c-sh_mobile.c 2008-07-18 14:56:40.000000000 +0900
> >> @@ -390,13 +390,19 @@ static int sh_mobile_i2c_probe(struct pl
> >> int size;
> >> int ret;
> >>
> >> + res = platform_get_resource(dev, IORESOURCE_CLK, 0);
> >> + if (res == NULL || res->name == NULL) {
> >> + dev_err(&dev->dev, "cannot find CLK resource\n");
> >> + return -ENOENT;
> >> + }
I note in this one you are re-using the resource.name field in the way
it was not intended to be used. This field is for use to differentiate
resources where this is more than one of them and they may not all be
present in the list. This is not a good course of action.
> >> pd = kzalloc(sizeof(struct sh_mobile_i2c_data), GFP_KERNEL);
> >> if (pd == NULL) {
> >> dev_err(&dev->dev, "cannot allocate private data\n");
> >> return -ENOMEM;
> >> }
> >>
> >> - pd->clk = clk_get(&dev->dev, "peripheral_clk");
> >
> > I think that is working correctly and there isn't really any
> > need to change this. The clk_get is supplied the device that
> > it needs the clock for, and the name of the clock needed.
>
> Right, we could handle this "under the hood" of the clock frame work
> implementation, or we could deal with it together with the rest of the
> platform data and have one unique string per hardware block. On SuperH
> Mobile we currently have one shared clock implementation that supports
> multiple processors. Which clock that is assigned to what hardware
> block is currently handled by per-cpu platform data, and that's where
> this patch comes in.
We have a shared implementation for the s3c24xx, which all have subtly
different clock requirements and we change the clock registration for
the chip, instead of trying to subvert the platform system. I do not
see this as being "under the hood", changing resources at registration
time is done all over the place.
Techincally, if there is only one clock per block, then you don't
actually need a name, just supply the device that you are looking up
a clock for.
Note, added Russell King to the discussion, as he is the original
authour of the clock framework anyway.
--
Ben (ben@fluff.org, http://www.fluff.org/)
'a smiley only costs 4 bytes'
next prev parent reply other threads:[~2008-08-13 5:54 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-07-18 7:40 [PATCH 00/05] resource: type, size and IORESOURCE_CLK patches V2 Magnus Damm
2008-07-18 7:40 ` [PATCH 01/05] resource: add resource_size() Magnus Damm
2008-07-18 7:54 ` Ben Dooks
2008-07-18 7:40 ` [PATCH 02/05] resource: add resource_type() and IORESOURCE_TYPE_BITS Magnus Damm
2008-07-18 7:56 ` Ben Dooks
2008-07-18 8:24 ` Magnus Damm
2008-07-18 8:33 ` Ben Dooks
2008-07-18 9:05 ` Magnus Damm
2008-07-18 7:40 ` [PATCH 03/05] resource: add new IORESOURCE_CLK type V2 Magnus Damm
2008-07-18 7:53 ` [i2c] " Ben Dooks
2008-07-18 8:53 ` Magnus Damm
2008-07-18 7:40 ` [PATCH 04/05] i2c-sh_mobile: IORESOURCE_CLK support Magnus Damm
2008-07-18 8:04 ` Ben Dooks
2008-07-18 9:18 ` Magnus Damm
2008-08-13 5:54 ` Ben Dooks [this message]
2008-08-13 7:51 ` [i2c] " Russell King
2008-07-18 7:40 ` [PATCH 05/05] sh: add IORESOURCE_CLK to SuperH Mobile I2C platform data Magnus Damm
2008-07-18 23:36 ` Andrew Morton
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=20080813055452.GG2716@fluff.org.uk \
--to=ben-linux@fluff.org \
--cc=akpm@linux-foundation.org \
--cc=gregkh@suse.de \
--cc=i2c@lm-sensors.org \
--cc=lethal@linux-sh.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-sh@vger.kernel.org \
--cc=magnus.damm@gmail.com \
--cc=rmk@arm.linux.org.uk \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox