From: rjw@sisk.pl (Rafael J. Wysocki)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 10/10] ARM: OMAP: SmartReflex: Move smartreflex driver to drivers/
Date: Thu, 15 Mar 2012 22:19:22 +0100 [thread overview]
Message-ID: <201203152219.22985.rjw@sisk.pl> (raw)
In-Reply-To: <1331829845-9526-11-git-send-email-j-pihet@ti.com>
On Thursday, March 15, 2012, jean.pihet at newoldbits.com wrote:
> From: Jean Pihet <j-pihet@ti.com>
>
> After a clean-up of the interfaces the OMAP IP driver and class
> support code is now a generic driver.
> Move it to drivers/power/avs/.
>
> The build is controlled by the following Kconfig options:
> . CONFIG_POWER_AVS: general knob for Adaptive Voltage Scaling support,
> . CONFIG_POWER_AVS_OMAP: AVS support on OMAP containing the version 1
> or version 2 of the SmartReflex IP,
> . CONFIG_POWER_AVS_OMAP_CLASS3: Class 3 implementation of Smartreflex.
>
> Signed-off-by: Jean Pihet <j-pihet@ti.com>
> ---
[...]
> diff --git a/drivers/power/Makefile b/drivers/power/Makefile
> index e429008..e4a8fd2 100644
> --- a/drivers/power/Makefile
> +++ b/drivers/power/Makefile
> @@ -41,3 +41,5 @@ obj-$(CONFIG_CHARGER_GPIO) += gpio-charger.o
> obj-$(CONFIG_CHARGER_MANAGER) += charger-manager.o
> obj-$(CONFIG_CHARGER_MAX8997) += max8997_charger.o
> obj-$(CONFIG_CHARGER_MAX8998) += max8998_charger.o
> +
> +obj-$(CONFIG_POWER_AVS) += avs/
> diff --git a/drivers/power/avs/Kconfig b/drivers/power/avs/Kconfig
> new file mode 100644
> index 0000000..35b21c4
> --- /dev/null
> +++ b/drivers/power/avs/Kconfig
> @@ -0,0 +1,45 @@
> +menuconfig POWER_AVS
> + tristate "Adaptive Voltage Scaling class support"
> + help
> + AVS is a power management technique which finely controls the
> + operating voltage of a device in order to optimize (i.e. reduce)
> + its power consumption.
> + At a given operating point the voltage is adapted depending on
> + static factors (chip manufacturing process) and dynamic factors
> + (temperature depending performance).
> + AVS is also called SmartReflex on OMAP devices.
> +
> + Say Y here to enable Adaptive Voltage Scaling class support.
> +
> +if POWER_AVS
> +
> +config POWER_AVS_OMAP
I think it would be better to keep this and the next one in the OMAP
arch Kconfig.
> + bool "AVS support for the OMAP IP versions 1&2"
> + depends on (ARCH_OMAP3 || ARCH_OMAP4) && PM
> + help
> + Say Y to enable AVS support on OMAP containing the version 1 or
> + version 2 of the SmartReflex IP.
> + V1 is the 65nm version used in OMAP3430.
> + V2 is the update for the 45nm version of the IP used in OMAP3630
> + and OMAP4430
> +
> + Please note, that by default SmartReflex is only
> + initialized and not enabled. To enable the automatic voltage
> + compensation for vdd mpu and vdd core from user space,
> + user must write 1 to
> + /debug/smartreflex/sr_<X>/autocomp,
> + where X is mpu_iva or core for OMAP3.
> + Optionally autocompensation can be enabled in the kernel
> + by default during system init via the enable_on_init flag
> + which an be passed as platform data to the smartreflex driver.
> +
> +config POWER_AVS_OMAP_CLASS3
> + bool "Class 3 mode of Smartreflex Implementation"
> + depends on POWER_AVS_OMAP && TWL4030_CORE
> + help
> + Say Y to enable Class 3 implementation of Smartreflex
> +
> + Class 3 implementation of Smartreflex employs continuous hardware
> + voltage calibration.
> +
> +endif # POWER_AVS
Thanks,
Rafael
prev parent reply other threads:[~2012-03-15 21:19 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-03-15 16:43 [PATCH 00/10] PM: Create the AVS class of drivers jean.pihet at newoldbits.com
2012-03-15 16:43 ` [PATCH 01/10] ARM: OMAP3+: voltage: export functions to plat/voltage.h jean.pihet at newoldbits.com
2012-03-15 16:43 ` [PATCH 02/10] ARM: OMAP2+: SmartReflex: move the platform specific macros in plat-omap jean.pihet at newoldbits.com
2012-03-15 17:14 ` Tony Lindgren
2012-03-16 15:19 ` Jean Pihet
2012-04-18 20:18 ` Tony Lindgren
2012-03-15 16:43 ` [PATCH 03/10] ARM: OMAP3+: SmartReflex: class drivers should use struct omap_sr * jean.pihet at newoldbits.com
2012-03-15 16:43 ` [PATCH 04/10] ARM: OMAP2+: smartreflex: Use the names from hwmod data instead of voltage domains jean.pihet at newoldbits.com
2012-03-15 16:44 ` [PATCH 05/10] ARM: OMAP3: hwmod: rename the smartreflex entries jean.pihet at newoldbits.com
2012-03-15 16:44 ` [PATCH 06/10] ARM: OMAP2+: SmartReflex: use the platform header file for voltage functions jean.pihet at newoldbits.com
2012-03-15 16:44 ` [PATCH 07/10] ARM: OMAP2+: SmartReflex: introduce a busy loop condition test macro jean.pihet at newoldbits.com
2012-03-15 16:44 ` [PATCH 08/10] ARM: OMAP2+: SmartReflex: Use per-OPP data structure jean.pihet at newoldbits.com
2012-03-15 16:44 ` [PATCH 09/10] ARM: OMAP2+: SmartReflex: add POWER_AVS Kconfig options jean.pihet at newoldbits.com
2012-03-15 16:44 ` [PATCH 10/10] ARM: OMAP: SmartReflex: Move smartreflex driver to drivers/ jean.pihet at newoldbits.com
2012-03-15 21:19 ` Rafael J. Wysocki [this message]
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=201203152219.22985.rjw@sisk.pl \
--to=rjw@sisk.pl \
--cc=linux-arm-kernel@lists.infradead.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).