lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Wed, 6 Nov 2013 02:15:07 +0000
From:	Rongjun Ying <Rongjun.Ying@....com>
To:	Shawn Guo <shawn.guo@...aro.org>,
	Viresh Kumar <viresh.kumar@...aro.org>
CC:	rjying <rjying@...il.com>, "Rafael J. Wysocki" <rjw@...k.pl>,
	"cpufreq@...r.kernel.org" <cpufreq@...r.kernel.org>,
	"linux-pm@...r.kernel.org" <linux-pm@...r.kernel.org>,
	"Linux Kernel Mailing List" <linux-kernel@...r.kernel.org>,
	"rongjun.ying@...r.com" <rongjun.ying@...r.com>
Subject: RE: [PATCH 1/1] cpufreq: cpufreq-cpu0: use the max voltage instead
 of voltage-tolerance



> -----Original Message-----
> From: Shawn Guo [mailto:shawn.guo@...aro.org]
> Sent: Tuesday, November 05, 2013 7:53 PM
> To: Viresh Kumar
> Cc: rjying; Rafael J. Wysocki; cpufreq@...r.kernel.org; linux-
> pm@...r.kernel.org; Linux Kernel Mailing List; rongjun.ying@...r.com;
> Rongjun Ying
> Subject: Re: [PATCH 1/1] cpufreq: cpufreq-cpu0: use the max voltage
> instead of voltage-tolerance
> 
> On Tue, Nov 05, 2013 at 10:08:06AM +0530, Viresh Kumar wrote:
> > Adding shawn in cc list..
> >
> > On 5 November 2013 08:40, rjying <rjying@...il.com> wrote:
> > > From: Rongjun Ying <rongjun.ying@....com>
> > >
> > > Sometime the regulator can't supply appropriate voltages for
> requestion of cpu.
> > > All voltage tolerance value can't figure out a good voltage.
> 
> The voltage-tolerance is an optional device tree property.  You can
> omit it if you do not have a value for it.
> 
> Shawn

It bounced for some reason, trying to send again.

If omit voltage-tolerance, sometimes also can't get appropriate voltages.
For example:
If the regulator IC only can supply min voltage is 1.000V and max voltage is 1.200V, and cpu work max voltage is 1.200V.
But the cpu just need 1.100V when cpu run under a freq.
So regulator_set_voltage_tol will return failed. 
Because the regulator_set_voltage will invoke with min-uV is 1100000 and max-uV is 1100000 parameters.
Regulator can't supply it.
As this case, the regulator just need supply 1.200V.

RongJun Ying
> 
> > >
> > > Signed-off-by: Rongjun Ying <rongjun.ying@....com>
> > > ---
> > >  drivers/cpufreq/cpufreq-cpu0.c |   17 ++++++++++-------
> > >  1 files changed, 10 insertions(+), 7 deletions(-)
> > >
> > > diff --git a/drivers/cpufreq/cpufreq-cpu0.c
> > > b/drivers/cpufreq/cpufreq-cpu0.c index c522a95..0c9e6b9 100644
> > > --- a/drivers/cpufreq/cpufreq-cpu0.c
> > > +++ b/drivers/cpufreq/cpufreq-cpu0.c
> > > @@ -23,7 +23,7 @@
> > >  #include <linux/slab.h>
> > >
> > >  static unsigned int transition_latency; -static unsigned int
> > > voltage_tolerance; /* in percentage */
> > > +static unsigned int voltage_max;
> > >
> > >  static struct device *cpu_dev;
> > >  static struct clk *cpu_clk;
> > > @@ -45,7 +45,7 @@ static int cpu0_set_target(struct cpufreq_policy
> > > *policy,  {
> > >         struct cpufreq_freqs freqs;
> > >         struct opp *opp;
> > > -       unsigned long volt = 0, volt_old = 0, tol = 0;
> > > +       unsigned long volt = 0, volt_old = 0;
> > >         long freq_Hz, freq_exact;
> > >         unsigned int index;
> > >         int ret;
> > > @@ -82,7 +82,6 @@ static int cpu0_set_target(struct cpufreq_policy
> *policy,
> > >                 }
> > >                 volt = opp_get_voltage(opp);
> > >                 rcu_read_unlock();
> > > -               tol = volt * voltage_tolerance / 100;
> > >                 volt_old = regulator_get_voltage(cpu_reg);
> > >         }
> > >
> > > @@ -92,7 +91,7 @@ static int cpu0_set_target(struct cpufreq_policy
> > > *policy,
> > >
> > >         /* scaling up?  scale voltage before frequency */
> > >         if (!IS_ERR(cpu_reg) && freqs.new > freqs.old) {
> > > -               ret = regulator_set_voltage_tol(cpu_reg, volt, tol);
> > > +               ret = regulator_set_voltage(cpu_reg, volt,
> > > + voltage_max);
> > >                 if (ret) {
> > >                         pr_err("failed to scale voltage up: %d\n",
> ret);
> > >                         freqs.new = freqs.old; @@ -104,14 +103,14
> @@
> > > static int cpu0_set_target(struct cpufreq_policy *policy,
> > >         if (ret) {
> > >                 pr_err("failed to set clock rate: %d\n", ret);
> > >                 if (!IS_ERR(cpu_reg))
> > > -                       regulator_set_voltage_tol(cpu_reg, volt_old,
> tol);
> > > +                       regulator_set_voltage(cpu_reg, volt_old,
> > > + voltage_max);
> > >                 freqs.new = freqs.old;
> > >                 goto post_notify;
> > >         }
> > >
> > >         /* scaling down?  scale voltage after frequency */
> > >         if (!IS_ERR(cpu_reg) && freqs.new < freqs.old) {
> > > -               ret = regulator_set_voltage_tol(cpu_reg, volt, tol);
> > > +               ret = regulator_set_voltage(cpu_reg, volt,
> > > + voltage_max);
> > >                 if (ret) {
> > >                         pr_err("failed to scale voltage down: %d\n",
> ret);
> > >                         clk_set_rate(cpu_clk, freqs.old * 1000); @@
> > > -224,7 +223,11 @@ static int cpu0_cpufreq_probe(struct
> platform_device *pdev)
> > >                 goto out_put_node;
> > >         }
> > >
> > > -       of_property_read_u32(np, "voltage-tolerance",
> &voltage_tolerance);
> > > +       ret = of_property_read_u32(np, "voltage-max", &voltage_max);
> > > +       if (ret) {
> > > +               pr_err("failed to get max voltage: %d\n", ret);
> > > +               goto out_put_node;
> > > +       }
> > >
> > >         if (of_property_read_u32(np, "clock-latency",
> &transition_latency))
> > >                 transition_latency = CPUFREQ_ETERNAL;
> > > --
> > > 1.7.5.4
> > >
> 
> 
> 
>  To report this email as spam click
> https://www.mailcontrol.com/sr/MZbqvYs5QwJvpeaetUwhCQ==
> X88IR7qi8t8XvyHQDjR!61qPoTyr8GNFXkv3KeH4!zzvzA== .


Member of the CSR plc group of companies. CSR plc registered in England and Wales, registered number 4187346, registered office Churchill House, Cambridge Business Park, Cowley Road, Cambridge, CB4 0WZ, United Kingdom
More information can be found at www.csr.com. Follow CSR on Twitter at http://twitter.com/CSR_PLC and read our blog at www.csr.com/blog
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ