[PATCHv3 0/7] cpufreq support for Marvell Armada XP
Thomas Petazzoni
thomas.petazzoni at free-electrons.com
Wed Jul 23 04:19:30 PDT 2014
Viresh, Jason,
So, what do we do with this patch series, which depends on the
cpufreq-generic driver? Has there been any solution found for 3.17 ?
Jason, in any case, I'd like the following patches to be merged for
3.17, regardless of what happens with the cpufreq driver:
ARM: mvebu: ensure CPU clocks are enabled
ARM: mvebu: extend PMSU code to support dynamic frequency scaling
clk: mvebu: extend clk-cpu for dynamic frequency scaling
One patch should be split:
ARM: mvebu: update Armada XP DT for dynamic frequency scaling
-> In this patch, the addition of clock-latency is related to the
cpufreq generic DT binding, so I think we shouldn't merge that. But
on the other hand, this patch also adds the new registers for the
Armada XP CPU clock, which is used by "clk: mvebu: extend clk-cpu
for dynamic frequency scaling".
The patch:
ARM: mvebu: allow enabling of cpufreq on Armada XP
can be dropped, since ARCH_HAS_CPUFREQ has been removed.
The other patches are defconfig changes, which are meaningless without
the cpufreq-generic driver.
Jason, what do you think about me sending a new version of the patch
series, which will have two clearly separated set of patches:
1/ A first set of patches that can be applied regardless of what
happens on the cpufreq driver side. Getting it merged will not
bring cpufreq support, but it will add the foundations needed to
support it.
2/ A second set of patches that use the cpufreq-generic driver, which
might get applied of the cpufreq maintainers find a solution in
time for 3.17. If not, then I'll re-adapt them for 3.18.
What do you think?
Thomas
On Wed, 9 Jul 2014 17:45:08 +0200, Thomas Petazzoni wrote:
> Mike, Viresh, Rafael, Jason, Gregory, Andrew, Sebastian,
>
> Here is the third version of the patches adding cpufreq support for
> the Marvell Armada XP processor.
>
> Changes since v2
> ================
>
> - As suggested by Stephen Boyd, instead of using a new clock notifier
> that somewhat "hides" the dependency of the clk-cpu clock driver on
> the PMSU, use a direct call from the clk-cpu driver to the PMSU
> driver.
>
> - Add a comment that explains why the OPP are not removed on failure
> in the PMSU code initializing the cpufreq logic, in answer to the
> review from Ezequiel Garcia.
>
> Changes since v1
> ================
>
> - Rework the patch series to use the generalized cpufreq-cpu0
> (renamed cpufreq-generic) driver instead of having an Armada XP
> specific cpufreq driver. This was suggested by Viresh
> Kumar. Basically, it only involved adding a "clock-latency"
> property in the DT, and changing the PMSU code to register the two
> OPPs supported by each CPU, and registering the "cpufreq-generic"
> platform device instead of the "armadaxp-cpufreq" one.
>
> Jason, this patch series is based on 3.16-rc3, but it applies fine
> even with mvebu/fixes and mvebu/soc merged (which contain some PMSU
> changes), so I haven't based the patch series on those branches. To
> _work_, the code needs the new cpufreq-generic driver which is pending
> in Viresh Kumar's tree for 3.17, but there is no build dependency.
>
> Thanks,
>
> Thomas
>
> Thomas Petazzoni (7):
> ARM: mvebu: ensure CPU clocks are enabled
> ARM: mvebu: extend PMSU code to support dynamic frequency scaling
> clk: mvebu: extend clk-cpu for dynamic frequency scaling
> ARM: mvebu: update Armada XP DT for dynamic frequency scaling
> ARM: mvebu: allow enabling of cpufreq on Armada XP
> ARM: mvebu: update mvebu_v7_defconfig with cpufreq support
> ARM: configs: add cpufreq-generic in multi_v7_defconfig
>
> .../devicetree/bindings/clock/mvebu-cpu-clock.txt | 5 +-
> arch/arm/boot/dts/armada-xp-mv78230.dtsi | 2 +
> arch/arm/boot/dts/armada-xp-mv78260.dtsi | 2 +
> arch/arm/boot/dts/armada-xp-mv78460.dtsi | 4 +
> arch/arm/boot/dts/armada-xp.dtsi | 2 +-
> arch/arm/configs/multi_v7_defconfig | 1 +
> arch/arm/configs/mvebu_v7_defconfig | 2 +
> arch/arm/mach-mvebu/Kconfig | 1 +
> arch/arm/mach-mvebu/platsmp.c | 1 +
> arch/arm/mach-mvebu/pmsu.c | 162 +++++++++++++++++++++
> drivers/clk/mvebu/clk-cpu.c | 80 +++++++++-
> include/linux/mvebu-pmsu.h | 20 +++
> 12 files changed, 274 insertions(+), 8 deletions(-)
> create mode 100644 include/linux/mvebu-pmsu.h
>
--
Thomas Petazzoni, CTO, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com
More information about the linux-arm-kernel
mailing list