From: Nishanth Menon <nm@ti.com>
To: "felipe.balbi@nokia.com" <felipe.balbi@nokia.com>
Cc: Linux-Omap <linux-omap@vger.kernel.org>,
"K, Ambresh" <ambresh@ti.com>,
"Cousson, Benoit" <b-cousson@ti.com>,
"Valentin Eduardo (Nokia-D/Helsinki)"
<eduardo.valentin@nokia.com>,
Kevin Hilman <khilman@deeprootsystems.com>,
"Carmody Phil.2 (EXT-Ixonos/Helsinki)"
<ext-phil.2.carmody@nokia.com>, "Premi, Sanjeev" <premi@ti.com>,
"Kristo Tero (Nokia-D/Tampere)" <Tero.Kristo@nokia.com>,
"Gopinath, Thara" <thara@ti.com>
Subject: Re: [PM-WIP-OPP][PATCH 3/4] omap: pm: opp: add ability to store data per opp
Date: Fri, 19 Mar 2010 10:25:18 -0500 [thread overview]
Message-ID: <4BA3975E.70206@ti.com> (raw)
In-Reply-To: <20100319144333.GU18995@nokia.com>
Felipe Balbi had written, on 03/19/2010 09:43 AM, the following:
> hi,
>
> On Thu, Mar 18, 2010 at 07:44:50PM +0100, ext Nishanth Menon wrote:
>> +int opp_store_data(struct omap_opp *opp, char *name, void *data)
>> +{
>> + return -EINVAL;
>
> Would -ENODATA fit better ??
wondered later on if 0 is better here and get_data with -ENODATA - for
the actual code also..
>
>> diff --git a/arch/arm/plat-omap/opp.c b/arch/arm/plat-omap/opp.c
>> index bb8120e..15f6f7c 100644
>> --- a/arch/arm/plat-omap/opp.c
>> +++ b/arch/arm/plat-omap/opp.c
>> @@ -14,12 +14,19 @@
>> #include <linux/errno.h>
>> #include <linux/err.h>
>> #include <linux/init.h>
>> +#include <linux/list.h>
>> #include <linux/slab.h>
>> #include <linux/cpufreq.h>
>>
>> #include <plat/opp_twl_tps.h>
>> #include <plat/opp.h>
>>
>> +struct omap_opp_data {
>> + char *name;
>> + void *data;
>> + struct list_head list;
>> +};
>> +
>> /**
>> * struct omap_opp - OMAP OPP description structure
>> * @enabled: true/false - marking this OPP as enabled/disabled
>> @@ -37,6 +44,7 @@ struct omap_opp {
>> unsigned long rate;
>> unsigned long u_volt;
>> u8 opp_id;
>> + struct list_head data_list;
>> };
>>
>> /*
>> @@ -218,6 +226,7 @@ static void omap_opp_populate(struct omap_opp *opp,
>> opp->rate = opp_def->freq;
>> opp->enabled = opp_def->enabled;
>> opp->u_volt = opp_def->u_volt;
>> + INIT_LIST_HEAD(&opp->data_list);
>> }
>>
>> int opp_add(enum opp_t opp_type, const struct omap_opp_def *opp_def)
>> @@ -352,6 +361,63 @@ int opp_disable(struct omap_opp *opp)
>> return 0;
>> }
>>
>> +void *opp_get_data(struct omap_opp *opp, char *name)
>> +{
>> + void *data = ERR_PTR(-EINVAL);
>> + struct omap_opp_data *tmp;
>> +
>> + if (unlikely(!opp || !name))
>> + return ERR_PTR(-EINVAL);
>> +
>> + list_for_each_entry(tmp, &opp->data_list, list)
>> + if (!strcmp(name, tmp->name)) {
>> + data = tmp->data;
>> + break;
>> + }
>> + return data;
>> +}
>> +
>> +int opp_store_data(struct omap_opp *opp, char *name, void *data)
>> +{
>> + struct omap_opp_data *new;
>> + if (unlikely(!opp || !name))
>> + return -EINVAL;
>> + /* NAK to double registration */
>> + if (unlikely(!IS_ERR(opp_get_data(opp, name))))
>> + return -EINVAL;
>> +
>> + new = kmalloc(sizeof(struct omap_opp), GFP_KERNEL);
>> + if (!new)
>> + return -ENOMEM;
>> + new->name = kmalloc(strlen(name) + 1, GFP_KERNEL);
>> + if (!new->name) {
>> + kfree(new);
>> + return -ENOMEM;
>> + }
>> + new->data = data;
>> + strcpy(new->name, name);
>> + INIT_LIST_HEAD(&new->list);
>> + list_add(&new->list, &opp->data_list);
>> + return 0;
>> +}
>
> will you really want to add several data entries there ? I don't see the
> point. Maybe I'm missing something.
>
> I like the idea of having a void * to allow you to store anything there.
> But generally that's a 1 - 1 relation:
>
> 1 device/bus/(in this case) opp - 1 data.
I think I am lost here -> why device/bus/opp? this is a 1-many
relationship. here is an example of it:
OPP by definition is a tuple (voltage,frequency).
for each OPP, we may have additional information which is custom to a
specific SOC ->
OMAP2 and OMAP1 have no SR module -> so I dont need to store SR nTarget
value.
data type 1: OMAP34xx and OMAP3630 have SR, and nTarget is a *per chip*
calibration value specific to an OPP -however, we have 5 OPPs (or upto 7
in the case of 3440 etc.) in omap34xx while omap3630 has upto 4 OPPs.
in omap3630, we use ABB data which is in addition to nTarget (if my
meager understanding of this is right)..
data type 2: The dependency of vdd1 OPP to vdd2 opp is variant based on SOC.
the types of data which is stored per OPP is changing all the time and
in future we will have varied data again.
Now, based on your proposal as I understand,
struct omap2_data {
blah_o21
blah_o22
};
struct omap3_data {
blah_o31
blah_o32
blah_o33
}
struct omap4_data {
blah_o41
blah_o42
blah_o31
blah_o32
}
and so on (remember we may have shared or similar data between various
SOCs at times)
redundancy, maintenance are the problems i see other than ability to
have a module which uses blah_o31 to be generic and not know the
difference between struct omap3_data and omap4_data
the resultant module code will look like:
if (cpu_is_omap3430()) {
my_blaho31 = ((struct omap3_data *) get_opp_data(opp))->blah_o31;
} else if cpu_is...() {
..
}
now in the approach I took,
you could have:
struct sr_ntarget_type{
unsigned long nTarget;
something else if needed
}
And in SR driver, the module doesnot need to care which silicon it is
running on.. it just does opp_get_data(opp,"sr_ntarget") and gets the
correct data for that silicon on that OPP. It is much simpler and
similar to the manner implemented in many other frameworks such as clock
etc..
[...]
--
Regards,
Nishanth Menon
next prev parent reply other threads:[~2010-03-19 15:25 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-03-18 18:44 [PM-WIP-OPP][PATCH 0/4] few opp layer cleanups Nishanth Menon
2010-03-18 18:44 ` [PM-WIP-OPP][PATCH 1/4] omap3: pm: cpufreq: BUG_ON cleanup Nishanth Menon
2010-03-18 18:44 ` [PM-WIP-OPP][PATCH 2/4] omap: pm: opp: twl: use DIV_ROUND_UP Nishanth Menon
2010-03-18 18:44 ` [PM-WIP-OPP][PATCH 3/4] omap: pm: opp: add ability to store data per opp Nishanth Menon
2010-03-18 18:44 ` [PM-WIP-OPP][PATCH 4/4] omap3: srf: remove hardcoded opp dependency Nishanth Menon
2010-03-19 14:47 ` Felipe Balbi
2010-03-19 15:36 ` Nishanth Menon
2010-03-19 10:14 ` [PM-WIP-OPP][PATCH 3/4] omap: pm: opp: add ability to store data per opp Cousson, Benoit
2010-03-19 14:27 ` Nishanth Menon
2010-03-19 14:43 ` Felipe Balbi
2010-03-19 15:25 ` Nishanth Menon [this message]
2010-03-19 17:47 ` Felipe Balbi
2010-03-19 18:10 ` Nishanth Menon
2010-03-21 21:50 ` Cousson, Benoit
2010-03-22 13:29 ` Nishanth Menon
2010-03-22 17:46 ` Cousson, Benoit
2010-03-22 18:25 ` Nishanth Menon
2010-03-23 5:06 ` Gopinath, Thara
2010-03-23 13:00 ` Nishanth Menon
2010-03-23 16:12 ` Cousson, Benoit
2010-03-23 20:04 ` Nishanth Menon
2010-03-18 22:49 ` [PM-WIP-OPP][PATCH 1/4] omap3: pm: cpufreq: BUG_ON cleanup Kevin Hilman
2010-03-19 14:21 ` Nishanth Menon
2010-03-19 14:50 ` Felipe Balbi
2010-03-19 17:46 ` Kevin Hilman
2010-03-19 17:52 ` Felipe Balbi
2010-03-19 18:42 ` Kevin Hilman
2010-03-19 19:56 ` Nishanth Menon
2010-03-19 20:49 ` Kevin Hilman
2010-03-19 21:53 ` Nishanth Menon
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=4BA3975E.70206@ti.com \
--to=nm@ti.com \
--cc=Tero.Kristo@nokia.com \
--cc=ambresh@ti.com \
--cc=b-cousson@ti.com \
--cc=eduardo.valentin@nokia.com \
--cc=ext-phil.2.carmody@nokia.com \
--cc=felipe.balbi@nokia.com \
--cc=khilman@deeprootsystems.com \
--cc=linux-omap@vger.kernel.org \
--cc=premi@ti.com \
--cc=thara@ti.com \
/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